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 46 of file markdown.h.

Constructor & Destructor Documentation

◆ MarkdownOutlineParser()

MarkdownOutlineParser::MarkdownOutlineParser ( )

Definition at line 3621 of file markdown.cpp.

3621 : p(std::make_unique<Private>())
3622{
3623}
std::unique_ptr< Private > p
Definition markdown.h:60

References p.

◆ ~MarkdownOutlineParser()

MarkdownOutlineParser::~MarkdownOutlineParser ( )
override

Definition at line 3625 of file markdown.cpp.

3626{
3627}

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 56 of file markdown.h.

56{ 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 3629 of file markdown.cpp.

3633{
3634 std::shared_ptr<Entry> current = std::make_shared<Entry>();
3635 int prepend = 0; // number of empty lines in front
3636 current->lang = SrcLangExt::Markdown;
3637 current->fileName = fileName;
3638 current->docFile = fileName;
3639 current->docLine = 1;
3640 QCString docs = stripIndentation(fileBuf);
3641 if (!docs.stripWhiteSpace().size()) return;
3642 Debug::print(Debug::Markdown,0,"======== Markdown =========\n---- input ------- \n{}\n",fileBuf);
3643 QCString id;
3644 Markdown markdown(fileName,1,0);
3645 bool isIdGenerated = false;
3646 QCString title = markdown.extractPageTitle(docs, id, prepend, isIdGenerated).stripWhiteSpace();
3647 QCString generatedId;
3648 if (isIdGenerated)
3649 {
3650 generatedId = id;
3651 id = "";
3652 }
3653 int indentLevel=title.isEmpty() ? 0 : -1;
3654 markdown.setIndentLevel(indentLevel);
3655 FileInfo fi(fileName.str());
3656 QCString fn = fi.fileName();
3657 QCString titleFn = stripExtensionGeneral(fn,getFileNameExtension(fn));
3658 QCString mdfileAsMainPage = Config_getString(USE_MDFILE_AS_MAINPAGE);
3659 QCString mdFileNameId = markdownFileNameToId(fileName);
3660 bool wasEmpty = id.isEmpty();
3661 if (wasEmpty) id = mdFileNameId;
3662 QCString relFileName = stripFromPath(fileName);
3663 bool isSubdirDocs = Config_getBool(IMPLICIT_DIR_DOCS) && relFileName.lower().endsWith("/readme.md");
3664 switch (isExplicitPage(docs))
3665 {
3667 if (!mdfileAsMainPage.isEmpty() &&
3668 (fi.absFilePath()==FileInfo(mdfileAsMainPage.str()).absFilePath()) // file reference with path
3669 )
3670 {
3671 docs.prepend("@ianchor{" + title + "} " + id + "\\ilinebr ");
3672 docs.prepend("@mainpage "+title+"\\ilinebr ");
3673 }
3674 else if (id=="mainpage" || id=="index")
3675 {
3676 if (title.isEmpty()) title = titleFn;
3677 docs.prepend("@ianchor{" + title + "} " + id + "\\ilinebr ");
3678 docs.prepend("@mainpage "+title+"\\ilinebr ");
3679 }
3680 else if (isSubdirDocs)
3681 {
3682 if (!generatedId.isEmpty() && !title.isEmpty())
3683 {
3684 docs.prepend("@section " + generatedId + " " + title + "\\ilinebr ");
3685 }
3686 docs.prepend("@dir\\ilinebr ");
3687 }
3688 else
3689 {
3690 if (title.isEmpty())
3691 {
3692 title = titleFn;
3693 prepend = 0;
3694 }
3695 if (!wasEmpty)
3696 {
3697 docs.prepend("@ianchor{" + title + "} " + id + "\\ilinebr @ianchor{" + relFileName + "} " + mdFileNameId + "\\ilinebr ");
3698 }
3699 else if (!generatedId.isEmpty())
3700 {
3701 docs.prepend("@ianchor " + generatedId + "\\ilinebr ");
3702 }
3703 else if (Config_getEnum(MARKDOWN_ID_STYLE)==MARKDOWN_ID_STYLE_t::GITHUB)
3704 {
3705 QCString autoId = AnchorGenerator::instance().generate(title.str());
3706 docs.prepend("@ianchor{" + title + "} " + autoId + "\\ilinebr ");
3707 }
3708 docs.prepend("@page "+id+" "+title+"\\ilinebr ");
3709 }
3710 for (int i = 0; i < prepend; i++) docs.prepend("\n");
3711 break;
3713 {
3714 // look for `@page label My Title\n` and capture `label` (match[1]) and ` My Title` (match[2])
3715 static const reg::Ex re(R"([ ]*[\\@]page\s+(\a[\w-]*)(\s*[^\n]*)\n)");
3716 reg::Match match;
3717 std::string s = docs.str();
3718 if (reg::search(s,match,re))
3719 {
3720 QCString orgLabel = match[1].str();
3721 QCString orgTitle = match[2].str();
3722 orgTitle = orgTitle.stripWhiteSpace();
3723 QCString newLabel = markdownFileNameToId(fileName);
3724 docs = docs.left(match[1].position())+ // part before label
3725 newLabel+ // new label
3726 match[2].str()+ // part between orgLabel and \n
3727 "\\ilinebr @ianchor{" + orgTitle + "} "+orgLabel+"\n"+ // add original anchor plus \n of above
3728 docs.right(docs.length()-match.length()); // add remainder of docs
3729 }
3730 }
3731 break;
3733 break;
3735 break;
3736 }
3737 int lineNr=1;
3738
3739 p->commentScanner.enterFile(fileName,lineNr);
3740 Protection prot = Protection::Public;
3741 bool needsEntry = false;
3742 int position=0;
3743 GuardedSectionStack guards;
3744 QCString processedDocs = markdown.process(docs,lineNr,true);
3745 while (p->commentScanner.parseCommentBlock(
3746 this,
3747 current.get(),
3748 processedDocs,
3749 fileName,
3750 lineNr,
3751 FALSE, // isBrief
3752 FALSE, // javadoc autobrief
3753 FALSE, // inBodyDocs
3754 prot, // protection
3755 position,
3756 needsEntry,
3757 true,
3758 &guards
3759 ))
3760 {
3761 if (needsEntry)
3762 {
3763 QCString docFile = current->docFile;
3764 root->moveToSubEntryAndRefresh(current);
3765 current->lang = SrcLangExt::Markdown;
3766 current->docFile = docFile;
3767 current->docLine = lineNr;
3768 }
3769 }
3770 if (needsEntry)
3771 {
3772 root->moveToSubEntryAndKeep(current);
3773 }
3774 p->commentScanner.leaveFile(fileName,lineNr);
3775}
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:59
@ Markdown
Definition debug.h:37
static void print(DebugMask mask, int prio, fmt::format_string< Args... > fmt, Args &&... args)
Definition debug.h:76
QCString & prepend(const char *s)
Definition qcstring.h:407
size_t length() const
Returns the length of the string, not counting the 0-terminator.
Definition qcstring.h:153
QCString lower() const
Definition qcstring.h:234
bool endsWith(const char *s) const
Definition qcstring.h:509
bool isEmpty() const
Returns TRUE iff the string is empty.
Definition qcstring.h:150
QCString stripWhiteSpace() const
returns a copy of this string with leading and trailing whitespace removed
Definition qcstring.h:245
const std::string & str() const
Definition qcstring.h:537
QCString right(size_t len) const
Definition qcstring.h:219
size_t size() const
Returns the length of the string, not counting the 0-terminator.
Definition qcstring.h:156
QCString left(size_t len) const
Definition qcstring.h:214
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:69
@ explicitPage
docs start with a page command
Definition markdown.cpp:68
@ notExplicit
docs doesn't start with either page or mainpage
Definition markdown.cpp:71
@ explicitOtherPage
docs start with a dir / defgroup / addtogroup command
Definition markdown.cpp:70
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:748
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:759
Protection
Definition types.h:32
QCString stripIndentation(const QCString &s, bool skipFirstLine)
Definition util.cpp:6428
QCString stripExtensionGeneral(const QCString &fName, const QCString &ext)
Definition util.cpp:5427
static QCString stripFromPath(const QCString &p, const StringVector &l)
Definition util.cpp:309
QCString getFileNameExtension(const QCString &fn)
Definition util.cpp:5763

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 3777 of file markdown.cpp.

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

References Doxygen::parserManager.

Member Data Documentation

◆ p

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

Definition at line 60 of file markdown.h.

Referenced by MarkdownOutlineParser(), and parseInput().


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