Doxygen
Loading...
Searching...
No Matches
MarkdownOutlineParser Class Reference

#include <src/markdown.h>

Inheritance diagram for MarkdownOutlineParser:
Collaboration diagram for MarkdownOutlineParser:

Classes

struct  Private

Public Member Functions

 MarkdownOutlineParser ()
 ~MarkdownOutlineParser () override
void parseInput (const QCString &fileName, const char *fileBuf, const std::shared_ptr< Entry > &root, ClangTUParser *clangParser) override
 Parses a single input file with the goal to build an Entry tree.
bool needsPreprocessing (const QCString &) const override
 Returns TRUE if the language identified by extension needs the C preprocessor to be run before feed the result to the input parser.
void parsePrototype (const QCString &text) override
 Callback function called by the comment block scanner.

Private Attributes

std::unique_ptr< Privatep

Detailed Description

Definition at line 50 of file markdown.h.

Constructor & Destructor Documentation

◆ MarkdownOutlineParser()

MarkdownOutlineParser::MarkdownOutlineParser ( )

Definition at line 3810 of file markdown.cpp.

3810 : p(std::make_unique<Private>())
3811{
3812}
std::unique_ptr< Private > p
Definition markdown.h:64

References p.

◆ ~MarkdownOutlineParser()

MarkdownOutlineParser::~MarkdownOutlineParser ( )
override

Definition at line 3814 of file markdown.cpp.

3815{
3816}

Member Function Documentation

◆ needsPreprocessing()

bool MarkdownOutlineParser::needsPreprocessing ( const QCString & extension) const
inlineoverridevirtual

Returns TRUE if the language identified by extension needs the C preprocessor to be run before feed the result to the input parser.

See also
parseInput()

Implements OutlineParserInterface.

Definition at line 60 of file markdown.h.

60{ return FALSE; }
#define FALSE
Definition qcstring.h:34

References FALSE.

◆ parseInput()

void MarkdownOutlineParser::parseInput ( const QCString & fileName,
const char * fileBuf,
const std::shared_ptr< Entry > & root,
ClangTUParser * clangParser )
overridevirtual

Parses a single input file with the goal to build an Entry tree.

Parameters
[in]fileNameThe full name of the file.
[in]fileBufThe contents of the file (zero terminated).
[in,out]rootThe root of the tree of Entry *nodes representing the information extracted from the file.
[in]clangParserThe clang translation unit parser object or nullptr if disabled.

Implements OutlineParserInterface.

Definition at line 3818 of file markdown.cpp.

3822{
3823 std::shared_ptr<Entry> current = std::make_shared<Entry>();
3824 int prepend = 0; // number of empty lines in front
3825 current->lang = SrcLangExt::Markdown;
3826 current->fileName = fileName;
3827 current->docFile = fileName;
3828 current->docLine = 1;
3829 QCString docs = stripIndentation(fileBuf);
3830 if (!docs.stripWhiteSpace().size()) return;
3831 Debug::print(Debug::Markdown,0,"======== Markdown =========\n---- input ------- \n{}\n",fileBuf);
3832 QCString id;
3833 Markdown markdown(fileName,1,0);
3834 bool isIdGenerated = false;
3835 QCString title = markdown.extractPageTitle(docs, id, prepend, isIdGenerated).stripWhiteSpace();
3836 QCString generatedId;
3837 if (isIdGenerated)
3838 {
3839 generatedId = id;
3840 id = "";
3841 }
3842 int indentLevel=title.isEmpty() ? 0 : -1;
3843 markdown.setIndentLevel(indentLevel);
3844 FileInfo fi(fileName.str());
3845 QCString fn = fi.fileName();
3846 QCString titleFn = stripExtensionGeneral(fn,getFileNameExtension(fn));
3847 QCString mdfileAsMainPage = Config_getString(USE_MDFILE_AS_MAINPAGE);
3848 QCString mdFileNameId = markdownFileNameToId(fileName);
3849 bool wasEmpty = id.isEmpty();
3850 if (wasEmpty) id = mdFileNameId;
3851 QCString relFileName = stripFromPath(fileName);
3852 bool isSubdirDocs = Config_getBool(IMPLICIT_DIR_DOCS) && relFileName.lower().endsWith("/readme.md");
3853 switch (isExplicitPage(docs))
3854 {
3856 if (!mdfileAsMainPage.isEmpty() &&
3857 (fi.absFilePath()==FileInfo(mdfileAsMainPage.str()).absFilePath()) // file reference with path
3858 )
3859 {
3860 docs.prepend("@ianchor{" + title + "} " + id + "\\ilinebr ");
3861 docs.prepend("@mainpage "+title+"\\ilinebr ");
3862 }
3863 else if (id=="mainpage" || id=="index")
3864 {
3865 if (title.isEmpty()) title = titleFn;
3866 docs.prepend("@ianchor{" + title + "} " + id + "\\ilinebr ");
3867 docs.prepend("@mainpage "+title+"\\ilinebr ");
3868 }
3869 else if (isSubdirDocs)
3870 {
3871 if (!generatedId.isEmpty() && !title.isEmpty())
3872 {
3873 docs.prepend("@section " + generatedId + " " + title + "\\ilinebr ");
3874 }
3875 docs.prepend("@dir\\ilinebr ");
3876 }
3877 else
3878 {
3879 if (title.isEmpty())
3880 {
3881 title = titleFn;
3882 prepend = 0;
3883 }
3884 if (!wasEmpty)
3885 {
3886 docs.prepend("@ianchor{" + title + "} " + id + "\\ilinebr @ianchor{" + relFileName + "} " + mdFileNameId + "\\ilinebr ");
3887 }
3888 else if (!generatedId.isEmpty())
3889 {
3890 docs.prepend("@ianchor " + generatedId + "\\ilinebr ");
3891 }
3892 else if (Config_getEnum(MARKDOWN_ID_STYLE)==MARKDOWN_ID_STYLE_t::GITHUB)
3893 {
3894 QCString autoId = AnchorGenerator::instance().generate(title.str());
3895 docs.prepend("@ianchor{" + title + "} " + autoId + "\\ilinebr ");
3896 }
3897 docs.prepend("@page "+id+" "+title+"\\ilinebr ");
3898 }
3899 for (int i = 0; i < prepend; i++) docs.prepend("\n");
3900 break;
3902 {
3903 // look for `@page label My Title\n` and capture `label` (match[1]) and ` My Title` (match[2])
3904 static const reg::Ex re(R"([ ]*[\\@]page\s+(\a[\w-]*)(\s*[^\n]*)\n)");
3905 reg::Match match;
3906 std::string s = docs.str();
3907 if (reg::search(s,match,re))
3908 {
3909 QCString orgLabel = match[1].str();
3910 QCString orgTitle = match[2].str();
3911 orgTitle = orgTitle.stripWhiteSpace();
3912 QCString newLabel = markdownFileNameToId(fileName);
3913 docs = docs.left(match[1].position())+ // part before label
3914 newLabel+ // new label
3915 match[2].str()+ // part between orgLabel and \n
3916 "\\ilinebr @ianchor{" + orgTitle + "} "+orgLabel+"\n"+ // add original anchor plus \n of above
3917 docs.right(docs.length()-match.length()); // add remainder of docs
3918 }
3919 }
3920 break;
3922 break;
3924 break;
3925 }
3926 int lineNr=1;
3927
3928 p->commentScanner.enterFile(fileName,lineNr);
3929 Protection prot = Protection::Public;
3930 bool needsEntry = false;
3931 int position=0;
3932 GuardedSectionStack guards;
3933 QCString processedDocs = markdown.process(docs,lineNr,true);
3934 while (p->commentScanner.parseCommentBlock(
3935 this,
3936 current.get(),
3937 processedDocs,
3938 fileName,
3939 lineNr,
3940 FALSE, // isBrief
3941 FALSE, // javadoc autobrief
3942 FALSE, // inBodyDocs
3943 prot, // protection
3944 position,
3945 needsEntry,
3946 true,
3947 &guards
3948 ))
3949 {
3950 if (needsEntry)
3951 {
3952 QCString docFile = current->docFile;
3953 root->moveToSubEntryAndRefresh(current);
3954 current->lang = SrcLangExt::Markdown;
3955 current->docFile = docFile;
3956 current->docLine = lineNr;
3957 }
3958 }
3959 if (needsEntry)
3960 {
3961 root->moveToSubEntryAndKeep(current);
3962 }
3963 p->commentScanner.leaveFile(fileName,lineNr);
3964}
static AnchorGenerator & instance()
Returns the singleton instance.
Definition anchor.cpp:38
std::string generate(const std::string &title)
generates an anchor for a section with title.
Definition anchor.cpp:53
@ Markdown
Definition debug.h:37
static void print(DebugMask mask, int prio, fmt::format_string< Args... > fmt, Args &&... args)
Definition debug.h:77
QCString & prepend(const char *s)
Definition qcstring.h:422
size_t length() const
Returns the length of the string, not counting the 0-terminator.
Definition qcstring.h:166
QCString lower() const
Definition qcstring.h:249
bool endsWith(const char *s) const
Definition qcstring.h:524
bool isEmpty() const
Returns TRUE iff the string is empty.
Definition qcstring.h:163
QCString stripWhiteSpace() const
returns a copy of this string with leading and trailing whitespace removed
Definition qcstring.h:260
const std::string & str() const
Definition qcstring.h:552
QCString right(size_t len) const
Definition qcstring.h:234
size_t size() const
Returns the length of the string, not counting the 0-terminator.
Definition qcstring.h:169
QCString left(size_t len) const
Definition qcstring.h:229
std::stack< GuardedSection > GuardedSectionStack
Definition commentscan.h:48
#define Config_getBool(name)
Definition config.h:33
#define Config_getString(name)
Definition config.h:32
#define Config_getEnum(name)
Definition config.h:35
@ explicitMainPage
docs start with a mainpage command
Definition markdown.cpp:71
@ explicitPage
docs start with a page command
Definition markdown.cpp:70
@ notExplicit
docs doesn't start with either page or mainpage
Definition markdown.cpp:73
@ explicitOtherPage
docs start with a dir / defgroup / addtogroup command
Definition markdown.cpp:72
static ExplicitPageResult isExplicitPage(const QCString &docs)
QCString markdownFileNameToId(const QCString &fileName)
processes string s and converts markdown into doxygen/html commands.
bool search(std::string_view str, Match &match, const Ex &re, size_t pos)
Search in a given string str starting at position pos for a match against regular expression re.
Definition regex.cpp:844
bool match(std::string_view str, Match &match, const Ex &re)
Matches a given string str for a match against regular expression re.
Definition regex.cpp:855
Protection
Definition types.h:32
QCString stripIndentation(const QCString &s, bool skipFirstLine)
Definition util.cpp:5967
QCString stripExtensionGeneral(const QCString &fName, const QCString &ext)
Definition util.cpp:4954
static QCString stripFromPath(const QCString &p, const StringVector &l)
Definition util.cpp:298
QCString getFileNameExtension(const QCString &fn)
Definition util.cpp:5273

References FileInfo::absFilePath(), Config_getBool, Config_getEnum, Config_getString, QCString::endsWith(), explicitMainPage, explicitOtherPage, explicitPage, Markdown::extractPageTitle(), FALSE, FileInfo::fileName(), AnchorGenerator::generate(), getFileNameExtension(), AnchorGenerator::instance(), QCString::isEmpty(), isExplicitPage(), QCString::left(), QCString::length(), QCString::lower(), Debug::Markdown, markdownFileNameToId(), notExplicit, p, QCString::prepend(), Debug::print(), Markdown::process(), QCString::right(), reg::search(), Markdown::setIndentLevel(), QCString::size(), QCString::str(), stripExtensionGeneral(), stripFromPath(), stripIndentation(), and QCString::stripWhiteSpace().

◆ parsePrototype()

void MarkdownOutlineParser::parsePrototype ( const QCString & text)
overridevirtual

Callback function called by the comment block scanner.

It provides a string text containing the prototype of a function or variable. The parser should parse this and store the information in the Entry node that corresponds with the node for which the comment block parser was invoked.

Implements OutlineParserInterface.

Definition at line 3966 of file markdown.cpp.

3967{
3968 Doxygen::parserManager->getOutlineParser("*.cpp")->parsePrototype(text);
3969}
static ParserManager * parserManager
Definition doxygen.h:129
std::unique_ptr< OutlineParserInterface > getOutlineParser(const QCString &extension)
Gets the interface to the parser associated with a given extension.
Definition parserintf.h:245

References Doxygen::parserManager.

Member Data Documentation

◆ p

std::unique_ptr<Private> MarkdownOutlineParser::p
private

Definition at line 64 of file markdown.h.

Referenced by MarkdownOutlineParser(), and parseInput().


The documentation for this class was generated from the following files: