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 968 of file docnode.h.

Constructor & Destructor Documentation

◆ DocInternal()

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

Definition at line 971 of file docnode.h.

DocCompoundNode(DocParser *parser, DocNodeVariant *parent)
Definition docnode.h:141
DocParser * parser()
Definition docnode.h:98
DocNodeVariant * parent()
Definition docnode.h:90

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

Member Function Documentation

◆ parse()

Token DocInternal::parse ( int level)

Definition at line 1558 of file docnode.cpp.

1559{
1560 AUTO_TRACE();
1561 Token retval(TokenRetval::RetVal_OK);
1562 auto ns = AutoNodeStack(parser(),thisVariant());
1563
1564 // first parse any number of paragraphs
1565 bool isFirst=TRUE;
1566 DocPara *lastPar=nullptr;
1567 do
1568 {
1569 children().append<DocPara>(parser(),thisVariant());
1570 DocPara *par = children().get_last<DocPara>();
1571 if (isFirst) { par->markFirst(); isFirst=FALSE; }
1572 retval=par->parse();
1573 if (!par->isEmpty())
1574 {
1575 if (lastPar) lastPar->markLast(FALSE);
1576 lastPar=par;
1577 }
1578 else
1579 {
1580 children().pop_back();
1581 }
1582 if (retval.is(TokenRetval::TK_LISTITEM))
1583 {
1584 warn_doc_error(parser()->context.fileName,parser()->tokenizer.getLineNr(),"Invalid list item found");
1585 }
1586 } while (!retval.is_any_of(TokenRetval::TK_NONE, TokenRetval::TK_EOF,
1587 TokenRetval::RetVal_Section, TokenRetval::RetVal_Subsection, TokenRetval::RetVal_Subsubsection,
1588 TokenRetval::RetVal_Paragraph, TokenRetval::RetVal_SubParagraph, TokenRetval::RetVal_SubSubParagraph,
1589 TokenRetval::RetVal_EndInternal));
1590 if (lastPar) lastPar->markLast();
1591
1592 // then parse any number of level-n sections
1593 while ((level==1 && retval.is(TokenRetval::RetVal_Section)) ||
1594 (level==2 && retval.is(TokenRetval::RetVal_Subsection)) ||
1595 (level==3 && retval.is(TokenRetval::RetVal_Subsubsection)) ||
1596 (level==4 && retval.is(TokenRetval::RetVal_Paragraph)) ||
1597 (level==5 && retval.is(TokenRetval::RetVal_SubParagraph)) ||
1598 (level==6 && retval.is(TokenRetval::RetVal_SubSubParagraph))
1599 )
1600 {
1601 children().append<DocSection>(parser(),thisVariant(),
1602 level,
1604 retval = children().get_last<DocSection>()->parse();
1605 }
1606
1607 if (retval.is(TokenRetval::RetVal_Internal))
1608 {
1609 warn_doc_error(parser()->context.fileName,parser()->tokenizer.getLineNr(),"\\internal command found inside internal section");
1610 }
1611
1612 AUTO_TRACE_EXIT("retval={}",retval.to_string());
1613 return retval;
1614}
DocNodeList & children()
Definition docnode.h:143
Token parse(int)
Definition docnode.cpp:1558
DocNodeVariant * thisVariant()
Definition docnode.h:93
void markLast(bool v=TRUE)
Definition docnode.h:1086
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:1399
T * get_last()
Returns a pointer to the last element in the list if that element exists and holds a T,...
Definition docnode.h:1410
TokenInfo * token
Definition docparser_p.h:93
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: