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

Node representing a simple section. More...

#include <src/docnode.h>

Inheritance diagram for DocSimpleSect:
Collaboration diagram for DocSimpleSect:

Public Types

enum  Type {
  Unknown , See , Return , Author ,
  Authors , Version , Since , Date ,
  Note , Warning , Copyright , Pre ,
  Post , Invar , Remark , Attention ,
  Important , User , Rcs
}

Public Member Functions

 DocSimpleSect (DocParser *parser, DocNodeVariant *parent, Type t)
Type type () const
QCString typeString () const
Token parse (bool userTitle, bool needsSeparator)
Token parseRcs ()
Token parseXml ()
void appendLinkWord (const QCString &word)
bool hasTitle () const
const DocNodeVarianttitle () const
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

Private Attributes

Type m_type = Unknown
std::unique_ptr< DocNodeVariantm_title

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 a simple section.

Definition at line 1016 of file docnode.h.

Member Enumeration Documentation

◆ Type

Enumerator
Unknown 
See 
Return 
Author 
Authors 
Version 
Since 
Date 
Note 
Warning 
Copyright 
Pre 
Post 
Invar 
Remark 
Attention 
Important 
User 
Rcs 

Definition at line 1019 of file docnode.h.

Constructor & Destructor Documentation

◆ DocSimpleSect()

DocSimpleSect::DocSimpleSect ( DocParser * parser,
DocNodeVariant * parent,
Type t )

Definition at line 3010 of file docnode.cpp.

3010 :
3012{
3013}
DocCompoundNode(DocParser *parser, DocNodeVariant *parent)
Definition docnode.h:141
DocParser * parser()
Definition docnode.h:98
DocNodeVariant * parent()
Definition docnode.h:90

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

Member Function Documentation

◆ appendLinkWord()

void DocSimpleSect::appendLinkWord ( const QCString & word)

Definition at line 3110 of file docnode.cpp.

3111{
3112 DocPara *p=nullptr;
3113 if (children().empty() || (p=std::get_if<DocPara>(&children().back()))==nullptr)
3114 {
3115 children().append<DocPara>(parser(),thisVariant());
3116 p = children().get_last<DocPara>();
3117 }
3118 else
3119 {
3120 // Comma-separate <seealso> links.
3121 p->injectToken(Token::make_TK_WORD(),",");
3122 p->injectToken(Token::make_TK_WHITESPACE()," ");
3123 }
3124
3126 p->injectToken(Token::make_TK_LNKWORD(),word);
3128}
DocNodeList & children()
Definition docnode.h:143
DocNodeVariant * thisVariant()
Definition docnode.h:93
bool injectToken(Token tok, const QCString &tokText)
Definition docnode.cpp:4085
DocParserContext context
#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

References DocNodeList::append(), DocCompoundNode::children(), DocParser::context, FALSE, DocNodeList::get_last(), DocPara::injectToken(), DocParserContext::inSeeBlock, DocNode::parser(), DocNode::thisVariant(), and TRUE.

◆ hasTitle()

bool DocSimpleSect::hasTitle ( ) const

Definition at line 3015 of file docnode.cpp.

3016{
3017 return m_title && std::get<DocTitle>(*m_title).hasTitle();
3018}
std::unique_ptr< DocNodeVariant > m_title
Definition docnode.h:1037

References m_title.

◆ parse()

Token DocSimpleSect::parse ( bool userTitle,
bool needsSeparator )

Definition at line 3020 of file docnode.cpp.

3021{
3022 AUTO_TRACE();
3023 auto ns = AutoNodeStack(parser(),thisVariant());
3024
3025 // handle case for user defined title
3026 if (userTitle)
3027 {
3029 std::get_if<DocTitle>(m_title.get())->parse();
3030 }
3031
3032 // add new paragraph as child
3033 if (!children().empty() && std::holds_alternative<DocPara>(children().back()))
3034 {
3035 std::get<DocPara>(children().back()).markLast(FALSE);
3036 }
3037 bool markFirst = children().empty();
3038 if (needsSeparator)
3039 {
3040 children().append<DocSimpleSectSep>(parser(),thisVariant());
3041 }
3042 children().append<DocPara>(parser(),thisVariant());
3043 DocPara *par = children().get_last<DocPara>();
3044 if (markFirst)
3045 {
3046 par->markFirst();
3047 }
3048 par->markLast();
3049
3050 // parse the contents of the paragraph
3051 Token retval = par->parse();
3052
3053 AUTO_TRACE_EXIT("retval={}",retval.to_string());
3054 return retval; // 0==EOF, TokenRetval::TK_NEWPARA, TokenRetval::TK_LISTITEM, TokenRetval::TK_ENDLIST, TokenRetval::RetVal_SimpleSec
3055}
bool empty() const
checks whether the container is empty
Definition growvector.h:140
TOKEN_SPECIFICATIONS RETVAL_SPECIFICATIONS const char * to_string() const
#define AUTO_TRACE(...)
Definition docnode.cpp:46
#define AUTO_TRACE_EXIT(...)
Definition docnode.cpp:48
std::unique_ptr< DocNodeVariant > createDocNode(Args &&...args)
Definition docnode.h:1495

References DocNodeList::append(), AUTO_TRACE, AUTO_TRACE_EXIT, DocCompoundNode::children(), createDocNode(), GrowVector< T >::empty(), FALSE, DocNodeList::get_last(), m_title, DocPara::markLast(), DocNode::parser(), DocNode::thisVariant(), and Token::to_string().

Referenced by DocPara::handleSimpleSection().

◆ parseRcs()

Token DocSimpleSect::parseRcs ( )

Definition at line 3057 of file docnode.cpp.

3058{
3059 AUTO_TRACE();
3060 auto ns = AutoNodeStack(parser(),thisVariant());
3061
3063 DocTitle *title = &std::get<DocTitle>(*m_title);
3064 title->parseFromString(thisVariant(),parser()->context.token->name);
3065
3066 QCString text = parser()->context.token->text;
3067 parser()->pushContext(); // this will create a new parser->context.token
3069 parser()->popContext(); // this will restore the old parser->context.token
3070
3071 return Token::make_RetVal_OK();
3072}
Token internalValidatingParseDoc(DocNodeVariant *parent, DocNodeList &children, const QCString &doc)
void popContext()
Definition docparser.cpp:74
void pushContext()
Definition docparser.cpp:60
const DocNodeVariant * title() const
Definition docnode.h:1033
TokenInfo * token
Definition docparser_p.h:92
QCString text

References AUTO_TRACE, DocCompoundNode::children(), DocParser::context, createDocNode(), DocParser::internalValidatingParseDoc(), m_title, DocNode::parser(), DocParser::popContext(), DocParser::pushContext(), TokenInfo::text, DocNode::thisVariant(), title(), and DocParserContext::token.

◆ parseXml()

Token DocSimpleSect::parseXml ( )

Definition at line 3074 of file docnode.cpp.

3075{
3076 AUTO_TRACE();
3077 auto ns = AutoNodeStack(parser(),thisVariant());
3078
3079 Token retval = Token::make_RetVal_OK();
3080 for (;;)
3081 {
3082 // add new paragraph as child
3083 if (!children().empty() && std::holds_alternative<DocPara>(children().back()))
3084 {
3085 std::get<DocPara>(children().back()).markLast(false);
3086 }
3087 bool markFirst = children().empty();
3088 children().append<DocPara>(parser(),thisVariant());
3089 DocPara *par = children().get_last<DocPara>();
3090 if (markFirst)
3091 {
3092 par->markFirst();
3093 }
3094 par->markLast();
3095
3096 // parse the contents of the paragraph
3097 retval = par->parse();
3098 if (retval.is_any_of(TokenRetval::TK_NONE,TokenRetval::TK_EOF)) break;
3099 if (retval.is(TokenRetval::RetVal_CloseXml))
3100 {
3101 retval = Token::make_RetVal_OK();
3102 break;
3103 }
3104 }
3105
3106 AUTO_TRACE_EXIT("retval={}",retval.to_string());
3107 return retval;
3108}
bool is(TokenRetval rv) const
bool is_any_of(ARGS... args) const

References DocNodeList::append(), AUTO_TRACE, AUTO_TRACE_EXIT, DocCompoundNode::children(), GrowVector< T >::empty(), DocNodeList::get_last(), Token::is(), Token::is_any_of(), DocPara::markLast(), DocNode::parser(), DocNode::thisVariant(), and Token::to_string().

Referenced by DocPara::handleSimpleSection().

◆ title()

const DocNodeVariant * DocSimpleSect::title ( ) const
inline

Definition at line 1033 of file docnode.h.

1033{ return m_title.get(); }

References m_title.

Referenced by parseRcs().

◆ type()

Type DocSimpleSect::type ( ) const
inline

Definition at line 1026 of file docnode.h.

1026{ return m_type; }

References m_type.

Referenced by DocPara::handleHtmlStartTag(), and DocPara::handleSimpleSection().

◆ typeString()

QCString DocSimpleSect::typeString ( ) const

Definition at line 3130 of file docnode.cpp.

3131{
3132 switch (m_type)
3133 {
3134 case Unknown: break;
3135 case See: return "see";
3136 case Return: return "return";
3137 case Author: // fall through
3138 case Authors: return "author";
3139 case Version: return "version";
3140 case Since: return "since";
3141 case Date: return "date";
3142 case Note: return "note";
3143 case Warning: return "warning";
3144 case Pre: return "pre";
3145 case Post: return "post";
3146 case Copyright: return "copyright";
3147 case Invar: return "invariant";
3148 case Remark: return "remark";
3149 case Attention: return "attention";
3150 case Important: return "important";
3151 case User: return "user";
3152 case Rcs: return "rcs";
3153 }
3154 return "unknown";
3155}

References Attention, Author, Authors, Copyright, Date, Important, Invar, m_type, Note, Post, Pre, Rcs, Remark, Return, See, Since, Unknown, User, Version, and Warning.

Member Data Documentation

◆ m_title

std::unique_ptr<DocNodeVariant> DocSimpleSect::m_title
private

Definition at line 1037 of file docnode.h.

Referenced by hasTitle(), parse(), parseRcs(), and title().

◆ m_type

Type DocSimpleSect::m_type = Unknown
private

Definition at line 1036 of file docnode.h.

Referenced by DocSimpleSect(), type(), and typeString().


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