Doxygen
Loading...
Searching...
No Matches
memberdef.cpp File Reference
#include <stdio.h>
#include <assert.h>
#include <mutex>
#include "md5.h"
#include "memberdef.h"
#include "membername.h"
#include "doxygen.h"
#include "util.h"
#include "code.h"
#include "message.h"
#include "htmlhelp.h"
#include "language.h"
#include "outputlist.h"
#include "example.h"
#include "membergroup.h"
#include "groupdef.h"
#include "defargs.h"
#include "docparser.h"
#include "dot.h"
#include "dotcallgraph.h"
#include "searchindex.h"
#include "parserintf.h"
#include "vhdldocgen.h"
#include "arguments.h"
#include "memberlist.h"
#include "namespacedef.h"
#include "moduledef.h"
#include "filedef.h"
#include "config.h"
#include "definitionimpl.h"
#include "regex.h"
#include "trace.h"
Include dependency graph for memberdef.cpp:

Go to the source code of this file.

Classes

class  MemberDefImpl
class  MemberDefAliasImpl

Functions

std::unique_ptr< MemberDefcreateMemberDef (const QCString &defFileName, int defLine, int defColumn, const QCString &type, const QCString &name, const QCString &args, const QCString &excp, Protection prot, Specifier virt, bool stat, Relationship related, MemberType t, const ArgumentList &tal, const ArgumentList &al, const QCString &metaData)
 Factory method to create a new instance of a MemberDef.
std::unique_ptr< MemberDefcreateMemberDefAlias (const Definition *newScope, const MemberDef *aliasMd)
static QCString addTemplateNames (const QCString &s, const QCString &n, const QCString &t)
static bool writeDefArgumentList (OutputList &ol, const Definition *scope, const MemberDef *md)
static void writeExceptionListImpl (OutputList &ol, const ClassDef *cd, const MemberDef *md, QCString const &exception)
static void writeExceptionList (OutputList &ol, const ClassDef *cd, const MemberDef *md)
static QCString combineArgsAndException (QCString args, QCString exception)
static QCString simplifyTypeForTable (const QCString &s)
static QCString stripTrailingReturn (const QCString &trailRet)
static void invalidateCachedTypesInArgumentList (ArgumentList &al)
static void transferArgumentDocumentation (ArgumentList &decAl, ArgumentList &defAl)
void combineDeclarationAndDefinition (MemberDefMutable *mdec, MemberDefMutable *mdef)
void addDocCrossReference (const MemberDef *s, const MemberDef *d)
MemberDeftoMemberDef (Definition *d)
MemberDeftoMemberDef (DefinitionMutable *md)
const MemberDeftoMemberDef (const Definition *d)
MemberDefMutabletoMemberDefMutable (Definition *d)

Variables

static std::mutex g_cachedAnonymousTypeMutex
static std::mutex g_hasDetailedDescriptionMutex
static const reg::Ex reAnonymous (R"([\w:@]*@\d+)")
static std::mutex g_detectUndocumentedParamsMutex
static std::mutex g_docCrossReferenceMutex

Function Documentation

◆ addDocCrossReference()

void addDocCrossReference ( const MemberDef * s,
const MemberDef * d )

Definition at line 6484 of file memberdef.cpp.

6485{
6486 MemberDefMutable *src = toMemberDefMutable(const_cast<MemberDef*>(s));
6487 MemberDefMutable *dst = toMemberDefMutable(const_cast<MemberDef*>(d));
6488 if (src==nullptr || dst==nullptr) return;
6489 //printf("--> addDocCrossReference src=%s,dst=%s\n",qPrint(src->name()),qPrint(dst->name()));
6490 if (dst->isTypedef() || dst->isEnumerate()) return; // don't add types
6491 if ((dst->hasReferencedByRelation() || dst->hasCallerGraph()) &&
6492 src->isCallable()
6493 )
6494 {
6495 QCString sourceRefName = src->sourceRefName();
6498
6499 // ---- critical section
6500 std::lock_guard<std::mutex> lock(g_docCrossReferenceMutex);
6501 dst->addSourceReferencedBy(src,sourceRefName);
6502 if (mdDef)
6503 {
6504 mdDef->addSourceReferencedBy(src,sourceRefName);
6505 }
6506 if (mdDecl)
6507 {
6508 mdDecl->addSourceReferencedBy(src,sourceRefName);
6509 }
6510 // ---- end critical section
6511 }
6512 if ((src->hasReferencesRelation() || src->hasCallGraph()) &&
6513 src->isCallable()
6514 )
6515 {
6516 QCString sourceRefName = dst->sourceRefName();
6519
6520 // ---- critical section
6521 std::lock_guard<std::mutex> lock(g_docCrossReferenceMutex);
6522 src->addSourceReferences(dst,sourceRefName);
6523 if (mdDef)
6524 {
6525 mdDef->addSourceReferences(dst,sourceRefName);
6526 }
6527 if (mdDecl)
6528 {
6529 mdDecl->addSourceReferences(dst,sourceRefName);
6530 }
6531 // ---- end critical section
6532 }
6533}
virtual void addSourceReferences(MemberDef *d, const QCString &sourceRefName)=0
virtual void addSourceReferencedBy(MemberDef *d, const QCString &sourceRefName)=0
A model of a class/file/namespace member symbol.
Definition memberdef.h:48
virtual MemberDef * memberDefinition() const =0
virtual MemberDef * memberDeclaration() const =0
virtual bool hasReferencesRelation() const =0
virtual bool isTypedef() const =0
virtual bool hasCallGraph() const =0
virtual QCString sourceRefName() const =0
virtual bool hasCallerGraph() const =0
virtual bool isEnumerate() const =0
virtual bool hasReferencedByRelation() const =0
virtual bool isCallable() const =0
This is an alternative implementation of QCString.
Definition qcstring.h:103
static std::mutex g_docCrossReferenceMutex
MemberDefMutable * toMemberDefMutable(Definition *d)

References DefinitionMutable::addSourceReferencedBy(), DefinitionMutable::addSourceReferences(), g_docCrossReferenceMutex, MemberDef::hasCallerGraph(), MemberDef::hasCallGraph(), MemberDef::hasReferencedByRelation(), MemberDef::hasReferencesRelation(), MemberDef::isCallable(), MemberDef::isEnumerate(), MemberDef::isTypedef(), MemberDef::memberDeclaration(), MemberDef::memberDefinition(), MemberDef::sourceRefName(), and toMemberDefMutable().

Referenced by findMemberLink(), generateClassMemberLink(), generateClassOrGlobalLink(), generateClassOrGlobalLink(), getLink(), getLinkInScope(), getLinkInScope(), MemberDefMutable::setFromAnonymousScope(), and writeObjCMethodCall().

◆ addTemplateNames()

QCString addTemplateNames ( const QCString & s,
const QCString & n,
const QCString & t )
static

Definition at line 989 of file memberdef.cpp.

990{
991 QCString result;
992 QCString clRealName=n;
993 int p=0,i=0;
994 if ((i=clRealName.find('<'))!=-1)
995 {
996 clRealName=clRealName.left(i); // strip template specialization
997 }
998 if ((i=clRealName.findRev("::"))!=-1)
999 {
1000 clRealName=clRealName.right(clRealName.length()-i-2);
1001 }
1002 while ((i=s.find(clRealName,p))!=-1)
1003 {
1004 result+=s.mid(p,i-p);
1005 size_t j=clRealName.length()+i;
1006 if (s.length()==j || (s.at(j)!='<' && !isId(s.at(j))))
1007 { // add template names
1008 //printf("Adding %s+%s\n",qPrint(clRealName),qPrint(t));
1009 result+=clRealName+t;
1010 }
1011 else
1012 { // template names already present
1013 //printf("Adding %s\n",qPrint(clRealName));
1014 result+=clRealName;
1015 }
1016 p=i+static_cast<int>(clRealName.length());
1017 }
1018 result+=s.right(s.length()-p);
1019 //printf("addTemplateNames(%s,%s,%s)=%s\n",qPrint(s),qPrint(n),qPrint(t),qPrint(result));
1020 return result;
1021}
int find(char c, int index=0, bool cs=TRUE) const
Definition qcstring.cpp:43
size_t length() const
Returns the length of the string, not counting the 0-terminator.
Definition qcstring.h:170
QCString mid(size_t index, size_t len=static_cast< size_t >(-1)) const
Definition qcstring.h:245
char & at(size_t i)
Returns a reference to the character at index i.
Definition qcstring.h:597
QCString right(size_t len) const
Definition qcstring.h:238
int findRev(char c, int index=-1, bool cs=TRUE) const
Definition qcstring.cpp:96
QCString left(size_t len) const
Definition qcstring.h:233
bool isId(int c)
Definition util.h:256

References QCString::at(), QCString::find(), QCString::findRev(), isId(), QCString::left(), QCString::length(), QCString::mid(), and QCString::right().

Referenced by writeDefArgumentList().

◆ combineArgsAndException()

QCString combineArgsAndException ( QCString args,
QCString exception )
static

Definition at line 2224 of file memberdef.cpp.

2225{
2226 if (exception.isEmpty()) return args; // no exception, nothing to combine args
2227 int pos = args.findRev(')');
2228 int eqPos = pos!=-1 ? args.find('=',pos) : -1; // look for '=' in '(args) = something'
2229 if (eqPos==-1) return args+" "+exception; // append exception at the end
2230 return args.left(eqPos)+" "+exception+" "+args.mid(eqPos); // insert exception before =
2231}
bool isEmpty() const
Returns TRUE iff the string is empty.
Definition qcstring.h:167

References QCString::find(), QCString::findRev(), QCString::isEmpty(), QCString::left(), and QCString::mid().

Referenced by MemberDefImpl::writeDeclaration().

◆ combineDeclarationAndDefinition()

void combineDeclarationAndDefinition ( MemberDefMutable * mdec,
MemberDefMutable * mdef )

Definition at line 6209 of file memberdef.cpp.

6210{
6211 AUTO_TRACE("mdec='{}' mdef='{}' mdec.isPrototype={} mdef.isPrototype={}",
6212 mdec->name(), mdef->name(), mdec->isPrototype(), mdef->isPrototype());
6213 if (
6214 (!mdef->isDocTransferDone() || !mdec->isDocTransferDone()) &&
6215 (
6216 (mdef->isFunction() && !mdef->isStatic() && !mdef->isPrototype()) ||
6217 (mdef->isVariable() && !mdef->isExternal() && !mdef->isStatic())
6218 )
6219 )
6220 {
6221 bool sameNumTemplateArgs = mdef->templateArguments().size()==mdec->templateArguments().size();
6222
6223 ArgumentList &mdefAl = const_cast<ArgumentList&>(mdef->argumentList());
6224 ArgumentList &mdecAl = const_cast<ArgumentList&>(mdec->argumentList());
6225 if (sameNumTemplateArgs &&
6226 matchArguments2(mdef->getOuterScope(),mdef->getFileDef(),mdef->typeString(),&mdefAl,
6227 mdec->getOuterScope(),mdec->getFileDef(),mdec->typeString(),&mdecAl,
6228 TRUE,mdef->getLanguage()
6229 )
6230 ) /* match found */
6231 {
6232 AUTO_TRACE_ADD("combining definition and declaration");
6233
6234 if (Config_getBool(RESOLVE_UNNAMED_PARAMS))
6235 {
6236 mdec->resolveUnnamedParameters(mdef);
6237 }
6238
6239 // first merge argument documentation
6240 transferArgumentDocumentation(mdecAl,mdefAl);
6241
6242 // copy brief description between definition and declaration
6243 QCString mdefBrief = mdef->briefDescription();
6244 QCString mdecBrief = mdec->briefDescription();
6245 QCString mdefBriefFile = mdef->briefFile();
6246 QCString mdecBriefFile = mdec->briefFile();
6247 int mdefBriefLine = mdef->briefLine();
6248 int mdecBriefLine = mdec->briefLine();
6249 if (!mdef->isDocTransferDone() && !mdecBrief.isEmpty())
6250 {
6251 mdef->setBriefDescription(mdecBrief,mdecBriefFile,mdecBriefLine);
6252 }
6253 if (!mdec->isDocTransferDone() && !mdefBrief.isEmpty())
6254 {
6255 mdec->setBriefDescription(mdefBrief,mdefBriefFile,mdefBriefLine);
6256 }
6257
6258 // copy detailed description between definition and declaration
6259 QCString mdefDocs = mdef->documentation();
6260 QCString mdecDocs = mdec->documentation();
6261 QCString mdefFile = mdef->docFile();
6262 QCString mdecFile = mdec->docFile();
6263 int mdefLine = mdef->docLine();
6264 int mdecLine = mdec->docLine();
6265 bool mdefDocsForDef = mdef->isDocsForDefinition();
6266 bool mdecDocsForDef = mdec->isDocsForDefinition();
6267 if (!mdec->isDocTransferDone() && !mdefDocs.isEmpty())
6268 {
6269 //printf("transferring docs mdef->mdec (%s->%s)\n",mdef->argsString(),mdec->argsString());
6270 mdec->setDocumentation(mdefDocs,mdefFile,mdefLine);
6271 mdec->setDocsForDefinition(mdefDocsForDef);
6272 if (mdefAl.hasParameters())
6273 {
6274 auto mdefAlComb = stringToArgumentList(mdef->getLanguage(),mdef->argsString());
6275 transferArgumentDocumentation(mdefAl,*mdefAlComb);
6276 mdec->moveArgumentList(std::move(mdefAlComb));
6277 }
6278 }
6279 if (!mdef->isDocTransferDone() && !mdecDocs.isEmpty())
6280 {
6281 //printf("transferring docs mdec->mdef (%s->%s)\n",mdec->argsString(),mdef->argsString());
6282 mdef->setDocumentation(mdecDocs,mdecFile,mdecLine);
6283 mdef->setDocsForDefinition(mdecDocsForDef);
6284 if (mdecAl.hasParameters())
6285 {
6286 auto mdecAlComb = stringToArgumentList(mdec->getLanguage(),mdec->argsString());
6287 transferArgumentDocumentation(mdecAl,*mdecAlComb);
6288 mdef->moveDeclArgumentList(std::move(mdecAlComb));
6289 }
6290 }
6291
6292 // copy inbody documentation between definition and declaration
6293 QCString mdefInbodyDocs = mdef->inbodyDocumentation();
6294 QCString mdecInbodyDocs = mdec->inbodyDocumentation();
6295 QCString mdefInbodyFile = mdef->inbodyFile();
6296 QCString mdecInbodyFile = mdec->inbodyFile();
6297 int mdefInbodyLine = mdef->inbodyLine();
6298 int mdecInbodyLine = mdec->inbodyLine();
6299 if (!mdec->isDocTransferDone() && !mdefInbodyDocs.isEmpty())
6300 {
6301 mdec->setInbodyDocumentation(mdefInbodyDocs,mdefInbodyFile,mdefInbodyLine);
6302 }
6303 if (!mdef->isDocTransferDone() && !mdecInbodyDocs.isEmpty())
6304 {
6305 mdef->setInbodyDocumentation(mdecInbodyDocs,mdecInbodyFile,mdecInbodyLine);
6306 }
6307
6308 if (mdec->getStartBodyLine()!=-1 && mdef->getStartBodyLine()==-1)
6309 {
6310 //printf("body mdec->mdef %d-%d\n",mdec->getStartBodyLine(),mdef->getEndBodyLine());
6311 mdef->setBodySegment(mdec->getDefLine(),mdec->getStartBodyLine(),mdec->getEndBodyLine());
6312 mdef->setBodyDef(mdec->getBodyDef());
6313 //mdef->setBodyMember(mdec);
6314 }
6315 else if (mdef->getStartBodyLine()!=-1 && mdec->getStartBodyLine()==-1)
6316 {
6317 //printf("body mdef->mdec %d-%d\n",mdef->getStartBodyLine(),mdec->getEndBodyLine());
6318 mdec->setBodySegment(mdef->getDefLine(),mdef->getStartBodyLine(),mdef->getEndBodyLine());
6319 mdec->setBodyDef(mdef->getBodyDef());
6320 //mdec->setBodyMember(mdef);
6321 }
6324
6325 // copy group info.
6326 if (mdec->getGroupDef()==nullptr && mdef->getGroupDef()!=nullptr)
6327 {
6328 mdec->setGroupDef(mdef->getGroupDef(),
6329 mdef->getGroupPri(),
6330 mdef->docFile(),
6331 mdef->docLine(),
6332 mdef->hasDocumentation(),
6333 mdef
6334 );
6335 }
6336 else if (mdef->getGroupDef()==nullptr && mdec->getGroupDef()!=nullptr)
6337 {
6338 mdef->setGroupDef(mdec->getGroupDef(),
6339 mdec->getGroupPri(),
6340 mdec->docFile(),
6341 mdec->docLine(),
6342 mdec->hasDocumentation(),
6343 mdec
6344 );
6345 }
6346
6347
6348 mdec->mergeRefItems(mdef);
6349 mdef->mergeRefItems(mdec);
6350
6351 mdef->setMemberDeclaration(mdec);
6352 mdec->setMemberDefinition(mdef);
6353
6354 mergeMemberOverrideOptions(mdec,mdef);
6355
6356 mdef->addQualifiers(mdec->getQualifiers());
6357 mdec->addQualifiers(mdef->getQualifiers());
6358
6359 mdef->setDocTransferDone();
6360 mdec->setDocTransferDone();
6361 }
6362 }
6363}
This class represents an function or template argument list.
Definition arguments.h:65
bool hasParameters() const
Definition arguments.h:76
size_t size() const
Definition arguments.h:100
virtual QCString docFile() const =0
virtual int getEndBodyLine() const =0
virtual SrcLangExt getLanguage() const =0
Returns the programming language this definition was written in.
virtual int docLine() const =0
virtual int getDefLine() const =0
virtual int inbodyLine() const =0
virtual const FileDef * getBodyDef() const =0
virtual int briefLine() const =0
virtual bool hasDocumentation() const =0
virtual QCString briefDescription(bool abbreviate=FALSE) const =0
virtual QCString documentation() const =0
virtual QCString briefFile() const =0
virtual Definition * getOuterScope() const =0
virtual int getStartBodyLine() const =0
virtual QCString inbodyDocumentation() const =0
virtual QCString inbodyFile() const =0
virtual const QCString & name() const =0
virtual void setBodySegment(int defLine, int bls, int ble)=0
virtual void setDocumentation(const QCString &d, const QCString &docFile, int docLine, bool stripWhiteSpace=TRUE)=0
virtual void setInbodyDocumentation(const QCString &d, const QCString &docFile, int docLine)=0
virtual void mergeRefItems(Definition *d)=0
virtual void setBodyDef(const FileDef *fd)=0
virtual void setBriefDescription(const QCString &b, const QCString &briefFile, int briefLine)=0
virtual QCString typeString() const =0
virtual const ArgumentList & templateArguments() const =0
virtual GroupDef * getGroupDef()=0
virtual const FileDef * getFileDef() const =0
virtual const ArgumentList & argumentList() const =0
virtual bool isFunction() const =0
virtual bool isExternal() const =0
virtual bool isStatic() const =0
virtual StringVector getQualifiers() const =0
virtual bool isDocsForDefinition() const =0
virtual Grouping::GroupPri_t getGroupPri() const =0
virtual TypeSpecifier getMemberSpecifiers() const =0
virtual bool isDocTransferDone() const =0
virtual bool isVariable() const =0
virtual QCString argsString() const =0
virtual bool isPrototype() const =0
virtual void setMemberDeclaration(MemberDef *md)=0
virtual void setDocTransferDone()=0
virtual void resolveUnnamedParameters(const MemberDef *md)=0
virtual void setDocsForDefinition(bool b)=0
virtual void mergeMemberSpecifiers(TypeSpecifier s)=0
virtual void addQualifiers(const StringVector &qualifiers)=0
virtual void moveDeclArgumentList(std::unique_ptr< ArgumentList > al)=0
virtual void setGroupDef(GroupDef *gd, Grouping::GroupPri_t pri, const QCString &fileName, int startLine, bool hasDocs, MemberDef *member=nullptr)=0
virtual void setMemberDefinition(MemberDef *md)=0
virtual void moveArgumentList(std::unique_ptr< ArgumentList > al)=0
#define Config_getBool(name)
Definition config.h:33
std::unique_ptr< ArgumentList > stringToArgumentList(SrcLangExt lang, const QCString &argsString, QCString *extraTypeChars=nullptr)
Definition defargs.l:826
#define AUTO_TRACE_ADD(...)
Definition docnode.cpp:49
#define AUTO_TRACE(...)
Definition docnode.cpp:48
static void transferArgumentDocumentation(ArgumentList &decAl, ArgumentList &defAl)
#define TRUE
Definition qcstring.h:37
bool matchArguments2(const Definition *srcScope, const FileDef *srcFileScope, const QCString &srcReturnType, const ArgumentList *srcAl, const Definition *dstScope, const FileDef *dstFileScope, const QCString &dstReturnType, const ArgumentList *dstAl, bool checkCV, SrcLangExt lang)
Definition util.cpp:2031
void mergeMemberOverrideOptions(MemberDefMutable *md1, MemberDefMutable *md2)
Definition util.cpp:6879

References MemberDefMutable::addQualifiers(), MemberDef::argsString(), MemberDef::argumentList(), AUTO_TRACE, AUTO_TRACE_ADD, Definition::briefDescription(), Definition::briefFile(), Definition::briefLine(), Config_getBool, Definition::docFile(), Definition::docLine(), Definition::documentation(), Definition::getBodyDef(), Definition::getDefLine(), Definition::getEndBodyLine(), MemberDef::getFileDef(), MemberDef::getGroupDef(), MemberDef::getGroupPri(), Definition::getLanguage(), MemberDef::getMemberSpecifiers(), Definition::getOuterScope(), MemberDef::getQualifiers(), Definition::getStartBodyLine(), Definition::hasDocumentation(), ArgumentList::hasParameters(), Definition::inbodyDocumentation(), Definition::inbodyFile(), Definition::inbodyLine(), MemberDef::isDocsForDefinition(), MemberDef::isDocTransferDone(), QCString::isEmpty(), MemberDef::isExternal(), MemberDef::isFunction(), MemberDef::isPrototype(), MemberDef::isStatic(), MemberDef::isVariable(), matchArguments2(), mergeMemberOverrideOptions(), MemberDefMutable::mergeMemberSpecifiers(), DefinitionMutable::mergeRefItems(), MemberDefMutable::moveArgumentList(), MemberDefMutable::moveDeclArgumentList(), Definition::name(), MemberDefMutable::resolveUnnamedParameters(), DefinitionMutable::setBodyDef(), DefinitionMutable::setBodySegment(), DefinitionMutable::setBriefDescription(), MemberDefMutable::setDocsForDefinition(), MemberDefMutable::setDocTransferDone(), DefinitionMutable::setDocumentation(), MemberDefMutable::setGroupDef(), DefinitionMutable::setInbodyDocumentation(), MemberDefMutable::setMemberDeclaration(), MemberDefMutable::setMemberDefinition(), ArgumentList::size(), stringToArgumentList(), MemberDef::templateArguments(), transferArgumentDocumentation(), TRUE, and MemberDef::typeString().

Referenced by ClassDefImpl::mergeCategory(), MemberDefMutable::setFromAnonymousScope(), and transferFunctionDocumentation().

◆ createMemberDef()

std::unique_ptr< MemberDef > createMemberDef ( const QCString & defFileName,
int defLine,
int defColumn,
const QCString & type,
const QCString & name,
const QCString & args,
const QCString & excp,
Protection prot,
Specifier virt,
bool stat,
Relationship related,
MemberType t,
const ArgumentList & tal,
const ArgumentList & al,
const QCString & metaData )

◆ createMemberDefAlias()

std::unique_ptr< MemberDef > createMemberDefAlias ( const Definition * newScope,
const MemberDef * aliasMd )

Definition at line 980 of file memberdef.cpp.

981{
982 auto amd = std::make_unique<MemberDefAliasImpl>(newScope,aliasMd);
983 //printf("amd: name=%s displayName=%s\n",qPrint(amd->name()),qPrint(amd->displayName()));
984 return amd;
985}

Referenced by MemberDefAliasImpl::deepCopy(), findUsingDeclImports(), NamespaceDefImpl::insertMember(), insertMemberAlias(), and MemberDefMutable::setFromAnonymousScope().

◆ invalidateCachedTypesInArgumentList()

void invalidateCachedTypesInArgumentList ( ArgumentList & al)
static

Definition at line 6145 of file memberdef.cpp.

6146{
6147 for (Argument &a : al)
6148 {
6149 a.canType.clear();
6150 }
6151}
This class contains the information about the argument of a function or template.
Definition arguments.h:27

Referenced by MemberDefImpl::invalidateCachedArgumentTypes().

◆ simplifyTypeForTable()

QCString simplifyTypeForTable ( const QCString & s)
static

Definition at line 3969 of file memberdef.cpp.

3970{
3972 if (ts.endsWith("::")) ts = ts.left(ts.length()-2);
3973 static const reg::Ex re1(R"(\a\w*::)"); // non-template version
3974 static const reg::Ex re2(R"(\a\w*<[^>]*>::)"); // template version
3976 std::string t = ts.str();
3977 while (reg::search(t,match,re2) || reg::search(t,match,re1))
3978 {
3979 t = match.prefix().str() + match.suffix().str(); // remove the matched part
3980 }
3981 //printf("simplifyTypeForTable(%s)->%s\n",qPrint(s),qPrint(t));
3982 return t;
3983}
bool endsWith(const char *s) const
Definition qcstring.h:528
const std::string & str() const
Definition qcstring.h:556
Class representing a regular expression.
Definition regex.h:39
Object representing the matching results.
Definition regex.h:151
bool search(std::string_view str, Match &match, const Ex &re, size_t pos)
Search in a given string str starting at position pos for a match against regular expression re.
Definition regex.cpp:844
bool match(std::string_view str, Match &match, const Ex &re)
Matches a given string str for a match against regular expression re.
Definition regex.cpp:855
QCString removeAnonymousScopes(const QCString &str)
Definition util.cpp:161

References QCString::endsWith(), QCString::left(), QCString::length(), removeAnonymousScopes(), reg::search(), and QCString::str().

Referenced by MemberDefImpl::fieldType().

◆ stripTrailingReturn()

QCString stripTrailingReturn ( const QCString & trailRet)
static

Definition at line 4205 of file memberdef.cpp.

4206{
4207 QCString ret = trailRet;
4208
4209 ret = ret.stripWhiteSpace();
4210 if (ret.startsWith("->"))
4211 {
4212 ret = ret.mid(2).stripWhiteSpace();
4213 return ret;
4214 }
4215 return trailRet;
4216}
bool startsWith(const char *s) const
Definition qcstring.h:511
QCString stripWhiteSpace() const
returns a copy of this string with leading and trailing whitespace removed
Definition qcstring.h:264

References QCString::mid(), QCString::startsWith(), and QCString::stripWhiteSpace().

Referenced by MemberDefImpl::warnIfUndocumentedParams().

◆ toMemberDef() [1/3]

const MemberDef * toMemberDef ( const Definition * d)

Definition at line 6562 of file memberdef.cpp.

6563{
6564 if (d && (typeid(*d)==typeid(MemberDefImpl) || typeid(*d)==typeid(MemberDefAliasImpl)))
6565 {
6566 return static_cast<const MemberDef*>(d);
6567 }
6568 else
6569 {
6570 return nullptr;
6571 }
6572}

◆ toMemberDef() [2/3]

◆ toMemberDef() [3/3]

MemberDef * toMemberDef ( DefinitionMutable * md)

Definition at line 6549 of file memberdef.cpp.

6550{
6551 Definition *d = toDefinition(md);
6552 if (d && typeid(*d)==typeid(MemberDefImpl))
6553 {
6554 return static_cast<MemberDef*>(d);
6555 }
6556 else
6557 {
6558 return nullptr;
6559 }
6560}
The common base class of all entity definitions found in the sources.
Definition definition.h:77
Definition * toDefinition(DefinitionMutable *dm)

References toDefinition().

◆ toMemberDefMutable()

MemberDefMutable * toMemberDefMutable ( Definition * d)

Definition at line 6574 of file memberdef.cpp.

6575{
6576 if (d && typeid(*d)==typeid(MemberDefImpl))
6577 {
6578 return static_cast<MemberDefMutable*>(d);
6579 }
6580 else
6581 {
6582 return nullptr;
6583 }
6584}

Referenced by addDocCrossReference(), addEnumValuesToEnums(), addGlobalFunction(), addInstance(), addInterfaceOrServiceToServiceOrSingleton(), MemberList::addListReferences(), addLocalObjCMethod(), addMemberFunction(), addMemberSpecialization(), addMembersToMemberGroup(), addMemberToGroups(), ClassDefImpl::addMemberToList(), FileDefImpl::addMemberToList(), ModuleDefImpl::addMemberToList(), NamespaceDefImpl::addMemberToList(), ModuleDefImpl::addMemberToModule(), ModuleManager::addMemberToModule(), ClassDefImpl::addMemberToTemplateInstance(), addMethodToClass(), addOverloaded(), MemberList::addRequirementReferences(), addVariableToClass(), addVariableToFile(), buildDefineList(), buildFunctionList(), buildTypedefList(), computeMemberRelationsForBaseClass(), createTagLessInstance(), MemberDefImpl::createTemplateInstanceMember(), createUsingMemberImportForClass(), ClassDefImpl::deepCopy(), MemberGroup::distributeMemberGroupDocumentation(), findDefineDocumentation(), findDEV(), findEnumDocumentation(), findEnums(), findFriends(), findGlobalMember(), findMember(), MemberList::findSectionsInDocumentation(), findUsingDeclImports(), flushCachedTemplateRelations(), flushUnresolvedRelations(), generateClassMemberLink(), generateClassOrGlobalLink(), getLinkInScope(), ClassDefImpl::hideDerivedVariablesInPython(), incrementFlowKeyWordCount(), incrementFlowKeyWordCount(), inheritDocumentation(), GroupDefImpl::insertMember(), MemberGroup::insertMember(), NamespaceDefImpl::insertMember(), MemberDefImpl::insertReimplementedBy(), ClassDefImpl::mergeCategory(), SymbolResolver::Private::newResolveTypedef(), processTagLessClasses(), MemberList::setAnchors(), MemberList::setAnonymousEnumType(), MemberDefMutable::setFromAnonymousScope(), ClassDefImpl::setGroupDefForAllMembers(), transferFunctionDocumentation(), transferFunctionReferences(), transferRelatedFunctionDocumentation(), transferStaticInstanceInitializers(), tryAddEnumDocsToGroupMember(), vhdlCorrectMemberProperties(), MemberDefImpl::writeDeclaration(), MemberList::writeDocumentation(), MemberList::writeDocumentationPage(), VhdlDocGen::writePlainVHDLDeclarations(), MemberList::writeSimpleDocumentation(), VhdlDocGen::writeSource(), and MemberList::writeTagFile().

◆ transferArgumentDocumentation()

void transferArgumentDocumentation ( ArgumentList & decAl,
ArgumentList & defAl )
static

Definition at line 6178 of file memberdef.cpp.

6179{
6180 for (auto decIt = decAl.begin(), defIt = defAl.begin();
6181 decIt!= decAl.end() && defIt!= defAl.end();
6182 ++decIt, ++defIt)
6183 {
6184 Argument &decA = *decIt;
6185 Argument &defA = *defIt;
6186 if (decA.docs.isEmpty() && !defA.docs.isEmpty())
6187 {
6188 decA.docs = defA.docs;
6189 }
6190 else if (defA.docs.isEmpty() && !decA.docs.isEmpty())
6191 {
6192 defA.docs = decA.docs;
6193 }
6194 //printf("transferArgumentDocumentation(%s<->%s)\n",qPrint(decA.name),qPrint(defA.name));
6195 if (Config_getBool(RESOLVE_UNNAMED_PARAMS))
6196 {
6197 if (decA.name.isEmpty() && !defA.name.isEmpty())
6198 {
6199 decA.name = defA.name;
6200 }
6201 else if (defA.name.isEmpty() && !decA.name.isEmpty())
6202 {
6203 defA.name = decA.name;
6204 }
6205 }
6206 }
6207}
iterator end()
Definition arguments.h:94
iterator begin()
Definition arguments.h:93
QCString name
Definition arguments.h:44
QCString docs
Definition arguments.h:47

References ArgumentList::begin(), Config_getBool, Argument::docs, ArgumentList::end(), QCString::isEmpty(), and Argument::name.

Referenced by combineDeclarationAndDefinition().

◆ writeDefArgumentList()

bool writeDefArgumentList ( OutputList & ol,
const Definition * scope,
const MemberDef * md )
static

Definition at line 1062 of file memberdef.cpp.

1063{
1064 const ArgumentList &defArgList=(md->isDocsForDefinition()) ?
1065 md->argumentList() : md->declArgumentList();
1066 //printf("writeDefArgumentList '%s' isDocsForDefinition()=%d hasParameters()=%d (%s)\n",
1067 // qPrint(md->name()),md->isDocsForDefinition(),defArgList.hasParameters(),qPrint(argListToString(defArgList)));
1068 if (!defArgList.hasParameters() || md->isProperty() || md->isTypedef())
1069 {
1070 return FALSE; // member has no function like argument list
1071 }
1072
1073 bool isDefine = md->isDefine();
1074 if (!isDefine) ol.docify(" ");
1075
1076 //printf("writeDefArgList(%d)\n",defArgList->count());
1077 ol.endMemberDocName();
1079 //printf("===> name=%s isDefine=%d\n",qPrint(md->name()),md->isDefine());
1080
1081 QCString cName;
1082 if (scope)
1083 {
1084 cName=scope->name();
1085 int il=cName.find('<');
1086 int ir=cName.findRev('>');
1087 if (il!=-1 && ir!=-1 && ir>il)
1088 {
1089 cName=cName.mid(il,ir-il+1);
1090 //printf("1. cName=%s\n",qPrint(cName));
1091 }
1092 else if (scope->definitionType()==Definition::TypeClass)
1093 {
1094 cName=tempArgListToString((toClassDef(scope))->templateArguments(),
1095 scope->getLanguage());
1096 //printf("2. cName=%s\n",qPrint(cName));
1097 }
1098 else // no template specifier
1099 {
1100 cName.clear();
1101 }
1102 }
1103 //printf("~~~ %s cName=%s\n",qPrint(md->name()),qPrint(cName));
1104
1106
1107 LinkifyTextOptions options;
1108 options.setScope(scope).setFileScope(md->getBodyDef()).setSelf(md);
1109
1110 bool first=TRUE;
1111 bool paramTypeStarted=FALSE;
1112 auto alIt = defArgList.begin();
1113 while (alIt!=defArgList.end())
1114 {
1115 Argument a = *alIt;
1116 if (isDefine || first)
1117 {
1118 ol.startParameterType(first,QCString());
1119 paramTypeStarted=true;
1120 if (isDefine)
1121 {
1122 ol.endParameterType();
1124 }
1125 }
1126
1127 if (!a.attrib.isEmpty() && !md->isObjCMethod()) // argument has an IDL attribute
1128 {
1129 ol.docify(a.attrib+" ");
1130 }
1131
1132 QCString atype = a.type;
1133 if (sep!="::") { atype=substitute(atype,"::",sep); }
1134
1135 int funcPtrPos=-1;
1136 {
1137 if (md->isObjCMethod()) { atype.prepend("("); atype.append(")"); }
1138 if (atype!="...")
1139 {
1140 if (!cName.isEmpty() && scope && scope!=Doxygen::globalScope)
1141 {
1142 atype=addTemplateNames(atype,scope->name(),cName);
1143 }
1144 // 1. split ...*)(... -> '*' + name + ')(...'
1145 // 2. split ...*[some thing])(... -> '*' + name + '[some thing])(...'
1146 int starPos = atype.find('*'); // find pointer
1147 if (starPos==-1) starPos = atype.find('&'); // can also be reference
1148 funcPtrPos = atype.find(")(");
1149 if (starPos!=-1 && funcPtrPos>starPos)
1150 {
1151 funcPtrPos=starPos+1;
1152 }
1153 else
1154 {
1155 funcPtrPos=-1;
1156 }
1158 funcPtrPos==-1 ? atype : atype.left(funcPtrPos),
1159 options);
1160 }
1161 }
1162
1163 if (!isDefine)
1164 {
1165 if (paramTypeStarted)
1166 {
1167 ol.endParameterType();
1168 paramTypeStarted=FALSE;
1169 }
1170 ol.startParameterName(defArgList.size()<2);
1171 }
1172 else
1173 {
1174 ol.endParameterName();
1175 }
1176
1177 if (atype=="...")
1178 {
1179 ol.docify(atype);
1180 }
1181 else if (!a.name.isEmpty()) // argument has a name
1182 {
1183 ol.docify(a.name);
1184 }
1185 if (!isDefine)
1186 {
1187 if (funcPtrPos!=-1)
1188 {
1190 }
1191 ol.endParameterName();
1192 }
1194 if (funcPtrPos!=-1)
1195 {
1196 linkifyText(TextGeneratorOLImpl(ol),atype.mid(funcPtrPos),options);
1197 }
1198 if (!a.array.isEmpty())
1199 {
1200 ol.docify(a.array);
1201 }
1202 if (!a.defval.isEmpty()) // write the default value
1203 {
1204 QCString n=a.defval;
1205 if (scope && scope!=Doxygen::globalScope && !cName.isEmpty())
1206 {
1207 n=addTemplateNames(n,scope->name(),cName);
1208 }
1209 ol.startParameterDefVal(" = ");
1210 linkifyText(TextGeneratorOLImpl(ol),n,LinkifyTextOptions(options).setKeepSpaces(true));
1211 ol.endParameterDefVal();
1212 }
1213 ++alIt;
1214 if (alIt!=defArgList.end())
1215 {
1216 a = *alIt;
1217 if (!md->isObjCMethod()) ol.docify(", "); // there are more arguments
1218 if (!isDefine)
1219 {
1220 QCString key;
1221 if (md->isObjCMethod() && a.attrib.length()>=2)
1222 {
1223 //printf("Found parameter keyword %s\n",a.qPrint(attrib));
1224 // strip [ and ]
1225 key=a.attrib.mid(1,a.attrib.length()-2);
1226 if (key!=",") key+=":"; // for normal keywords add colon
1227 }
1228 ol.endParameterExtra(false,false,!md->isObjCMethod());
1229 ol.startParameterType(FALSE,key);
1230 paramTypeStarted=TRUE;
1231 }
1232 else // isDefine
1233 {
1234 ol.endParameterExtra(false,false,true);
1235 }
1236 }
1237 first=FALSE;
1238 }
1239 if (first)
1240 {
1241 ol.startParameterName(defArgList.size()<2);
1242 ol.endParameterName();
1244 }
1245 ol.endParameterExtra(TRUE,defArgList.size()<2,!md->isObjCMethod());
1246 if (!md->extraTypeChars().isEmpty())
1247 {
1248 ol.docify(md->extraTypeChars());
1249 }
1250 if (defArgList.constSpecifier())
1251 {
1252 ol.docify(" const");
1253 }
1254 if (defArgList.volatileSpecifier())
1255 {
1256 ol.docify(" volatile");
1257 }
1258 if (defArgList.refQualifier()==RefQualifierType::LValue)
1259 {
1260 ol.docify(" &");
1261 }
1262 else if (defArgList.refQualifier()==RefQualifierType::RValue)
1263 {
1264 ol.docify(" &&");
1265 }
1266 if (!defArgList.trailingReturnType().isEmpty())
1267 {
1268 linkifyText(TextGeneratorOLImpl(ol), defArgList.trailingReturnType(), options);
1269 }
1270 return TRUE;
1271}
RefQualifierType refQualifier() const
Definition arguments.h:116
QCString trailingReturnType() const
Definition arguments.h:114
bool constSpecifier() const
Definition arguments.h:111
bool volatileSpecifier() const
Definition arguments.h:112
virtual DefType definitionType() const =0
static NamespaceDefMutable * globalScope
Definition doxygen.h:121
virtual bool isObjCMethod() const =0
virtual QCString extraTypeChars() const =0
virtual bool isDefine() const =0
virtual const ArgumentList & declArgumentList() const =0
virtual bool isProperty() const =0
void endParameterExtra(bool last, bool one, bool bracket)
Definition outputlist.h:694
void endMemberDocName()
Definition outputlist.h:682
void startParameterExtra()
Definition outputlist.h:692
void startParameterList(bool openBracket)
Definition outputlist.h:700
void docify(const QCString &s)
Definition outputlist.h:437
void startParameterDefVal(const char *separator)
Definition outputlist.h:696
void endParameterDefVal()
Definition outputlist.h:698
void startParameterType(bool first, const QCString &key)
Definition outputlist.h:684
void endParameterName()
Definition outputlist.h:690
void endParameterType()
Definition outputlist.h:686
void startParameterName(bool one)
Definition outputlist.h:688
void writeNonBreakableSpace(int num)
Definition outputlist.h:626
QCString & prepend(const char *s)
Definition qcstring.h:426
QCString & append(char c)
Definition qcstring.h:400
void clear()
Definition qcstring.h:186
Implements TextGeneratorIntf for an OutputDocInterface stream.
Definition util.h:76
ClassDef * toClassDef(Definition *d)
static QCString addTemplateNames(const QCString &s, const QCString &n, const QCString &t)
QCString substitute(const QCString &s, const QCString &src, const QCString &dst)
substitute all occurrences of src in s by dst
Definition qcstring.cpp:571
#define FALSE
Definition qcstring.h:34
QCString type
Definition arguments.h:42
QCString defval
Definition arguments.h:46
QCString array
Definition arguments.h:45
QCString attrib
Definition arguments.h:41
LinkifyTextOptions & setScope(const Definition *scope)
Definition util.h:110
LinkifyTextOptions & setSelf(const Definition *self)
Definition util.h:116
LinkifyTextOptions & setFileScope(const FileDef *fileScope)
Definition util.h:113
QCString tempArgListToString(const ArgumentList &al, SrcLangExt lang, bool includeDefault)
Definition util.cpp:1299
QCString getLanguageSpecificSeparator(SrcLangExt lang, bool classScope)
Returns the scope separator to use given the programming language lang.
Definition util.cpp:5915
void linkifyText(const TextGeneratorIntf &out, const QCString &text, const LinkifyTextOptions &options)
Definition util.cpp:893

References addTemplateNames(), QCString::append(), MemberDef::argumentList(), Argument::array, Argument::attrib, ArgumentList::begin(), QCString::clear(), ArgumentList::constSpecifier(), MemberDef::declArgumentList(), Definition::definitionType(), Argument::defval, OutputList::docify(), ArgumentList::end(), OutputList::endMemberDocName(), OutputList::endParameterDefVal(), OutputList::endParameterExtra(), OutputList::endParameterName(), OutputList::endParameterType(), MemberDef::extraTypeChars(), FALSE, QCString::find(), QCString::findRev(), Definition::getBodyDef(), Definition::getLanguage(), getLanguageSpecificSeparator(), Doxygen::globalScope, ArgumentList::hasParameters(), MemberDef::isDefine(), MemberDef::isDocsForDefinition(), QCString::isEmpty(), MemberDef::isObjCMethod(), MemberDef::isProperty(), MemberDef::isTypedef(), QCString::left(), QCString::length(), linkifyText(), LValue, QCString::mid(), Argument::name, Definition::name(), QCString::prepend(), ArgumentList::refQualifier(), RValue, LinkifyTextOptions::setFileScope(), LinkifyTextOptions::setScope(), LinkifyTextOptions::setSelf(), ArgumentList::size(), OutputList::startParameterDefVal(), OutputList::startParameterExtra(), OutputList::startParameterList(), OutputList::startParameterName(), OutputList::startParameterType(), substitute(), tempArgListToString(), toClassDef(), ArgumentList::trailingReturnType(), TRUE, Argument::type, Definition::TypeClass, ArgumentList::volatileSpecifier(), and OutputList::writeNonBreakableSpace().

Referenced by MemberDefImpl::writeDocumentation().

◆ writeExceptionList()

void writeExceptionList ( OutputList & ol,
const ClassDef * cd,
const MemberDef * md )
static

Definition at line 1313 of file memberdef.cpp.

1314{
1315 QCString exception = md->excpString().stripWhiteSpace();
1316 if ('{'==exception.at(0))
1317 {
1318 // this is an UNO IDL attribute - need special handling
1319 int index = exception.find(';');
1320 int oldIndex = 1;
1321 while (-1 != index) // there should be no more than 2 (set / get)
1322 {
1323 // omit '{' and ';' -> "set raises (...)"
1324 writeExceptionListImpl(ol,cd,md,exception.mid(oldIndex,index-oldIndex));
1325 oldIndex=index+1;
1326 index = exception.find(';',oldIndex);
1327 }
1328 // the rest is now just '}' - omit that
1329 }
1330 else
1331 {
1332 writeExceptionListImpl(ol,cd,md,exception);
1333 }
1334}
virtual QCString excpString() const =0
static void writeExceptionListImpl(OutputList &ol, const ClassDef *cd, const MemberDef *md, QCString const &exception)

References QCString::at(), MemberDef::excpString(), QCString::find(), QCString::mid(), QCString::stripWhiteSpace(), and writeExceptionListImpl().

Referenced by MemberDefImpl::writeDocumentation().

◆ writeExceptionListImpl()

void writeExceptionListImpl ( OutputList & ol,
const ClassDef * cd,
const MemberDef * md,
QCString const & exception )
static

Definition at line 1273 of file memberdef.cpp.

1275{
1276 // this is ordinary exception spec - there must be a '('
1277 //printf("exception='%s'\n",qPrint(exception));
1278 int index = exception.find('(');
1279 LinkifyTextOptions options;
1280 options.setScope(cd).setFileScope(md->getBodyDef()).setSelf(md);
1281 if (index!=-1)
1282 {
1283 ol.exceptionEntry(exception.left(index),false);
1284 ++index; // paren in second column so skip it here
1285 for (int comma = exception.find(',', index); comma!=-1; )
1286 {
1287 ++comma; // include comma
1288 linkifyText(TextGeneratorOLImpl(ol),exception.mid(index,comma-index),options);
1289 ol.exceptionEntry(QCString(),false);
1290 index=comma;
1291 comma = exception.find(',', index);
1292 }
1293 int close = exception.find(')', index);
1294 if (close!=-1)
1295 {
1296 QCString type=removeRedundantWhiteSpace(exception.mid(index,close-index));
1297 linkifyText(TextGeneratorOLImpl(ol),type,options);
1298 ol.exceptionEntry(QCString(),true);
1299 }
1300 else
1301 {
1302 warn(md->getDefFileName(),md->getDefLine(),
1303 "missing ) in exception list on member {}",md->name());
1304 }
1305 }
1306 else // Java Exception
1307 {
1308 ol.docify(" ");
1309 linkifyText(TextGeneratorOLImpl(ol),exception,options);
1310 }
1311}
virtual QCString getDefFileName() const =0
void exceptionEntry(const QCString &prefix, bool closeBracket)
Definition outputlist.h:704
#define warn(file, line, fmt,...)
Definition message.h:97
QCString removeRedundantWhiteSpace(const QCString &s)
Definition util.cpp:567

References OutputList::docify(), OutputList::exceptionEntry(), QCString::find(), Definition::getBodyDef(), Definition::getDefFileName(), Definition::getDefLine(), QCString::left(), linkifyText(), QCString::mid(), Definition::name(), removeRedundantWhiteSpace(), LinkifyTextOptions::setFileScope(), LinkifyTextOptions::setScope(), LinkifyTextOptions::setSelf(), and warn.

Referenced by writeExceptionList().

Variable Documentation

◆ g_cachedAnonymousTypeMutex

std::mutex g_cachedAnonymousTypeMutex
static

Definition at line 1993 of file memberdef.cpp.

Referenced by MemberDefImpl::getClassDefOfAnonymousType().

◆ g_detectUndocumentedParamsMutex

std::mutex g_detectUndocumentedParamsMutex
static

Definition at line 4218 of file memberdef.cpp.

Referenced by MemberDefImpl::detectUndocumentedParams().

◆ g_docCrossReferenceMutex

std::mutex g_docCrossReferenceMutex
static

Definition at line 6482 of file memberdef.cpp.

Referenced by addDocCrossReference().

◆ g_hasDetailedDescriptionMutex

std::mutex g_hasDetailedDescriptionMutex
static

Definition at line 2672 of file memberdef.cpp.

Referenced by MemberDefImpl::hasDetailedDescription().

◆ reAnonymous

const reg::Ex reAnonymous(R"([\w:@]*@\d+)") ( R"([\w:@]*@\d+)" )
static