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 ,
  Requirement
}
Protected Member Functions inherited from DocNode
void setInsidePreformatted (bool p)

Detailed Description

Node representing an internal section of documentation.

Definition at line 977 of file docnode.h.

Constructor & Destructor Documentation

◆ DocInternal()

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

Definition at line 980 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 1619 of file docnode.cpp.

1620{
1621 AUTO_TRACE();
1622 Token retval(TokenRetval::RetVal_OK);
1623 auto ns = AutoNodeStack(parser(),thisVariant());
1624
1625 // first parse any number of paragraphs
1626 bool isFirst=TRUE;
1627 DocPara *lastPar=nullptr;
1628 do
1629 {
1630 children().append<DocPara>(parser(),thisVariant());
1631 DocPara *par = children().get_last<DocPara>();
1632 if (isFirst) { par->markFirst(); isFirst=FALSE; }
1633 retval=par->parse();
1634 if (!par->isEmpty())
1635 {
1636 if (lastPar) lastPar->markLast(FALSE);
1637 lastPar=par;
1638 }
1639 else
1640 {
1641 children().pop_back();
1642 }
1643 if (retval.is(TokenRetval::TK_LISTITEM))
1644 {
1645 warn_doc_error(parser()->context.fileName,parser()->tokenizer.getLineNr(),"Invalid list item found");
1646 }
1647 } while (!retval.is_any_of(TokenRetval::TK_NONE, TokenRetval::TK_EOF,
1648 TokenRetval::RetVal_Section, TokenRetval::RetVal_Subsection, TokenRetval::RetVal_Subsubsection,
1649 TokenRetval::RetVal_Paragraph, TokenRetval::RetVal_SubParagraph, TokenRetval::RetVal_SubSubParagraph,
1650 TokenRetval::RetVal_EndInternal));
1651 if (lastPar) lastPar->markLast();
1652
1653 // then parse any number of level-n sections
1654 while ((level==1 && retval.is(TokenRetval::RetVal_Section)) ||
1655 (level==2 && retval.is(TokenRetval::RetVal_Subsection)) ||
1656 (level==3 && retval.is(TokenRetval::RetVal_Subsubsection)) ||
1657 (level==4 && retval.is(TokenRetval::RetVal_Paragraph)) ||
1658 (level==5 && retval.is(TokenRetval::RetVal_SubParagraph)) ||
1659 (level==6 && retval.is(TokenRetval::RetVal_SubSubParagraph))
1660 )
1661 {
1662 children().append<DocSection>(parser(),thisVariant(),
1663 level,
1665 retval = children().get_last<DocSection>()->parse();
1666 }
1667
1668 if (retval.is(TokenRetval::RetVal_Internal))
1669 {
1670 warn_doc_error(parser()->context.fileName,parser()->tokenizer.getLineNr(),"\\internal command found inside internal section");
1671 }
1672
1673 AUTO_TRACE_EXIT("retval={}",retval.to_string());
1674 return retval;
1675}
DocNodeList & children()
Definition docnode.h:143
Token parse(int)
Definition docnode.cpp:1619
DocNodeVariant * thisVariant()
Definition docnode.h:93
void markLast(bool v=TRUE)
Definition docnode.h:1095
DocParserContext context
void pop_back()
removes the last element
Definition growvector.h:115
#define AUTO_TRACE(...)
Definition docnode.cpp:48
#define AUTO_TRACE_EXIT(...)
Definition docnode.cpp:50
#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:1405
T * get_last()
Returns a pointer to the last element in the list if that element exists and holds a T,...
Definition docnode.h:1416
TokenInfo * token
Definition docparser_p.h:95
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: