Doxygen
|
#include <stdio.h>
#include <stdlib.h>
#include <cassert>
#include <ctype.h>
#include "classlist.h"
#include "cmdmapper.h"
#include "config.h"
#include "debug.h"
#include "dir.h"
#include "docparser.h"
#include "docparser_p.h"
#include "doxygen.h"
#include "filedef.h"
#include "fileinfo.h"
#include "groupdef.h"
#include "namespacedef.h"
#include "message.h"
#include "pagedef.h"
#include "portable.h"
#include "printdocvisitor.h"
#include "util.h"
#include "indexlist.h"
#include "trace.h"
Go to the source code of this file.
Macros | |
#define | AUTO_TRACE(...) |
#define | AUTO_TRACE_ADD(...) |
#define | AUTO_TRACE_EXIT(...) |
#define | CHECK_FOR_COMMAND(str, action) |
Functions | |
IDocParserPtr | createDocParser () |
factory function to create a parser | |
static QCString | extractCopyDocId (const char *data, size_t &j, size_t len) |
static size_t | isCopyBriefOrDetailsCmd (const char *data, size_t i, size_t len, bool &brief) |
static size_t | isVerbatimSection (const char *data, size_t i, size_t len, QCString &endMarker) |
static size_t | skipToEndMarker (const char *data, size_t i, size_t len, const QCString &endMarker) |
IDocNodeASTPtr | validatingParseDoc (IDocParser &parserIntf, const QCString &fileName, int startLine, const Definition *ctx, const MemberDef *md, const QCString &input, bool indexWords, bool isExample, const QCString &exampleName, bool singleLine, bool linkFromIndex, bool markdownSupport) |
IDocNodeASTPtr | validatingParseText (IDocParser &parserIntf, const QCString &input) |
IDocNodeASTPtr | createRef (IDocParser &parserIntf, const QCString &target, const QCString &context, const QCString &srcFile, int srcLine) |
void | docFindSections (const QCString &input, const Definition *d, const QCString &fileName) |
#define AUTO_TRACE | ( | ... | ) |
Definition at line 46 of file docparser.cpp.
#define AUTO_TRACE_ADD | ( | ... | ) |
Definition at line 47 of file docparser.cpp.
#define AUTO_TRACE_EXIT | ( | ... | ) |
Definition at line 48 of file docparser.cpp.
#define CHECK_FOR_COMMAND | ( | str, | |
action ) |
Definition at line 1831 of file docparser.cpp.
Referenced by isCopyBriefOrDetailsCmd(), and isVerbatimSection().
IDocParserPtr createDocParser | ( | ) |
factory function to create a parser
Definition at line 54 of file docparser.cpp.
Referenced by addPerlModDocBlock(), convertMapFile(), RTFGenerator::endIndexSection(), generateBriefDoc(), OutputList::generateDoc(), generateHtmlOutput(), getSQLDocBlock(), parseCommentAsText(), OutputList::parseText(), replaceRef(), LayoutNavEntry::url(), ConceptDefImpl::writeBriefDescription(), DirDefImpl::writeBriefDescription(), FileDefImpl::writeBriefDescription(), GroupDefImpl::writeBriefDescription(), ModuleDefImpl::writeBriefDescription(), NamespaceDefImpl::writeBriefDescription(), MemberDefImpl::writeDeclaration(), ClassDefImpl::writeDeclarationLink(), ConceptDefImpl::writeDeclarationLink(), ModuleDefImpl::writeDeclarationLink(), MemberList::writePlainDeclarations(), and writeXMLDocBlock().
IDocNodeASTPtr createRef | ( | IDocParser & | parserIntf, |
const QCString & | target, | ||
const QCString & | context, | ||
const QCString & | srcFile, | ||
int | srcLine ) |
Definition at line 2188 of file docparser.cpp.
References DocParser::context, DocParserContext::fileName, QCString::isEmpty(), DocTokenizer::setLineNr(), and DocParser::tokenizer.
Referenced by convertMapFile(), replaceRef(), and LayoutNavEntry::url().
void docFindSections | ( | const QCString & | input, |
const Definition * | d, | ||
const QCString & | fileName ) |
Searches for section and anchor commands in the input Sections found will be added to the SectionManager.
Definition at line 2201 of file docparser.cpp.
References DocTokenizer::findSections(), and DocParser::tokenizer.
Referenced by ClassDefImpl::findSectionsInDocumentation(), ConceptDefImpl::findSectionsInDocumentation(), FileDefImpl::findSectionsInDocumentation(), GroupDefImpl::findSectionsInDocumentation(), MemberDefImpl::findSectionsInDocumentation(), MemberGroup::findSectionsInDocumentation(), ModuleDefImpl::findSectionsInDocumentation(), NamespaceDefImpl::findSectionsInDocumentation(), and PageDefImpl::findSectionsInDocumentation().
|
static |
Definition at line 1758 of file docparser.cpp.
References FALSE, found, qstrncmp(), and TRUE.
Referenced by DocParser::processCopyDoc().
|
static |
Definition at line 1835 of file docparser.cpp.
References CHECK_FOR_COMMAND, FALSE, and TRUE.
Referenced by DocParser::processCopyDoc().
|
static |
Definition at line 1846 of file docparser.cpp.
References CHECK_FOR_COMMAND.
Referenced by DocParser::processCopyDoc().
|
static |
Definition at line 1870 of file docparser.cpp.
References QCString::data(), QCString::length(), and qstrncmp().
Referenced by DocParser::processCopyDoc().
IDocNodeASTPtr validatingParseDoc | ( | IDocParser & | parserIntf, |
const QCString & | fileName, | ||
int | startLine, | ||
const Definition * | ctx, | ||
const MemberDef * | md, | ||
const QCString & | input, | ||
bool | indexWords, | ||
bool | isExample, | ||
const QCString & | exampleName, | ||
bool | singleLine, | ||
bool | linkFromIndex, | ||
bool | markdownSupport ) |
Main entry point for the comment block parser.
parserIntf | The parser object created via createDocParser() |
fileName | File in which the documentation block is found (or the name of the example file in case isExample is TRUE). |
startLine | Line at which the documentation block is found. |
ctx | Class or namespace to which this block belongs. |
md | Member definition to which the documentation belongs. Can be 0. |
input | String representation of the documentation block. |
indexWords | Indicates whether or not words should be put in the search index. |
isExample | TRUE if the documentation belongs to an example. |
exampleName | Base name of the example file (0 if isExample is FALSE). |
singleLine | Output should be presented on a single line, so without starting a new paragraph at the end. |
linkFromIndex | TRUE if the documentation is generated from an index page. In this case context is not used to determine the relative path when making a link. |
markdownSupport | TRUE if the input needs to take markdown markup into account. |
Definition at line 2002 of file docparser.cpp.
References Definition::anchor(), QCString::at(), DocParser::checkUnOrMultipleDocumentedParams(), DocParser::context, DocParserContext::context, QCString::data(), Definition::definitionType(), MemberDef::detectUndocumentedParams(), DocParserContext::exampleName, FALSE, DocParserContext::fileName, Definition::getLanguage(), getLanguageFromFileName(), getLanguageSpecificSeparator(), Definition::getOutputFileBase(), Doxygen::globalScope, DocParserContext::hasParamCommand, DocParserContext::hasReturnCommand, DocParserContext::includeFileLength, DocParserContext::includeFileOffset, DocParserContext::includeFileText, DocTokenizer::init(), DocParserContext::initialStyleStack, DocParserContext::inSeeBlock, DocParserContext::insideHtmlLink, QCString::isEmpty(), DocParserContext::isExample, Debug::isFlagSet(), MemberDef::isFunction(), DocParserContext::lang, QCString::length(), DocParserContext::markdownSupport, DocParserContext::memberDef, Definition::name(), DocParserContext::nodeStack, DocParserContext::paramsFound, Debug::PrintTree, DocParser::processCopyDoc(), Definition::qualifiedName(), relativePathToRoot(), DocParserContext::relPath, DocTokenizer::resetToken(), DocParserContext::retvalsFound, DocParserContext::scope, Doxygen::searchIndex, DocParserContext::searchUrl, DocTokenizer::setLineNr(), DocParserContext::styleStack, substitute(), toGroupDef(), DocParserContext::token, DocParser::tokenizer, toPageDef(), Definition::TypeClass, Definition::TypeGroup, Definition::TypeNamespace, Definition::TypePage, and DocParserContext::xmlComment.
Referenced by addPerlModDocBlock(), generateBriefDoc(), OutputList::generateDoc(), generateHtmlOutput(), getSQLDocBlock(), parseCommentAsText(), ConceptDefImpl::writeBriefDescription(), DirDefImpl::writeBriefDescription(), FileDefImpl::writeBriefDescription(), GroupDefImpl::writeBriefDescription(), ModuleDefImpl::writeBriefDescription(), NamespaceDefImpl::writeBriefDescription(), MemberDefImpl::writeDeclaration(), ClassDefImpl::writeDeclarationLink(), ConceptDefImpl::writeDeclarationLink(), ModuleDefImpl::writeDeclarationLink(), MemberList::writePlainDeclarations(), and writeXMLDocBlock().
IDocNodeASTPtr validatingParseText | ( | IDocParser & | parser, |
const QCString & | input ) |
Main entry point for parsing simple text fragments. These fragments are limited to words, whitespace and symbols.
Definition at line 2131 of file docparser.cpp.
References Config_getBool, DocParser::context, DocParserContext::context, QCString::data(), DocParserContext::exampleName, FALSE, DocParserContext::fileName, DocParserContext::hasParamCommand, DocParserContext::hasReturnCommand, DocParserContext::includeFileLength, DocParserContext::includeFileOffset, DocParserContext::includeFileText, DocTokenizer::init(), DocParserContext::initialStyleStack, DocParserContext::inSeeBlock, DocParserContext::insideHtmlLink, QCString::isEmpty(), DocParserContext::isExample, Debug::isFlagSet(), DocParserContext::lang, DocParserContext::markdownSupport, DocParserContext::memberDef, DocParserContext::nodeStack, DocParserContext::paramsFound, Debug::PrintTree, DocParserContext::relPath, DocTokenizer::resetToken(), DocParserContext::retvalsFound, DocParserContext::searchUrl, DocTokenizer::setLineNr(), DocParserContext::styleStack, DocParserContext::token, DocParser::tokenizer, Unknown, and DocParserContext::xmlComment.
Referenced by RTFGenerator::endIndexSection(), and OutputList::parseText().