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

Node representing a parameter list. More...

#include <src/docnode.h>

Inheritance diagram for DocParamList:
Collaboration diagram for DocParamList:

Public Member Functions

 DocParamList (DocParser *parser, DocNodeVariant *parent, DocParamSect::Type t, DocParamSect::Direction d)
const DocNodeListparameters () const
const DocNodeListparamTypes () const
const DocNodeListparagraphs () const
DocParamSect::Type type () const
DocParamSect::Direction direction () const
void markFirst (bool b=TRUE)
void markLast (bool b=TRUE)
bool isFirst () const
bool isLast () const
Token parse (const QCString &cmdName)
Token parseXml (const QCString &paramName)
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

DocNodeList m_paragraphs
DocNodeList m_params
DocNodeList m_paramTypes
DocParamSect::Type m_type = DocParamSect::Unknown
DocParamSect::Direction m_dir = DocParamSect::Unspecified
bool m_isFirst = false
bool m_isLast = false

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 a parameter list.

Definition at line 1130 of file docnode.h.

Constructor & Destructor Documentation

◆ DocParamList()

DocParamList::DocParamList ( DocParser * parser,
DocNodeVariant * parent,
DocParamSect::Type t,
DocParamSect::Direction d )
inline

Definition at line 1133 of file docnode.h.

1134 : DocNode(parser,parent), m_type(t), m_dir(d) {}
DocNode(DocParser *parser, DocNodeVariant *parent)
Definition docnode.h:85
DocParser * parser()
Definition docnode.h:98
DocNodeVariant * parent()
Definition docnode.h:90
DocParamSect::Direction m_dir
Definition docnode.h:1152
DocParamSect::Type m_type
Definition docnode.h:1151

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

Member Function Documentation

◆ direction()

◆ isFirst()

bool DocParamList::isFirst ( ) const
inline

Definition at line 1142 of file docnode.h.

1142{ return m_isFirst; }
bool m_isFirst
Definition docnode.h:1153

References m_isFirst.

◆ isLast()

bool DocParamList::isLast ( ) const
inline

Definition at line 1143 of file docnode.h.

1143{ return m_isLast; }
bool m_isLast
Definition docnode.h:1154

References m_isLast.

Referenced by ManDocVisitor::operator()().

◆ markFirst()

void DocParamList::markFirst ( bool b = TRUE)
inline

Definition at line 1140 of file docnode.h.

1140{ m_isFirst=b; }

References m_isFirst, and TRUE.

Referenced by parseXml().

◆ markLast()

void DocParamList::markLast ( bool b = TRUE)
inline

Definition at line 1141 of file docnode.h.

1141{ m_isLast=b; }

References m_isLast, and TRUE.

Referenced by DocParamSect::parse(), and parseXml().

◆ paragraphs()

◆ parameters()

◆ paramTypes()

const DocNodeList & DocParamList::paramTypes ( ) const
inline

◆ parse()

Token DocParamList::parse ( const QCString & cmdName)

Definition at line 3289 of file docnode.cpp.

