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

Node representing an internal section of documentation. More...

#include <src/docnode.h>

Inheritance diagram for DocInternal:
Collaboration diagram for DocInternal:

Public Member Functions

 DocInternal (DocParser *parser, DocNodeVariant *parent)
Token parse (int)
Public Member Functions inherited from DocCompoundNode
 DocCompoundNode (DocParser *parser, DocNodeVariant *parent)
DocNodeListchildren ()
const DocNodeListchildren () const
Public Member Functions inherited from DocNode
 DocNode (DocParser *parser, DocNodeVariant *parent)
 ~DocNode ()=default
DocNodeVariantparent ()
const DocNodeVariantparent () const
DocNodeVariantthisVariant ()
const DocNodeVariantthisVariant () const
void setThisVariant (DocNodeVariant *thisVariant)
DocParserparser ()
const DocParserparser () const
void setParent (DocNodeVariant *parent)
bool isPreformatted () const

Additional Inherited Members

Protected Types inherited from DocNode
enum  RefType { Unknown , Anchor , Section , Table }
Protected Member Functions inherited from DocNode
void setInsidePreformatted (bool p)

Detailed Description

Node representing an internal section of documentation.

Definition at line 963 of file docnode.h.

Constructor & Destructor Documentation

◆ DocInternal()

DocInternal::DocInternal ( DocParser * parser,
DocNodeVariant * parent )
inline

Definition at line 966 of file docnode.h.

DocCompoundNode(DocParser *parser, DocNodeVariant *parent)
Definition docnode.h:140
DocParser * parser()
Definition docnode.h:97
DocNodeVariant * parent()
Definition docnode.h:89

References DocCompoundNode::DocCompoundNode(), DocNode::parent(), and DocNode::parser().

Member Function Documentation

◆ parse()

Token DocInternal::parse ( int level)

Definition at line 1515 of file docnode.cpp.

1516{
1517 AUTO_TRACE();
1518 Token retval(TokenRetval::RetVal_OK);
1519 auto ns = AutoNodeStack(parser(),thisVariant());
1520
1521 // first parse any number of paragraphs
1522 bool isFirst=TRUE;
1523 DocPara *lastPar=nullptr;
1524 do
1525 {
1526 children().append<DocPara>(parser(),thisVariant());
1527 DocPara *par = children().get_last<DocPara>();
1528 if (isFirst) { par->markFirst(); isFirst=FALSE; }
1529 retval=par->parse();
1530 if (!par->isEmpty())
1531 {
1532 if (lastPar) lastPar->markLast(FALSE);
1533 lastPar=par;
1534 }
1535 else
1536 {
1537 children().pop_back();
1538 }
1539 if (retval.is(TokenRetval::TK_LISTITEM))
1540 {
1541 warn_doc_error(parser()->context.fileName,parser()->tokenizer.getLineNr(),"Invalid list item found");
1542 }
1543 } while (!retval.is_any_of(TokenRetval::TK_NONE, TokenRetval::TK_EOF,
1544 TokenRetval::RetVal_Section, TokenRetval::RetVal_Subsection, TokenRetval::RetVal_Subsubsection,
1545 TokenRetval::RetVal_Paragraph, TokenRetval::RetVal_SubParagraph, TokenRetval::RetVal_SubSubParagraph,
1546 TokenRetval::RetVal_EndInternal));
1547 if (lastPar) lastPar->markLast();
1548
1549 // then parse any number of level-n sections
1550 while ((level==1 && retval.is(TokenRetval::RetVal_Section)) ||
1551 (level==2 && retval.is(TokenRetval::RetVal_Subsection)) ||
1552 (level==3 && retval.is(TokenRetval::RetVal_Subsubsection)) ||
1553 (level==4 && retval.is(TokenRetval::RetVal_Paragraph)) ||
1554 (level==5 && retval.is(TokenRetval::RetVal_SubParagraph)) ||
1555 (level==6 && retval.is(TokenRetval::RetVal_SubSubParagraph))
1556 )
1557 {
1558 children().append<DocSection>(parser(),thisVariant(),
1559 level,
1561 retval = children().get_last<DocSection>()->parse();
1562 }
1563
1564 if (retval.is(TokenRetval::RetVal_Internal))
1565 {
1566 warn_doc_error(parser()->context.fileName,parser()->tokenizer.getLineNr(),"\\internal command found inside internal section");
1567 }
1568
1569 AUTO_TRACE_EXIT("retval={}",retval.to_string());
1570 return retval;
1571}
DocNodeList & children()
Definition docnode.h:142
Token parse(int)
Definition docnode.cpp:1515
DocNodeVariant * thisVariant()
Definition docnode.h:92
void markLast(bool v=TRUE)
Definition docnode.h:1081
DocParserContext context
void pop_back()
removes the last element
Definition growvector.h:115
#define AUTO_TRACE(...)
Definition docnode.cpp:46
#define AUTO_TRACE_EXIT(...)
Definition docnode.cpp:48
#define warn_doc_error(file, line, fmt,...)
Definition message.h:112
#define TRUE
Definition qcstring.h:37
#define FALSE
Definition qcstring.h:34
void append(Args &&... args)
Append a new DocNodeVariant to the list by constructing it with type T and parameters Args.
Definition docnode.h:1394
T * get_last()
Returns a pointer to the last element in the list if that element exists and holds a T,...
Definition docnode.h:1405
TokenInfo * token
Definition docparser_p.h:92
QCString sectionId

References DocNodeList::append(), AUTO_TRACE, AUTO_TRACE_EXIT, DocCompoundNode::children(), DocParser::context, FALSE, DocNodeList::get_last(), Token::is(), Token::is_any_of(), DocPara::markLast(), parse(), DocNode::parser(), GrowVector< T >::pop_back(), TokenInfo::sectionId, DocNode::thisVariant(), Token::to_string(), DocParserContext::token, TRUE, and warn_doc_error.

Referenced by parse().


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