3290{
3291 AUTO_TRACE();
3292 Token retval = Token::make_RetVal_OK();
3293 auto ns = AutoNodeStack(parser(),thisVariant());
3294 DocPara *par=nullptr;
3295 QCString saveCmdName = cmdName;
3296 DocParserContext &context = parser()->context;
3297 DocTokenizer &tokenizer = parser()->tokenizer;
3298
3299 Token tok=tokenizer.lex();
3300 if (!tok.is(TokenRetval::TK_WHITESPACE))
3301 {
3302 warn_doc_error(context.fileName,tokenizer.getLineNr(),"expected whitespace after \\{} command",
3303 saveCmdName);
3304 retval = Token::make_RetVal_EndParBlock();
3305 goto endparamlist;
3306 }
3307 tokenizer.setStateParam();
3308 tok=tokenizer.lex();
3309 while (tok.is(TokenRetval::TK_WORD)) /* there is a parameter name */
3310 {
3312 {
3313 int typeSeparator = context.token->name.find('#'); // explicit type position
3314 if (typeSeparator!=-1)
3315 {
3316 parser()->handleParameterType(thisVariant(),m_paramTypes,context.token->name.left(typeSeparator));
3317 context.token->name = context.token->name.mid(typeSeparator+1);
3318 context.hasParamCommand=TRUE;
3319 if (parent() && std::holds_alternative<DocParamSect>(*parent()))
3320 {
3321 std::get<DocParamSect>(*parent()).m_hasTypeSpecifier=true;
3322 }
3323 }
3324 else
3325 {
3326 context.hasParamCommand=TRUE;
3327 }
3329 }
3330 else if (m_type==DocParamSect::RetVal)
3331 {
3332 context.hasReturnCommand=TRUE;
3334 }
3335 context.inSeeBlock=true;
3337 context.inSeeBlock=false;
3338 tok=tokenizer.lex();
3339 }
3340 tokenizer.setStatePara();
3341 if (tok.is_any_of(TokenRetval::TK_NONE,TokenRetval::TK_EOF)) // premature end of comment
3342 {
3343 warn_doc_error(context.fileName,tokenizer.getLineNr(),"unexpected end of comment block while parsing the "
3344 "argument of command {}",saveCmdName);
3345 retval = Token::make_RetVal_EndParBlock();
3346 goto endparamlist;
3347 }
3348 if (!tok.is(TokenRetval::TK_WHITESPACE)) /* premature end of comment block */
3349 {
3350 if (!tok.is(TokenRetval::TK_NEWPARA)) /* empty param description */
3351 {
3352 warn_doc_error(context.fileName,tokenizer.getLineNr(),"unexpected token {} in comment block while parsing the "
3353 "argument of command {}",tok.to_string(),saveCmdName);
3354 }
3355 retval = Token::make_RetVal_EndParBlock();
3356 goto endparamlist;
3357 }
3358
3359 m_paragraphs.append<DocPara>(parser(),thisVariant());
3360 par = m_paragraphs.get_last<DocPara>();
3361 retval = par->parse();
3362 par->markFirst();
3363 par->markLast();
3364
3365endparamlist:
3366 AUTO_TRACE_EXIT("retval={}",retval.to_string());
3367 return retval;
3368}
DocNodeVariant * thisVariant()
Definition docnode.h:93
void markLast(bool v=TRUE)
Definition docnode.h:1095
void markFirst(bool v=TRUE)
Definition docnode.h:1094
Token parse()
Definition docnode.cpp:5784
void handleLinkedWord(DocNodeVariant *parent, DocNodeList &children, bool ignoreAutoLinkFlag=FALSE)
DocTokenizer tokenizer
void handleParameterType(DocNodeVariant *parent, DocNodeList &children, const QCString &paramTypes)
void checkRetvalName()
void checkArgumentName()
DocParserContext context
void setStateParam()
int getLineNr() const
void setStatePara()
int find(char c, int index=0, bool cs=TRUE) const
Definition qcstring.cpp:43
QCString mid(size_t index, size_t len=static_cast< size_t >(-1)) const
Definition qcstring.h:241
QCString left(size_t len) const
Definition qcstring.h:229
bool is(TokenRetval rv) const
TOKEN_SPECIFICATIONS RETVAL_SPECIFICATIONS const char * to_string() const
bool is_any_of(ARGS... args) const
#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
QCString fileName
Definition docparser_p.h:71
TokenInfo * token
Definition docparser_p.h:95
QCString name

References AUTO_TRACE, AUTO_TRACE_EXIT, DocParser::checkArgumentName(), DocParser::checkRetvalName(), DocParser::context, DocParserContext::fileName, QCString::find(), DocTokenizer::getLineNr(), DocParser::handleLinkedWord(), DocParser::handleParameterType(), DocParserContext::hasParamCommand, DocParserContext::hasReturnCommand, DocParserContext::inSeeBlock, Token::is(), Token::is_any_of(), QCString::left(), DocTokenizer::lex(), m_paragraphs, m_params, m_paramTypes, m_type, DocPara::markFirst(), DocPara::markLast(), QCString::mid(), TokenInfo::name, DocParamSect::Param, DocNode::parent(), DocPara::parse(), DocNode::parser(), DocParamSect::RetVal, DocTokenizer::setStatePara(), DocTokenizer::setStateParam(), DocNode::thisVariant(), Token::to_string(), DocParserContext::token, DocParser::tokenizer, TRUE, and warn_doc_error.

◆ parseXml()

Token DocParamList::parseXml ( const QCString & paramName)

Definition at line 3370 of file docnode.cpp.

3371{
3372 AUTO_TRACE();
3373 Token retval = Token::make_RetVal_OK();
3374 auto ns = AutoNodeStack(parser(),thisVariant());
3375
3376 parser()->context.token->name = paramName;
3378 {
3381 }
3382 else if (m_type==DocParamSect::RetVal)
3383 {
3386 }
3387
3389
3390 do
3391 {
3392 m_paragraphs.append<DocPara>(parser(),thisVariant());
3393 DocPara *par = m_paragraphs.get_last<DocPara>();
3394 retval = par->parse();
3395 if (par->isEmpty()) // avoid adding an empty paragraph for the whitespace
3396 // after </para> and before </param>
3397 {
3398 m_paragraphs.pop_back();
3399 break;
3400 }
3401 else // append the paragraph to the list
3402 {
3403 if (!m_paragraphs.empty())
3404 {
3405 m_paragraphs.get_last<DocPara>()->markLast(FALSE);
3406 }
3407 bool markFirst = m_paragraphs.empty();
3408 par = &std::get<DocPara>(m_paragraphs.back());
3409 if (markFirst)
3410 {
3411 par->markFirst();
3412 }
3413 par->markLast();
3414 }
3415
3416 if (retval.is_any_of(TokenRetval::TK_NONE,TokenRetval::TK_EOF)) break;
3417
3418 } while (retval.is(TokenRetval::RetVal_CloseXml) &&
3419 Mappers::htmlTagMapper->map(parser()->context.token->name)!=HtmlTagType::XML_PARAM &&
3420 Mappers::htmlTagMapper->map(parser()->context.token->name)!=HtmlTagType::XML_TYPEPARAM &&
3421 Mappers::htmlTagMapper->map(parser()->context.token->name)!=HtmlTagType::XML_EXCEPTION);
3422
3423 if (retval.is_any_of(TokenRetval::TK_NONE,TokenRetval::TK_EOF)) /* premature end of comment block */
3424 {
3425 warn_doc_error(parser()->context.fileName,parser()->tokenizer.getLineNr(),"unterminated param or exception tag");
3426 }
3427 else
3428 {
3429 retval = Token::make_RetVal_OK();
3430 }
3431
3432 AUTO_TRACE_EXIT("retval={}",retval.to_string());
3433 return retval;
3434}
void markFirst(bool b=TRUE)
Definition docnode.h:1140
void markLast(bool b=TRUE)
Definition docnode.h:1141
const Mapper< HtmlTagType > * htmlTagMapper
#define FALSE
Definition qcstring.h:34

References AUTO_TRACE, AUTO_TRACE_EXIT, DocParser::checkArgumentName(), DocParser::checkRetvalName(), DocParser::context, FALSE, DocParser::handleLinkedWord(), DocParserContext::hasParamCommand, DocParserContext::hasReturnCommand, Mappers::htmlTagMapper, Token::is(), Token::is_any_of(), m_paragraphs, m_params, m_type, markFirst(), markLast(), TokenInfo::name, DocParamSect::Param, DocNode::parser(), DocParamSect::RetVal, DocNode::thisVariant(), Token::to_string(), DocParserContext::token, TRUE, warn_doc_error, XML_EXCEPTION, XML_PARAM, and XML_TYPEPARAM.

◆ type()

DocParamSect::Type DocParamList::type ( ) const
inline

Definition at line 1138 of file docnode.h.

1138{ return m_type; }

References m_type.

Member Data Documentation

◆ m_dir

DocParamSect::Direction DocParamList::m_dir = DocParamSect::Unspecified
private

Definition at line 1152 of file docnode.h.

Referenced by direction(), and DocParamList().

◆ m_isFirst

bool DocParamList::m_isFirst = false
private

Definition at line 1153 of file docnode.h.

Referenced by isFirst(), and markFirst().

◆ m_isLast

bool DocParamList::m_isLast = false
private

Definition at line 1154 of file docnode.h.

Referenced by isLast(), and markLast().

◆ m_paragraphs

DocNodeList DocParamList::m_paragraphs
private

Definition at line 1148 of file docnode.h.

Referenced by paragraphs(), parse(), and parseXml().

◆ m_params

DocNodeList DocParamList::m_params
private

Definition at line 1149 of file docnode.h.

Referenced by parameters(), parse(), and parseXml().

◆ m_paramTypes

DocNodeList DocParamList::m_paramTypes
private

Definition at line 1150 of file docnode.h.

Referenced by paramTypes(), and parse().

◆ m_type

DocParamSect::Type DocParamList::m_type = DocParamSect::Unknown
private

Definition at line 1151 of file docnode.h.

Referenced by DocParamList(), parse(), parseXml(), and type().


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