Doxygen
Loading...
Searching...
No Matches
classdef.cpp
Go to the documentation of this file.
1/******************************************************************************
2 *
3 * Copyright (C) 1997-2024 by Dimitri van Heesch.
4 *
5 * Permission to use, copy, modify, and distribute this software and its
6 * documentation under the terms of the GNU General Public License is hereby
7 * granted. No representations are made about the suitability of this software
8 * for any purpose. It is provided "as is" without express or implied warranty.
9 * See the GNU General Public License for more details.
10 *
11 * Documents produced by Doxygen are derivative works derived from the
12 * input used in their production; they are not affected by this license.
13 *
14 */
15
16#include <cstdio>
17#include <algorithm>
18
19#include "types.h"
20#include "classdef.h"
21#include "classlist.h"
22#include "entry.h"
23#include "doxygen.h"
24#include "membername.h"
25#include "message.h"
26#include "config.h"
27#include "util.h"
28#include "diagram.h"
29#include "language.h"
30#include "htmlhelp.h"
31#include "example.h"
32#include "outputlist.h"
33#include "dot.h"
34#include "dotclassgraph.h"
35#include "dotrunner.h"
36#include "defargs.h"
37#include "debug.h"
38#include "docparser.h"
39#include "searchindex.h"
40#include "vhdldocgen.h"
41#include "layout.h"
42#include "arguments.h"
43#include "memberlist.h"
44#include "groupdef.h"
45#include "filedef.h"
46#include "namespacedef.h"
47#include "membergroup.h"
48#include "definitionimpl.h"
49#include "symbolresolver.h"
50#include "fileinfo.h"
51#include "trace.h"
52#include "moduledef.h"
53
54//-----------------------------------------------------------------------------
55
57 const ArgumentLists *actualParams,uint32_t *actualParamIndex)
58{
59 //bool optimizeOutputJava = Config_getBool(OPTIMIZE_OUTPUT_JAVA);
60 bool hideScopeNames = Config_getBool(HIDE_SCOPE_NAMES);
61 //printf("qualifiedNameWithTemplateParameters() localName=%s\n",qPrint(cd->localName()));
62 QCString scName;
63 const Definition *d=cd->getOuterScope();
64 if (d)
65 {
67 {
68 const ClassDef *ocd=toClassDef(d);
69 scName = ocd->qualifiedNameWithTemplateParameters(actualParams,actualParamIndex);
70 }
71 else if (!hideScopeNames)
72 {
73 scName = d->qualifiedName();
74 }
75 }
76
77 SrcLangExt lang = cd->getLanguage();
78 QCString scopeSeparator = getLanguageSpecificSeparator(lang);
79 if (!scName.isEmpty()) scName+=scopeSeparator;
80
81 bool isSpecialization = cd->localName().find('<')!=-1;
82 QCString clName = cd->className();
83 scName+=clName;
84 if (lang!=SrcLangExt::CSharp && !cd->templateArguments().empty())
85 {
86 if (actualParams && *actualParamIndex<actualParams->size())
87 {
88 const ArgumentList &al = actualParams->at(*actualParamIndex);
90 {
91 scName+=tempArgListToString(al,lang);
92 }
93 (*actualParamIndex)++;
94 }
95 else
96 {
98 {
99 scName+=tempArgListToString(cd->templateArguments(),lang);
100 }
101 }
102 }
103 //printf("qualifiedNameWithTemplateParameters: scope=%s qualifiedName=%s\n",qPrint(name()),qPrint(scName));
104 return scName;
105}
106
107static QCString makeDisplayName(const ClassDef *cd,bool includeScope)
108{
109 //bool optimizeOutputForJava = Config_getBool(OPTIMIZE_OUTPUT_JAVA);
110 SrcLangExt lang = cd->getLanguage();
111 //bool vhdlOpt = Config_getBool(OPTIMIZE_OUTPUT_VHDL);
112 QCString n;
113 if (lang==SrcLangExt::VHDL)
114 {
116 }
117 else
118 {
119 if (includeScope)
120 {
122 }
123 else
124 {
125 n=cd->className();
126 }
127 }
128 if (cd->isAnonymous())
129 {
131 }
133 if (sep!="::")
134 {
135 n=substitute(n,"::",sep);
136 }
137 if (cd->compoundType()==ClassDef::Protocol && n.endsWith("-p"))
138 {
139 n="<"+n.left(n.length()-2)+">";
140 }
141 return n;
142}
143
144//-----------------------------------------------------------------------------
145
147{
148 if (lang==SrcLangExt::Fortran)
149 {
150 switch (compType)
151 {
152 case ClassDef::Class: return "module";
153 case ClassDef::Struct: return "type";
154 case ClassDef::Union: return "union";
155 case ClassDef::Interface: return "interface";
156 case ClassDef::Protocol: return "protocol";
157 case ClassDef::Category: return "category";
158 case ClassDef::Exception: return "exception";
159 default: return "unknown";
160 }
161 }
162 else
163 {
164 switch (compType)
165 {
166 case ClassDef::Class: return isJavaEnum ? "enum" : "class";
167 case ClassDef::Struct: return "struct";
168 case ClassDef::Union: return "union";
169 case ClassDef::Interface: return lang==SrcLangExt::ObjC ? "class" : "interface";
170 case ClassDef::Protocol: return "protocol";
171 case ClassDef::Category: return "category";
172 case ClassDef::Exception: return "exception";
173 case ClassDef::Service: return "service";
174 case ClassDef::Singleton: return "singleton";
175 default: return "unknown";
176 }
177 }
178}
179
180//-----------------------------------------------------------------------------
181
182
183/** Implementation of the ClassDef interface */
184class ClassDefImpl : public DefinitionMixin<ClassDefMutable>
185{
186 public:
187 ClassDefImpl(const QCString &fileName,int startLine,int startColumn,
188 const QCString &name,CompoundType ct,
189 const QCString &ref=QCString(),const QCString &fName=QCString(),
190 bool isSymbol=TRUE,bool isJavaEnum=FALSE);
191
192 DefType definitionType() const override { return TypeClass; }
193 std::unique_ptr<ClassDef> deepCopy(const QCString &name) const override;
194 void moveTo(Definition *) override;
195 CodeSymbolType codeSymbolType() const override;
196 QCString getOutputFileBase() const override;
197 QCString getInstanceOutputFileBase() const override;
198 QCString getSourceFileBase() const override;
199 QCString getReference() const override;
200 bool isReference() const override;
201 bool isLocal() const override;
202 ClassLinkedRefMap getClasses() const override;
203 bool hasDocumentation() const override;
204 bool hasDetailedDescription() const override;
205 QCString collaborationGraphFileName() const override;
206 QCString inheritanceGraphFileName() const override;
207 QCString displayName(bool includeScope=TRUE) const override;
208 CompoundType compoundType() const override;
209 QCString compoundTypeString() const override;
210 const BaseClassList &baseClasses() const override;
211 void updateBaseClasses(const BaseClassList &bcd) override;
212 const BaseClassList &subClasses() const override;
213 void updateSubClasses(const BaseClassList &bcd) override;
214 const MemberNameInfoLinkedMap &memberNameInfoLinkedMap() const override;
215 Protection protection() const override;
216 bool isLinkableInProject() const override;
217 bool isLinkable() const override;
218 bool isVisibleInHierarchy() const override;
219 bool visibleInParentsDeclList() const override;
220 const ArgumentList &templateArguments() const override;
221 FileDef *getFileDef() const override;
222 ModuleDef *getModuleDef() const override;
223 const MemberDef *getMemberByName(const QCString &) const override;
224 int isBaseClass(const ClassDef *bcd,bool followInstances,const QCString &templSpec) const override;
225 bool isSubClass(ClassDef *bcd,int level=0) const override;
226 bool isAccessibleMember(const MemberDef *md) const override;
227 const TemplateInstanceList &getTemplateInstances() const override;
228 const ClassDef *templateMaster() const override;
229 bool isTemplate() const override;
230 const IncludeInfo *includeInfo() const override;
231 const UsesClassList &usedImplementationClasses() const override;
232 const UsesClassList &usedByImplementationClasses() const override;
233 const ConstraintClassList &templateTypeConstraints() const override;
234 bool isTemplateArgument() const override;
235 const Definition *findInnerCompound(const QCString &name) const override;
238 const ArgumentLists *actualParams=nullptr,uint32_t *actualParamIndex=nullptr) const override;
239 bool isAbstract() const override;
240 bool isObjectiveC() const override;
241 bool isFortran() const override;
242 bool isCSharp() const override;
243 bool isFinal() const override;
244 bool isSealed() const override;
245 bool isPublished() const override;
246 bool isExtension() const override;
247 bool isForwardDeclared() const override;
248 bool isInterface() const override;
249 ClassDef *categoryOf() const override;
250 QCString className() const override;
251 MemberList *getMemberList(MemberListType lt) const override;
252 const MemberLists &getMemberLists() const override;
253 const MemberGroupList &getMemberGroups() const override;
254 const TemplateNameMap &getTemplateBaseClassNames() const override;
255 bool isUsedOnly() const override;
256 QCString anchor() const override;
257 bool isEmbeddedInOuterScope() const override;
258 bool isSimple() const override;
259 const ClassDef *tagLessReference() const override;
260 const MemberDef *isSmartPointer() const override;
261 bool isJavaEnum() const override;
262 QCString title() const override;
263 QCString generatedFromFiles() const override;
264 const FileList &usedFiles() const override;
265 const ArgumentList &typeConstraints() const override;
266 const ExampleList &getExamples() const override;
267 bool hasExamples() const override;
268 QCString getMemberListFileName() const override;
269 bool subGrouping() const override;
270 bool isSliceLocal() const override;
271 bool hasNonReferenceSuperClass() const override;
272 QCString requiresClause() const override;
273 StringVector getQualifiers() const override;
274 bool containsOverload(const MemberDef *md) const override;
275 bool isImplicitTemplateInstance() const override;
276
277 ClassDef *insertTemplateInstance(const QCString &fileName,int startLine,int startColumn,
278 const QCString &templSpec,bool &freshInstance) override;
279 void insertBaseClass(ClassDef *,const QCString &name,Protection p,Specifier s,const QCString &t=QCString()) override;
280 void insertSubClass(ClassDef *,Protection p,Specifier s,const QCString &t=QCString()) override;
281 void insertExplicitTemplateInstance(ClassDef *instance,const QCString &spec) override;
282 void setIncludeFile(FileDef *fd,const QCString &incName,bool local,bool force) override;
283 void insertMember(MemberDef *) override;
284 void insertUsedFile(const FileDef *) override;
285 bool addExample(const QCString &anchor,const QCString &name, const QCString &file) override;
286 void mergeCategory(ClassDef *category) override;
287 void setFileDef(FileDef *fd) override;
288 void setModuleDef(ModuleDef *mod) override;
289 void setSubGrouping(bool enabled) override;
290 void setProtection(Protection p) override;
291 void setGroupDefForAllMembers(GroupDef *g,Grouping::GroupPri_t pri,const QCString &fileName,int startLine,bool hasDocs) override;
292 void addInnerCompound(Definition *d) override;
293 void addUsedClass(ClassDef *cd,const QCString &accessName,Protection prot) override;
294 void addUsedByClass(ClassDef *cd,const QCString &accessName,Protection prot) override;
295 void setIsStatic(bool b) override;
296 void setCompoundType(CompoundType t) override;
297 void setClassName(const QCString &name) override;
298 void setClassSpecifier(TypeSpecifier spec) override;
299 void addQualifiers(const StringVector &qualifiers) override;
300 void setTemplateArguments(const ArgumentList &al) override;
301 void setTemplateBaseClassNames(const TemplateNameMap &templateNames) override;
302 void setTemplateMaster(const ClassDef *tm) override;
303 void setImplicitTemplateInstance(bool b) override;
304 void setTypeConstraints(const ArgumentList &al) override;
305 void addMemberToTemplateInstance(const MemberDef *md, const ArgumentList &templateArguments, const QCString &templSpec) override;
306 void addMembersToTemplateInstance(const ClassDef *cd,const ArgumentList &templateArguments,const QCString &templSpec) override;
307 void makeTemplateArgument(bool b=TRUE) override;
308 void setCategoryOf(ClassDef *cd) override;
309 void setUsedOnly(bool b) override;
310 void setTagLessReference(const ClassDef *cd) override;
311 void setMetaData(const QCString &md) override;
312 void findSectionsInDocumentation() override;
313 void addMembersToMemberGroup() override;
314 void addListReferences() override;
315 void addRequirementReferences() override;
316 void addTypeConstraints() override;
317 void computeAnchors() override;
318 void mergeMembers() override;
319 void sortMemberLists() override;
321 void writeDocumentation(OutputList &ol) const override;
322 void writeDocumentationForInnerClasses(OutputList &ol) const override;
323 void writeMemberPages(OutputList &ol) const override;
324 void writeMemberList(OutputList &ol) const override;
325 void writeDeclaration(OutputList &ol,const MemberDef *md,bool inGroup,int indentLevel,
326 const ClassDef *inheritedFrom,const QCString &inheritId) const override;
327 void writeQuickMemberLinks(OutputList &ol,const MemberDef *md) const override;
328 void writePageNavigation(OutputList &ol) const override;
329 void writeSummaryLinks(OutputList &ol) const override;
330 void reclassifyMember(MemberDefMutable *md,MemberType t) override;
331 void writeInlineDocumentation(OutputList &ol) const override;
332 void writeDeclarationLink(OutputList &ol,bool &found,
333 const QCString &header,bool localNames) const override;
334 void removeMemberFromLists(MemberDef *md) override;
335 void setAnonymousEnumType() override;
336 void countMembers() override;
337 void sortAllMembersList() override;
338
340 const ClassDef *inheritedFrom,const QCString &inheritId) const override;
341 void writeTagFile(TextStream &) const override;
342
343 int countMembersIncludingGrouped(MemberListType lt,const ClassDef *inheritedFrom,bool additional) const override;
344 int countMemberDeclarations(MemberListType lt,const ClassDef *inheritedFrom,
345 MemberListType lt2,bool invert,bool showAlways,ClassDefSet &visitedClasses) const override;
346 void writeMemberDeclarations(OutputList &ol,ClassDefSet &visitedClasses,
347 MemberListType lt,const QCString &title,
348 const QCString &subTitle=QCString(),
349 bool showInline=FALSE,const ClassDef *inheritedFrom=nullptr,
350 MemberListType lt2=MemberListType::Invalid(),bool invert=FALSE,bool showAlways=FALSE) const override;
351 void setRequiresClause(const QCString &req) override;
352 void setPrimaryConstructorParams(const ArgumentList &list) override;
353
354 // inheritance graph related members
355 CLASS_GRAPH_t hasInheritanceGraph() const override;
356 void overrideInheritanceGraph(CLASS_GRAPH_t e) override;
357
358 // collaboration graph related members
359 bool hasCollaborationGraph() const override;
360 void overrideCollaborationGraph(bool e) override;
361 private:
362 int countInheritedByNodes() const;
363 int countInheritsNodes() const;
364 int countInheritanceNodes() const;
366 void showUsedFiles(OutputList &ol) const;
367
368 void writeDocumentationContents(OutputList &ol,const QCString &pageTitle) const;
369 void internalInsertMember(MemberDef *md,Protection prot,bool addToAllList);
370 void addMemberToList(MemberListType lt,MemberDef *md,bool isBrief);
373 const ClassDef *inheritedFrom,bool invert,
374 bool showAlways) const;
375 void writeMemberDocumentation(OutputList &ol,MemberListType lt,const QCString &title,bool showInline=FALSE) const;
378 int indentLevel,const ClassDef *inheritedFrom,const QCString &inheritId) const;
379 void writeBriefDescription(OutputList &ol,bool exampleFlag) const;
380 void writeDetailedDescription(OutputList &ol,const QCString &pageType,bool exampleFlag,
381 const QCString &title,const QCString &anchor=QCString()) const;
382 void writeIncludeFiles(OutputList &ol) const;
384 void writeInheritanceGraph(OutputList &ol) const;
385 void writeCollaborationGraph(OutputList &ol) const;
386 void writeMemberGroups(OutputList &ol,bool showInline=FALSE) const;
387 void writeNestedClasses(OutputList &ol,const QCString &title) const;
388 void writeInlineClasses(OutputList &ol) const;
389 void startMemberDeclarations(OutputList &ol) const;
390 void endMemberDeclarations(OutputList &ol) const;
391 void startMemberDocumentation(OutputList &ol) const;
392 void endMemberDocumentation(OutputList &ol) const;
393 void writeAuthorSection(OutputList &ol) const;
394 void writeMoreLink(OutputList &ol,const QCString &anchor) const;
396
399 void addClassAttributes(OutputList &ol) const;
401 const ClassDef *inheritedFrom,bool invert,bool showAlways,
402 ClassDefSet &visitedClasses) const;
404 QCString &title,QCString &subtitle) const;
405 void addTypeConstraint(const QCString &typeConstraint,const QCString &type);
406 void writeTemplateSpec(OutputList &ol,const Definition *d,
407 const QCString &type,SrcLangExt lang) const;
408 void mergeMembersFromBaseClasses(bool mergeVirtualBaseClass);
410 private:
411 /*! file name that forms the base for the output file containing the
412 * class documentation. For compatibility with Qt (e.g. links via tag
413 * files) this name cannot be derived from the class name directly.
414 */
416
417 /*! file name used for the list of all members */
419
420 /*! file name used for the collaboration diagram */
422
423 /*! file name used for the inheritance graph */
425
426 /*! Include information about the header file should be included
427 * in the documentation. 0 by default, set by setIncludeFile().
428 */
429 std::unique_ptr<IncludeInfo> m_incInfo;
430
431 /*! List of base class (or super-classes) from which this class derives
432 * directly.
433 */
435
436 /*! List of sub-classes that directly derive from this class
437 */
439
440 /*! Namespace this class is part of
441 * (this is the inner most namespace in case of nested namespaces)
442 */
443 //NamespaceDef *m_nspace = nullptr;
444
445 /*! File this class is defined in */
446 FileDef *m_fileDef = nullptr;
447
448 /*! Module this class is defined in */
450
451 /*! List of all members (including inherited members) */
453
454 /*! Template arguments of this class */
456
457 /*! Type constraints for template parameters */
459
460 /*! Files that were used for generating the class documentation. */
462
463 /*! Examples that use this class */
465
466 /*! Holds the kind of "class" this is. */
468
469 /*! The protection level in which this class was found.
470 * Typically Public, but for nested classes this can also be Protected
471 * or Private.
472 */
474
475 /*! The inner classes contained in this class. Will be 0 if there are
476 * no inner classes.
477 */
479
480 /* classes for the collaboration diagram */
483
485
486 /*! Template instances that exists of this class, the key in the
487 * dictionary is the template argument list.
488 */
490
492
493 /*! The class this class is an instance of. */
494 const ClassDef *m_templateMaster = nullptr;
495
496 /*! local class name which could be a typedef'ed alias name. */
498
499 /*! If this class is a Objective-C category, then this points to the
500 * class which is extended.
501 */
503
505
506 /* user defined member groups */
508
509 /*! Is this an abstract class? */
510 bool m_isAbstract = false;
511
512 /*! Is the class part of an unnamed namespace? */
513 bool m_isStatic = false;
514
515 /*! TRUE if classes members are merged with those of the base classes. */
516 bool m_membersMerged = false;
517
518 /*! TRUE if the class is defined in a source file rather than a header file. */
519 bool m_isLocal = false;
520
521 bool m_isTemplArg = false;
522
523 /*! Does this class group its user-grouped members
524 * as a sub-section of the normal (public/protected/..)
525 * groups?
526 */
527 bool m_subGrouping = false;
528
529 /** Reason of existence is a "use" relation */
530 bool m_usedOnly = false;
531
532 /** List of titles to use for the summary */
534
535 /** Is this a simple (non-nested) C structure? */
536 bool m_isSimple = false;
537
538 /** Does this class overloaded the -> operator? */
539 const MemberDef *m_arrowOperator = nullptr;
540
541 const ClassDef *m_tagLessRef = nullptr;
542
543 /** Does this class represent a Java style enum? */
544 bool m_isJavaEnum = false;
545
547
549
550 /** C++20 requires clause */
552
554
556 CLASS_GRAPH_t m_typeInheritanceGraph = CLASS_GRAPH_t::NO;
557
559
561};
562
563std::unique_ptr<ClassDef> createClassDef(
564 const QCString &fileName,int startLine,int startColumn,
565 const QCString &name,ClassDef::CompoundType ct,
566 const QCString &ref,const QCString &fName,
567 bool isSymbol,bool isJavaEnum)
568{
569 return std::make_unique<ClassDefImpl>(fileName,startLine,startColumn,name,ct,ref,fName,isSymbol,isJavaEnum);
570}
571//-----------------------------------------------------------------------------
572
574{
575 public:
576 ClassDefAliasImpl(const Definition *newScope,const ClassDef *cd)
577 : DefinitionAliasMixin(newScope,cd) { init(); }
578 ~ClassDefAliasImpl() override { deinit(); }
580
581 DefType definitionType() const override { return TypeClass; }
582
583 const ClassDef *getCdAlias() const { return toClassDef(getAlias()); }
584 std::unique_ptr<ClassDef> deepCopy(const QCString &name) const override {
586 }
587 void moveTo(Definition *) override {}
588
590 { return getCdAlias()->codeSymbolType(); }
592 { return getCdAlias()->getOutputFileBase(); }
596 { return getCdAlias()->getSourceFileBase(); }
597 QCString getReference() const override
598 { return getCdAlias()->getReference(); }
599 bool isReference() const override
600 { return getCdAlias()->isReference(); }
601 bool isLocal() const override
602 { return getCdAlias()->isLocal(); }
604 { return getCdAlias()->getClasses(); }
605 bool hasDocumentation() const override
606 { return getCdAlias()->hasDocumentation(); }
607 bool hasDetailedDescription() const override
608 { return getCdAlias()->hasDetailedDescription(); }
613 QCString displayName(bool includeScope=TRUE) const override
614 { return makeDisplayName(this,includeScope); }
615 CompoundType compoundType() const override
616 { return getCdAlias()->compoundType(); }
618 { return getCdAlias()->compoundTypeString(); }
619 const BaseClassList &baseClasses() const override
620 { return getCdAlias()->baseClasses(); }
621 const BaseClassList &subClasses() const override
622 { return getCdAlias()->subClasses(); }
625 Protection protection() const override
626 { return getCdAlias()->protection(); }
627 bool isLinkableInProject() const override
628 { return getCdAlias()->isLinkableInProject(); }
629 bool isLinkable() const override
630 { return getCdAlias()->isLinkable(); }
631 bool isVisibleInHierarchy() const override
632 { return getCdAlias()->isVisibleInHierarchy(); }
633 bool visibleInParentsDeclList() const override
634 { return getCdAlias()->visibleInParentsDeclList(); }
635 const ArgumentList &templateArguments() const override
636 { return getCdAlias()->templateArguments(); }
637 FileDef *getFileDef() const override
638 { return getCdAlias()->getFileDef(); }
639 ModuleDef *getModuleDef() const override
640 { return getCdAlias()->getModuleDef(); }
641 const MemberDef *getMemberByName(const QCString &s) const override
642 { return getCdAlias()->getMemberByName(s); }
643 int isBaseClass(const ClassDef *bcd,bool followInstances,const QCString &templSpec) const override
644 { return getCdAlias()->isBaseClass(bcd,followInstances,templSpec); }
645 bool isSubClass(ClassDef *bcd,int level=0) const override
646 { return getCdAlias()->isSubClass(bcd,level); }
647 bool isAccessibleMember(const MemberDef *md) const override
648 { return getCdAlias()->isAccessibleMember(md); }
650 { return getCdAlias()->getTemplateInstances(); }
651 const ClassDef *templateMaster() const override
652 { return getCdAlias()->templateMaster(); }
653 bool isTemplate() const override
654 { return getCdAlias()->isTemplate(); }
655 const IncludeInfo *includeInfo() const override
656 { return getCdAlias()->includeInfo(); }
663 bool isTemplateArgument() const override
664 { return getCdAlias()->isTemplateArgument(); }
665 const Definition *findInnerCompound(const QCString &name) const override
666 { return getCdAlias()->findInnerCompound(name); }
670 const ArgumentLists *actualParams=nullptr,uint32_t *actualParamIndex=nullptr) const override
671 { return makeQualifiedNameWithTemplateParameters(this,actualParams,actualParamIndex); }
672 bool isAbstract() const override
673 { return getCdAlias()->isAbstract(); }
674 bool isObjectiveC() const override
675 { return getCdAlias()->isObjectiveC(); }
676 bool isFortran() const override
677 { return getCdAlias()->isFortran(); }
678 bool isCSharp() const override
679 { return getCdAlias()->isCSharp(); }
680 bool isFinal() const override
681 { return getCdAlias()->isFinal(); }
682 bool isSealed() const override
683 { return getCdAlias()->isSealed(); }
684 bool isPublished() const override
685 { return getCdAlias()->isPublished(); }
686 bool isExtension() const override
687 { return getCdAlias()->isExtension(); }
688 bool isForwardDeclared() const override
689 { return getCdAlias()->isForwardDeclared(); }
690 bool isInterface() const override
691 { return getCdAlias()->isInterface(); }
692 ClassDef *categoryOf() const override
693 { return getCdAlias()->categoryOf(); }
694 QCString className() const override
695 { return getCdAlias()->className(); }
697 { return getCdAlias()->getMemberList(lt); }
698 const MemberLists &getMemberLists() const override
699 { return getCdAlias()->getMemberLists(); }
700 const MemberGroupList &getMemberGroups() const override
701 { return getCdAlias()->getMemberGroups(); }
704 bool isUsedOnly() const override
705 { return getCdAlias()->isUsedOnly(); }
706 QCString anchor() const override
707 { return getCdAlias()->anchor(); }
708 bool isEmbeddedInOuterScope() const override
709 { return getCdAlias()->isEmbeddedInOuterScope(); }
710 bool isSimple() const override
711 { return getCdAlias()->isSimple(); }
712 const ClassDef *tagLessReference() const override
713 { return getCdAlias()->tagLessReference(); }
714 const MemberDef *isSmartPointer() const override
715 { return getCdAlias()->isSmartPointer(); }
716 bool isJavaEnum() const override
717 { return getCdAlias()->isJavaEnum(); }
718 QCString title() const override
719 { return getCdAlias()->title(); }
721 { return getCdAlias()->generatedFromFiles(); }
722 const FileList &usedFiles() const override
723 { return getCdAlias()->usedFiles(); }
724 const ArgumentList &typeConstraints() const override
725 { return getCdAlias()->typeConstraints(); }
726 const ExampleList &getExamples() const override
727 { return getCdAlias()->getExamples(); }
728 bool hasExamples() const override
729 { return getCdAlias()->hasExamples(); }
731 { return getCdAlias()->getMemberListFileName(); }
732 bool subGrouping() const override
733 { return getCdAlias()->subGrouping(); }
734 bool isSliceLocal() const override
735 { return getCdAlias()->isSliceLocal(); }
736 bool hasNonReferenceSuperClass() const override
738 QCString requiresClause() const override
739 { return getCdAlias()->requiresClause(); }
741 { return getCdAlias()->getQualifiers(); }
742 bool containsOverload(const MemberDef *md) const override
743 { return getCdAlias()->containsOverload(md); }
744
745 int countMembersIncludingGrouped(MemberListType lt,const ClassDef *inheritedFrom,bool additional) const override
746 { return getCdAlias()->countMembersIncludingGrouped(lt,inheritedFrom,additional); }
748 MemberListType lt2,bool invert,bool showAlways,ClassDefSet &visitedClasses) const override
749 { return getCdAlias()->countMemberDeclarations(lt,inheritedFrom,lt2,invert,showAlways,visitedClasses); }
750
751 void writeDeclarationLink(OutputList &ol,bool &found,
752 const QCString &header,bool localNames) const override
753 { getCdAlias()->writeDeclarationLink(ol,found,header,localNames); }
754 bool isImplicitTemplateInstance() const override
756
757 void writeDocumentation(OutputList &ol) const override
761 void writeMemberPages(OutputList &ol) const override
762 { getCdAlias()->writeMemberPages(ol); }
763 void writeMemberList(OutputList &ol) const override
764 { getCdAlias()->writeMemberList(ol); }
765 void writeDeclaration(OutputList &ol,const MemberDef *md,bool inGroup,
766 int indentLevel, const ClassDef *inheritedFrom,const QCString &inheritId) const override
767 { getCdAlias()->writeDeclaration(ol,md,inGroup,indentLevel,inheritedFrom,inheritId); }
768 void writeQuickMemberLinks(OutputList &ol,const MemberDef *md) const override
769 { getCdAlias()->writeQuickMemberLinks(ol,md); }
770 void writeSummaryLinks(OutputList &ol) const override
771 { getCdAlias()->writeSummaryLinks(ol); }
772 void writePageNavigation(OutputList &ol) const override
776 void writeTagFile(TextStream &ol) const override
777 { getCdAlias()->writeTagFile(ol); }
779 MemberListType lt,const QCString &title,
780 const QCString &subTitle=QCString(),
781 bool showInline=FALSE,const ClassDef *inheritedFrom=nullptr,
782 MemberListType lt2=MemberListType::Invalid(),bool invert=FALSE,bool showAlways=FALSE) const override
783 { getCdAlias()->writeMemberDeclarations(ol,visitedClasses,lt,title,subTitle,showInline,inheritedFrom,lt2,invert,showAlways); }
785 const ClassDef *inheritedFrom,const QCString &inheritId) const override
786 { getCdAlias()->addGroupedInheritedMembers(ol,lt,inheritedFrom,inheritId); }
787
788 void updateBaseClasses(const BaseClassList &) override {}
789 void updateSubClasses(const BaseClassList &) override {}
790};
791
792std::unique_ptr<ClassDef> createClassDefAlias(const Definition *newScope,const ClassDef *cd)
793{
794 auto acd = std::make_unique<ClassDefAliasImpl>(newScope,cd);
795 //printf("cd name=%s localName=%s qualifiedName=%s qualifiedNameWith=%s displayName()=%s\n",
796 // qPrint(acd->name()),qPrint(acd->localName()),qPrint(acd->qualifiedName()),
797 // qPrint(acd->qualifiedNameWithTemplateParameters()),qPrint(acd->displayName()));
798 return acd;
799}
800
801//-----------------------------------------------------------------------------
802
803// constructs a new class definition
805 const QCString &defFileName,int defLine,int defColumn,
806 const QCString &nm,CompoundType ct,
807 const QCString &lref,const QCString &fName,
808 bool isSymbol,bool isJavaEnum)
809 : DefinitionMixin(defFileName,defLine,defColumn,removeRedundantWhiteSpace(nm),nullptr,nullptr,isSymbol)
810{
811 AUTO_TRACE("name={}",name());
812 setReference(lref);
813 m_compType = ct;
816 if (!fName.isEmpty())
817 {
819 }
820 else
821 {
822 m_fileName=compTypeString+name();
823 }
824 m_prot=Protection::Public;
825 //nspace=nullptr;
826 m_fileDef=nullptr;
827 m_moduleDef=nullptr;
828 m_subGrouping=Config_getBool(SUBGROUPING);
829 m_templateMaster =nullptr;
834 m_categoryOf = nullptr;
836 m_isSimple = Config_getBool(INLINE_SIMPLE_STRUCTS);
837 m_arrowOperator = nullptr;
838 m_tagLessRef = nullptr;
840 //QCString ns;
841 //extractNamespaceName(name,className,ns);
842 //printf("m_name=%s m_className=%s ns=%s\n",qPrint(m_name),qPrint(m_className),qPrint(ns));
843
844 // we cannot use getLanguage at this point, as setLanguage has not been called.
845 SrcLangExt lang = getLanguageFromFileName(defFileName);
846 if ((lang==SrcLangExt::Cpp || lang==SrcLangExt::ObjC) && guessSection(defFileName).isSource())
847 {
849 }
850 else
851 {
853 }
854 m_hasCollaborationGraph = Config_getBool(COLLABORATION_GRAPH);
856 m_memberListFileName = convertNameToFile(compTypeString+name()+"-members");
859 if (lref.isEmpty())
860 {
862 }
863 AUTO_TRACE_EXIT("m_fileName='{}'",m_fileName);
864}
865
866std::unique_ptr<ClassDef> ClassDefImpl::deepCopy(const QCString &name) const
867{
868 AUTO_TRACE("name='{}'",name);
869 auto result = std::make_unique<ClassDefImpl>(
871 std::string(),std::string(),true,m_isJavaEnum);
872 result->setBriefDescription(briefDescription(),briefFile(),briefLine());
873 result->setDocumentation(documentation(),docFile(),docLine());
874 result->setInbodyDocumentation(inbodyDocumentation(),inbodyFile(),inbodyLine());
875 result->setBodySegment(getStartDefLine(),getStartBodyLine(),getEndBodyLine());
876 result->setBodyDef(getBodyDef());
877 result->setLanguage(getLanguage());
878
879 // copy other members
880 result->m_memberListFileName = m_memberListFileName;
881 result->m_collabFileName = m_collabFileName;
882 result->m_inheritFileName = m_inheritFileName;
883 if (m_incInfo)
884 {
885 result->m_incInfo = std::make_unique<IncludeInfo>();
886 *(result->m_incInfo) = *m_incInfo;
887 }
888 result->m_inherits = m_inherits;
889 result->m_inheritedBy = m_inheritedBy;
890 result->m_fileDef = m_fileDef;
891 result->m_moduleDef = m_moduleDef;
892 result->m_tempArgs = m_tempArgs;
893 result->m_typeConstraints = m_typeConstraints;
894 result->m_files = m_files;
895 result->m_examples = m_examples;
896 result->m_compType = m_compType;
897 result->m_prot = m_prot;
898 result->m_usesImplClassList = m_usesImplClassList;
899 result->m_usedByImplClassList = m_usedByImplClassList;
900 result->m_constraintClassList = m_constraintClassList;
901 result->m_templateInstances = m_templateInstances;
902 result->m_templBaseClassNames = m_templBaseClassNames;
903 result->m_templateMaster = m_templateMaster;
904 result->m_className = m_className;
905 result->m_categoryOf = m_categoryOf;
906 result->m_isAbstract = m_isAbstract;
907 result->m_isStatic = m_isStatic;
908 result->m_membersMerged = m_membersMerged;
909 result->m_isLocal = m_isLocal;
910 result->m_isTemplArg = m_isTemplArg;
911 result->m_subGrouping = m_subGrouping;
912 result->m_usedOnly = m_usedOnly;
913 result->m_vhdlSummaryTitles = m_vhdlSummaryTitles;
914 result->m_isSimple = m_isSimple;
915 result->m_arrowOperator = m_arrowOperator;
916 result->m_tagLessRef = m_tagLessRef;
917 result->m_isJavaEnum = m_isJavaEnum;
918 result->m_spec = m_spec;
919 result->m_metaData = m_metaData;
920 result->m_requiresClause = m_requiresClause;
921 result->m_qualifiers = m_qualifiers;
922 result->m_hasCollaborationGraph = m_hasCollaborationGraph;
923 result->m_typeInheritanceGraph = m_typeInheritanceGraph;
924
925 // set new file name
927 result->m_fileName = compTypeString+name;
928 result->m_memberListFileName = convertNameToFile(compTypeString+name+"-members");
929 result->m_collabFileName = convertNameToFile(result->m_fileName+"_coll_graph");
930 result->m_inheritFileName = convertNameToFile(result->m_fileName+"_inherit_graph");
931 result->m_fileName = convertNameToFile(result->m_fileName);
932
933 // deep copy nested classes
934 for (const auto &innerCd : m_innerClasses)
935 {
936 QCString innerName = name+"::"+innerCd->localName();
937 if (Doxygen::classLinkedMap->find(innerName)==nullptr)
938 {
939 auto cd = Doxygen::classLinkedMap->add(innerName,innerCd->deepCopy(innerName));
940 result->addInnerCompound(cd);
942 if (cdm)
943 {
944 cdm->setOuterScope(result.get());
945 }
946 }
947 }
948
949 // copy all member list (and make deep copies of members)
950 for (auto &mni : m_allMemberNameInfoLinkedMap)
951 {
952 for (auto &mi : *mni)
953 {
954 const MemberDef *md=mi->memberDef();
955 auto newMd = md->deepCopy();
956 if (newMd)
957 {
958 auto mmd = toMemberDefMutable(newMd.get());
959 AUTO_TRACE_ADD("Copying member {}",mmd->name());
960 mmd->moveTo(result.get());
961
962 result->internalInsertMember(newMd.get(),newMd->protection(),true);
963
964 // also add to the global list (which will own newMd)
965 MemberName *mn = Doxygen::memberNameLinkedMap->add(newMd->name());
966 mn->push_back(std::move(newMd));
967 }
968 }
969 }
970
971 return result;
972}
973
975{
976 //printf("%s::moveTo(%s)\n",qPrint(name()),qPrint(scope->name()));
977 setOuterScope(scope);
979 {
980 m_fileDef = toFileDef(scope);
981 }
982 else if (scope->definitionType()==Definition::TypeModule)
983 {
984 m_moduleDef = toModuleDef(scope);
985 }
986}
987
992
993QCString ClassDefImpl::displayName(bool includeScope) const
994{
995 return makeDisplayName(this,includeScope);
996}
997
998// inserts a base/super class in the inheritance list
1000 Specifier s,const QCString &t)
1001{
1002 //printf("*** insert base class %s into %s\n",qPrint(cd->name()),qPrint(name()));
1003 m_inherits.emplace_back(cd,n,p,s,t);
1004 m_isSimple = FALSE;
1005}
1006
1007// inserts a derived/sub class in the inherited-by list
1009 Specifier s,const QCString &t)
1010{
1011 //printf("*** insert sub class %s into %s\n",qPrint(cd->name()),qPrint(name()));
1012 bool extractPrivate = Config_getBool(EXTRACT_PRIVATE);
1013 if (!extractPrivate && cd->protection()==Protection::Private) return;
1014 m_inheritedBy.emplace_back(cd,QCString(),p,s,t);
1015 m_isSimple = FALSE;
1016}
1017
1019{
1020 for (auto &ml : m_memberLists)
1021 {
1022 if (!ml->listType().isDetailed())
1023 {
1025 }
1026 }
1027
1028 // add members inside sections to their groups
1029 for (const auto &mg : m_memberGroups)
1030 {
1031 if (mg->allMembersInSameSection() && m_subGrouping)
1032 {
1033 //printf("addToDeclarationSection(%s)\n",qPrint(mg->header()));
1034 mg->addToDeclarationSection();
1035 }
1036 }
1037}
1038
1039// adds new member definition to the class
1041 Protection prot,
1042 bool addToAllList
1043 )
1044{
1045 AUTO_TRACE("{} name={} isHidden={}",name(),md->name(),md->isHidden());
1046 if (md->isHidden()) return;
1047
1048 if (getLanguage()==SrcLangExt::VHDL)
1049 {
1051 m_vhdlSummaryTitles.insert(title.str());
1052 }
1053
1054 if (1 /*!isReference()*/) // changed to 1 for showing members of external
1055 // classes when HAVE_DOT and UML_LOOK are enabled.
1056 {
1057 bool isSimple=FALSE;
1058
1059 /********************************************/
1060 /* insert member in the declaration section */
1061 /********************************************/
1062 if (md->isRelated() && protectionLevelVisible(prot))
1063 {
1064 addMemberToList(MemberListType::Related(),md,TRUE);
1065 }
1066 else if (md->isFriend())
1067 {
1068 addMemberToList(MemberListType::Friends(),md,TRUE);
1069 }
1070 else
1071 {
1072 switch (md->memberType())
1073 {
1074 case MemberType::Service: // UNO IDL
1075 addMemberToList(MemberListType::Services(),md,TRUE);
1076 break;
1077 case MemberType::Interface: // UNO IDL
1078 addMemberToList(MemberListType::Interfaces(),md,TRUE);
1079 break;
1080 case MemberType::Signal: // Qt specific
1081 addMemberToList(MemberListType::Signals(),md,TRUE);
1082 break;
1083 case MemberType::DCOP: // KDE2 specific
1084 addMemberToList(MemberListType::DcopMethods(),md,TRUE);
1085 break;
1087 addMemberToList(MemberListType::Properties(),md,TRUE);
1088 break;
1089 case MemberType::Event:
1090 addMemberToList(MemberListType::Events(),md,TRUE);
1091 break;
1092 case MemberType::Slot: // Qt specific
1093 switch (prot)
1094 {
1095 case Protection::Protected:
1096 case Protection::Package: // slots in packages are not possible!
1097 addMemberToList(MemberListType::ProSlots(),md,TRUE);
1098 break;
1099 case Protection::Public:
1100 addMemberToList(MemberListType::PubSlots(),md,TRUE);
1101 break;
1102 case Protection::Private:
1103 addMemberToList(MemberListType::PriSlots(),md,TRUE);
1104 break;
1105 }
1106 break;
1107 default: // any of the other members
1108 if (md->isStatic())
1109 {
1110 if (md->isVariable())
1111 {
1112 switch (prot)
1113 {
1114 case Protection::Protected:
1115 addMemberToList(MemberListType::ProStaticAttribs(),md,TRUE);
1116 break;
1117 case Protection::Package:
1118 addMemberToList(MemberListType::PacStaticAttribs(),md,TRUE);
1119 break;
1120 case Protection::Public:
1121 addMemberToList(MemberListType::PubStaticAttribs(),md,TRUE);
1122 break;
1123 case Protection::Private:
1124 addMemberToList(MemberListType::PriStaticAttribs(),md,TRUE);
1125 break;
1126 }
1127 }
1128 else // function
1129 {
1130 switch (prot)
1131 {
1132 case Protection::Protected:
1133 addMemberToList(MemberListType::ProStaticMethods(),md,TRUE);
1134 break;
1135 case Protection::Package:
1136 addMemberToList(MemberListType::PacStaticMethods(),md,TRUE);
1137 break;
1138 case Protection::Public:
1139 addMemberToList(MemberListType::PubStaticMethods(),md,TRUE);
1140 break;
1141 case Protection::Private:
1142 addMemberToList(MemberListType::PriStaticMethods(),md,TRUE);
1143 break;
1144 }
1145 }
1146 }
1147 else // not static
1148 {
1149 if (md->isVariable())
1150 {
1151 switch (prot)
1152 {
1153 case Protection::Protected:
1154 addMemberToList(MemberListType::ProAttribs(),md,TRUE);
1155 break;
1156 case Protection::Package:
1157 addMemberToList(MemberListType::PacAttribs(),md,TRUE);
1158 break;
1159 case Protection::Public:
1160 {
1161 addMemberToList(MemberListType::PubAttribs(),md,TRUE);
1162 const int MAX_CELL_SIZE=60;
1163 isSimple=md->typeString().length()+md->name().length()+md->argsString().length()<=MAX_CELL_SIZE;
1164 }
1165 break;
1166 case Protection::Private:
1167 addMemberToList(MemberListType::PriAttribs(),md,TRUE);
1168 break;
1169 }
1170 }
1171 else if (md->isTypedef() || md->isEnumerate() || md->isEnumValue())
1172 {
1173 switch (prot)
1174 {
1175 case Protection::Protected:
1176 addMemberToList(MemberListType::ProTypes(),md,TRUE);
1177 break;
1178 case Protection::Package:
1179 addMemberToList(MemberListType::PacTypes(),md,TRUE);
1180 break;
1181 case Protection::Public:
1182 addMemberToList(MemberListType::PubTypes(),md,TRUE);
1183 isSimple=!md->isEnumerate() &&
1184 !md->isEnumValue() &&
1185 md->typeString().find(")(")==-1; // func ptr typedef
1186 break;
1187 case Protection::Private:
1188 addMemberToList(MemberListType::PriTypes(),md,TRUE);
1189 break;
1190 }
1191 }
1192 else // member function
1193 {
1194 switch (prot)
1195 {
1196 case Protection::Protected:
1197 addMemberToList(MemberListType::ProMethods(),md,TRUE);
1198 break;
1199 case Protection::Package:
1200 addMemberToList(MemberListType::PacMethods(),md,TRUE);
1201 break;
1202 case Protection::Public:
1203 addMemberToList(MemberListType::PubMethods(),md,TRUE);
1204 break;
1205 case Protection::Private:
1206 addMemberToList(MemberListType::PriMethods(),md,TRUE);
1207 break;
1208 }
1209 }
1210 }
1211 break;
1212 }
1213 }
1214 if (!isSimple) // not a simple field -> not a simple struct
1215 {
1216 m_isSimple = FALSE;
1217 }
1218 //printf("adding %s simple=%d total_simple=%d\n",qPrint(name()),isSimple,m_isSimple);
1219
1220 /*******************************************************/
1221 /* insert member in the detailed documentation section */
1222 /*******************************************************/
1223 if ((md->isRelated() && protectionLevelVisible(prot)) || md->isFriend())
1224 {
1225 addMemberToList(MemberListType::RelatedMembers(),md,FALSE);
1226 }
1227 else if (md->isFunction() &&
1228 md->protection()==Protection::Private &&
1229 (md->virtualness()!=Specifier::Normal || md->isOverride() || md->isFinal()) &&
1230 Config_getBool(EXTRACT_PRIV_VIRTUAL))
1231 {
1232 addMemberToList(MemberListType::FunctionMembers(),md,FALSE);
1233 }
1234 else
1235 {
1236 switch (md->memberType())
1237 {
1238 case MemberType::Service: // UNO IDL
1239 addMemberToList(MemberListType::ServiceMembers(),md,FALSE);
1240 break;
1241 case MemberType::Interface: // UNO IDL
1242 addMemberToList(MemberListType::InterfaceMembers(),md,FALSE);
1243 break;
1245 addMemberToList(MemberListType::PropertyMembers(),md,FALSE);
1246 break;
1247 case MemberType::Event:
1248 addMemberToList(MemberListType::EventMembers(),md,FALSE);
1249 break;
1250 case MemberType::Signal: // fall through
1251 case MemberType::DCOP:
1252 addMemberToList(MemberListType::FunctionMembers(),md,FALSE);
1253 break;
1254 case MemberType::Slot:
1255 if (protectionLevelVisible(prot))
1256 {
1257 addMemberToList(MemberListType::FunctionMembers(),md,FALSE);
1258 }
1259 break;
1260 default: // any of the other members
1261 if (protectionLevelVisible(prot))
1262 {
1263 switch (md->memberType())
1264 {
1266 addMemberToList(MemberListType::TypedefMembers(),md,FALSE);
1267 break;
1269 addMemberToList(MemberListType::EnumMembers(),md,FALSE);
1270 break;
1272 addMemberToList(MemberListType::EnumValMembers(),md,FALSE);
1273 break;
1275 if (md->isConstructor() || md->isDestructor())
1276 {
1277 m_memberLists.get(MemberListType::Constructors(),MemberListContainer::Class)->push_back(md);
1278 }
1279 else
1280 {
1281 addMemberToList(MemberListType::FunctionMembers(),md,FALSE);
1282 }
1283 break;
1285 addMemberToList(MemberListType::VariableMembers(),md,FALSE);
1286 break;
1287 case MemberType::Define:
1288 warn(md->getDefFileName(),md->getDefLine()-1,"A define ({}) cannot be made a member of {}",
1289 md->name(), this->name());
1290 break;
1291 default:
1292 err("Unexpected member type '{}' found!\n",md->memberTypeName());
1293 }
1294 }
1295 break;
1296 }
1297 }
1298
1299 /*************************************************/
1300 /* insert member in the appropriate member group */
1301 /*************************************************/
1302 // Note: this must be done AFTER inserting the member in the
1303 // regular groups
1304 //addMemberToGroup(md,groupId);
1305
1306 }
1307
1308 if (md->virtualness()==Specifier::Pure)
1309 {
1310 m_isAbstract=true;
1311 }
1312
1313 if (md->name()=="operator->")
1314 {
1315 m_arrowOperator=md;
1316 }
1317
1318 if (addToAllList &&
1319 !(Config_getBool(HIDE_FRIEND_COMPOUNDS) &&
1320 md->isFriend() &&
1321 (md->typeString()=="friend class" ||
1322 md->typeString()=="friend struct" ||
1323 md->typeString()=="friend union")))
1324 {
1325 //printf("=======> adding member %s to class %s\n",qPrint(md->name()),qPrint(name()));
1326
1328 mni->push_back(std::make_unique<MemberInfo>(md,prot,md->virtualness(),false,false));
1329 }
1330
1331 // if we already created template instances before inserting this member (i.e. due to a typedef or using statement)
1332 // then we also need to insert the member in the template instance.
1333 for (const auto &ti : getTemplateInstances())
1334 {
1335 AUTO_TRACE_ADD("member {} of class {} with template instance {}\n",md->name(),name(),ti.templSpec);
1336 ClassDefMutable *cdm = toClassDefMutable(ti.classDef);
1337 if (cdm)
1338 {
1339 cdm->addMemberToTemplateInstance(md,templateArguments(),ti.templSpec);
1340 }
1341 }
1342
1343}
1344
1349
1350// compute the anchors for all members
1352{
1353 for (auto &ml : m_memberLists)
1354 {
1355 if (!ml->listType().isDetailed())
1356 {
1357 ml->setAnchors();
1358 }
1359 }
1360
1361 for (const auto &mg : m_memberGroups)
1362 {
1363 mg->setAnchors();
1364 }
1365}
1366
1368{
1369 for (const auto &mg : m_memberGroups)
1370 {
1371 mg->distributeMemberGroupDocumentation();
1372 }
1373}
1374
1376{
1380 for (const auto &mg : m_memberGroups)
1381 {
1382 mg->findSectionsInDocumentation(this);
1383 }
1384 for (auto &ml : m_memberLists)
1385 {
1386 if (!ml->listType().isDetailed())
1387 {
1388 ml->findSectionsInDocumentation(this);
1389 }
1390 }
1391}
1392
1393
1394// add a file name to the used files set
1396{
1397 if (fd == nullptr) return;
1398
1399 if (std::find(m_files.begin(), m_files.end(), fd) == m_files.end()) m_files.push_back(fd);
1400
1401 for (const auto &ti : m_templateInstances)
1402 {
1403 if (ClassDefMutable *cdm = toClassDefMutable(ti.classDef)) cdm->insertUsedFile(fd);
1404 }
1405}
1406
1408{
1409 if (bcd.prot!=Protection::Public || bcd.virt!=Specifier::Normal)
1410 {
1411 ol.startTypewriter();
1412 ol.docify(" [");
1413 StringVector sl;
1414 if (bcd.prot==Protection::Protected) sl.emplace_back("protected");
1415 else if (bcd.prot==Protection::Private) sl.emplace_back("private");
1416 if (bcd.virt==Specifier::Virtual) sl.emplace_back("virtual");
1417 bool first=true;
1418 for (const auto &s : sl)
1419 {
1420 if (!first) ol.docify(", ");
1421 ol.docify(s);
1422 first=false;
1423 }
1424 ol.docify("]");
1425 ol.endTypewriter();
1426 }
1427}
1428
1430 const QCString &includeName,bool local, bool force)
1431{
1432 //printf("ClassDefImpl::setIncludeFile(%p,%s,%d,%d)\n",fd,includeName,local,force);
1433 if (!m_incInfo) m_incInfo = std::make_unique<IncludeInfo>();
1434 if ((!includeName.isEmpty() && m_incInfo->includeName.isEmpty()) ||
1435 (fd!=nullptr && m_incInfo->fileDef==nullptr)
1436 )
1437 {
1438 //printf("Setting file info\n");
1439 m_incInfo->fileDef = fd;
1440 m_incInfo->includeName = includeName;
1442 }
1443 if (force && !includeName.isEmpty())
1444 {
1445 m_incInfo->includeName = includeName;
1447 }
1448}
1449
1450// TODO: fix this: a nested template class can have multiple outer templates
1451//ArgumentList *ClassDefImpl::outerTemplateArguments() const
1452//{
1453// int ti;
1454// ClassDef *pcd=nullptr;
1455// int pi=0;
1456// if (m_tempArgs) return m_tempArgs;
1457// // find the outer most class scope
1458// while ((ti=name().find("::",pi))!=-1 &&
1459// (pcd=getClass(name().left(ti)))==0
1460// ) pi=ti+2;
1461// if (pcd)
1462// {
1463// return pcd->templateArguments();
1464// }
1465// return nullptr;
1466//}
1467
1468static void searchTemplateSpecs(/*in*/ const Definition *d,
1469 /*out*/ ArgumentLists &result,
1470 /*out*/ QCString &name,
1471 /*in*/ SrcLangExt lang)
1472{
1474 {
1475 if (d->getOuterScope())
1476 {
1477 searchTemplateSpecs(d->getOuterScope(),result,name,lang);
1478 }
1479 const ClassDef *cd=toClassDef(d);
1480 if (!name.isEmpty()) name+="::";
1481 QCString clName = d->localName();
1482 if (clName.endsWith("-p"))
1483 {
1484 clName = clName.left(clName.length()-2);
1485 }
1486 name+=clName;
1487 bool isSpecialization = d->localName().find('<')!=-1;
1488 if (!cd->templateArguments().empty())
1489 {
1490 result.push_back(cd->templateArguments());
1491 if (!isSpecialization)
1492 {
1493 name+=tempArgListToString(cd->templateArguments(),lang);
1494 }
1495 }
1496 }
1497 else
1498 {
1499 name+=d->qualifiedName();
1500 }
1501}
1502
1504 const QCString &type,SrcLangExt lang) const
1505{
1506 ArgumentLists specs;
1507 QCString name;
1508 searchTemplateSpecs(d,specs,name,lang);
1509 if (!specs.empty()) // class has template scope specifiers
1510 {
1512 for (const ArgumentList &al : specs)
1513 {
1514 ol.docify("template<");
1515 auto it = al.begin();
1516 while (it!=al.end())
1517 {
1518 Argument a = *it;
1520 a.type, // text
1521 LinkifyTextOptions().setScope(d).setFileScope(getFileDef()).setSelf(this));
1522 if (!a.name.isEmpty())
1523 {
1524 ol.docify(" ");
1525 ol.docify(a.name);
1526 }
1527 if (a.defval.length()!=0)
1528 {
1529 ol.docify(" = ");
1530 ol.docify(a.defval);
1531 }
1532 ++it;
1533 if (it!=al.end()) ol.docify(", ");
1534 }
1535 ol.docify(">");
1536 ol.lineBreak();
1537 }
1538 if (!m_requiresClause.isEmpty())
1539 {
1540 ol.docify("requires ");
1542 m_requiresClause, // text
1543 LinkifyTextOptions().setScope(d).setFileScope(getFileDef()).setSelf(this));
1544 ol.lineBreak();
1545 }
1546 ol.docify(type.lower()+" "+name);
1548 }
1549}
1550
1551void ClassDefImpl::writeBriefDescription(OutputList &ol,bool exampleFlag) const
1552{
1553 if (hasBriefDescription())
1554 {
1555 ol.startParagraph();
1556 ol.pushGeneratorState();
1558 ol.writeString(" - ");
1559 ol.popGeneratorState();
1561 briefLine(),
1562 this,
1563 nullptr,
1565 DocOptions()
1566 .setIndexWords(true)
1567 .setSingleLine(true));
1568 ol.pushGeneratorState();
1570 ol.writeString(" \n");
1572 ol.popGeneratorState();
1573
1574 if (hasDetailedDescription() || exampleFlag)
1575 {
1576 writeMoreLink(ol,anchor());
1577 }
1578
1579 ol.endParagraph();
1580 }
1581 ol.writeSynopsis();
1582}
1583
1585{
1586 bool repeatBrief = Config_getBool(REPEAT_BRIEF);
1587
1588 ol.startTextBlock();
1589
1590 if (getLanguage()==SrcLangExt::Cpp)
1591 {
1592 writeTemplateSpec(ol,this,compoundTypeString(),SrcLangExt::Cpp);
1593 }
1594
1595 // repeat brief description
1596 if (!briefDescription().isEmpty() && repeatBrief)
1597 {
1599 briefLine(),
1600 this,
1601 nullptr,
1603 DocOptions());
1604 }
1605 if (!briefDescription().isEmpty() && repeatBrief &&
1606 !documentation().isEmpty())
1607 {
1608 ol.pushGeneratorState();
1610 ol.writeString("\n\n");
1611 ol.popGeneratorState();
1612 }
1613 // write documentation
1614 if (!documentation().isEmpty())
1615 {
1616 ol.generateDoc(docFile(),
1617 docLine(),
1618 this,
1619 nullptr,
1620 documentation(),
1621 DocOptions()
1622 .setIndexWords(true));
1623 }
1624 // write type constraints
1626
1627 ol.generateDoc(
1628 docFile(),docLine(),
1629 this,
1630 nullptr, // memberDef
1632 DocOptions()
1633 .setIndexWords(true));
1634
1635 // write examples
1636 if (hasExamples())
1637 {
1638 ol.startExamples();
1639 ol.startDescForItem();
1641 ol.endDescForItem();
1642 ol.endExamples();
1643 }
1644 writeSourceDef(ol);
1646 ol.endTextBlock();
1647}
1648
1650{
1651 bool repeatBrief = Config_getBool(REPEAT_BRIEF);
1652 bool sourceBrowser = Config_getBool(SOURCE_BROWSER);
1653 return ((!briefDescription().isEmpty() && repeatBrief) ||
1654 (!documentation().isEmpty() || m_tempArgs.hasTemplateDocumentation()) ||
1655 (sourceBrowser && getStartBodyLine()!=-1 && getBodyDef()) ||
1657}
1658
1659// write the detailed description for this class
1660void ClassDefImpl::writeDetailedDescription(OutputList &ol, const QCString &/*pageType*/, bool exampleFlag,
1661 const QCString &title,const QCString &anchor) const
1662{
1663 if (hasDetailedDescription() || exampleFlag)
1664 {
1665 ol.pushGeneratorState();
1667 ol.writeRuler();
1668 ol.popGeneratorState();
1669
1670 ol.pushGeneratorState();
1672 ol.writeAnchor(QCString(),anchor.isEmpty() ? QCString("details") : anchor);
1673 ol.popGeneratorState();
1674
1675 if (!anchor.isEmpty())
1676 {
1677 ol.pushGeneratorState();
1681 ol.popGeneratorState();
1682 }
1683
1684 ol.startGroupHeader("details");
1685 ol.parseText(title);
1686 ol.endGroupHeader();
1687
1689 }
1690 else
1691 {
1692 //writeTemplateSpec(ol,this,pageType);
1693 }
1694}
1695
1697{
1698 QCString result;
1699 SrcLangExt lang = getLanguage();
1700 size_t numFiles = m_files.size();
1701 if (lang==SrcLangExt::Fortran)
1702 {
1703 result = theTranslator->trGeneratedFromFilesFortran(
1704 getLanguage()==SrcLangExt::ObjC && m_compType==Interface ? Class : m_compType,
1705 numFiles==1);
1706 }
1707 else if (isJavaEnum())
1708 {
1709 result = theTranslator->trEnumGeneratedFromFiles(numFiles==1);
1710 }
1711 else if (m_compType==Service)
1712 {
1713 result = theTranslator->trServiceGeneratedFromFiles(numFiles==1);
1714 }
1715 else if (m_compType==Singleton)
1716 {
1717 result = theTranslator->trSingletonGeneratedFromFiles(numFiles==1);
1718 }
1719 else
1720 {
1721 result = theTranslator->trGeneratedFromFiles(
1722 getLanguage()==SrcLangExt::ObjC && m_compType==Interface ? Class : m_compType,
1723 numFiles==1);
1724 }
1725 return result;
1726}
1727
1729{
1730 ol.pushGeneratorState();
1732
1733
1734 ol.writeRuler();
1735 ol.pushGeneratorState();
1737 ol.startParagraph();
1739 ol.endParagraph();
1740 ol.popGeneratorState();
1744
1745 bool first=TRUE;
1746 for (const auto &fd : m_files)
1747 {
1748 if (first)
1749 {
1750 first=FALSE;
1751 ol.startItemList();
1752 }
1753
1754 ol.startItemListItem();
1755 QCString path=fd->getPath();
1756 if (Config_getBool(FULL_PATH_NAMES))
1757 {
1758 ol.docify(stripFromPath(path));
1759 }
1760
1761 QCString fname = fd->name();
1762 if (!fd->getVersion().isEmpty()) // append version if available
1763 {
1764 fname += " (" + fd->getVersion() + ")";
1765 }
1766
1767 // for HTML
1768 ol.pushGeneratorState();
1770 if (fd->generateSourceFile())
1771 {
1772 ol.writeObjectLink(QCString(),fd->getSourceFileBase(),QCString(),fname);
1773 }
1774 else if (fd->isLinkable())
1775 {
1776 ol.writeObjectLink(fd->getReference(),fd->getOutputFileBase(),QCString(),fname);
1777 }
1778 else
1779 {
1780 ol.startBold();
1781 ol.docify(fname);
1782 ol.endBold();
1783 }
1784 ol.popGeneratorState();
1785
1786 // for other output formats
1787 ol.pushGeneratorState();
1789 if (fd->isLinkable())
1790 {
1791 ol.writeObjectLink(fd->getReference(),fd->getOutputFileBase(),QCString(),fname);
1792 }
1793 else
1794 {
1795 ol.docify(fname);
1796 }
1797 ol.popGeneratorState();
1798
1799 ol.endItemListItem();
1800 }
1801 if (!first) ol.endItemList();
1802
1803 ol.popGeneratorState();
1804}
1805
1807{
1808 int count=0;
1809 for (const auto &ibcd : m_inheritedBy)
1810 {
1811 const ClassDef *icd=ibcd.classDef;
1812 if ( icd->isVisibleInHierarchy()) count++;
1813 }
1814 return count;
1815}
1816
1818{
1819 int count=0;
1820 for (const auto &ibcd : m_inherits)
1821 {
1822 const ClassDef *icd=ibcd.classDef;
1823 if ( icd->isVisibleInHierarchy()) count++;
1824 }
1825 return count;
1826}
1827
1832
1834{
1835 bool haveDot = Config_getBool(HAVE_DOT);
1836 auto classGraph = m_typeInheritanceGraph;
1837
1838 if (classGraph == CLASS_GRAPH_t::NO) return;
1839 // count direct inheritance relations
1840 int count=countInheritanceNodes();
1841
1842 bool renderDiagram = FALSE;
1843 if (haveDot && (classGraph==CLASS_GRAPH_t::YES || classGraph==CLASS_GRAPH_t::GRAPH))
1844 // write class diagram using dot
1845 {
1846 DotClassGraph inheritanceGraph(this,GraphType::Inheritance);
1847 if (inheritanceGraph.isTooBig())
1848 {
1849 warn_uncond("Inheritance graph for '{}' not generated, too many nodes ({}), threshold is {}. Consider increasing DOT_GRAPH_MAX_NODES.\n",
1850 name(), inheritanceGraph.numNodes(), Config_getInt(DOT_GRAPH_MAX_NODES));
1851 }
1852 else if (!inheritanceGraph.isTrivial())
1853 {
1854 ol.pushGeneratorState();
1856 ol.startDotGraph();
1857 ol.parseText(theTranslator->trClassDiagram(displayName()));
1858 ol.endDotGraph(inheritanceGraph);
1859 ol.popGeneratorState();
1860 renderDiagram = TRUE;
1861 }
1862 }
1863 else if ((classGraph==CLASS_GRAPH_t::YES || classGraph==CLASS_GRAPH_t::GRAPH || classGraph==CLASS_GRAPH_t::BUILTIN) && count>0)
1864 // write class diagram using built-in generator
1865 {
1866 ClassDiagram diagram(this); // create a diagram of this class.
1867 ol.startClassDiagram();
1869 ol.parseText(theTranslator->trClassDiagram(displayName()));
1872 renderDiagram = TRUE;
1873 }
1874
1875 if (renderDiagram) // if we already show the inheritance relations graphically,
1876 // then hide the text version
1877 {
1879 }
1880
1881 count = countInheritsNodes();
1882 if (count>0)
1883 {
1884 auto replaceFunc = [this,&ol](size_t entryIndex)
1885 {
1886 for (size_t index=0; index<m_inherits.size() ; index++)
1887 {
1888 const BaseClassDef &bcd=m_inherits[index];
1889 const ClassDef *cd=bcd.classDef;
1890
1891 if (cd->isVisibleInHierarchy()) // filter on the class we want to show
1892 {
1893 if (index==entryIndex) // found the requested index
1894 {
1895 // use the class name but with the template arguments as given
1896 // in the inheritance relation
1898 cd->displayName(),bcd.templSpecifiers);
1899
1900 if (cd->isLinkable())
1901 {
1903 cd->getOutputFileBase(),
1904 cd->anchor(),
1905 displayName);
1906 }
1907 else
1908 {
1909 ol.docify(displayName);
1910 }
1911 return;
1912 }
1913 }
1914 }
1915 };
1916
1917 ol.startParagraph();
1918 writeMarkerList(ol,
1919 theTranslator->trInheritsList(count).str(),
1920 static_cast<size_t>(count),
1921 replaceFunc);
1922 ol.endParagraph();
1923 }
1924
1925 // write subclasses
1926 count = countInheritedByNodes();
1927 if (count>0)
1928 {
1929 auto replaceFunc = [this,&ol](size_t entryIndex)
1930 {
1931 for (size_t index=0; index<m_inheritedBy.size() ; index++)
1932 {
1933 const BaseClassDef &bcd=m_inheritedBy[index];
1934 const ClassDef *cd=bcd.classDef;
1935 if (cd->isVisibleInHierarchy()) // filter on the class we want to show
1936 {
1937 if (index==entryIndex) // found the requested index
1938 {
1939 if (cd->isLinkable())
1940 {
1943 }
1944 else
1945 {
1946 ol.docify(cd->displayName());
1947 }
1948 return;
1949 }
1950 }
1951 }
1952 };
1953
1954 ol.startParagraph();
1955 writeMarkerList(ol,
1956 theTranslator->trInheritedByList(count).str(),
1957 static_cast<size_t>(count),
1958 replaceFunc);
1959 ol.endParagraph();
1960 }
1961
1962 if (renderDiagram)
1963 {
1964 ol.enableAll();
1965 }
1966}
1967
1969{
1970 if (Config_getBool(HAVE_DOT) && m_hasCollaborationGraph /*&& Config_getBool(COLLABORATION_GRAPH)*/)
1971 {
1972 DotClassGraph usageImplGraph(this,GraphType::Collaboration);
1973 if (usageImplGraph.isTooBig())
1974 {
1975 warn_uncond("Collaboration graph for '{}' not generated, too many nodes ({}), threshold is {}. Consider increasing DOT_GRAPH_MAX_NODES.\n",
1976 name(), usageImplGraph.numNodes(), Config_getInt(DOT_GRAPH_MAX_NODES));
1977 }
1978 else if (!usageImplGraph.isTrivial())
1979 {
1980 ol.pushGeneratorState();
1982 ol.startDotGraph();
1983 ol.parseText(theTranslator->trCollaborationDiagram(displayName()));
1984 ol.endDotGraph(usageImplGraph);
1985 ol.popGeneratorState();
1986 }
1987 }
1988}
1989
1990
1992{
1993 if (m_incInfo)
1994 {
1995 QCString nm;
1996 const StringVector &paths = Config_getList(STRIP_FROM_PATH);
1997 if (!paths.empty() && m_incInfo->fileDef)
1998 {
1999 QCString abs = m_incInfo->fileDef->absFilePath();
2000 QCString potential;
2001 size_t length = 0;
2002 for (const auto &s : paths)
2003 {
2004 FileInfo info(s);
2005 if (info.exists())
2006 {
2007 QCString prefix = info.absFilePath();
2008 if (prefix.at(prefix.length() - 1) != '/')
2009 {
2010 prefix += '/';
2011 }
2012
2013 if (prefix.length() > length &&
2014 qstricmp(abs.left(prefix.length()).data(), prefix.data()) == 0) // case insensitive compare
2015 {
2016 length = prefix.length();
2017 potential = abs.right(abs.length() - prefix.length());
2018 }
2019 }
2020 }
2021
2022 if (length > 0)
2023 {
2024 nm = potential;
2025 }
2026 }
2027
2028 if (nm.isEmpty())
2029 {
2030 nm = m_incInfo->includeName;
2031 }
2032
2033 ol.startParagraph();
2034 ol.docify(theTranslator->trDefinedIn()+" ");
2035 ol.startTypewriter();
2036 ol.docify("<");
2037 if (m_incInfo->fileDef)
2038 {
2039 ol.writeObjectLink(QCString(),m_incInfo->fileDef->includeName(),QCString(),nm);
2040 }
2041 else
2042 {
2043 ol.docify(nm);
2044 }
2045 ol.docify(">");
2046 ol.endTypewriter();
2047 ol.endParagraph();
2048 }
2049
2050 // Write a summary of the Slice definition including metadata.
2051 ol.startParagraph();
2052 ol.startTypewriter();
2053 if (!m_metaData.isEmpty())
2054 {
2055 ol.docify(m_metaData);
2056 ol.lineBreak();
2057 }
2058 if (m_spec.isLocal())
2059 {
2060 ol.docify("local ");
2061 }
2062 if (m_spec.isInterface())
2063 {
2064 ol.docify("interface ");
2065 }
2066 else if (m_spec.isStruct())
2067 {
2068 ol.docify("struct ");
2069 }
2070 else if (m_spec.isException())
2071 {
2072 ol.docify("exception ");
2073 }
2074 else
2075 {
2076 ol.docify("class ");
2077 }
2078 ol.docify(stripScope(name()));
2079 if (!m_inherits.empty())
2080 {
2081 if (m_spec.isInterface() || m_spec.isException())
2082 {
2083 ol.docify(" extends ");
2084 bool first=true;
2085 for (const auto &ibcd : m_inherits)
2086 {
2087 if (!first) ol.docify(", ");
2088 ClassDef *icd = ibcd.classDef;
2089 ol.docify(icd->name());
2090 first=false;
2091 }
2092 }
2093 else
2094 {
2095 // Must be a class.
2096 bool implements = false;
2097 for (const auto &ibcd : m_inherits)
2098 {
2099 ClassDef *icd = ibcd.classDef;
2100 if (icd->isInterface())
2101 {
2102 implements = true;
2103 }
2104 else
2105 {
2106 ol.docify(" extends ");
2107 ol.docify(icd->name());
2108 }
2109 }
2110 if (implements)
2111 {
2112 ol.docify(" implements ");
2113 bool first = true;
2114 for (const auto &ibcd : m_inherits)
2115 {
2116 ClassDef *icd = ibcd.classDef;
2117 if (icd->isInterface())
2118 {
2119 if (!first) ol.docify(", ");
2120 first = false;
2121 ol.docify(icd->name());
2122 }
2123 }
2124 }
2125 }
2126 }
2127 ol.docify(" { ... }");
2128 ol.endTypewriter();
2129 ol.endParagraph();
2130}
2131
2133{
2134 if (m_incInfo /*&& Config_getBool(SHOW_HEADERFILE)*/)
2135 {
2136 SrcLangExt lang = getLanguage();
2137 QCString nm=m_incInfo->includeName.isEmpty() ?
2138 (m_incInfo->fileDef ?
2139 m_incInfo->fileDef->docName() : QCString()
2140 ) :
2141 m_incInfo->includeName;
2142 if (!nm.isEmpty())
2143 {
2144 ol.startParagraph();
2145 ol.startTypewriter();
2146 ol.docify(::includeStatement(lang,m_incInfo->kind));
2147 ol.docify(::includeOpen(lang,m_incInfo->kind));
2148 ol.pushGeneratorState();
2150 ol.docify(nm);
2153 if (m_incInfo->fileDef)
2154 {
2155 ol.writeObjectLink(QCString(),m_incInfo->fileDef->includeName(),QCString(),nm);
2156 }
2157 else
2158 {
2159 ol.docify(nm);
2160 }
2161 ol.popGeneratorState();
2162 ol.docify(::includeClose(lang,m_incInfo->kind));
2163 ol.endTypewriter();
2164 ol.endParagraph();
2165 }
2166 }
2167}
2168
2169void ClassDefImpl::writeMemberGroups(OutputList &ol,bool showInline) const
2170{
2171 // write user defined member groups
2172 for (const auto &mg : m_memberGroups)
2173 {
2174 if (!mg->allMembersInSameSection() || !m_subGrouping) // group is in its own section
2175 {
2176 mg->writeDeclarations(ol,this,nullptr,nullptr,nullptr,nullptr,showInline);
2177 }
2178 else // add this group to the corresponding member section
2179 {
2180 //printf("addToDeclarationSection(%s)\n",qPrint(mg->header()));
2181 //mg->addToDeclarationSection();
2182 }
2183 }
2184}
2185
2187{
2188 // nested classes
2189 m_innerClasses.writeDeclaration(ol,nullptr,title,TRUE);
2190}
2191
2193{
2194 m_innerClasses.writeDocumentation(ol,this);
2195}
2196
2198{
2199 //printf("%s: ClassDefImpl::startMemberDocumentation()\n",qPrint(name()));
2200 if (Config_getBool(SEPARATE_MEMBER_PAGES))
2201 {
2204 }
2205}
2206
2208{
2209 //printf("%s: ClassDefImpl::endMemberDocumentation()\n",qPrint(name()));
2210 if (Config_getBool(SEPARATE_MEMBER_PAGES))
2211 {
2214 }
2215}
2216
2218{
2219 //printf("%s: ClassDefImpl::startMemberDeclarations()\n",qPrint(name()));
2221}
2222
2224{
2225 //printf("%s: ClassDefImpl::endMemberDeclarations()\n",qPrint(name()));
2226 bool inlineInheritedMembers = Config_getBool(INLINE_INHERITED_MEMB);
2227 if (!inlineInheritedMembers && countAdditionalInheritedMembers()>0)
2228 {
2229 ol.startMemberHeader("inherited");
2230 ol.parseText(theTranslator->trAdditionalInheritedMembers());
2231 ol.endMemberHeader();
2233 }
2234 ol.endMemberSections();
2235}
2236
2238{
2239 ol.pushGeneratorState();
2241 ol.writeString("\n");
2242 ol.startGroupHeader();
2243 ol.parseText(theTranslator->trAuthor(TRUE,TRUE));
2244 ol.endGroupHeader();
2245 ol.parseText(theTranslator->trGeneratedAutomatically(Config_getString(PROJECT_NAME)));
2246 ol.popGeneratorState();
2247}
2248
2249
2251{
2252 static bool extractPrivate = Config_getBool(EXTRACT_PRIVATE);
2253 ol.pushGeneratorState();
2255 bool first=TRUE;
2256 SrcLangExt lang = getLanguage();
2257
2258 if (lang!=SrcLangExt::VHDL)
2259 {
2260 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::Class))
2261 {
2262 if (lde->kind()==LayoutDocEntry::ClassNestedClasses &&
2263 m_innerClasses.declVisible()
2264 )
2265 {
2266 for (const auto &innerCd : m_innerClasses)
2267 {
2268 if (!innerCd->isAnonymous() &&
2269 !innerCd->isExtension() &&
2270 (innerCd->protection()!=Protection::Private || extractPrivate) &&
2271 innerCd->visibleInParentsDeclList()
2272 )
2273 {
2274 const LayoutDocEntrySection *ls = dynamic_cast<const LayoutDocEntrySection *>(lde.get());
2275 ol.writeSummaryLink(QCString(),"nested-classes",ls->title(lang),first);
2276 first=FALSE;
2277 break;
2278 }
2279 }
2280 }
2281 else if (lde->kind()==LayoutDocEntry::ClassAllMembersLink &&
2283 !Config_getBool(OPTIMIZE_OUTPUT_FOR_C)
2284 )
2285 {
2286 ol.writeSummaryLink(getMemberListFileName(),"all-members-list",theTranslator->trListOfAllMembers(),first);
2287 first=FALSE;
2288 }
2289 else if (lde->kind()==LayoutDocEntry::MemberDecl)
2290 {
2291 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
2292 if (lmd)
2293 {
2294 MemberList * ml = getMemberList(lmd->type);
2295 if (ml && ml->declVisible())
2296 {
2297 ol.writeSummaryLink(QCString(),ml->listType().toLabel(),lmd->title(lang),first);
2298 first=FALSE;
2299 }
2300 }
2301 }
2302 }
2303 }
2304 else // VDHL only
2305 {
2306 for (const auto &s : m_vhdlSummaryTitles)
2307 {
2308 ol.writeSummaryLink(QCString(),convertToId(s),s,first);
2309 first=FALSE;
2310 }
2311 }
2312 if (!first)
2313 {
2314 ol.writeString(" </div>\n");
2315 }
2316 ol.popGeneratorState();
2317}
2318
2323
2325{
2326 if (!isLinkableInProject() || isArtificial()) return;
2327 tagFile << " <compound kind=\"";
2328 if (isFortran() && (compoundTypeString() == "type"))
2329 tagFile << "struct";
2330 else
2331 tagFile << compoundTypeString();
2332 tagFile << "\"";
2333 if (isObjectiveC()) { tagFile << " objc=\"yes\""; }
2334 tagFile << ">\n";
2335 tagFile << " <name>" << convertToXML(name()) << "</name>\n";
2338 tagFile << " <filename>" << convertToXML(fn) << "</filename>\n";
2339 if (!anchor().isEmpty())
2340 {
2341 tagFile << " <anchor>" << convertToXML(anchor()) << "</anchor>\n";
2342 }
2343 QCString idStr = id();
2344 if (!idStr.isEmpty())
2345 {
2346 tagFile << " <clangid>" << convertToXML(idStr) << "</clangid>\n";
2347 }
2348 for (const Argument &a : m_tempArgs)
2349 {
2350 tagFile << " <templarg>" << convertToXML(a.type);
2351 if (!a.name.isEmpty())
2352 {
2353 tagFile << " " << convertToXML(a.name);
2354 }
2355 tagFile << "</templarg>\n";
2356 }
2357 for (const auto &ibcd : m_inherits)
2358 {
2359 ClassDef *cd=ibcd.classDef;
2360 if (cd && cd->isLinkable())
2361 {
2362 tagFile << " <base";
2363 if (ibcd.prot==Protection::Protected)
2364 {
2365 tagFile << " protection=\"protected\"";
2366 }
2367 else if (ibcd.prot==Protection::Private)
2368 {
2369 tagFile << " protection=\"private\"";
2370 }
2371 if (ibcd.virt==Specifier::Virtual)
2372 {
2373 tagFile << " virtualness=\"virtual\"";
2374 }
2376 cd->displayName(),ibcd.templSpecifiers);
2377 tagFile << ">" << convertToXML(displayName) << "</base>\n";
2378 }
2379 }
2380 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::Class))
2381 {
2382 switch (lde->kind())
2383 {
2384 case LayoutDocEntry::ClassNestedClasses:
2385 {
2386 for (const auto &innerCd : m_innerClasses)
2387 {
2388 if (innerCd->isLinkableInProject() && !innerCd->isImplicitTemplateInstance() &&
2389 protectionLevelVisible(innerCd->protection()) &&
2390 !innerCd->isEmbeddedInOuterScope()
2391 )
2392 {
2393 tagFile << " <class kind=\"" << innerCd->compoundTypeString() <<
2394 "\">" << convertToXML(innerCd->name()) << "</class>\n";
2395 }
2396 }
2397 }
2398 break;
2399 case LayoutDocEntry::MemberDecl:
2400 {
2401 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
2402 if (lmd)
2403 {
2404 MemberList * ml = getMemberList(lmd->type);
2405 if (ml)
2406 {
2407 ml->writeTagFile(tagFile);
2408 }
2409 }
2410 }
2411 break;
2412 case LayoutDocEntry::MemberGroups:
2413 {
2414 for (const auto &mg : m_memberGroups)
2415 {
2416 mg->writeTagFile(tagFile);
2417 }
2418 }
2419 break;
2420 default:
2421 break;
2422 }
2423 }
2424 writeDocAnchorsToTagFile(tagFile);
2425 tagFile << " </compound>\n";
2426}
2427
2428/** Write class documentation inside another container (i.e. a group) */
2430{
2431 bool isSimple = m_isSimple;
2432
2433 ol.addIndexItem(name(),QCString());
2434 //printf("ClassDefImpl::writeInlineDocumentation(%s)\n",qPrint(name()));
2435
2436 // part 1: anchor and title
2437 QCString s = compoundTypeString()+" "+name();
2438
2439 // part 1a
2440 ol.pushGeneratorState();
2442 { // only HTML only
2443 ol.writeAnchor(QCString(),anchor());
2446 ol.parseText(s);
2447 ol.endMemberDocName();
2448 ol.endMemberDoc(FALSE);
2449 ol.writeString("</div>");
2450 ol.startIndent();
2451 }
2452 ol.popGeneratorState();
2453
2454 // part 1b
2455 ol.pushGeneratorState();
2458 { // for LaTeX/RTF only
2460 }
2461 ol.popGeneratorState();
2462
2463 // part 1c
2464 ol.pushGeneratorState();
2466 {
2467 // for LaTeX/RTF/Man
2468 ol.startGroupHeader("",1);
2469 ol.parseText(s);
2470 ol.endGroupHeader(1);
2471 }
2472 ol.popGeneratorState();
2473
2474 SrcLangExt lang=getLanguage();
2475
2476 // part 2: the header and detailed description
2477 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::Class))
2478 {
2479 switch (lde->kind())
2480 {
2481 case LayoutDocEntry::BriefDesc:
2482 {
2483 // since we already shown the brief description in the
2484 // declaration part of the container, so we use this to
2485 // show the details on top.
2487 }
2488 break;
2489 case LayoutDocEntry::ClassInheritanceGraph:
2491 break;
2492 case LayoutDocEntry::ClassCollaborationGraph:
2494 break;
2495 case LayoutDocEntry::MemberDeclStart:
2497 break;
2498 case LayoutDocEntry::MemberDecl:
2499 {
2500 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
2501 if (lmd)
2502 {
2503 ClassDefSet visitedClasses;
2504 if (!isSimple) writeMemberDeclarations(ol,visitedClasses,lmd->type,lmd->title(lang),lmd->subtitle(lang),TRUE);
2505 }
2506 }
2507 break;
2508 case LayoutDocEntry::MemberGroups:
2510 break;
2511 case LayoutDocEntry::MemberDeclEnd:
2513 break;
2514 case LayoutDocEntry::MemberDefStart:
2516 break;
2517 case LayoutDocEntry::MemberDef:
2518 {
2519 const LayoutDocEntryMemberDef *lmd = dynamic_cast<const LayoutDocEntryMemberDef*>(lde.get());
2520 if (lmd)
2521 {
2522 if (isSimple)
2523 {
2525 }
2526 else
2527 {
2528 writeMemberDocumentation(ol,lmd->type,lmd->title(lang),TRUE);
2529 }
2530 }
2531 }
2532 break;
2533 case LayoutDocEntry::MemberDefEnd:
2535 break;
2536 default:
2537 break;
2538 }
2539 }
2540
2541 // part 3: close the block
2542 ol.pushGeneratorState();
2544 { // HTML only
2545 ol.endIndent();
2546 }
2547 ol.popGeneratorState();
2548}
2549
2551{
2552 // TODO: clean up this mess by moving it to
2553 // the output generators...
2554 bool pdfHyperlinks = Config_getBool(PDF_HYPERLINKS);
2555 bool rtfHyperlinks = Config_getBool(RTF_HYPERLINKS);
2556 bool usePDFLatex = Config_getBool(USE_PDFLATEX);
2557
2558 // HTML only
2559 ol.pushGeneratorState();
2561 ol.docify(" ");
2563 anchor.isEmpty() ? QCString("details") : anchor);
2564 ol.parseText(theTranslator->trMore());
2565 ol.endTextLink();
2566 ol.popGeneratorState();
2567
2568 if (!anchor.isEmpty())
2569 {
2570 ol.pushGeneratorState();
2571 // LaTeX + RTF
2575 if (!(usePDFLatex && pdfHyperlinks))
2576 {
2578 }
2579 if (!rtfHyperlinks)
2580 {
2582 }
2583 ol.docify(" ");
2585 ol.parseText(theTranslator->trMore());
2586 ol.endTextLink();
2587 // RTF only
2589 ol.writeString("\\par");
2590 ol.popGeneratorState();
2591 }
2592}
2593
2595{
2596 bool extractPrivate = Config_getBool(EXTRACT_PRIVATE);
2597 bool hideUndocClasses = Config_getBool(HIDE_UNDOC_CLASSES);
2598 bool extractLocalClasses = Config_getBool(EXTRACT_LOCAL_CLASSES);
2599 bool linkable = isLinkable();
2600 return (!isAnonymous() && !isExtension() &&
2601 (protection()!=Protection::Private || extractPrivate) &&
2602 (linkable || (!hideUndocClasses && (!isLocal() || extractLocalClasses)))
2603 );
2604}
2605
2606void ClassDefImpl::writeDeclarationLink(OutputList &ol,bool &found,const QCString &header,bool localNames) const
2607{
2608 //bool fortranOpt = Config_getBool(OPTIMIZE_FOR_FORTRAN);
2609 //bool vhdlOpt = Config_getBool(OPTIMIZE_OUTPUT_VHDL);
2610 bool sliceOpt = Config_getBool(OPTIMIZE_OUTPUT_SLICE);
2611 SrcLangExt lang = getLanguage();
2613 {
2614 if (!found) // first class
2615 {
2616 if (sliceOpt)
2617 {
2618 if (compoundType()==Interface)
2619 {
2620 ol.startMemberHeader("interfaces");
2621 }
2622 else if (compoundType()==Struct)
2623 {
2624 ol.startMemberHeader("structs");
2625 }
2626 else if (compoundType()==Exception)
2627 {
2628 ol.startMemberHeader("exceptions");
2629 }
2630 else // compoundType==Class
2631 {
2632 ol.startMemberHeader("nested-classes");
2633 }
2634 }
2635 else // non-Slice optimization: single header for class/struct/..
2636 {
2637 ol.startMemberHeader("nested-classes");
2638 }
2639 if (!header.isEmpty())
2640 {
2641 ol.parseText(header);
2642 }
2643 else if (lang==SrcLangExt::VHDL)
2644 {
2646 }
2647 else
2648 {
2649 ol.parseText(lang==SrcLangExt::Fortran ?
2650 theTranslator->trDataTypes() :
2651 theTranslator->trCompounds());
2652 }
2653 ol.endMemberHeader();
2654 ol.startMemberList();
2655 found=TRUE;
2656 }
2658 QCString ctype = compoundTypeString();
2659 QCString cname = displayName(!localNames);
2660 QCString anc = anchor();
2661 if (anc.isEmpty()) anc = cname; else anc.prepend(cname+"_");
2663
2664 if (lang!=SrcLangExt::VHDL) // for VHDL we swap the name and the type
2665 {
2666 if (isSliceLocal())
2667 {
2668 ol.writeString("local ");
2669 }
2670 ol.writeString(ctype);
2671 ol.writeString(" ");
2672 ol.insertMemberAlign();
2673 }
2674 if (isLinkable())
2675 {
2678 anchor(),
2679 cname
2680 );
2681 }
2682 else
2683 {
2684 ol.startBold();
2685 ol.docify(cname);
2686 ol.endBold();
2687 }
2688 if (lang==SrcLangExt::VHDL) // now write the type
2689 {
2690 ol.writeString(" ");
2691 ol.insertMemberAlign();
2693 }
2695
2696 // add the brief description if available
2697 if (!briefDescription().isEmpty() && Config_getBool(BRIEF_MEMBER_DESC))
2698 {
2699 auto parser { createDocParser() };
2700 auto ast { validatingParseDoc(*parser.get(),
2701 briefFile(),
2702 briefLine(),
2703 this,
2704 nullptr,
2706 DocOptions()
2707 .setSingleLine(true))
2708 };
2709 if (!ast->isEmpty())
2710 {
2712 ol.writeDoc(ast.get(),this,nullptr);
2713 if (isLinkableInProject())
2714 {
2715 writeMoreLink(ol,anchor());
2716 }
2718 }
2719 }
2721 }
2722}
2723
2725{
2726 StringVector sl;
2727 if (isFinal()) sl.emplace_back("final");
2728 if (isSealed()) sl.emplace_back("sealed");
2729 if (isAbstract()) sl.emplace_back("abstract");
2730 if (isExported()) sl.emplace_back("export");
2731 if (getLanguage()==SrcLangExt::IDL && isPublished()) sl.emplace_back("published");
2732
2733 for (const auto &sx : m_qualifiers)
2734 {
2735 bool alreadyAdded = std::find(sl.begin(), sl.end(), sx) != sl.end();
2736 if (!alreadyAdded)
2737 {
2738 sl.push_back(sx);
2739 }
2740 }
2741
2742 ol.pushGeneratorState();
2744 if (!sl.empty())
2745 {
2746 ol.startLabels();
2747 size_t i=0;
2748 for (const auto &s : sl)
2749 {
2750 i++;
2751 ol.writeLabel(s,i==sl.size());
2752 }
2753 ol.endLabels();
2754 }
2755 ol.popGeneratorState();
2756}
2757
2759{
2760 ol.startContents();
2761
2762 QCString pageType = " ";
2763 pageType += compoundTypeString();
2764
2765 bool exampleFlag=hasExamples();
2766
2767 //---------------------------------------- start flexible part -------------------------------
2768
2769 SrcLangExt lang = getLanguage();
2770
2771 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::Class))
2772 {
2773 switch (lde->kind())
2774 {
2775 case LayoutDocEntry::BriefDesc:
2776 writeBriefDescription(ol,exampleFlag);
2777 break;
2778 case LayoutDocEntry::ClassIncludes:
2779 if (lang==SrcLangExt::Slice)
2780 {
2782 }
2783 else
2784 {
2786 }
2787 break;
2788 case LayoutDocEntry::ClassInheritanceGraph:
2790 break;
2791 case LayoutDocEntry::ClassCollaborationGraph:
2793 break;
2794 case LayoutDocEntry::ClassAllMembersLink:
2795 //writeAllMembersLink(ol); // this is now part of the summary links
2796 break;
2797 case LayoutDocEntry::MemberDeclStart:
2799 break;
2800 case LayoutDocEntry::MemberGroups:
2802 break;
2803 case LayoutDocEntry::MemberDecl:
2804 {
2805 ClassDefSet visitedClasses;
2806 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
2807 if (lmd)
2808 {
2809 writeMemberDeclarations(ol,visitedClasses,lmd->type,lmd->title(lang),lmd->subtitle(lang));
2810 }
2811 }
2812 break;
2813 case LayoutDocEntry::ClassNestedClasses:
2814 {
2815 const LayoutDocEntrySection *ls = dynamic_cast<const LayoutDocEntrySection*>(lde.get());
2816 if (ls)
2817 {
2818 writeNestedClasses(ol,ls->title(lang));
2819 }
2820 }
2821 break;
2822 case LayoutDocEntry::MemberDeclEnd:
2824 break;
2825 case LayoutDocEntry::DetailedDesc:
2826 {
2827 const LayoutDocEntrySection *ls = dynamic_cast<const LayoutDocEntrySection*>(lde.get());
2828 if (ls)
2829 {
2830 writeDetailedDescription(ol,pageType,exampleFlag,ls->title(lang));
2831 }
2832 }
2833 break;
2834 case LayoutDocEntry::MemberDefStart:
2836 break;
2837 case LayoutDocEntry::ClassInlineClasses:
2839 break;
2840 case LayoutDocEntry::MemberDef:
2841 {
2842 const LayoutDocEntryMemberDef *lmd = dynamic_cast<const LayoutDocEntryMemberDef*>(lde.get());
2843 if (lmd)
2844 {
2845 writeMemberDocumentation(ol,lmd->type,lmd->title(lang));
2846 }
2847 }
2848 break;
2849 case LayoutDocEntry::MemberDefEnd:
2851 break;
2852 case LayoutDocEntry::ClassUsedFiles:
2853 showUsedFiles(ol);
2854 break;
2855 case LayoutDocEntry::AuthorSection:
2857 break;
2858 case LayoutDocEntry::NamespaceNestedNamespaces:
2859 case LayoutDocEntry::NamespaceNestedConstantGroups:
2860 case LayoutDocEntry::NamespaceClasses:
2861 case LayoutDocEntry::NamespaceConcepts:
2862 case LayoutDocEntry::NamespaceInterfaces:
2863 case LayoutDocEntry::NamespaceStructs:
2864 case LayoutDocEntry::NamespaceExceptions:
2865 case LayoutDocEntry::NamespaceInlineClasses:
2866 case LayoutDocEntry::ConceptDefinition:
2867 case LayoutDocEntry::FileClasses:
2868 case LayoutDocEntry::FileConcepts:
2869 case LayoutDocEntry::FileInterfaces:
2870 case LayoutDocEntry::FileStructs:
2871 case LayoutDocEntry::FileExceptions:
2872 case LayoutDocEntry::FileNamespaces:
2873 case LayoutDocEntry::FileConstantGroups:
2874 case LayoutDocEntry::FileIncludes:
2875 case LayoutDocEntry::FileIncludeGraph:
2876 case LayoutDocEntry::FileIncludedByGraph:
2877 case LayoutDocEntry::FileSourceLink:
2878 case LayoutDocEntry::FileInlineClasses:
2879 case LayoutDocEntry::GroupClasses:
2880 case LayoutDocEntry::GroupConcepts:
2881 case LayoutDocEntry::GroupModules:
2882 case LayoutDocEntry::GroupInlineClasses:
2883 case LayoutDocEntry::GroupNamespaces:
2884 case LayoutDocEntry::GroupDirs:
2885 case LayoutDocEntry::GroupNestedGroups:
2886 case LayoutDocEntry::GroupFiles:
2887 case LayoutDocEntry::GroupGraph:
2888 case LayoutDocEntry::GroupPageDocs:
2889 case LayoutDocEntry::ModuleExports:
2890 case LayoutDocEntry::ModuleClasses:
2891 case LayoutDocEntry::ModuleConcepts:
2892 case LayoutDocEntry::ModuleUsedFiles:
2893 case LayoutDocEntry::DirSubDirs:
2894 case LayoutDocEntry::DirFiles:
2895 case LayoutDocEntry::DirGraph:
2896 err("Internal inconsistency: member '{}' should not be part of LayoutDocManager::Class entry list\n",lde->entryToString());
2897 break;
2898 }
2899 }
2900
2901 ol.endContents();
2902}
2903
2905{
2906 QCString pageTitle;
2907 SrcLangExt lang = getLanguage();
2908
2909 auto getReferenceTitle = [this](std::function<QCString()> translateFunc) -> QCString
2910 {
2911 return Config_getBool(HIDE_COMPOUND_REFERENCE) ? displayName() : translateFunc();
2912 };
2913
2914 if (lang==SrcLangExt::Fortran)
2915 {
2916 pageTitle = getReferenceTitle([this](){
2917 return theTranslator->trCompoundReferenceFortran(displayName(), m_compType, !m_tempArgs.empty());
2918 });
2919 }
2920 else if (lang==SrcLangExt::Slice)
2921 {
2922 pageTitle = getReferenceTitle([this](){
2923 return theTranslator->trCompoundReferenceSlice(displayName(), m_compType, isSliceLocal());
2924 });
2925 }
2926 else if (lang==SrcLangExt::VHDL)
2927 {
2928 pageTitle = getReferenceTitle([this](){
2929 return theTranslator->trCustomReference(VhdlDocGen::getClassTitle(this));
2930 });
2931 }
2932 else if (lang==SrcLangExt::CSharp && !m_primaryConstructorParams.empty())
2933 {
2934 pageTitle = getReferenceTitle([this](){
2936 m_compType,
2937 !m_tempArgs.empty());
2938 });
2939 }
2940 else if (isJavaEnum())
2941 {
2942 pageTitle = getReferenceTitle([this](){
2943 return theTranslator->trEnumReference(displayName());
2944 });
2945 }
2946 else if (m_compType==Service)
2947 {
2948 pageTitle = getReferenceTitle([this](){
2949 return theTranslator->trServiceReference(displayName());
2950 });
2951 }
2952 else if (m_compType==Singleton)
2953 {
2954 pageTitle = getReferenceTitle([this](){
2955 return theTranslator->trSingletonReference(displayName());
2956 });
2957 }
2958 else
2959 {
2960 pageTitle = getReferenceTitle([this](){
2961 return theTranslator->trCompoundReference(displayName(),
2962 m_compType == Interface && getLanguage()==SrcLangExt::ObjC ? Class : m_compType,
2963 !m_tempArgs.empty());
2964 });
2965 }
2966 return pageTitle;
2967}
2968
2969// write all documentation for this class
2971{
2972 bool generateTreeView = Config_getBool(GENERATE_TREEVIEW);
2973 //bool fortranOpt = Config_getBool(OPTIMIZE_FOR_FORTRAN);
2974 //bool vhdlOpt = Config_getBool(OPTIMIZE_OUTPUT_VHDL);
2975 bool sliceOpt = Config_getBool(OPTIMIZE_OUTPUT_SLICE);
2976 QCString pageTitle = title();
2977
2979 if (sliceOpt)
2980 {
2981 if (compoundType()==Interface)
2982 {
2984 }
2985 else if (compoundType()==Struct)
2986 {
2988 }
2989 else if (compoundType()==Exception)
2990 {
2992 }
2993 else
2994 {
2996 }
2997 }
2998 else
2999 {
3001 }
3002
3003 AUTO_TRACE("name='{}' getOutputFileBase='{}'",name(),getOutputFileBase());
3004 bool hasAllMembersLink=false;
3005 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::Class))
3006 {
3007 if (lde->kind()==LayoutDocEntry::ClassAllMembersLink)
3008 {
3009 hasAllMembersLink = true;
3010 break;
3011 }
3012 }
3013 QCString memListFile;
3014 if (hasAllMembersLink && !m_allMemberNameInfoLinkedMap.empty() && !Config_getBool(OPTIMIZE_OUTPUT_FOR_C))
3015 {
3016 memListFile = getMemberListFileName();
3017 }
3018 startFile(ol,getOutputFileBase(),false,name(),pageTitle,hli,!generateTreeView,QCString(),0,memListFile);
3019 if (!generateTreeView)
3020 {
3022 {
3024 }
3025 ol.endQuickIndices();
3026 }
3027
3028 startTitle(ol,getOutputFileBase(),this);
3029 ol.parseText(pageTitle);
3031 addGroupListToTitle(ol,this);
3033 writeDocumentationContents(ol,pageTitle);
3034
3035 endFileWithNavPath(ol,this);
3036
3037 if (Config_getBool(SEPARATE_MEMBER_PAGES))
3038 {
3039 writeMemberPages(ol);
3040 }
3041}
3042
3044{
3045 ///////////////////////////////////////////////////////////////////////////
3046 //// Member definitions on separate pages
3047 ///////////////////////////////////////////////////////////////////////////
3048
3049 ol.pushGeneratorState();
3051
3052 for (const auto &ml : m_memberLists)
3053 {
3054 if (ml->numDocMembers()>ml->numDocEnumValues() && ml->listType().isDetailed())
3055 {
3056 ml->writeDocumentationPage(ol,displayName(),this);
3057 }
3058 }
3059
3060 ol.popGeneratorState();
3061}
3062
3064{
3065 bool createSubDirs=Config_getBool(CREATE_SUBDIRS);
3066
3067 ol.writeString(" <div class=\"navtab\">\n");
3068 ol.writeString(" <table>\n");
3069
3070 for (auto &mni : m_allMemberNameInfoLinkedMap)
3071 {
3072 for (auto &mi : *mni)
3073 {
3074 const MemberDef *md=mi->memberDef();
3075 if (md->getClassDef()==this && md->isLinkable() && !md->isEnumValue())
3076 {
3077 if (md->isLinkableInProject())
3078 {
3079 if (md==currentMd) // selected item => highlight
3080 {
3081 ol.writeString(" <tr><td class=\"navtabHL\">");
3082 }
3083 else
3084 {
3085 ol.writeString(" <tr><td class=\"navtab\">");
3086 }
3087 ol.writeString("<span class=\"label\"><a ");
3088 ol.writeString("href=\"");
3089 if (createSubDirs) ol.writeString("../../");
3090 QCString url = md->getOutputFileBase();
3092 ol.writeString(url+"#"+md->anchor());
3093 ol.writeString("\">");
3094 ol.writeString(convertToHtml(md->name()));
3095 ol.writeString("</a></span>");
3096 ol.writeString("</td></tr>\n");
3097 }
3098 }
3099 }
3100 }
3101
3102 ol.writeString(" </table>\n");
3103 ol.writeString(" </div>\n");
3104}
3105
3106
3107
3109{
3110 // write inner classes after the parent, so the tag files contain
3111 // the definition in proper order!
3112 for (const auto &innerCd : m_innerClasses)
3113 {
3114 if (
3115 innerCd->isLinkableInProject() && !innerCd->isImplicitTemplateInstance() &&
3116 protectionLevelVisible(innerCd->protection()) &&
3117 !innerCd->isEmbeddedInOuterScope()
3118 )
3119 {
3120 msg("Generating docs for nested compound {}...\n",innerCd->displayName());
3121 innerCd->writeDocumentation(ol);
3122 innerCd->writeMemberList(ol);
3123 }
3124 innerCd->writeDocumentationForInnerClasses(ol);
3125 }
3126}
3127
3128// write the list of all (inherited) members for this class
3130{
3131 bool cOpt = Config_getBool(OPTIMIZE_OUTPUT_FOR_C);
3132 //bool vhdlOpt = Config_getBool(OPTIMIZE_OUTPUT_VHDL);
3133 bool sliceOpt = Config_getBool(OPTIMIZE_OUTPUT_SLICE);
3134 bool generateTreeView = Config_getBool(GENERATE_TREEVIEW);
3135 if (m_allMemberNameInfoLinkedMap.empty() || cOpt) return;
3136 // only for HTML
3137 ol.pushGeneratorState();
3139
3141 if (sliceOpt)
3142 {
3143 if (compoundType()==Interface)
3144 {
3146 }
3147 else if (compoundType()==Struct)
3148 {
3150 }
3151 else if (compoundType()==Exception)
3152 {
3154 }
3155 else
3156 {
3158 }
3159 }
3160 else
3161 {
3163 }
3164
3165 QCString memListFile = getMemberListFileName();
3166 startFile(ol,memListFile,false,memListFile,theTranslator->trMemberList(),hli,!generateTreeView,getOutputFileBase());
3167 if (!generateTreeView)
3168 {
3170 {
3172 }
3173 ol.endQuickIndices();
3174 }
3175 startTitle(ol,QCString());
3176 ol.parseText(displayName()+" "+theTranslator->trMemberList());
3177 endTitle(ol,QCString(),QCString());
3178 ol.startContents();
3179 ol.startParagraph();
3180 ol.parseText(theTranslator->trThisIsTheListOfAllMembers());
3181 ol.docify(" ");
3183 ol.parseText(theTranslator->trIncludingInheritedMembers());
3184 ol.endParagraph();
3185
3186 //ol.startItemList();
3187
3188 bool first = true; // to prevent empty table
3189 int idx=0;
3190 for (auto &mni : m_allMemberNameInfoLinkedMap)
3191 {
3192 for (auto &mi : *mni)
3193 {
3194 const MemberDef *md=mi->memberDef();
3195 const ClassDef *cd=md->getClassDef();
3196 Protection prot = mi->prot();
3197 Specifier virt=md->virtualness();
3198
3199 //printf("%s: Member %s of class %s md->protection()=%d mi->prot=%d prot=%d inherited=%d\n",
3200 // qPrint(name()),qPrint(md->name()),qPrint(cd->name()),md->protection(),mi->prot,prot,mi->inherited);
3201
3202 if (cd && !md->name().isEmpty() && !md->isAnonymous())
3203 {
3204 bool memberWritten=FALSE;
3205 if (cd->isLinkable() && md->isLinkable())
3206 // create a link to the documentation
3207 {
3208 QCString name=mi->ambiguityResolutionScope()+md->name();
3209 //ol.writeListItem();
3210 if (first)
3211 {
3212 ol.writeString("<table class=\"directory\">\n");
3213 first = false;
3214 }
3215 ol.writeString(" <tr");
3216 if ((idx&1)==0) ol.writeString(" class=\"even\""); else ol.writeString(" class=\"odd\"");
3217 idx++;
3218 ol.writeString("><td class=\"entry\">");
3219 if (cd->isObjectiveC())
3220 {
3221 if (md->isObjCMethod())
3222 {
3223 if (md->isStatic())
3224 ol.writeString("+&#160;</td><td>");
3225 else
3226 ol.writeString("-&#160;</td><td>");
3227 }
3228 else
3229 ol.writeString("</td><td class=\"entry\">");
3230 }
3231 if (md->isObjCMethod())
3232 {
3234 md->getOutputFileBase(),
3235 md->anchor(),md->name());
3236 }
3237 else
3238 {
3239 //Definition *bd = md->getGroupDef();
3240 //if (bd==nullptr) bd=cd;
3242 md->getOutputFileBase(),
3243 md->anchor(),name);
3244
3245 if ( md->isFunction() || md->isSignal() || md->isSlot() ||
3246 (md->isFriend() && !md->argsString().isEmpty()))
3247 ol.docify(md->argsString());
3248 else if (md->isEnumerate())
3249 ol.parseText(" "+theTranslator->trEnumName());
3250 else if (md->isEnumValue())
3251 ol.parseText(" "+theTranslator->trEnumValue());
3252 else if (md->isTypedef())
3253 ol.docify(" typedef");
3254 else if (md->isFriend() && md->typeString()=="friend class")
3255 ol.docify(" class");
3256 //ol.writeString("\n");
3257 }
3258 ol.writeString("</td>");
3259 memberWritten=TRUE;
3260 }
3261 else if (!cd->isArtificial() &&
3262 !Config_getBool(HIDE_UNDOC_MEMBERS) &&
3264 ) // no documentation,
3265 // generate link to the class instead.
3266 {
3267 //ol.writeListItem();
3268 if (first)
3269 {
3270 ol.writeString("<table class=\"directory\">\n");
3271 first = false;
3272 }
3273 ol.writeString(" <tr bgcolor=\"#f0f0f0\"");
3274 if ((idx&1)==0) ol.writeString(" class=\"even\""); else ol.writeString(" class=\"odd\"");
3275 idx++;
3276 ol.writeString("><td class=\"entry\">");
3277 if (cd->isObjectiveC())
3278 {
3279 if (md->isObjCMethod())
3280 {
3281 if (md->isStatic())
3282 ol.writeString("+&#160;</td><td class=\"entry\">");
3283 else
3284 ol.writeString("-&#160;</td><td class=\"entry\">");
3285 }
3286 else
3287 ol.writeString("</td><td class=\"entry\">");
3288 }
3289 ol.startBold();
3290 ol.docify(md->name());
3291 ol.endBold();
3292 if (!md->isObjCMethod())
3293 {
3294 if ( md->isFunction() || md->isSignal() || md->isSlot() )
3295 ol.docify(md->argsString());
3296 else if (md->isEnumerate())
3297 ol.parseText(" "+theTranslator->trEnumName());
3298 else if (md->isEnumValue())
3299 ol.parseText(" "+theTranslator->trEnumValue());
3300 else if (md->isTypedef())
3301 ol.docify(" typedef");
3302 }
3303 ol.writeString(" (");
3304 ol.parseText(theTranslator->trDefinedIn()+" ");
3305 if (cd->isLinkable())
3306 {
3307 ol.writeObjectLink(
3308 cd->getReference(),
3309 cd->getOutputFileBase(),
3310 cd->anchor(),
3311 cd->displayName());
3312 }
3313 else
3314 {
3315 ol.startBold();
3316 ol.docify(cd->displayName());
3317 ol.endBold();
3318 }
3319 ol.writeString(")");
3320 ol.writeString("</td>");
3321 memberWritten=TRUE;
3322 }
3323 if (memberWritten)
3324 {
3325 ol.writeString("<td class=\"entry\">");
3327 cd->getOutputFileBase(),
3328 cd->anchor(),
3329 md->category() ?
3330 md->category()->displayName() :
3331 cd->displayName());
3332 ol.writeString("</td>");
3333 ol.writeString("<td class=\"entry\">");
3334 }
3335 SrcLangExt lang = md->getLanguage();
3336 if (
3337 (prot!=Protection::Public || (virt!=Specifier::Normal && getLanguage()!=SrcLangExt::ObjC) ||
3338 md->isFriend() || md->isRelated() || md->isExplicit() ||
3339 md->isMutable() || (md->isInline() && Config_getBool(INLINE_INFO)) ||
3340 md->isSignal() || md->isSlot() || md->isThreadLocal() ||
3341 (getLanguage()==SrcLangExt::IDL &&
3342 (md->isOptional() || md->isAttribute() || md->isUNOProperty())) ||
3343 md->isStatic() || lang==SrcLangExt::VHDL
3344 )
3345 && memberWritten)
3346 {
3347 StringVector sl;
3348 if (lang==SrcLangExt::VHDL)
3349 {
3350 sl.push_back(theTranslator->trVhdlType(md->getVhdlSpecifiers(),TRUE).str()); //append vhdl type
3351 }
3352 else if (md->isFriend()) sl.emplace_back("friend");
3353 else if (md->isRelated()) sl.emplace_back("related");
3354 else
3355 {
3356 if (Config_getBool(INLINE_INFO) && md->isInline())
3357 sl.emplace_back("inline");
3358 if (md->isExplicit()) sl.emplace_back("explicit");
3359 if (md->isMutable()) sl.emplace_back("mutable");
3360 if (md->isThreadLocal()) sl.emplace_back("thread_local");
3361 if (prot==Protection::Protected) sl.emplace_back("protected");
3362 else if (prot==Protection::Private) sl.emplace_back("private");
3363 else if (prot==Protection::Package) sl.emplace_back("package");
3364 if (virt==Specifier::Virtual && getLanguage()!=SrcLangExt::ObjC)
3365 sl.emplace_back("virtual");
3366 else if (virt==Specifier::Pure) sl.emplace_back("pure virtual");
3367 if (md->isStatic()) sl.emplace_back("static");
3368 if (md->isSignal()) sl.emplace_back("signal");
3369 if (md->isSlot()) sl.emplace_back("slot");
3370// this is the extra member page
3371 if (md->isOptional()) sl.emplace_back("optional");
3372 if (md->isAttribute()) sl.emplace_back("attribute");
3373 if (md->isUNOProperty()) sl.emplace_back("property");
3374 if (md->isReadonly()) sl.emplace_back("readonly");
3375 if (md->isBound()) sl.emplace_back("bound");
3376 if (md->isRemovable()) sl.emplace_back("removable");
3377 if (md->isConstrained()) sl.emplace_back("constrained");
3378 if (md->isTransient()) sl.emplace_back("transient");
3379 if (md->isMaybeVoid()) sl.emplace_back("maybevoid");
3380 if (md->isMaybeDefault()) sl.emplace_back("maybedefault");
3381 if (md->isMaybeAmbiguous()) sl.emplace_back("maybeambiguous");
3382 }
3383 bool firstSpan=true;
3384 for (const auto &s : sl)
3385 {
3386 if (!firstSpan)
3387 {
3388 ol.writeString("</span><span class=\"mlabel\">");
3389 }
3390 else
3391 {
3392 ol.writeString("<span class=\"mlabel\">");
3393 firstSpan=false;
3394 }
3395 ol.docify(s);
3396 }
3397 if (!firstSpan) ol.writeString("</span>");
3398 }
3399 if (memberWritten)
3400 {
3401 ol.writeString("</td>");
3402 ol.writeString("</tr>\n");
3403 }
3404 }
3405 }
3406 }
3407 //ol.endItemList();
3408
3409 if (!first) ol.writeString("</table>");
3410
3411 endFile(ol);
3412 ol.popGeneratorState();
3413}
3414
3415// add a reference to an example
3416bool ClassDefImpl::addExample(const QCString &anchor,const QCString &nameStr, const QCString &file)
3417{
3418 return m_examples.inSort(Example(anchor,nameStr,file));
3419}
3420
3421// returns TRUE if this class is used in an example
3423{
3424 return !m_examples.empty();
3425}
3426
3427void ClassDefImpl::addTypeConstraint(const QCString &typeConstraint,const QCString &type)
3428{
3429 //printf("addTypeConstraint(%s,%s)\n",qPrint(type),qPrint(typeConstraint));
3430 bool hideUndocRelation = Config_getBool(HIDE_UNDOC_RELATIONS);
3431 if (typeConstraint.isEmpty() || type.isEmpty()) return;
3432 SymbolResolver resolver(getFileDef());
3433 ClassDefMutable *cd = resolver.resolveClassMutable(this,typeConstraint);
3434 if (cd==nullptr && !hideUndocRelation)
3435 {
3436 cd = toClassDefMutable(
3437 Doxygen::hiddenClassLinkedMap->add(typeConstraint,
3438 std::unique_ptr<ClassDef>(
3439 new ClassDefImpl(
3441 getDefColumn(),
3442 typeConstraint,
3443 ClassDef::Class))));
3444 if (cd)
3445 {
3446 cd->setUsedOnly(TRUE);
3447 cd->setLanguage(getLanguage());
3448 //printf("Adding undocumented constraint '%s' to class %s on type %s\n",
3449 // qPrint(typeConstraint),qPrint(name()),qPrint(type));
3450 }
3451 }
3452 if (cd)
3453 {
3454 auto it = std::find_if(m_constraintClassList.begin(),
3456 [&cd](const auto &ccd) { return ccd.classDef==cd; });
3457
3458 if (it==m_constraintClassList.end())
3459 {
3460 m_constraintClassList.emplace_back(cd);
3461 it = m_constraintClassList.end()-1;
3462 }
3463 (*it).addAccessor(type);
3464 //printf("Adding constraint '%s' to class %s on type %s\n",
3465 // qPrint(typeConstraint),qPrint(name()),qPrint(type));
3466 }
3467}
3468
3469// Java Type Constrains: A<T extends C & I>
3471{
3472 for (const Argument &a : m_tempArgs)
3473 {
3474 if (!a.typeConstraint.isEmpty())
3475 {
3476 QCString typeConstraint;
3477 int i=0,p=0;
3478 while ((i=a.typeConstraint.find('&',p))!=-1) // typeConstraint="A &I" for C<T extends A & I>
3479 {
3480 typeConstraint = a.typeConstraint.mid(p,i-p).stripWhiteSpace();
3481 addTypeConstraint(typeConstraint,a.type);
3482 p=i+1;
3483 }
3484 typeConstraint = a.typeConstraint.right(a.typeConstraint.length()-p).stripWhiteSpace();
3485 addTypeConstraint(typeConstraint,a.type);
3486 }
3487 }
3488}
3489
3490// C# Type Constraints: D<T> where T : C, I
3495
3497{
3498 m_tempArgs = al;
3499}
3500
3501static bool hasNonReferenceSuperClassRec(const ClassDef *cd,int level)
3502{
3503 bool found=!cd->isReference() && cd->isLinkableInProject() && !cd->isHidden();
3504 if (found)
3505 {
3506 return TRUE; // we're done if this class is not a reference
3507 }
3508 for (const auto &ibcd : cd->subClasses())
3509 {
3510 const ClassDef *bcd=ibcd.classDef;
3511 if (level>256)
3512 {
3513 err("Possible recursive class relation while inside {} and looking for base class {}\n",cd->name(),bcd->name());
3514 return FALSE;
3515 }
3516 // recurse into the super class branch
3517 found = found || hasNonReferenceSuperClassRec(bcd,level+1);
3518 if (!found)
3519 {
3520 // look for template instances that might have non-reference super classes
3521 for (const auto &cil : bcd->getTemplateInstances())
3522 {
3523 // recurse into the template instance branch
3524 found = hasNonReferenceSuperClassRec(cil.classDef,level+1);
3525 if (found) break;
3526 }
3527 }
3528 else
3529 {
3530 break;
3531 }
3532 }
3533 return found;
3534}
3535
3536/*! Returns \c TRUE iff this class or a class inheriting from this class
3537 * is \e not defined in an external tag file.
3538 */
3540{
3541 return hasNonReferenceSuperClassRec(this,0);
3542}
3543
3548
3550{
3551 m_requiresClause = req;
3552}
3553
3558
3559/*! called from MemberDef::writeDeclaration() to (recursively) write the
3560 * definition of an anonymous struct, union or class.
3561 */
3562void ClassDefImpl::writeDeclaration(OutputList &ol,const MemberDef *md,bool inGroup,int indentLevel,
3563 const ClassDef *inheritedFrom,const QCString &inheritId) const
3564{
3565 //printf("ClassName='%s' inGroup=%d\n",qPrint(name()),inGroup);
3566
3569 if (!cn.isEmpty())
3570 {
3571 ol.docify(" ");
3572 if (md && isLinkable())
3573 {
3574 ol.writeObjectLink(QCString(),QCString(),md->anchor(),cn);
3575 }
3576 else
3577 {
3578 ol.startBold();
3579 ol.docify(cn);
3580 ol.endBold();
3581 }
3582 }
3583 ol.docify(" {");
3585 ol.endMemberDeclaration(md ? md->anchor() : QCString(),inheritId);
3586
3587 // write user defined member groups
3588 for (const auto &mg : m_memberGroups)
3589 {
3590 mg->writePlainDeclarations(ol,inGroup,this,nullptr,nullptr,nullptr,nullptr,indentLevel,inheritedFrom,inheritId);
3591 }
3592
3593 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::Class))
3594 {
3595 if (lde->kind()==LayoutDocEntry::MemberDecl)
3596 {
3597 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
3598 if (lmd)
3599 {
3600 writePlainMemberDeclaration(ol,lmd->type,inGroup,indentLevel,inheritedFrom,inheritId);
3601 }
3602 }
3603 }
3604}
3605
3606/*! a link to this class is possible within this project */
3608{
3609 bool extractLocal = Config_getBool(EXTRACT_LOCAL_CLASSES);
3610 bool extractStatic = Config_getBool(EXTRACT_STATIC);
3611 bool hideUndoc = Config_getBool(HIDE_UNDOC_CLASSES);
3613 {
3614 return m_templateMaster->isLinkableInProject();
3615 }
3616 else
3617 {
3618 //printf("%s::isLinkableInProject() conditions: artificial=%d hidden=%d anonymous=%d protection=%d local=%d docs=%d static=%d ref=%d\n",
3619 // qPrint(name()),
3620 // !isArtificial(),
3621 // !isHidden(),
3622 // !isAnonymous(),
3623 // m_prot,
3624 // !m_isLocal || extractLocal,
3625 // hasDocumentation() || m_tempArgs.hasTemplateDocumentation() || !hideUndoc,
3626 // !m_isStatic || extractStatic,
3627 // !isReference());
3628 return
3629 !isArtificial() && !isHidden() && /* not hidden */
3630 !isAnonymous() && /* not anonymous */
3631 protectionLevelVisible(m_prot) && /* private/internal */
3632 (!m_isLocal || extractLocal) && /* local */
3633 (hasDocumentation() || m_tempArgs.hasTemplateDocumentation() || !hideUndoc) && /* documented */
3634 (!m_isStatic || extractStatic) && /* static */
3635 !isReference(); /* not an external reference */
3636 }
3637}
3638
3640{
3642 {
3643 return m_templateMaster->isLinkable();
3644 }
3645 else
3646 {
3647 return isReference() || isLinkableInProject();
3648 }
3649}
3650
3651
3652/*! the class is visible in a class diagram, or class hierarchy */
3654{
3655 bool allExternals = Config_getBool(ALLEXTERNALS);
3656 bool hideUndocClasses = Config_getBool(HIDE_UNDOC_CLASSES);
3657 bool extractStatic = Config_getBool(EXTRACT_STATIC);
3658
3659 return // show all classes or a subclass is visible
3660 ((allExternals && !isArtificial()) || hasNonReferenceSuperClass()) &&
3661 // and not an anonymous compound
3662 !isAnonymous() &&
3663 // and not privately inherited
3665 // documented or shown anyway or documentation is external
3666 (hasDocumentation() ||
3667 !hideUndocClasses ||
3668 (m_templateMaster && m_templateMaster->hasDocumentation()) ||
3669 isReference()
3670 ) &&
3671 // if this is an implicit template instance then it most be part of the inheritance hierarchy
3672 (!m_implicitTemplateInstance || !m_inherits.empty() || !m_inheritedBy.empty()) &&
3673 // is not part of an unnamed namespace or shown anyway
3674 (!m_isStatic || extractStatic);
3675}
3676
3681
3682//----------------------------------------------------------------------
3683// recursive function:
3684// returns the distance to the base class definition 'bcd' represents an (in)direct base
3685// class of class definition 'cd' or nullptr if it does not.
3686
3687int ClassDefImpl::isBaseClass(const ClassDef *bcd, bool followInstances,const QCString &templSpec) const
3688{
3689 int distance=0;
3690 //printf("isBaseClass(cd=%s) looking for %s templSpec=%s\n",qPrint(name()),qPrint(bcd->name()),qPrint(templSpec));
3691 for (const auto &bclass : baseClasses())
3692 {
3693 const ClassDef *ccd = bclass.classDef;
3694 if (!followInstances && ccd->templateMaster())
3695 {
3696 ccd=ccd->templateMaster();
3697 }
3698 if (ccd==bcd && (templSpec.isEmpty() || templSpec==bclass.templSpecifiers))
3699 {
3700 distance=1;
3701 break; // no shorter path possible
3702 }
3703 else
3704 {
3705 int d = ccd->isBaseClass(bcd,followInstances,templSpec);
3706 if (d>256)
3707 {
3708 err("Possible recursive class relation while inside {} and looking for base class {}\n",name(),bcd->name());
3709 return 0;
3710 }
3711 else if (d>0) // path found
3712 {
3713 if (distance==0 || d+1<distance) // update if no path found yet or shorter path found
3714 {
3715 distance=d+1;
3716 }
3717 }
3718 }
3719 }
3720 return distance;
3721}
3722
3723//----------------------------------------------------------------------
3724
3725bool ClassDefImpl::isSubClass(ClassDef *cd,int level) const
3726{
3727 bool found=FALSE;
3728 if (level>256)
3729 {
3730 err("Possible recursive class relation while inside {} and looking for derived class {}\n",name(),cd->name());
3731 return FALSE;
3732 }
3733 for (const auto &iscd : subClasses())
3734 {
3735 ClassDef *ccd=iscd.classDef;
3736 found = (ccd==cd) || ccd->isSubClass(cd,level+1);
3737 if (found) break;
3738 }
3739 return found;
3740}
3741
3742//----------------------------------------------------------------------------
3743
3744static bool isStandardFunc(const MemberDef *md)
3745{
3746 return md->name()=="operator=" || // assignment operator
3747 md->isConstructor() || // constructor
3748 md->isDestructor(); // destructor
3749}
3750
3751void ClassDefImpl::mergeMembersFromBaseClasses(bool mergeVirtualBaseClass)
3752{
3753 SrcLangExt lang = getLanguage();
3755 size_t sepLen = sep.length();
3756 bool inlineInheritedMembers = Config_getBool(INLINE_INHERITED_MEMB);
3757 bool extractPrivate = Config_getBool(EXTRACT_PRIVATE);
3758
3759 //printf(" mergeMembers for %s mergeVirtualBaseClass=%d\n",qPrint(name()),mergeVirtualBaseClass);
3760 // the merge the base members with this class' members
3761 for (const auto &bcd : baseClasses())
3762 {
3763 ClassDefMutable *bClass=toClassDefMutable(bcd.classDef);
3764 if (bClass)
3765 {
3766 const MemberNameInfoLinkedMap &srcMnd = bClass->memberNameInfoLinkedMap();
3768
3769 for (auto &srcMni : srcMnd)
3770 {
3771 MemberNameInfo *dstMni=dstMnd.find(srcMni->memberName());
3772 if (dstMni)
3773 // a member with that name is already in the class.
3774 // the member may hide or reimplement the one in the sub class
3775 // or there may be another path to the base class that is already
3776 // visited via another branch in the class hierarchy.
3777 {
3778 //printf(" %s hides member name %s\n",qPrint(bClass->name()),qPrint(srcMni->memberName()));
3779 for (auto &srcMi : *srcMni)
3780 {
3781 MemberDef *srcMd = srcMi->memberDef();
3782 bool found=FALSE;
3783 bool ambiguous=FALSE;
3784 bool hidden=FALSE;
3785 const ClassDef *srcCd = srcMd->getClassDef();
3786 for (auto &dstMi : *dstMni)
3787 {
3788 const MemberDef *dstMd = dstMi->memberDef();
3789 if (srcMd!=dstMd) // different members
3790 {
3791 const ClassDef *dstCd = dstMd->getClassDef();
3792 //printf(" Is %s a base class of %s?\n",qPrint(srcCd->name()),qPrint(dstCd->name()));
3793 if (srcCd==dstCd || dstCd->isBaseClass(srcCd,TRUE))
3794 // member is in the same or a base class
3795 {
3796 const ArgumentList &srcAl = srcMd->argumentList();
3797 const ArgumentList &dstAl = dstMd->argumentList();
3798 found=matchArguments2(
3799 srcMd->getOuterScope(),srcMd->getFileDef(),srcMd->typeString(),&srcAl,
3800 dstMd->getOuterScope(),dstMd->getFileDef(),dstMd->typeString(),&dstAl,
3801 TRUE,lang
3802 );
3803 //printf(" Yes, matching (%s<->%s): %d\n",
3804 // qPrint(argListToString(srcMd->argumentList())),
3805 // qPrint(argListToString(dstMd->argumentList())),
3806 // found);
3807 hidden = hidden || !found;
3808 }
3809 else // member is in a non base class => multiple inheritance
3810 // using the same base class.
3811 {
3812 //printf(" $$ Existing member %s %s add scope %s\n",
3813 // qPrint(dstMi->ambiguityResolutionScope()),
3814 // qPrint(dstMd->name()),
3815 // qPrint(dstMi->scopePath().left(dstMi->scopePath().find("::")+2)));
3816
3817 QCString scope=dstMi->scopePath().left(dstMi->scopePath().find(sep)+sepLen);
3818 if (scope!=dstMi->ambiguityResolutionScope().left(scope.length()))
3819 {
3820 dstMi->setAmbiguityResolutionScope(scope+dstMi->ambiguityResolutionScope());
3821 }
3822 ambiguous=TRUE;
3823 }
3824 }
3825 else // same members
3826 {
3827 // do not add if base class is virtual or
3828 // if scope paths are equal or
3829 // if base class is an interface (and thus implicitly virtual).
3830 //printf(" same member found srcMi->virt=%d dstMi->virt=%d\n",srcMi->virt(),dstMi->virt());
3831 if ((srcMi->virt()!=Specifier::Normal && dstMi->virt()!=Specifier::Normal) ||
3832 bClass->name()+sep+srcMi->scopePath() == dstMi->scopePath() ||
3834 )
3835 {
3836 found=TRUE;
3837 }
3838 else // member can be reached via multiple paths in the
3839 // inheritance tree
3840 {
3841 //printf(" $$ Existing member %s %s add scope %s\n",
3842 // qPrint(dstMi->ambiguityResolutionScope()),
3843 // qPrint(dstMd->name()),
3844 // qPrint(dstMi->scopePath().left(dstMi->scopePath().find("::")+2)));
3845
3846 QCString scope=dstMi->scopePath().left(dstMi->scopePath().find(sep)+sepLen);
3847 if (scope!=dstMi->ambiguityResolutionScope().left(scope.length()))
3848 {
3849 dstMi->setAmbiguityResolutionScope(dstMi->ambiguityResolutionScope()+scope);
3850 }
3851 ambiguous=TRUE;
3852 }
3853 }
3854 if (found) break;
3855 }
3856 //printf(" member %s::%s hidden %d ambiguous %d srcMi->ambigClass=%p found=%d\n",
3857 // qPrint(srcCd->name()),qPrint(srcMd->name()),hidden,ambiguous,
3858 // (void*)srcMi->ambigClass(),found);
3859
3860 // TODO: fix the case where a member is hidden by inheritance
3861 // of a member with the same name but with another prototype,
3862 // while there is more than one path to the member in the
3863 // base class due to multiple inheritance. In this case
3864 // it seems that the member is not reachable by prefixing a
3865 // scope name either (according to my compiler). Currently,
3866 // this case is shown anyway.
3867 if (!found && srcMd->protection()!=Protection::Private && !srcMd->isFriend() &&
3868 srcMi->virtualBaseClass()==mergeVirtualBaseClass && lang!=SrcLangExt::Python)
3869 {
3870 Protection prot = srcMd->protection();
3871 if (bcd.prot==Protection::Protected && prot==Protection::Public)
3872 {
3873 prot = bcd.prot;
3874 }
3875 else if (bcd.prot==Protection::Private)
3876 {
3877 prot = bcd.prot;
3878 }
3879
3880 if (inlineInheritedMembers)
3881 {
3882 if (!isStandardFunc(srcMd))
3883 {
3884 //printf(" %s::insertMember(%s)\n",qPrint(name()),qPrint(srcMd->name()));
3885 internalInsertMember(srcMd,prot,FALSE);
3886 }
3887 }
3888
3889 Specifier virt=srcMi->virt();
3890 if (virt==Specifier::Normal && bcd.virt!=Specifier::Normal) virt=bcd.virt;
3891 bool virtualBaseClass = bcd.virt!=Specifier::Normal;
3892
3893 auto newMi = std::make_unique<MemberInfo>(srcMd,prot,virt,TRUE,virtualBaseClass);
3894 newMi->setScopePath(bClass->name()+sep+srcMi->scopePath());
3895 if (ambiguous)
3896 {
3897 //printf("$$ New member %s %s add scope %s::\n",
3898 // qPrint(srcMi->ambiguityResolutionScope),
3899 // qPrint(srcMd->name()),
3900 // qPrint(bClass->name()));
3901
3902 QCString scope=bClass->name()+sep;
3903 if (scope!=srcMi->ambiguityResolutionScope().left(scope.length()))
3904 {
3905 newMi->setAmbiguityResolutionScope(scope+srcMi->ambiguityResolutionScope());
3906 }
3907 }
3908 if (hidden)
3909 {
3910 if (srcMi->ambigClass()==nullptr)
3911 {
3912 newMi->setAmbigClass(bClass);
3913 newMi->setAmbiguityResolutionScope(bClass->name()+sep);
3914 }
3915 else
3916 {
3917 newMi->setAmbigClass(srcMi->ambigClass());
3918 newMi->setAmbiguityResolutionScope(srcMi->ambigClass()->name()+sep);
3919 }
3920 }
3921 dstMni->push_back(std::move(newMi));
3922 }
3923 }
3924 }
3925 else // base class has a member that is not in the sub class => copy
3926 {
3927 //printf(" %s adds member name %s\n",qPrint(bClass->name()),qPrint(srcMni->memberName()));
3928 // create a deep copy of the list (only the MemberInfo's will be
3929 // copied, not the actual MemberDef's)
3930 MemberNameInfo *newMni = dstMnd.add(srcMni->memberName());
3931
3932 // copy the member(s) from the base to the sub class
3933 for (auto &mi : *srcMni)
3934 {
3935 if (mi->virtualBaseClass()==mergeVirtualBaseClass && !mi->memberDef()->isFriend()) // don't inherit friends
3936 {
3937 Protection prot = mi->prot();
3938 if (bcd.prot==Protection::Protected)
3939 {
3940 if (prot==Protection::Public) prot=Protection::Protected;
3941 }
3942 else if (bcd.prot==Protection::Private)
3943 {
3944 prot=Protection::Private;
3945 }
3946 Specifier virt=mi->virt();
3947 bool virtualBaseClass = bcd.virt!=Specifier::Normal || mi->virtualBaseClass();
3948 if (virt==Specifier::Normal && bcd.virt!=Specifier::Normal) virt=bcd.virt;
3949 //printf(" %s::%s: [mi.prot=%d, bcd.prot=%d => prot=%d], [mi.virt=%d, bcd.virt=%d => virt=%d] virtualBase=%d\n",
3950 // qPrint(name()),qPrint(mi->memberDef()->name()),
3951 // mi->prot(),bcd.prot,prot,
3952 // mi->virt(),bcd.virt,virt,
3953 // virtualBaseClass
3954 // );
3955
3956 if (prot!=Protection::Private || extractPrivate)
3957 {
3958
3959 if (inlineInheritedMembers)
3960 {
3961 if (!isStandardFunc(mi->memberDef()))
3962 {
3963 //printf(" %s::insertMember '%s'\n",qPrint(name()),qPrint(mi->memberDef()->name()));
3964 internalInsertMember(mi->memberDef(),prot,FALSE);
3965 }
3966 }
3967 //printf("Adding!\n");
3968 std::unique_ptr<MemberInfo> newMi = std::make_unique<MemberInfo>(mi->memberDef(),prot,virt,TRUE,virtualBaseClass);
3969 newMi->setScopePath(bClass->name()+sep+mi->scopePath());
3970 newMi->setAmbigClass(mi->ambigClass());
3971 newMi->setAmbiguityResolutionScope(mi->ambiguityResolutionScope());
3972 newMni->push_back(std::move(newMi));
3973 }
3974 }
3975 }
3976 }
3977 }
3978 }
3979 }
3980}
3981
3982// See issue11260, referring to a variable in a base class will make doxygen
3983// add it as a member to the derived class, but this is not correct for non-private variables
3984// so we correct this here, now we know the inheritance hierarchy
3986{
3987 //printf("hideDerivedVariableInPython()\n");
3988 if (bClass)
3989 {
3990 const MemberNameInfoLinkedMap &srcMnd = bClass->memberNameInfoLinkedMap();
3992
3993 // recurse up the inheritance hierarchy
3994 for (const auto &bcd : bClass->baseClasses())
3995 {
3997 }
3998
3999 for (auto &srcMni : srcMnd) // for each member in a base class
4000 {
4001 //printf(" candidate(%s)\n",qPrint(srcMni->memberName()));
4002 MemberNameInfo *dstMni=dstMnd.find(srcMni->memberName());
4003 if (dstMni) // that is also in this class
4004 {
4006 //printf("%s member in %s and %s\n",qPrint(name()),qPrint(bClass->name()),qPrint(name()));
4007 for (it=dstMni->begin();it!=dstMni->end();)
4008 {
4009 MemberDefMutable *dstMd = toMemberDefMutable((*it)->memberDef());
4010 if (dstMd && dstMd->isVariable() && !dstMd->name().startsWith("__"))
4011 {
4012 //printf(" hiding member %s\n",qPrint(dstMd->name()));
4013 // hide a member variable if it is already defined in a base class, unless
4014 // it is a __private variable
4015 removeMemberFromLists(dstMd);
4016 it = dstMni->erase(it);
4017 }
4018 else
4019 {
4020 ++it;
4021 }
4022 }
4023 if (dstMni->empty()) // if the list has become empty, remove the entry from the dictionary
4024 {
4025 dstMnd.del(srcMni->memberName());
4026 }
4027 }
4028 }
4029 }
4030}
4031
4032/*!
4033 * recursively merges the 'all members' lists of a class base
4034 * with that of this class. Must only be called for classes without
4035 * subclasses!
4036 */
4038{
4039 if (m_membersMerged) return;
4040 if (getLanguage()==SrcLangExt::Python)
4041 {
4042 for (const auto &bcd : baseClasses())
4043 {
4044 ClassDefMutable *bClass=toClassDefMutable(bcd.classDef);
4046 }
4047 }
4048
4049 //printf("> %s::mergeMembers()\n",qPrint(name()));
4050
4052
4053 // first merge the members of the base class recursively
4054 for (const auto &bcd : baseClasses())
4055 {
4056 ClassDefMutable *bClass=toClassDefMutable(bcd.classDef);
4057 if (bClass)
4058 {
4059 // merge the members in the base class of this inheritance branch first
4060 bClass->mergeMembers();
4061 }
4062 }
4063
4064 // first merge the member that are not inherited via a virtual base class
4065 // (as this can end up reimplemented via multiple paths, see #10717 for examples)
4067 // then process the member that are inherited via a virtual base class to add the
4068 // ones that are not reimplemented via any path
4070
4071 //printf("< %s::mergeMembers()\n",qPrint(name()));
4072}
4073
4074//----------------------------------------------------------------------------
4075
4076/*! Merges the members of a Objective-C category into this class.
4077 */
4079{
4080 AUTO_TRACE();
4081 ClassDefMutable *category = toClassDefMutable(cat);
4082 if (category)
4083 {
4084 bool extractLocalMethods = Config_getBool(EXTRACT_LOCAL_METHODS);
4085 bool makePrivate = category->isLocal();
4086 // in case extract local methods is not enabled we don't add the methods
4087 // of the category in case it is defined in the .m file.
4088 if (makePrivate && !extractLocalMethods) return;
4089 bool isExtension = category->isExtension();
4090
4091 category->setCategoryOf(this);
4092 if (isExtension)
4093 {
4094 category->setArtificial(TRUE);
4095
4096 // copy base classes/protocols from extension
4097 for (const auto &bcd : category->baseClasses())
4098 {
4099 insertBaseClass(bcd.classDef,bcd.usedName,bcd.prot,bcd.virt,bcd.templSpecifiers);
4100 // correct bcd.classDef so that they do no longer derive from
4101 // category, but from this class!
4102 BaseClassList scl = bcd.classDef->subClasses();
4103 for (auto &scd : scl)
4104 {
4105 if (scd.classDef==category)
4106 {
4107 scd.classDef=this;
4108 }
4109 }
4110 bcd.classDef->updateSubClasses(scl);
4111 }
4112 }
4113 // make methods private for categories defined in the .m file
4114 //printf("%s::mergeCategory makePrivate=%d\n",qPrint(name()),makePrivate);
4115
4116 const MemberNameInfoLinkedMap &srcMnd = category->memberNameInfoLinkedMap();
4118
4119 for (auto &srcMni : srcMnd)
4120 {
4121 MemberNameInfo *dstMni=dstMnd.find(srcMni->memberName());
4122 if (dstMni) // method is already defined in the class
4123 {
4124 AUTO_TRACE_ADD("Existing member {}",srcMni->memberName());
4125 const auto &dstMi = dstMni->front();
4126 const auto &srcMi = srcMni->front();
4127 if (srcMi && dstMi)
4128 {
4129 MemberDefMutable *smdm = toMemberDefMutable(srcMi->memberDef());
4130 MemberDefMutable *dmdm = toMemberDefMutable(dstMi->memberDef());
4131 if (smdm && dmdm)
4132 {
4134 dmdm->setCategory(category);
4135 dmdm->setCategoryRelation(smdm);
4136 smdm->setCategoryRelation(dmdm);
4137 }
4138 }
4139 }
4140 else // new method name
4141 {
4142 AUTO_TRACE_ADD("New member {}",srcMni->memberName());
4143 // create a deep copy of the list
4144 MemberNameInfo *newMni = dstMnd.add(srcMni->memberName());
4145
4146 // copy the member(s) from the category to this class
4147 for (auto &mi : *srcMni)
4148 {
4149 //printf("Adding '%s'\n",qPrint(mi->memberDef->name()));
4150 Protection prot = mi->prot();
4151 //if (makePrivate) prot = Private;
4152 auto newMd = mi->memberDef()->deepCopy();
4153 if (newMd)
4154 {
4155 auto mmd = toMemberDefMutable(newMd.get());
4156 AUTO_TRACE_ADD("Copying member {}",mmd->name());
4157 mmd->moveTo(this);
4158
4159 auto newMi=std::make_unique<MemberInfo>(newMd.get(),prot,mi->virt(),mi->inherited(),mi->virtualBaseClass());
4160 newMi->setScopePath(mi->scopePath());
4161 newMi->setAmbigClass(mi->ambigClass());
4162 newMi->setAmbiguityResolutionScope(mi->ambiguityResolutionScope());
4163 newMni->push_back(std::move(newMi));
4164
4165 // also add the newly created member to the global members list
4166
4167 QCString name = newMd->name();
4169
4170 mmd->setCategory(category);
4171 mmd->setCategoryRelation(mi->memberDef());
4172 auto miMmd = toMemberDefMutable(mi->memberDef());
4173 if (miMmd) miMmd->setCategoryRelation(newMd.get());
4174
4175 if (makePrivate || isExtension)
4176 {
4177 mmd->makeImplementationDetail();
4178 }
4179 internalInsertMember(newMd.get(),prot,FALSE);
4180 mn->push_back(std::move(newMd));
4181 }
4182 }
4183 }
4184 }
4185 }
4186}
4187
4188//----------------------------------------------------------------------------
4189
4191 Protection prot)
4192{
4193 bool extractPrivate = Config_getBool(EXTRACT_PRIVATE);
4194 bool umlLook = Config_getBool(UML_LOOK);
4195 if (prot==Protection::Private && !extractPrivate) return;
4196 //printf("%s::addUsedClass(%s,%s)\n",qPrint(name()),qPrint(cd->name()),accessName);
4197
4198 auto it = std::find_if(m_usesImplClassList.begin(),
4199 m_usesImplClassList.end(),
4200 [&cd](const auto &ucd) { return ucd.classDef==cd; });
4201 if (it==m_usesImplClassList.end())
4202 {
4203 m_usesImplClassList.emplace_back(cd);
4204 //printf("Adding used class %s to class %s via accessor %s\n",
4205 // qPrint(cd->name()),qPrint(name()),accessName);
4206 it = m_usesImplClassList.end()-1;
4207 }
4208 QCString acc = accessName;
4209 if (umlLook)
4210 {
4211 switch(prot)
4212 {
4213 case Protection::Public: acc.prepend("+"); break;
4214 case Protection::Private: acc.prepend("-"); break;
4215 case Protection::Protected: acc.prepend("#"); break;
4216 case Protection::Package: acc.prepend("~"); break;
4217 }
4218 }
4219 (*it).addAccessor(acc);
4220}
4221
4223 Protection prot)
4224{
4225 bool extractPrivate = Config_getBool(EXTRACT_PRIVATE);
4226 bool umlLook = Config_getBool(UML_LOOK);
4227 if (prot==Protection::Private && !extractPrivate) return;
4228 //printf("%s::addUsedByClass(%s,%s)\n",qPrint(name()),qPrint(cd->name()),accessName);
4229 //
4230 auto it = std::find_if(m_usedByImplClassList.begin(),
4232 [&cd](const auto &ucd) { return ucd.classDef==cd; });
4233 if (it==m_usedByImplClassList.end())
4234 {
4235 m_usedByImplClassList.emplace_back(cd);
4236 //printf("Adding used by class %s to class %s\n",
4237 // qPrint(cd->name()),qPrint(name()));
4238 it = m_usedByImplClassList.end()-1;
4239 }
4240 QCString acc = accessName;
4241 if (umlLook)
4242 {
4243 switch(prot)
4244 {
4245 case Protection::Public: acc.prepend("+"); break;
4246 case Protection::Private: acc.prepend("-"); break;
4247 case Protection::Protected: acc.prepend("#"); break;
4248 case Protection::Package: acc.prepend("~"); break;
4249 }
4250 }
4251 (*it).addAccessor(acc);
4252}
4253
4254
4259
4261{
4262 bool inlineGroupedClasses = Config_getBool(INLINE_GROUPED_CLASSES);
4263 bool inlineSimpleClasses = Config_getBool(INLINE_SIMPLE_STRUCTS);
4265 {
4266 Definition *scope=nullptr;
4267 if (inlineGroupedClasses && !partOfGroups().empty())
4268 {
4269 // point to the group that embeds this class
4270 return partOfGroups().front()->getOutputFileBase();
4271 }
4272 else if (inlineSimpleClasses && m_isSimple && !partOfGroups().empty())
4273 {
4274 // point to simple struct inside a group
4275 return partOfGroups().front()->getOutputFileBase();
4276 }
4277 else if (inlineSimpleClasses && m_isSimple && (scope=getOuterScope()))
4278 {
4279 if (scope==Doxygen::globalScope && getFileDef() && getFileDef()->isLinkableInProject()) // simple struct embedded in file
4280 {
4281 return getFileDef()->getOutputFileBase();
4282 }
4283 else if (scope->isLinkableInProject()) // simple struct embedded in other container (namespace/group/class)
4284 {
4285 return getOuterScope()->getOutputFileBase();
4286 }
4287 }
4288 }
4289 AUTO_TRACE("name='{}' m_templateMaster={} m_implicitTemplateInstance={}",name(),(void*)m_templateMaster,m_implicitTemplateInstance);
4291 {
4292 // point to the template of which this class is an instance
4293 return m_templateMaster->getOutputFileBase();
4294 }
4295 return m_fileName;
4296}
4297
4302
4304{
4306 {
4307 return m_templateMaster->getSourceFileBase();
4308 }
4309 else
4310 {
4312 }
4313}
4314
4315void ClassDefImpl::setGroupDefForAllMembers(GroupDef *gd,Grouping::GroupPri_t pri,const QCString &fileName,int startLine,bool hasDocs)
4316{
4317 gd->addClass(this);
4318 //printf("ClassDefImpl::setGroupDefForAllMembers(%s)\n",qPrint(gd->name()));
4319 for (auto &mni : m_allMemberNameInfoLinkedMap)
4320 {
4321 for (auto &mi : *mni)
4322 {
4323 MemberDefMutable *md = toMemberDefMutable(mi->memberDef());
4324 if (md)
4325 {
4326 md->setGroupDef(gd,pri,fileName,startLine,hasDocs);
4327 gd->insertMember(md,TRUE);
4329 if (innerClass) innerClass->setGroupDefForAllMembers(gd,pri,fileName,startLine,hasDocs);
4330 }
4331 }
4332 }
4333}
4334
4336{
4337 //printf("**** %s::addInnerCompound(%s)\n",qPrint(name()),qPrint(d->name()));
4338 if (d->definitionType()==Definition::TypeClass) // only classes can be
4339 // nested in classes.
4340 {
4341 m_innerClasses.add(d->localName(),toClassDef(d));
4342 }
4343}
4344
4346{
4347 return m_innerClasses.find(name);
4348}
4349
4351 int startLine, int startColumn, const QCString &templSpec,bool &freshInstance)
4352{
4353 freshInstance = FALSE;
4354 auto it = std::find_if(m_templateInstances.begin(),
4355 m_templateInstances.end(),
4356 [&templSpec](const auto &ti) { return templSpec==ti.templSpec; });
4357 ClassDefMutable *templateClass=nullptr;
4358 if (it!=m_templateInstances.end())
4359 {
4360 templateClass = toClassDefMutable((*it).classDef);
4361 }
4362 if (templateClass==nullptr)
4363 {
4364 QCString tcname = removeRedundantWhiteSpace(name()+templSpec);
4365 AUTO_TRACE("New template instance class name='{}' templSpec='{}' inside '{}' hidden={}",
4366 name(),templSpec,name(),isHidden());
4367
4368 ClassDef *foundCd = Doxygen::classLinkedMap->find(tcname);
4369 if (foundCd)
4370 {
4371 return foundCd;
4372 }
4373 templateClass =
4375 Doxygen::classLinkedMap->add(tcname,
4376 std::unique_ptr<ClassDef>(
4377 new ClassDefImpl(fileName,startLine,startColumn,tcname,ClassDef::Class))));
4378 if (templateClass)
4379 {
4380 templateClass->setTemplateMaster(this);
4381 ArgumentList tal = *stringToArgumentList(getLanguage(),templSpec);
4382 templateClass->setTemplateArguments(tal);
4383 templateClass->setOuterScope(getOuterScope());
4384 templateClass->setHidden(isHidden());
4385 templateClass->setArtificial(isArtificial());
4386 templateClass->setImplicitTemplateInstance(true);
4387 m_templateInstances.emplace_back(templSpec,templateClass);
4388
4389 // also add nested classes
4390 for (const auto &innerCd : m_innerClasses)
4391 {
4392 QCString innerName = tcname+"::"+innerCd->localName();
4393 ClassDefMutable *innerClass =
4395 Doxygen::classLinkedMap->add(innerName,
4396 std::unique_ptr<ClassDef>(
4397 new ClassDefImpl(fileName,startLine,startColumn,innerName,ClassDef::Class))));
4398 if (innerClass)
4399 {
4400 templateClass->addInnerCompound(innerClass);
4401 innerClass->setOuterScope(templateClass);
4402 innerClass->setHidden(isHidden());
4403 innerClass->setArtificial(TRUE);
4404 innerClass->setImplicitTemplateInstance(true);
4405 }
4406 }
4407 freshInstance=TRUE;
4408 }
4409 }
4410 return templateClass;
4411}
4412
4414{
4415 AUTO_TRACE("this={} cd={} templSpec={}",name(),templateClass->name(),templSpec);
4416 m_templateInstances.emplace_back(templSpec,templateClass);
4417}
4418
4420{
4421 m_templBaseClassNames = templateNames;
4422}
4423
4428
4431 const QCString &templSpec)
4432{
4433 AUTO_TRACE("this={} md={}",name(),md->name());
4434 auto actualArguments_p = stringToArgumentList(getLanguage(),templSpec);
4435 auto imd = md->createTemplateInstanceMember(templateArguments,actualArguments_p);
4436 auto mmd = toMemberDefMutable(imd.get());
4437 mmd->setMemberClass(this);
4438 mmd->setTemplateMaster(md);
4439 mmd->setDocumentation(md->documentation(),md->docFile(),md->docLine());
4440 mmd->setBriefDescription(md->briefDescription(),md->briefFile(),md->briefLine());
4441 mmd->setInbodyDocumentation(md->inbodyDocumentation(),md->inbodyFile(),md->inbodyLine());
4442 mmd->setMemberSpecifiers(md->getMemberSpecifiers());
4443 mmd->setMemberGroupId(md->getMemberGroupId());
4444 mmd->setArtificial(true);
4445 insertMember(imd.get());
4446 //printf("Adding member=%s %s%s to class %s templSpec %s\n",
4447 // imd->typeString(),qPrint(imd->name()),imd->argsString(),
4448 // qPrint(imd->getClassDef()->name()),templSpec);
4449 // insert imd in the list of all members
4450 //printf("Adding member=%s class=%s\n",qPrint(imd->name()),qPrint(name()));
4451 MemberName *mn = Doxygen::memberNameLinkedMap->add(imd->name());
4452 mn->push_back(std::move(imd));
4453}
4454
4456{
4457 AUTO_TRACE("this={} cd={} templSpec={}",name(),cd->name(),templSpec);
4458 //printf("%s::addMembersToTemplateInstance(%s,%s)\n",qPrint(name()),qPrint(cd->name()),templSpec);
4459 for (const auto &mni : cd->memberNameInfoLinkedMap())
4460 {
4461 for (const auto &mi : *mni)
4462 {
4463 const MemberDef *md = mi->memberDef();
4464 if (m_allMemberNameInfoLinkedMap.find(md->name())==nullptr) // only insert the member if not hidden by one with the same name (#11541)
4465 {
4467 }
4468 }
4469 }
4470 // also instantatie members for nested classes
4471 for (const auto &innerCd : cd->getClasses())
4472 {
4473 ClassDefMutable *ncd = toClassDefMutable(m_innerClasses.find(innerCd->localName()));
4474 if (ncd)
4475 {
4476 ncd->addMembersToTemplateInstance(innerCd,cd->templateArguments(),templSpec);
4477 }
4478 }
4479}
4480
4482{
4484 {
4485 return m_templateMaster->getReference();
4486 }
4487 else
4488 {
4490 }
4491}
4492
4494{
4496 {
4497 return m_templateMaster->isReference();
4498 }
4499 else
4500 {
4502 }
4503}
4504
4506{
4507 ArgumentLists result;
4509 while (d && d->definitionType()==Definition::TypeClass)
4510 {
4511 result.insert(result.begin(),toClassDef(d)->templateArguments());
4512 d = d->getOuterScope();
4513 }
4514 if (!templateArguments().empty())
4515 {
4516 result.push_back(templateArguments());
4517 }
4518 return result;
4519}
4520
4522 const ArgumentLists *actualParams,uint32_t *actualParamIndex) const
4523{
4524 return makeQualifiedNameWithTemplateParameters(this,actualParams,actualParamIndex);
4525}
4526
4528{
4529 QCString name = m_className.isEmpty() ? localName() : m_className;
4530 auto lang = getLanguage();
4531 if (lang==SrcLangExt::CSharp)
4532 {
4534 }
4535 return name;
4536}
4537
4542
4544{
4545 if (!isLinkableInProject()) return;
4546 SrcLangExt lang = getLanguage();
4548 qualifiedName(),
4549 theTranslator->trCompoundType(compoundType(), lang),
4551 displayName(),
4552 QCString(),
4553 this
4554 );
4555 for (const auto &mg : m_memberGroups)
4556 {
4557 mg->addListReferences(this);
4558 }
4559 for (auto &ml : m_memberLists)
4560 {
4561 if (ml->listType().isDetailed())
4562 {
4563 ml->addListReferences(this);
4564 }
4565 }
4566}
4567
4569{
4570 if (!isLinkableInProject()) return;
4572 for (const auto &mg : m_memberGroups)
4573 {
4574 mg->addRequirementReferences(this);
4575 }
4576 for (auto &ml : m_memberLists)
4577 {
4578 if (ml->listType().isDetailed())
4579 {
4580 ml->addRequirementReferences(this);
4581 }
4582 }
4583}
4584
4586{
4587 const MemberDef *xmd = nullptr;
4589 if (mni)
4590 {
4591 const int maxInheritanceDepth = 100000;
4592 int mdist=maxInheritanceDepth;
4593 for (auto &mi : *mni)
4594 {
4595 const ClassDef *mcd=mi->memberDef()->getClassDef();
4596 int m=minClassDistance(this,mcd);
4597 //printf("found member in %s linkable=%d m=%d\n",
4598 // qPrint(mcd->name()),mcd->isLinkable(),m);
4599 if (m<mdist)
4600 {
4601 mdist=m;
4602 xmd=mi->memberDef();
4603 }
4604 }
4605 }
4606 //printf("getMemberByName(%s)=%p\n",qPrint(name),xmd);
4607 return xmd;
4608}
4609
4611{
4612 return md->getClassDef() && isBaseClass(md->getClassDef(),TRUE,QCString());
4613}
4614
4616{
4617 for (auto &ml : m_memberLists)
4618 {
4619 if (ml->listType()==lt)
4620 {
4621 return ml.get();
4622 }
4623 }
4624 return nullptr;
4625}
4626
4628{
4629 AUTO_TRACE("{} md={} lt={} isBrief={}",name(),md->name(),lt,isBrief);
4630 bool sortBriefDocs = Config_getBool(SORT_BRIEF_DOCS);
4631 bool sortMemberDocs = Config_getBool(SORT_MEMBER_DOCS);
4632 const auto &ml = m_memberLists.get(lt,MemberListContainer::Class);
4633 ml->setNeedsSorting((isBrief && sortBriefDocs) || (!isBrief && sortMemberDocs));
4634 ml->push_back(md);
4635
4636 // for members in the declaration lists we set the section, needed for member grouping
4637 if (!ml->listType().isDetailed())
4638 {
4640 if (mdm)
4641 {
4642 mdm->setSectionList(this,ml.get());
4643 }
4644 }
4645}
4646
4648{
4649 for (auto &ml : m_memberLists)
4650 {
4651 if (ml->needsSorting()) { ml->sort(); ml->setNeedsSorting(FALSE); }
4652 }
4653 if (Config_getBool(SORT_BRIEF_DOCS))
4654 {
4655 std::stable_sort(m_innerClasses.begin(),
4656 m_innerClasses.end(),
4657 [](const auto &c1,const auto &c2)
4658 {
4659 return Config_getBool(SORT_BY_SCOPE_NAME) ?
4660 qstricmp_sort(c1->name(), c2->name() )<0 :
4661 qstricmp_sort(c1->className(), c2->className())<0 ;
4662 });
4663 }
4664}
4665
4667 MemberListType lt2,bool invert,bool showAlways,ClassDefSet &visitedClasses) const
4668{
4669 //printf("%s: countMemberDeclarations for %s and %s\n",qPrint(name()),lt.to_string(),lt2.to_string());
4670 int count=0;
4671 MemberList * ml = getMemberList(lt);
4672 MemberList * ml2 = getMemberList(lt2);
4673 if (getLanguage()!=SrcLangExt::VHDL) // use specific declarations function
4674 {
4675 if (ml)
4676 {
4677 count+=ml->numDecMembers(inheritedFrom);
4678 //printf("-> ml=%d\n",ml->numDecMembers());
4679 }
4680 if (ml2)
4681 {
4682 count+=ml2->numDecMembers(inheritedFrom);
4683 //printf("-> ml2=%d\n",ml2->numDecMembers());
4684 }
4685 // also include grouped members that have their own section in the class (see bug 722759)
4686 if (inheritedFrom)
4687 {
4688 for (const auto &mg : m_memberGroups)
4689 {
4690 count+=mg->countGroupedInheritedMembers(lt);
4691 if (!lt2.isInvalid()) count+=mg->countGroupedInheritedMembers(lt2);
4692 }
4693 }
4694 bool inlineInheritedMembers = Config_getBool(INLINE_INHERITED_MEMB);
4695 if (!inlineInheritedMembers) // show inherited members as separate lists
4696 {
4697 count+=countInheritedDecMembers(lt,inheritedFrom,invert,showAlways,visitedClasses);
4698 }
4699 }
4700 //printf("-> %d\n",count);
4701 return count;
4702}
4703
4705{
4706 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::Class))
4707 {
4708 if (lde->kind()==LayoutDocEntry::MemberDecl)
4709 {
4710 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
4711 if (lmd)
4712 {
4713 MemberList * ml = getMemberList(lmd->type);
4714 if (ml)
4715 {
4717 }
4718 }
4719 }
4720 else if (lde->kind()==LayoutDocEntry::MemberGroups)
4721 {
4722 for (const auto &mg : m_memberGroups)
4723 {
4724 mg->setAnonymousEnumType();
4725 }
4726 }
4727 }
4728}
4729
4731{
4732 for (auto &ml : m_memberLists)
4733 {
4734 ml->countDecMembers();
4735 ml->countDocMembers();
4736 }
4737 for (const auto &mg : m_memberGroups)
4738 {
4739 mg->countDecMembers();
4740 mg->countDocMembers();
4741 }
4742}
4743
4745 const ClassDef *inheritedFrom,bool invert,bool showAlways,
4746 ClassDefSet &visitedClasses) const
4747{
4748 int inhCount = 0;
4749 int count = countMembersIncludingGrouped(lt,inheritedFrom,FALSE);
4750 bool process = count>0;
4751 //printf("%s: countInheritedDecMembers: lt=%s process=%d count=%d invert=%d\n",
4752 // qPrint(name()),lt.to_string(),process,count,invert);
4753 if ((process^invert) || showAlways)
4754 {
4755 for (const auto &ibcd : m_inherits)
4756 {
4757 ClassDefMutable *icd = toClassDefMutable(ibcd.classDef);
4760 if (icd && icd->isLinkable())
4761 {
4762 convertProtectionLevel(lt,ibcd.prot,&lt1,&lt2);
4763 //printf("%s: convert %s->(%s,%s) prot=%d\n",
4764 // qPrint(icd->name()),lt.to_string(),lt1.to_string(),lt2.to_string(),ibcd.prot);
4765 if (visitedClasses.find(icd)==visitedClasses.end())
4766 {
4767 visitedClasses.insert(icd); // guard for multiple virtual inheritance
4768 if (!lt1.isInvalid())
4769 {
4770 inhCount+=icd->countMemberDeclarations(lt1,inheritedFrom,lt2,FALSE,TRUE,visitedClasses);
4771 }
4772 }
4773 }
4774 }
4775 }
4776 //printf("%s: count=%d\n",qPrint(name()),inhCount);
4777 return inhCount;
4778}
4779
4781 QCString &title,QCString &subtitle) const
4782{
4783 SrcLangExt lang = getLanguage();
4784 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::Class))
4785 {
4786 if (lde->kind()==LayoutDocEntry::MemberDecl)
4787 {
4788 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
4789 if (lmd && lmd->type==type)
4790 {
4791 title = lmd->title(lang);
4792 subtitle = lmd->subtitle(lang);
4793 return;
4794 }
4795 }
4796 }
4797 title="";
4798 subtitle="";
4799}
4800
4802{
4803 int totalCount=0;
4804 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::Class))
4805 {
4806 if (lde->kind()==LayoutDocEntry::MemberDecl)
4807 {
4808 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
4809 if (lmd && lmd->type!=MemberListType::Friends()) // friendship is not inherited
4810 {
4811 ClassDefSet visited;
4812 totalCount+=countInheritedDecMembers(lmd->type,this,TRUE,FALSE,visited);
4813 }
4814 }
4815 }
4816 //printf("countAdditionalInheritedMembers()=%d\n",totalCount);
4817 return totalCount;
4818}
4819
4821{
4822 //printf("**** writeAdditionalInheritedMembers()\n");
4823 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::Class))
4824 {
4825 if (lde->kind()==LayoutDocEntry::MemberDecl)
4826 {
4827 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
4828 if (lmd && lmd->type!=MemberListType::Friends())
4829 {
4830 ClassDefSet visited;
4832 }
4833 }
4834 }
4835}
4836
4838 const ClassDef *inheritedFrom,bool additional) const
4839{
4840 int count=0;
4841 MemberList *ml = getMemberList(lt);
4842 if (ml)
4843 {
4844 count=ml->countInheritableMembers(inheritedFrom);
4845 }
4846 //printf("%s:countMembersIncludingGrouped: count=%d\n",qPrint(name()),count);
4847 for (const auto &mg : m_memberGroups)
4848 {
4849 bool hasOwnSection = !mg->allMembersInSameSection() ||
4850 !m_subGrouping; // group is in its own section
4851 if ((additional && hasOwnSection) || (!additional && !hasOwnSection))
4852 {
4853 count+=mg->countGroupedInheritedMembers(lt);
4854 }
4855 }
4856 //printf("%s:countMembersIncludingGrouped(lt=%s,%s)=%d\n",
4857 // qPrint(name()),qPrint(lt.to_string()),ml?qPrint(ml->listType().to_string()):"<none>",count);
4858 return count;
4859}
4860
4861
4864 const ClassDef *inheritedFrom,bool invert,bool showAlways) const
4865{
4866 int count = countMembersIncludingGrouped(lt,inheritedFrom,FALSE);
4867 bool process = count>0;
4868 //printf("%s: writeInheritedMemberDec: lt=%s process=%d invert=%d always=%d\n",
4869 // qPrint(name()),qPrint(lt.to_string()),process,invert,showAlways);
4870 if ((process^invert) || showAlways)
4871 {
4872 for (const auto &ibcd : m_inherits)
4873 {
4874 ClassDefMutable *icd=toClassDefMutable(ibcd.classDef);
4875 if (icd && icd->isLinkable())
4876 {
4879 convertProtectionLevel(lt,ibcd.prot,&lt1,&lt3);
4880 if (lt2.isInvalid() && !lt3.isInvalid())
4881 {
4882 lt2=lt3;
4883 }
4884 //printf("%s:convert %s->(%s,%s) prot=%d\n",qPrint(icd->name()),qPrint(lt.to_string()),
4885 // qPrint(lt1.to_string()),qPrint(lt2.to_string()),ibcd.prot);
4886 if (visitedClasses.find(icd)==visitedClasses.end())
4887 {
4888 visitedClasses.insert(icd); // guard for multiple virtual inheritance
4889 if (!lt1.isInvalid())
4890 {
4891 //printf("--> writeMemberDeclarations for type %s\n",qPrint(lt1.to_string()));
4892 icd->writeMemberDeclarations(ol,visitedClasses,lt1,
4893 title,QCString(),FALSE,inheritedFrom,lt2,FALSE,TRUE);
4894 }
4895 }
4896 else
4897 {
4898 //printf("%s: class already visited!\n",qPrint(icd->name()));
4899 }
4900 }
4901 }
4902 }
4903}
4904
4906 MemberListType lt,const QCString &title,
4907 const QCString &subTitle,bool showInline,const ClassDef *inheritedFrom,MemberListType lt2,
4908 bool invert,bool showAlways) const
4909{
4910 //printf("%s: ClassDefImpl::writeMemberDeclarations lt=%s lt2=%s\n",qPrint(name()),qPrint(lt.to_string()),qPrint(lt2.to_string()));
4911 MemberList * ml = getMemberList(lt);
4912 MemberList * ml2 = getMemberList(lt2);
4913 if (getLanguage()==SrcLangExt::VHDL) // use specific declarations function
4914 {
4915 static const ClassDef *cdef;
4916 if (cdef!=this)
4917 { // only one inline link
4919 cdef=this;
4920 }
4921 if (ml)
4922 {
4923 VhdlDocGen::writeVhdlDeclarations(ml,ol,nullptr,this,nullptr,nullptr,nullptr);
4924 }
4925 }
4926 else
4927 {
4928 //printf("%s::writeMemberDeclarations(%s) ml=%p ml2=%p\n",qPrint(name()),qPrint(title),(void*)ml,(void*)ml2);
4929 QCString tt = title, st = subTitle;
4930 if (ml)
4931 {
4932 //printf(" writeDeclarations ml type=%s count=%d\n",qPrint(lt.to_string()),ml->numDecMembers(inheritedFrom));
4933 ml->writeDeclarations(ol,this,nullptr,nullptr,nullptr,nullptr,tt,st,FALSE,showInline,inheritedFrom,lt,true);
4934 tt.clear();
4935 st.clear();
4936 }
4937 if (ml2)
4938 {
4939 //printf(" writeDeclarations ml2 type=%s count=%d\n",qPrint(lt2.to_string()),ml2->numDecMembers(inheritedFrom));
4940 ml2->writeDeclarations(ol,this,nullptr,nullptr,nullptr,nullptr,tt,st,FALSE,showInline,inheritedFrom,lt,ml==nullptr);
4941 }
4942 bool inlineInheritedMembers = Config_getBool(INLINE_INHERITED_MEMB);
4943 if (!inlineInheritedMembers) // show inherited members as separate lists
4944 {
4945 writeInheritedMemberDeclarations(ol,visitedClasses,lt,lt2,title,
4946 inheritedFrom ? inheritedFrom : this,
4947 invert,showAlways);
4948 }
4949 }
4950}
4951
4953 const ClassDef *inheritedFrom,const QCString &inheritId) const
4954{
4955 //printf("** %s::addGroupedInheritedMembers() inheritId=%s\n",qPrint(name()),qPrint(inheritId));
4956 for (const auto &mg : m_memberGroups)
4957 {
4958 if (!mg->allMembersInSameSection() || !m_subGrouping) // group is in its own section
4959 {
4960 mg->addGroupedInheritedMembers(ol,this,lt,inheritedFrom,inheritId);
4961 }
4962 }
4963}
4964
4966{
4967 //printf("%s: ClassDefImpl::writeMemberDocumentation()\n",qPrint(name()));
4968 MemberList * ml = getMemberList(lt);
4969 if (ml) ml->writeDocumentation(ol,displayName(),this,title,ml->listType().toLabel(),FALSE,showInline);
4970}
4971
4973{
4974 //printf("%s: ClassDefImpl::writeSimpleMemberDocumentation()\n",qPrint(name()));
4975 MemberList * ml = getMemberList(lt);
4976 if (ml) ml->writeSimpleDocumentation(ol,this);
4977}
4978
4980 MemberListType lt,bool inGroup,
4981 int indentLevel,const ClassDef *inheritedFrom,const QCString &inheritId) const
4982{
4983 //printf("%s: ClassDefImpl::writePlainMemberDeclaration()\n",qPrint(name()));
4984 MemberList * ml = getMemberList(lt);
4985 if (ml)
4986 {
4987 ml->writePlainDeclarations(ol,inGroup,this,nullptr,nullptr,nullptr,nullptr,indentLevel,inheritedFrom,inheritId);
4988 }
4989}
4990
4992{
4993 return m_isLocal;
4994}
4995
5000
5005
5007{
5008 return m_inherits;
5009}
5010
5012{
5013 m_inherits = bcd;
5014}
5015
5017{
5018 return m_inheritedBy;
5019}
5020
5022{
5023 m_inheritedBy = bcd;
5024}
5025
5030
5032{
5033 std::stable_sort(m_allMemberNameInfoLinkedMap.begin(),
5035 [](const auto &m1,const auto &m2)
5036 {
5037 return qstricmp_sort(m1->memberName(),m2->memberName())<0;
5038 });
5039}
5040
5042{
5043 return m_prot;
5044}
5045
5047{
5048 return m_tempArgs;
5049}
5050
5052{
5053 return m_fileDef;
5054}
5055
5057{
5058 return m_moduleDef;
5059}
5060
5065
5067{
5068 return m_templateMaster;
5069}
5070
5075
5080
5082{
5083 return !m_tempArgs.empty();
5084}
5085
5087{
5088 return m_incInfo.get();
5089}
5090
5095
5100
5105
5107{
5108 return m_isTemplArg;
5109}
5110
5112{
5113 return m_isAbstract || m_spec.isAbstract();
5114}
5115
5117{
5118 return m_spec.isFinal();
5119}
5120
5122{
5123 return m_spec.isSealed();
5124}
5125
5127{
5128 return m_spec.isPublished();
5129}
5130
5132{
5133 return m_spec.isForwardDecl();
5134}
5135
5137{
5138 return m_spec.isInterface();
5139}
5140
5142{
5143 return getLanguage()==SrcLangExt::ObjC;
5144}
5145
5147{
5148 return getLanguage()==SrcLangExt::Fortran;
5149}
5150
5152{
5153 return getLanguage()==SrcLangExt::CSharp;
5154}
5155
5157{
5158 return m_categoryOf;
5159}
5160
5162{
5163 return m_memberLists;
5164}
5165
5167{
5168 return m_memberGroups;
5169}
5170
5172{
5173 m_fileDef = fd;
5174}
5175
5177{
5178 m_moduleDef = mod;
5179}
5180
5182{
5183 m_subGrouping = enabled;
5184}
5185
5187{
5188 m_prot=p;
5189 if (getLanguage()==SrcLangExt::VHDL && VhdlDocGen::convert(p)==VhdlDocGen::ARCHITECTURECLASS)
5190 {
5191 m_className = name();
5192 }
5193}
5194
5196{
5197 m_isStatic=b;
5198}
5199
5204
5206{
5207 assert(tm!=this);
5209}
5210
5212{
5213 m_isTemplArg = b;
5214}
5215
5217{
5218 m_categoryOf = cd;
5219}
5220
5222{
5223 m_usedOnly = b;
5224}
5225
5227{
5228 return m_usedOnly;
5229}
5230
5232{
5233 return m_isSimple;
5234}
5235
5237{
5238 return m_arrowOperator;
5239}
5240
5242{
5243 md->setMemberType(t);
5244 for (auto &ml : m_memberLists)
5245 {
5246 ml->remove(md);
5247 }
5248 insertMember(md);
5249}
5250
5252{
5253 QCString anc;
5255 {
5257 {
5258 // point to the template of which this class is an instance
5259 anc = m_templateMaster->getOutputFileBase();
5260 }
5261 else
5262 {
5263 anc = m_fileName;
5264 }
5265 }
5266 return anc;
5267}
5268
5270{
5271 bool inlineGroupedClasses = Config_getBool(INLINE_GROUPED_CLASSES);
5272 bool inlineSimpleClasses = Config_getBool(INLINE_SIMPLE_STRUCTS);
5273
5274 Definition *container = getOuterScope();
5275
5276 bool containerLinkable =
5277 container &&
5278 (
5279 (container==Doxygen::globalScope && getFileDef() && getFileDef()->isLinkableInProject()) || // global class in documented file
5280 container->isLinkableInProject() // class in documented scope
5281 );
5282
5283 // inline because of INLINE_GROUPED_CLASSES=YES ?
5284 bool b1 = (inlineGroupedClasses && !partOfGroups().empty()); // a grouped class
5285 // inline because of INLINE_SIMPLE_STRUCTS=YES ?
5286 bool b2 = (inlineSimpleClasses && m_isSimple && // a simple class
5287 (containerLinkable || // in a documented container
5288 !partOfGroups().empty() // or part of a group
5289 )
5290 );
5291 //printf("%s::isEmbeddedInOuterScope(): inlineGroupedClasses=%d "
5292 // "inlineSimpleClasses=%d partOfGroups()=%p m_isSimple=%d "
5293 // "getOuterScope()=%s b1=%d b2=%d\n",
5294 // qPrint(name()),inlineGroupedClasses,inlineSimpleClasses,
5295 // partOfGroups().pointer(),m_isSimple,getOuterScope()?qPrint(getOuterScope()->name()):"<none>",b1,b2);
5296 return b1 || b2; // either reason will do
5297}
5298
5300{
5301 return m_tagLessRef;
5302}
5303
5305{
5306 m_tagLessRef = cd;
5307}
5308
5310{
5311 for (auto &ml : m_memberLists)
5312 {
5313 ml->remove(md);
5314 }
5315}
5316
5318{
5319 return m_isJavaEnum;
5320}
5321
5323{
5324 m_spec = spec;
5325}
5326
5328{
5329 for (const auto &sx : qualifiers)
5330 {
5331 bool alreadyAdded = std::find(m_qualifiers.begin(), m_qualifiers.end(), sx) != m_qualifiers.end();
5332 if (!alreadyAdded)
5333 {
5334 m_qualifiers.push_back(sx);
5335 }
5336 }
5337}
5338
5343
5345{
5346 AUTO_TRACE("name={}",md->name());
5347 const auto &mni = m_allMemberNameInfoLinkedMap.find(md->name());
5348 if (mni)
5349 {
5350 for (const auto &mi : *mni)
5351 {
5352 const MemberDef *classMd = mi->memberDef();
5353 const ArgumentList &classAl = classMd->argumentList();
5354 const ArgumentList &al = md->argumentList();
5355 bool found = matchArguments2(
5356 classMd->getOuterScope(),classMd->getFileDef(),classMd->typeString(),&classAl,
5357 md->getOuterScope(),md->getFileDef(),md->typeString(),&al,
5358 true,getLanguage()
5359 );
5360 if (found)
5361 {
5362 AUTO_TRACE_EXIT("true");
5363 return true;
5364 }
5365 }
5366 }
5367 AUTO_TRACE_EXIT("false");
5368 return false;
5369}
5370
5372{
5373 QCString n = name();
5374 int si = n.find('(');
5375 int ei = n.find(')');
5376 bool b = ei>si && n.mid(si+1,ei-si-1).stripWhiteSpace().isEmpty();
5377 return b;
5378}
5379
5381{
5382 return m_files;
5383}
5384
5386{
5387 return m_typeConstraints;
5388}
5389
5391{
5392 return m_examples;
5393}
5394
5396{
5397 return m_subGrouping;
5398}
5399
5401{
5402 return m_spec.isLocal();
5403}
5404
5406{
5407 m_metaData = md;
5408}
5409
5414
5419
5421{
5423}
5424
5426{
5428}
5429
5431{
5432 switch (compoundType())
5433 {
5434 case Class: return CodeSymbolType::Class; break;
5435 case Struct: return CodeSymbolType::Struct; break;
5436 case Union: return CodeSymbolType::Union; break;
5437 case Interface: return CodeSymbolType::Interface; break;
5438 case Protocol: return CodeSymbolType::Protocol; break;
5439 case Category: return CodeSymbolType::Category; break;
5440 case Exception: return CodeSymbolType::Exception; break;
5441 case Service: return CodeSymbolType::Service; break;
5442 case Singleton: return CodeSymbolType::Singleton; break;
5443 }
5444 return CodeSymbolType::Class;
5445}
5446
5451
5456
5457
5458// --- Cast functions
5459//
5461{
5462 if (d && (typeid(*d)==typeid(ClassDefImpl) || typeid(*d)==typeid(ClassDefAliasImpl)))
5463 {
5464 return static_cast<ClassDef*>(d);
5465 }
5466 else
5467 {
5468 return nullptr;
5469 }
5470}
5471
5473{
5474 Definition *d = toDefinition(md);
5475 if (d && typeid(*d)==typeid(ClassDefImpl))
5476 {
5477 return static_cast<ClassDef*>(d);
5478 }
5479 else
5480 {
5481 return nullptr;
5482 }
5483}
5484
5486{
5487 if (d && (typeid(*d)==typeid(ClassDefImpl) || typeid(*d)==typeid(ClassDefAliasImpl)))
5488 {
5489 return static_cast<const ClassDef*>(d);
5490 }
5491 else
5492 {
5493 return nullptr;
5494 }
5495}
5496
5498{
5499 if (d && typeid(*d)==typeid(ClassDefImpl))
5500 {
5501 return static_cast<ClassDefMutable*>(d);
5502 }
5503 else
5504 {
5505 return nullptr;
5506 }
5507}
5508
5509// --- Helpers
5510
5511/*! Get a class definition given its name.
5512 * Returns nullptr if the class is not found.
5513 */
5515{
5516 if (n.isEmpty()) return nullptr;
5517 return Doxygen::classLinkedMap->find(n);
5518}
5519
5521{
5522 for (const auto &bcd : bcl)
5523 {
5524 const ClassDef *cd=bcd.classDef;
5525 if (cd->isVisibleInHierarchy()) return true;
5526 if (classHasVisibleRoot(cd->baseClasses())) return true;
5527 }
5528 return false;
5529}
5530
5532{
5533 BaseClassList bcl;
5534
5535 if (cd->getLanguage()==SrcLangExt::VHDL) // reverse baseClass/subClass relation
5536 {
5537 if (cd->baseClasses().empty()) return FALSE;
5538 bcl=cd->baseClasses();
5539 }
5540 else
5541 {
5542 if (cd->subClasses().empty()) return FALSE;
5543 bcl=cd->subClasses();
5544 }
5545
5546 for (const auto &bcd : bcl)
5547 {
5548 if (bcd.classDef->isVisibleInHierarchy())
5549 {
5550 return TRUE;
5551 }
5552 }
5553 return FALSE;
5554}
5555
5557{
5558 bool allExternals = Config_getBool(ALLEXTERNALS);
5559 return (allExternals && cd->isLinkable()) || cd->isLinkableInProject();
5560}
5561
5562//----------------------------------------------------------------------
5563// recursive function that returns the number of branches in the
5564// inheritance tree that the base class 'bcd' is below the class 'cd'
5565
5566int minClassDistance(const ClassDef *cd,const ClassDef *bcd,int level)
5567{
5568 const int maxInheritanceDepth = 100000;
5569 if (bcd->categoryOf()) // use class that is being extended in case of
5570 // an Objective-C category
5571 {
5572 bcd=bcd->categoryOf();
5573 }
5574 if (cd==bcd) return level;
5575 if (level==256)
5576 {
5577 warn_uncond("class {} seem to have a recursive inheritance relation!\n",cd->name());
5578 return -1;
5579 }
5580 int m=maxInheritanceDepth;
5581 for (const auto &bcdi : cd->baseClasses())
5582 {
5583 int mc=minClassDistance(bcdi.classDef,bcd,level+1);
5584 if (mc<m) m=mc;
5585 if (m<0) break;
5586 }
5587 return m;
5588}
5589
5591{
5592 if (bcd->categoryOf()) // use class that is being extended in case of
5593 // an Objective-C category
5594 {
5595 bcd=bcd->categoryOf();
5596 }
5597 if (cd==bcd)
5598 {
5599 goto exit;
5600 }
5601 if (level==256)
5602 {
5603 err("Internal inconsistency: found class {} seem to have a recursive "
5604 "inheritance relation! Please send a bug report to doxygen@gmail.com\n",cd->name());
5605 }
5606 else if (prot!=Protection::Private)
5607 {
5608 for (const auto &bcdi : cd->baseClasses())
5609 {
5610 Protection baseProt = classInheritedProtectionLevel(bcdi.classDef,bcd,bcdi.prot,level+1);
5611 if (baseProt==Protection::Private) prot=Protection::Private;
5612 else if (baseProt==Protection::Protected) prot=Protection::Protected;
5613 }
5614 }
5615exit:
5616 //printf("classInheritedProtectionLevel(%s,%s)=%d\n",qPrint(cd->name()),qPrint(bcd->name()),prot);
5617 return prot;
5618}
5619
5620
constexpr auto prefix
Definition anchor.cpp:44
std::vector< ArgumentList > ArgumentLists
Definition arguments.h:147
This class represents an function or template argument list.
Definition arguments.h:65
bool empty() const
Definition arguments.h:99
bool isSimple() const override
Definition classdef.cpp:710
bool isFortran() const override
Returns TRUE if this class is implemented in Fortran.
Definition classdef.cpp:676
QCString requiresClause() const override
Definition classdef.cpp:738
void writeTagFile(TextStream &ol) const override
Definition classdef.cpp:776
int countMemberDeclarations(MemberListType lt, const ClassDef *inheritedFrom, MemberListType lt2, bool invert, bool showAlways, ClassDefSet &visitedClasses) const override
Definition classdef.cpp:747
bool isSubClass(ClassDef *bcd, int level=0) const override
Returns TRUE iff bcd is a direct or indirect sub class of this class.
Definition classdef.cpp:645
const UsesClassList & usedByImplementationClasses() const override
Definition classdef.cpp:659
bool hasDetailedDescription() const override
returns TRUE if this class has a non-empty detailed description
Definition classdef.cpp:607
void writePageNavigation(OutputList &ol) const override
Definition classdef.cpp:772
ModuleDef * getModuleDef() const override
Returns the C++20 module in which this compound's definition can be found.
Definition classdef.cpp:639
void writeDocumentation(OutputList &ol) const override
Definition classdef.cpp:757
const UsesClassList & usedImplementationClasses() const override
Definition classdef.cpp:657
StringVector getQualifiers() const override
Definition classdef.cpp:740
void writeSummaryLinks(OutputList &ol) const override
Definition classdef.cpp:770
bool isVisibleInHierarchy() const override
the class is visible in a class diagram, or class hierarchy
Definition classdef.cpp:631
QCString qualifiedNameWithTemplateParameters(const ArgumentLists *actualParams=nullptr, uint32_t *actualParamIndex=nullptr) const override
Definition classdef.cpp:669
bool isPublished() const override
Returns TRUE if this class is marked as published.
Definition classdef.cpp:684
const MemberNameInfoLinkedMap & memberNameInfoLinkedMap() const override
Returns a dictionary of all members.
Definition classdef.cpp:623
QCString anchor() const override
Definition classdef.cpp:706
QCString title() const override
Definition classdef.cpp:718
bool isImplicitTemplateInstance() const override
Definition classdef.cpp:754
const FileList & usedFiles() const override
Definition classdef.cpp:722
CodeSymbolType codeSymbolType() const override
Definition classdef.cpp:589
bool isFinal() const override
Returns TRUE if this class is marked as final.
Definition classdef.cpp:680
const ExampleList & getExamples() const override
Definition classdef.cpp:726
void moveTo(Definition *) override
Definition classdef.cpp:587
bool isReference() const override
Definition classdef.cpp:599
bool isTemplateArgument() const override
Definition classdef.cpp:663
void updateSubClasses(const BaseClassList &) override
Update the list of sub classes to the one passed.
Definition classdef.cpp:789
bool isForwardDeclared() const override
Returns TRUE if this class represents a forward declaration of a template class.
Definition classdef.cpp:688
const ArgumentList & typeConstraints() const override
Definition classdef.cpp:724
const IncludeInfo * includeInfo() const override
Definition classdef.cpp:655
bool isAccessibleMember(const MemberDef *md) const override
returns TRUE iff md is a member of this class or of the the public/protected members of a base class
Definition classdef.cpp:647
QCString getSourceFileBase() const override
Definition classdef.cpp:595
void writeMemberPages(OutputList &ol) const override
Definition classdef.cpp:761
ClassDefAliasImpl(const Definition *newScope, const ClassDef *cd)
Definition classdef.cpp:576
void writeDeclaration(OutputList &ol, const MemberDef *md, bool inGroup, int indentLevel, const ClassDef *inheritedFrom, const QCString &inheritId) const override
Definition classdef.cpp:765
void writeQuickMemberLinks(OutputList &ol, const MemberDef *md) const override
Definition classdef.cpp:768
void updateBaseClasses(const BaseClassList &) override
Update the list of base classes to the one passed.
Definition classdef.cpp:788
bool containsOverload(const MemberDef *md) const override
Definition classdef.cpp:742
bool subGrouping() const override
Definition classdef.cpp:732
const ArgumentList & templateArguments() const override
Returns the template arguments of this class.
Definition classdef.cpp:635
Protection protection() const override
Return the protection level (Public,Protected,Private) in which this compound was found.
Definition classdef.cpp:625
bool isCSharp() const override
Returns TRUE if this class is implemented in C#.
Definition classdef.cpp:678
const MemberGroupList & getMemberGroups() const override
Returns the member groups defined for this class.
Definition classdef.cpp:700
bool isEmbeddedInOuterScope() const override
Definition classdef.cpp:708
QCString getReference() const override
Definition classdef.cpp:597
int isBaseClass(const ClassDef *bcd, bool followInstances, const QCString &templSpec) const override
Returns TRUE iff bcd is a direct or indirect base class of this class.
Definition classdef.cpp:643
int countMembersIncludingGrouped(MemberListType lt, const ClassDef *inheritedFrom, bool additional) const override
Definition classdef.cpp:745
void addGroupedInheritedMembers(OutputList &ol, MemberListType lt, const ClassDef *inheritedFrom, const QCString &inheritId) const override
Definition classdef.cpp:784
bool isSealed() const override
Returns TRUE if this class is marked as sealed.
Definition classdef.cpp:682
bool hasDocumentation() const override
Definition classdef.cpp:605
FileDef * getFileDef() const override
Returns the namespace this compound is in, or 0 if it has a global scope.
Definition classdef.cpp:637
ArgumentLists getTemplateParameterLists() const override
Returns the template parameter lists that form the template declaration of this class.
Definition classdef.cpp:667
QCString getMemberListFileName() const override
Definition classdef.cpp:730
bool hasNonReferenceSuperClass() const override
Definition classdef.cpp:736
void writeInlineDocumentation(OutputList &ol) const override
Definition classdef.cpp:774
const BaseClassList & subClasses() const override
Returns the list of sub classes that directly derive from this class.
Definition classdef.cpp:621
bool isJavaEnum() const override
Definition classdef.cpp:716
QCString inheritanceGraphFileName() const override
returns the file name to use for the inheritance graph
Definition classdef.cpp:611
~ClassDefAliasImpl() override
Definition classdef.cpp:578
const TemplateInstanceList & getTemplateInstances() const override
Returns a sorted dictionary with all template instances found for this template class.
Definition classdef.cpp:649
QCString compoundTypeString() const override
Returns the type of compound as a string.
Definition classdef.cpp:617
bool isLinkableInProject() const override
Definition classdef.cpp:627
QCString displayName(bool includeScope=TRUE) const override
Definition classdef.cpp:613
QCString className() const override
Returns the name of the class including outer classes, but not including namespaces.
Definition classdef.cpp:694
bool isLocal() const override
Returns TRUE if this is a local class definition, see EXTRACT_LOCAL_CLASSES.
Definition classdef.cpp:601
QCString getInstanceOutputFileBase() const override
Definition classdef.cpp:593
void writeDocumentationForInnerClasses(OutputList &ol) const override
Definition classdef.cpp:759
const MemberLists & getMemberLists() const override
Returns the list containing the list of members sorted per type.
Definition classdef.cpp:698
MemberList * getMemberList(MemberListType lt) const override
Returns the members in the list identified by lt.
Definition classdef.cpp:696
ClassDef * categoryOf() const override
Returns the class of which this is a category (Objective-C only).
Definition classdef.cpp:692
const ClassDef * getCdAlias() const
Definition classdef.cpp:583
QCString collaborationGraphFileName() const override
returns the file name to use for the collaboration graph
Definition classdef.cpp:609
void writeMemberDeclarations(OutputList &ol, ClassDefSet &visitedClasses, MemberListType lt, const QCString &title, const QCString &subTitle=QCString(), bool showInline=FALSE, const ClassDef *inheritedFrom=nullptr, MemberListType lt2=MemberListType::Invalid(), bool invert=FALSE, bool showAlways=FALSE) const override
Definition classdef.cpp:778
QCString getOutputFileBase() const override
Definition classdef.cpp:591
CompoundType compoundType() const override
Returns the type of compound this is, i.e.
Definition classdef.cpp:615
const TemplateNameMap & getTemplateBaseClassNames() const override
Definition classdef.cpp:702
void writeDeclarationLink(OutputList &ol, bool &found, const QCString &header, bool localNames) const override
Definition classdef.cpp:751
const Definition * findInnerCompound(const QCString &name) const override
Definition classdef.cpp:665
DefType definitionType() const override
Definition classdef.cpp:581
QCString generatedFromFiles() const override
Definition classdef.cpp:720
bool isLinkable() const override
Definition classdef.cpp:629
const BaseClassList & baseClasses() const override
Returns the list of base classes from which this class directly inherits.
Definition classdef.cpp:619
const ClassDef * tagLessReference() const override
Definition classdef.cpp:712
bool isExtension() const override
Returns TRUE if this class represents an Objective-C 2.0 extension (nameless category).
Definition classdef.cpp:686
ClassLinkedRefMap getClasses() const override
returns the classes nested into this class
Definition classdef.cpp:603
const ConstraintClassList & templateTypeConstraints() const override
Definition classdef.cpp:661
bool isInterface() const override
Returns TRUE if this class represents an interface.
Definition classdef.cpp:690
std::unique_ptr< ClassDef > deepCopy(const QCString &name) const override
Definition classdef.cpp:584
bool isAbstract() const override
Returns TRUE if there is at least one pure virtual member in this class.
Definition classdef.cpp:672
bool hasExamples() const override
Definition classdef.cpp:728
bool visibleInParentsDeclList() const override
show this class in the declaration section of its parent?
Definition classdef.cpp:633
const MemberDef * getMemberByName(const QCString &s) const override
Returns the member with the given name.
Definition classdef.cpp:641
const ClassDef * templateMaster() const override
Returns the template master of which this class is an instance.
Definition classdef.cpp:651
bool isTemplate() const override
Returns TRUE if this class is a template.
Definition classdef.cpp:653
bool isSliceLocal() const override
Definition classdef.cpp:734
bool isUsedOnly() const override
Definition classdef.cpp:704
const MemberDef * isSmartPointer() const override
Definition classdef.cpp:714
bool isObjectiveC() const override
Returns TRUE if this class is implemented in Objective-C.
Definition classdef.cpp:674
void writeMemberList(OutputList &ol) const override
Definition classdef.cpp:763
A abstract class representing of a compound symbol.
Definition classdef.h:104
virtual int countMemberDeclarations(MemberListType lt, const ClassDef *inheritedFrom, MemberListType lt2, bool invert, bool showAlways, ClassDefSet &visitedClasses) const =0
virtual bool isSliceLocal() const =0
virtual ModuleDef * getModuleDef() const =0
Returns the C++20 module in which this compound's definition can be found.
virtual bool isAbstract() const =0
Returns TRUE if there is at least one pure virtual member in this class.
virtual bool isFinal() const =0
Returns TRUE if this class is marked as final.
virtual bool visibleInParentsDeclList() const =0
show this class in the declaration section of its parent?
virtual bool subGrouping() const =0
virtual void writeSummaryLinks(OutputList &ol) const =0
virtual bool hasDetailedDescription() const =0
returns TRUE if this class has a non-empty detailed description
virtual const ArgumentList & templateArguments() const =0
Returns the template arguments of this class.
virtual void writeMemberPages(OutputList &ol) const =0
virtual QCString compoundTypeString() const =0
Returns the type of compound as a string.
virtual bool isFortran() const =0
Returns TRUE if this class is implemented in Fortran.
virtual void writeDocumentation(OutputList &ol) const =0
virtual const MemberLists & getMemberLists() const =0
Returns the list containing the list of members sorted per type.
virtual QCString className() const =0
Returns the name of the class including outer classes, but not including namespaces.
virtual void writeMemberList(OutputList &ol) const =0
virtual bool isVisibleInHierarchy() const =0
the class is visible in a class diagram, or class hierarchy
virtual bool isTemplate() const =0
Returns TRUE if this class is a template.
virtual const BaseClassList & baseClasses() const =0
Returns the list of base classes from which this class directly inherits.
virtual bool isSealed() const =0
Returns TRUE if this class is marked as sealed.
virtual const MemberDef * getMemberByName(const QCString &) const =0
Returns the member with the given name.
virtual const TemplateInstanceList & getTemplateInstances() const =0
Returns a sorted dictionary with all template instances found for this template class.
virtual int isBaseClass(const ClassDef *bcd, bool followInstances, const QCString &templSpec=QCString()) const =0
Returns TRUE iff bcd is a direct or indirect base class of this class.
virtual ArgumentLists getTemplateParameterLists() const =0
Returns the template parameter lists that form the template declaration of this class.
virtual const UsesClassList & usedImplementationClasses() const =0
virtual bool isObjectiveC() const =0
Returns TRUE if this class is implemented in Objective-C.
virtual bool hasExamples() const =0
virtual QCString inheritanceGraphFileName() const =0
returns the file name to use for the inheritance graph
virtual StringVector getQualifiers() const =0
virtual bool isLocal() const =0
Returns TRUE if this is a local class definition, see EXTRACT_LOCAL_CLASSES.
virtual void writeQuickMemberLinks(OutputList &ol, const MemberDef *md) const =0
virtual bool isSimple() const =0
virtual Protection protection() const =0
Return the protection level (Public,Protected,Private) in which this compound was found.
virtual const ClassDef * tagLessReference() const =0
virtual MemberList * getMemberList(MemberListType lt) const =0
Returns the members in the list identified by lt.
virtual void writePageNavigation(OutputList &ol) const =0
virtual ClassDef * categoryOf() const =0
Returns the class of which this is a category (Objective-C only).
virtual QCString getInstanceOutputFileBase() const =0
virtual const MemberDef * isSmartPointer() const =0
virtual bool isExtension() const =0
Returns TRUE if this class represents an Objective-C 2.0 extension (nameless category).
virtual bool hasNonReferenceSuperClass() const =0
virtual bool isCSharp() const =0
Returns TRUE if this class is implemented in C#.
virtual bool isForwardDeclared() const =0
Returns TRUE if this class represents a forward declaration of a template class.
virtual QCString generatedFromFiles() const =0
virtual const ExampleList & getExamples() const =0
virtual bool isJavaEnum() const =0
virtual bool isSubClass(ClassDef *bcd, int level=0) const =0
Returns TRUE iff bcd is a direct or indirect sub class of this class.
virtual bool isTemplateArgument() const =0
virtual int countMembersIncludingGrouped(MemberListType lt, const ClassDef *inheritedFrom, bool additional) const =0
virtual const ArgumentList & typeConstraints() const =0
virtual bool isAccessibleMember(const MemberDef *md) const =0
returns TRUE iff md is a member of this class or of the the public/protected members of a base class
virtual QCString collaborationGraphFileName() const =0
returns the file name to use for the collaboration graph
virtual const TemplateNameMap & getTemplateBaseClassNames() const =0
virtual bool isPublished() const =0
Returns TRUE if this class is marked as published.
virtual const FileList & usedFiles() const =0
virtual void writeMemberDeclarations(OutputList &ol, ClassDefSet &visitedClasses, MemberListType lt, const QCString &title, const QCString &subTitle=QCString(), bool showInline=FALSE, const ClassDef *inheritedFrom=nullptr, MemberListType lt2=MemberListType::Invalid(), bool invert=FALSE, bool showAlways=FALSE) const =0
virtual QCString getMemberListFileName() const =0
virtual bool isEmbeddedInOuterScope() const =0
virtual void addGroupedInheritedMembers(OutputList &ol, MemberListType lt, const ClassDef *inheritedFrom, const QCString &inheritId) const =0
virtual const MemberNameInfoLinkedMap & memberNameInfoLinkedMap() const =0
Returns a dictionary of all members.
virtual void writeDeclarationLink(OutputList &ol, bool &found, const QCString &header, bool localNames) const =0
virtual const ConstraintClassList & templateTypeConstraints() const =0
virtual void writeDeclaration(OutputList &ol, const MemberDef *md, bool inGroup, int indentLevel, const ClassDef *inheritedFrom, const QCString &inheritId) const =0
virtual bool isImplicitTemplateInstance() const =0
virtual QCString qualifiedNameWithTemplateParameters(const ArgumentLists *actualParams=nullptr, uint32_t *actualParamIndex=nullptr) const =0
virtual const MemberGroupList & getMemberGroups() const =0
Returns the member groups defined for this class.
virtual const UsesClassList & usedByImplementationClasses() const =0
virtual const ClassDef * templateMaster() const =0
Returns the template master of which this class is an instance.
CompoundType
The various compound types.
Definition classdef.h:109
@ Singleton
Definition classdef.h:117
@ Interface
Definition classdef.h:112
@ Exception
Definition classdef.h:115
virtual CompoundType compoundType() const =0
Returns the type of compound this is, i.e.
virtual bool containsOverload(const MemberDef *md) const =0
virtual ClassLinkedRefMap getClasses() const =0
returns the classes nested into this class
virtual bool isInterface() const =0
Returns TRUE if this class represents an interface.
virtual FileDef * getFileDef() const =0
Returns the namespace this compound is in, or 0 if it has a global scope.
virtual const IncludeInfo * includeInfo() const =0
virtual QCString requiresClause() const =0
virtual void writeInlineDocumentation(OutputList &ol) const =0
virtual void writeTagFile(TextStream &) const =0
virtual QCString title() const =0
virtual void writeDocumentationForInnerClasses(OutputList &ol) const =0
virtual const BaseClassList & subClasses() const =0
Returns the list of sub classes that directly derive from this class.
virtual bool isUsedOnly() const =0
Implementation of the ClassDef interface.
Definition classdef.cpp:185
bool isSubClass(ClassDef *bcd, int level=0) const override
Returns TRUE iff bcd is a direct or indirect sub class of this class.
bool addExample(const QCString &anchor, const QCString &name, const QCString &file) override
QCString getReference() const override
QCString getInstanceOutputFileBase() const override
TemplateInstanceList m_templateInstances
Definition classdef.cpp:489
void writeIncludeFilesForSlice(OutputList &ol) const
void overrideInheritanceGraph(CLASS_GRAPH_t e) override
ClassLinkedRefMap getClasses() const override
returns the classes nested into this class
QCString m_collabFileName
Definition classdef.cpp:421
ArgumentList m_typeConstraints
Definition classdef.cpp:458
void writePageNavigation(OutputList &ol) const override
void addMembersToMemberGroup() override
bool subGrouping() const override
void setMetaData(const QCString &md) override
void distributeMemberGroupDocumentation() override
void addMemberToList(MemberListType lt, MemberDef *md, bool isBrief)
bool isObjectiveC() const override
Returns TRUE if this class is implemented in Objective-C.
StringSet m_vhdlSummaryTitles
List of titles to use for the summary.
Definition classdef.cpp:533
QCString compoundTypeString() const override
Returns the type of compound as a string.
ExampleList m_examples
Definition classdef.cpp:464
void setImplicitTemplateInstance(bool b) override
void insertUsedFile(const FileDef *) override
QCString qualifiedNameWithTemplateParameters(const ArgumentLists *actualParams=nullptr, uint32_t *actualParamIndex=nullptr) const override
void writeTemplateSpec(OutputList &ol, const Definition *d, const QCString &type, SrcLangExt lang) const
void addUsedByClass(ClassDef *cd, const QCString &accessName, Protection prot) override
QCString m_fileName
Definition classdef.cpp:415
const MemberDef * m_arrowOperator
Does this class overloaded the -> operator?
Definition classdef.cpp:539
void addClassAttributes(OutputList &ol) const
void updateSubClasses(const BaseClassList &bcd) override
Update the list of sub classes to the one passed.
void addMemberToTemplateInstance(const MemberDef *md, const ArgumentList &templateArguments, const QCString &templSpec) override
MemberGroupList m_memberGroups
Definition classdef.cpp:507
TypeSpecifier m_spec
Definition classdef.cpp:546
ClassDef * m_categoryOf
Definition classdef.cpp:502
FileDef * getFileDef() const override
Returns the namespace this compound is in, or 0 if it has a global scope.
bool isTemplateArgument() const override
void writeInheritanceGraph(OutputList &ol) const
QCString className() const override
Returns the name of the class including outer classes, but not including namespaces.
const ClassDef * m_tagLessRef
Definition classdef.cpp:541
void setAnonymousEnumType() override
void setTagLessReference(const ClassDef *cd) override
Protection m_prot
Definition classdef.cpp:473
bool isLinkableInProject() const override
BaseClassList m_inheritedBy
Definition classdef.cpp:438
FileList m_files
Definition classdef.cpp:461
const TemplateInstanceList & getTemplateInstances() const override
Returns a sorted dictionary with all template instances found for this template class.
MemberLists m_memberLists
Definition classdef.cpp:504
const UsesClassList & usedByImplementationClasses() const override
ArgumentLists getTemplateParameterLists() const override
Returns the template parameter lists that form the template declaration of this class.
void writeMemberList(OutputList &ol) const override
void writeMemberDeclarations(OutputList &ol, ClassDefSet &visitedClasses, MemberListType lt, const QCString &title, const QCString &subTitle=QCString(), bool showInline=FALSE, const ClassDef *inheritedFrom=nullptr, MemberListType lt2=MemberListType::Invalid(), bool invert=FALSE, bool showAlways=FALSE) const override
void writeBriefDescription(OutputList &ol, bool exampleFlag) const
void writeInlineClasses(OutputList &ol) const
void moveTo(Definition *) override
Definition classdef.cpp:974
const ExampleList & getExamples() const override
UsesClassList m_usesImplClassList
Definition classdef.cpp:481
void addListReferences() override
const ArgumentList & templateArguments() const override
Returns the template arguments of this class.
QCString m_inheritFileName
Definition classdef.cpp:424
void writeDetailedDocumentationBody(OutputList &ol) const
ClassDefImpl(const QCString &fileName, int startLine, int startColumn, const QCString &name, CompoundType ct, const QCString &ref=QCString(), const QCString &fName=QCString(), bool isSymbol=TRUE, bool isJavaEnum=FALSE)
Definition classdef.cpp:804
QCString generatedFromFiles() const override
const ClassDef * m_templateMaster
Definition classdef.cpp:494
void writeTagFile(TextStream &) const override
void endMemberDeclarations(OutputList &ol) const
bool m_membersMerged
Definition classdef.cpp:516
const MemberGroupList & getMemberGroups() const override
Returns the member groups defined for this class.
void sortMemberLists() override
const FileList & usedFiles() const override
void insertExplicitTemplateInstance(ClassDef *instance, const QCString &spec) override
void setTemplateArguments(const ArgumentList &al) override
void mergeCategory(ClassDef *category) override
void countMembers() override
void setClassSpecifier(TypeSpecifier spec) override
const MemberDef * getMemberByName(const QCString &) const override
Returns the member with the given name.
void reclassifyMember(MemberDefMutable *md, MemberType t) override
int countAdditionalInheritedMembers() const
void writePlainMemberDeclaration(OutputList &ol, MemberListType lt, bool inGroup, int indentLevel, const ClassDef *inheritedFrom, const QCString &inheritId) const
bool isFinal() const override
Returns TRUE if this class is marked as final.
void insertSubClass(ClassDef *, Protection p, Specifier s, const QCString &t=QCString()) override
void writeDocumentationForInnerClasses(OutputList &ol) const override
bool isUsedOnly() const override
QCString m_requiresClause
C++20 requires clause.
Definition classdef.cpp:551
void addQualifiers(const StringVector &qualifiers) override
void setTypeConstraints(const ArgumentList &al) override
bool isInterface() const override
Returns TRUE if this class represents an interface.
void writeSimpleMemberDocumentation(OutputList &ol, MemberListType lt) const
int countMemberDeclarations(MemberListType lt, const ClassDef *inheritedFrom, MemberListType lt2, bool invert, bool showAlways, ClassDefSet &visitedClasses) const override
void writeInlineDocumentation(OutputList &ol) const override
Write class documentation inside another container (i.e.
int countMembersIncludingGrouped(MemberListType lt, const ClassDef *inheritedFrom, bool additional) const override
bool isLocal() const override
Returns TRUE if this is a local class definition, see EXTRACT_LOCAL_CLASSES.
const BaseClassList & baseClasses() const override
Returns the list of base classes from which this class directly inherits.
void writeCollaborationGraph(OutputList &ol) const
void writeDeclarationLink(OutputList &ol, bool &found, const QCString &header, bool localNames) const override
void setRequiresClause(const QCString &req) override
void writeAuthorSection(OutputList &ol) const
void writeDetailedDescription(OutputList &ol, const QCString &pageType, bool exampleFlag, const QCString &title, const QCString &anchor=QCString()) const
TemplateNameMap m_templBaseClassNames
Definition classdef.cpp:491
const ConstraintClassList & templateTypeConstraints() const override
const UsesClassList & usedImplementationClasses() const override
std::unique_ptr< IncludeInfo > m_incInfo
Definition classdef.cpp:429
ClassDef * categoryOf() const override
Returns the class of which this is a category (Objective-C only).
bool isReference() const override
bool isPublished() const override
Returns TRUE if this class is marked as published.
bool m_isJavaEnum
Does this class represent a Java style enum?
Definition classdef.cpp:544
void writeDeclaration(OutputList &ol, const MemberDef *md, bool inGroup, int indentLevel, const ClassDef *inheritedFrom, const QCString &inheritId) const override
void addGroupedInheritedMembers(OutputList &ol, MemberListType lt, const ClassDef *inheritedFrom, const QCString &inheritId) const override
bool isFortran() const override
Returns TRUE if this class is implemented in Fortran.
BaseClassList m_inherits
Definition classdef.cpp:434
void writeMemberPages(OutputList &ol) const override
MemberNameInfoLinkedMap m_allMemberNameInfoLinkedMap
Definition classdef.cpp:452
void makeTemplateArgument(bool b=TRUE) override
void endMemberDocumentation(OutputList &ol) const
void writeDocumentation(OutputList &ol) const override
void writeMoreLink(OutputList &ol, const QCString &anchor) const
void setModuleDef(ModuleDef *mod) override
const BaseClassList & subClasses() const override
Returns the list of sub classes that directly derive from this class.
std::unique_ptr< ClassDef > deepCopy(const QCString &name) const override
Definition classdef.cpp:866
bool isSimple() const override
ModuleDef * m_moduleDef
Definition classdef.cpp:449
void hideDerivedVariablesInPython(ClassDefMutable *cls)
void addUsedInterfaceClasses(MemberDef *md, const QCString &typeStr)
bool hasCollaborationGraph() const override
void writeInheritedMemberDeclarations(OutputList &ol, ClassDefSet &visitedClasses, MemberListType lt, MemberListType lt2, const QCString &title, const ClassDef *inheritedFrom, bool invert, bool showAlways) const
void writeQuickMemberLinks(OutputList &ol, const MemberDef *md) const override
bool containsOverload(const MemberDef *md) const override
void getTitleForMemberListType(MemberListType type, QCString &title, QCString &subtitle) const
bool isJavaEnum() const override
void setCompoundType(CompoundType t) override
void insertMember(MemberDef *) override
int countInheritedDecMembers(MemberListType lt, const ClassDef *inheritedFrom, bool invert, bool showAlways, ClassDefSet &visitedClasses) const
bool m_isSimple
Is this a simple (non-nested) C structure?
Definition classdef.cpp:536
const ClassDef * tagLessReference() const override
bool isForwardDeclared() const override
Returns TRUE if this class represents a forward declaration of a template class.
CLASS_GRAPH_t m_typeInheritanceGraph
Definition classdef.cpp:556
int countInheritanceNodes() const
void setTemplateBaseClassNames(const TemplateNameMap &templateNames) override
void findSectionsInDocumentation() override
bool isTemplate() const override
Returns TRUE if this class is a template.
int countInheritsNodes() const
void addMembersToTemplateInstance(const ClassDef *cd, const ArgumentList &templateArguments, const QCString &templSpec) override
void mergeMembersFromBaseClasses(bool mergeVirtualBaseClass)
const MemberNameInfoLinkedMap & memberNameInfoLinkedMap() const override
Returns a dictionary of all members.
bool m_isAbstract
Definition classdef.cpp:510
StringVector m_qualifiers
Definition classdef.cpp:553
ArgumentList m_primaryConstructorParams
Definition classdef.cpp:560
FileDef * m_fileDef
Definition classdef.cpp:446
const ClassDef * templateMaster() const override
Returns the template master of which this class is an instance.
const TemplateNameMap & getTemplateBaseClassNames() const override
ClassDef::CompoundType m_compType
Definition classdef.cpp:467
bool m_hasCollaborationGraph
Definition classdef.cpp:555
bool isExtension() const override
Returns TRUE if this class represents an Objective-C 2.0 extension (nameless category).
void addTypeConstraint(const QCString &typeConstraint, const QCString &type)
void setIncludeFile(FileDef *fd, const QCString &incName, bool local, bool force) override
bool isAbstract() const override
Returns TRUE if there is at least one pure virtual member in this class.
QCString getOutputFileBase() const override
void setGroupDefForAllMembers(GroupDef *g, Grouping::GroupPri_t pri, const QCString &fileName, int startLine, bool hasDocs) override
const IncludeInfo * includeInfo() const override
void setCategoryOf(ClassDef *cd) override
QCString m_className
Definition classdef.cpp:497
void addUsedClass(ClassDef *cd, const QCString &accessName, Protection prot) override
void addTypeConstraints() override
void setClassName(const QCString &name) override
QCString title() const override
bool visibleInParentsDeclList() const override
show this class in the declaration section of its parent?
const MemberLists & getMemberLists() const override
Returns the list containing the list of members sorted per type.
void overrideCollaborationGraph(bool e) override
bool isSealed() const override
Returns TRUE if this class is marked as sealed.
ClassLinkedRefMap m_innerClasses
Definition classdef.cpp:478
UsesClassList m_usedByImplClassList
Definition classdef.cpp:482
bool isSliceLocal() const override
ConstraintClassList m_constraintClassList
Definition classdef.cpp:484
void setIsStatic(bool b) override
int countInheritedByNodes() const
QCString getMemberListFileName() const override
Definition classdef.cpp:988
void setFileDef(FileDef *fd) override
void insertBaseClass(ClassDef *, const QCString &name, Protection p, Specifier s, const QCString &t=QCString()) override
Definition classdef.cpp:999
bool m_isTemplArg
Definition classdef.cpp:521
DefType definitionType() const override
Definition classdef.cpp:192
CodeSymbolType codeSymbolType() const override
QCString collaborationGraphFileName() const override
returns the file name to use for the collaboration graph
bool m_usedOnly
Reason of existence is a "use" relation.
Definition classdef.cpp:530
bool isCSharp() const override
Returns TRUE if this class is implemented in C#.
void computeAnchors() override
void writeIncludeFiles(OutputList &ol) const
void addRequirementReferences() override
QCString m_metaData
Definition classdef.cpp:548
QCString anchor() const override
void addInnerCompound(Definition *d) override
void setSubGrouping(bool enabled) override
void mergeMembers() override
void writeSummaryLinks(OutputList &ol) const override
void writeMemberGroups(OutputList &ol, bool showInline=FALSE) const
int isBaseClass(const ClassDef *bcd, bool followInstances, const QCString &templSpec) const override
Returns TRUE iff bcd is a direct or indirect base class of this class.
QCString requiresClause() const override
void writeAdditionalInheritedMembers(OutputList &ol) const
void writeNestedClasses(OutputList &ol, const QCString &title) const
void removeMemberFromLists(MemberDef *md) override
QCString displayName(bool includeScope=TRUE) const override
Definition classdef.cpp:993
bool isVisibleInHierarchy() const override
void writeMemberDocumentation(OutputList &ol, MemberListType lt, const QCString &title, bool showInline=FALSE) const
QCString m_memberListFileName
Definition classdef.cpp:418
bool isLinkable() const override
bool m_implicitTemplateInstance
Definition classdef.cpp:558
bool hasDocumentation() const override
ModuleDef * getModuleDef() const override
Returns the C++20 module in which this compound's definition can be found.
ArgumentList m_tempArgs
Definition classdef.cpp:455
void internalInsertMember(MemberDef *md, Protection prot, bool addToAllList)
void startMemberDeclarations(OutputList &ol) const
bool m_subGrouping
Definition classdef.cpp:527
void writeDocumentationContents(OutputList &ol, const QCString &pageTitle) const
bool hasExamples() const override
StringVector getQualifiers() const override
const MemberDef * isSmartPointer() const override
void updateBaseClasses(const BaseClassList &bcd) override
Update the list of base classes to the one passed.
CLASS_GRAPH_t hasInheritanceGraph() const override
MemberList * getMemberList(MemberListType lt) const override
Returns the members in the list identified by lt.
void setUsedOnly(bool b) override
Protection protection() const override
Return the protection level (Public,Protected,Private) in which this compound was found.
const ArgumentList & typeConstraints() const override
void showUsedFiles(OutputList &ol) const
const Definition * findInnerCompound(const QCString &name) const override
ClassDef * insertTemplateInstance(const QCString &fileName, int startLine, int startColumn, const QCString &templSpec, bool &freshInstance) override
bool isEmbeddedInOuterScope() const override
void sortAllMembersList() override
CompoundType compoundType() const override
Returns the type of compound this is, i.e.
bool isAccessibleMember(const MemberDef *md) const override
returns TRUE iff md is a member of this class or of the the public/protected members of a base class
bool isImplicitTemplateInstance() const override
bool hasNonReferenceSuperClass() const override
void setTemplateMaster(const ClassDef *tm) override
QCString inheritanceGraphFileName() const override
returns the file name to use for the inheritance graph
void setPrimaryConstructorParams(const ArgumentList &list) override
void startMemberDocumentation(OutputList &ol) const
QCString getSourceFileBase() const override
void setProtection(Protection p) override
bool hasDetailedDescription() const override
returns TRUE if this class has a non-empty detailed description
virtual void setGroupDefForAllMembers(GroupDef *g, Grouping::GroupPri_t pri, const QCString &fileName, int startLine, bool hasDocs)=0
virtual void setTemplateArguments(const ArgumentList &al)=0
virtual void setTemplateMaster(const ClassDef *tm)=0
virtual void setImplicitTemplateInstance(bool b)=0
virtual void addMemberToTemplateInstance(const MemberDef *md, const ArgumentList &templateArguments, const QCString &templSpec)=0
virtual void setUsedOnly(bool b)=0
virtual void setCategoryOf(ClassDef *cd)=0
virtual void addMembersToTemplateInstance(const ClassDef *cd, const ArgumentList &templateArguments, const QCString &templSpec)=0
virtual void mergeMembers()=0
Class representing a built-in class diagram.
Definition diagram.h:31
const QCString & name() const override
const Definition * getAlias() const
const Definition * getScope() const
DefinitionAliasMixin(const Definition *scope, const Definition *alias)
The common base class of all entity definitions found in the sources.
Definition definition.h:77
virtual QCString docFile() const =0
virtual const QCString & localName() const =0
virtual SrcLangExt getLanguage() const =0
Returns the programming language this definition was written in.
virtual int docLine() const =0
virtual QCString getDefFileName() const =0
virtual bool isLinkable() const =0
virtual int getDefLine() const =0
virtual DefType definitionType() const =0
virtual QCString anchor() const =0
virtual int inbodyLine() const =0
virtual int briefLine() const =0
virtual bool hasDocumentation() const =0
virtual bool isLinkableInProject() const =0
virtual QCString briefDescription(bool abbreviate=FALSE) const =0
virtual bool isAnonymous() const =0
virtual bool isHidden() const =0
virtual const Definition * findInnerCompound(const QCString &name) const =0
virtual QCString getReference() const =0
virtual QCString getSourceFileBase() const =0
virtual QCString documentation() const =0
virtual QCString qualifiedName() const =0
virtual QCString displayName(bool includeScope=TRUE) const =0
virtual bool isArtificial() const =0
virtual QCString briefFile() const =0
virtual CodeSymbolType codeSymbolType() const =0
virtual QCString getOutputFileBase() const =0
virtual Definition * getOuterScope() const =0
virtual bool isReference() const =0
virtual QCString inbodyDocumentation() const =0
virtual QCString inbodyFile() const =0
virtual const QCString & name() const =0
bool isReference() const override
const QCString & name() const override
void writeSourceDef(OutputList &ol) const override
QCString inbodyFile() const override
QCString getDefFileName() const override
void writeNavigationPath(OutputList &ol) const override
bool hasBriefDescription() const override
QCString docFile() const override
bool hasRequirementRefs() const override
QCString briefFile() const override
QCString qualifiedName() const override
QCString id() const override
void setOuterScope(Definition *def) override
void setReference(const QCString &r) override
void writeRequirementRefs(OutputList &ol) const override
QCString getSourceFileBase() const override
const RefItemVector & xrefListItems() const override
QCString briefDescription(bool abbreviate=FALSE) const override
Definition * getOuterScope() const override
QCString getReference() const override
DefinitionMixin(const QCString &defFileName, int defLine, int defColumn, const QCString &name, const char *b=nullptr, const char *d=nullptr, bool isSymbol=TRUE)
const QCString & localName() const override
const GroupList & partOfGroups() const override
const FileDef * getBodyDef() const override
int getStartBodyLine() const override
QCString inbodyDocumentation() const override
QCString documentation() const override
void writeDocAnchorsToTagFile(TextStream &fs) const override
bool hasDocumentation() const override
SrcLangExt getLanguage() const override
virtual void setHidden(bool b)=0
virtual void addInnerCompound(Definition *d)=0
virtual void setLanguage(SrcLangExt lang)=0
virtual void setOuterScope(Definition *d)=0
virtual void setArtificial(bool b)=0
Representation of a class inheritance or dependency graph.
bool isTooBig() const
bool isTrivial() const
int numNodes() const
static bool suppressDocWarnings
Definition doxygen.h:129
static ClassLinkedMap * classLinkedMap
Definition doxygen.h:95
static NamespaceDefMutable * globalScope
Definition doxygen.h:120
static ClassLinkedMap * hiddenClassLinkedMap
Definition doxygen.h:96
static bool generatingXmlOutput
Definition doxygen.h:133
static MemberNameLinkedMap * memberNameLinkedMap
Definition doxygen.h:110
A model of a file symbol.
Definition filedef.h:99
Minimal replacement for QFileInfo.
Definition fileinfo.h:23
bool exists() const
Definition fileinfo.cpp:30
std::string absFilePath() const
Definition fileinfo.cpp:101
A model of a group of symbols.
Definition groupdef.h:52
virtual bool addClass(ClassDef *def)=0
virtual bool insertMember(MemberDef *def, bool docOnly=FALSE)=0
static LayoutDocManager & instance()
Returns a reference to this singleton.
Definition layout.cpp:1437
bool del(const QCString &key)
Definition linkedmap.h:183
T * add(const char *k, Args &&... args)
Definition linkedmap.h:90
const T * find(const std::string &key) const
Definition linkedmap.h:47
A model of a class/file/namespace member symbol.
Definition memberdef.h:48
virtual QCString typeString() const =0
virtual bool isSignal() const =0
virtual bool isDestructor() const =0
virtual bool isExplicit() const =0
virtual bool isObjCMethod() const =0
virtual bool isMaybeVoid() const =0
virtual bool isConstructor() const =0
virtual bool isFriend() const =0
virtual bool isRelated() const =0
virtual const ClassDef * getClassDef() const =0
virtual bool isOverride() const =0
virtual bool isTypedef() const =0
virtual ClassDef * category() const =0
virtual bool isSlot() const =0
virtual const FileDef * getFileDef() const =0
virtual bool isInline() const =0
virtual const ArgumentList & argumentList() const =0
virtual bool isMaybeAmbiguous() const =0
virtual VhdlSpecifier getVhdlSpecifiers() const =0
virtual bool isFunction() const =0
virtual bool isAttribute() const =0
virtual int getMemberGroupId() const =0
virtual bool isStatic() const =0
virtual bool isMaybeDefault() const =0
virtual bool isRemovable() const =0
virtual bool isConstrained() const =0
virtual bool isReadonly() const =0
virtual bool isBound() const =0
virtual bool isThreadLocal() const =0
virtual ClassDef * getClassDefOfAnonymousType() const =0
virtual std::unique_ptr< MemberDef > createTemplateInstanceMember(const ArgumentList &formalArgs, const std::unique_ptr< ArgumentList > &actualArgs) const =0
virtual bool isTransient() const =0
virtual Protection protection() const =0
virtual TypeSpecifier getMemberSpecifiers() const =0
virtual bool isOptional() const =0
virtual bool isEnumerate() const =0
virtual MemberType memberType() const =0
virtual std::unique_ptr< MemberDef > deepCopy() const =0
virtual QCString memberTypeName() const =0
virtual bool isVariable() const =0
virtual QCString argsString() const =0
virtual Specifier virtualness(int count=0) const =0
virtual bool isUNOProperty() const =0
virtual bool isFinal() const =0
virtual bool isMutable() const =0
virtual bool isEnumValue() const =0
virtual void setMemberType(MemberType t)=0
virtual void setSectionList(const Definition *container, const MemberList *sl)=0
virtual void setCategory(ClassDef *)=0
virtual void setGroupDef(GroupDef *gd, Grouping::GroupPri_t pri, const QCString &fileName, int startLine, bool hasDocs, MemberDef *member=nullptr)=0
virtual void setCategoryRelation(const MemberDef *)=0
A list of MemberDef objects as shown in documentation sections.
Definition memberlist.h:125
void writeDeclarations(OutputList &ol, const ClassDef *cd, const NamespaceDef *nd, const FileDef *fd, const GroupDef *gd, const ModuleDef *mod, const QCString &title, const QCString &subtitle, bool showEnumValues=FALSE, bool showInline=FALSE, const ClassDef *inheritedFrom=nullptr, MemberListType lt=MemberListType::PubMethods(), bool showSectionTitle=true) const
Writes the list of members to the output.
void writeTagFile(TextStream &, bool useQualifiedName=false, bool showNamespaceMembers=true)
void writePlainDeclarations(OutputList &ol, bool inGroup, const ClassDef *cd, const NamespaceDef *nd, const FileDef *fd, const GroupDef *gd, const ModuleDef *mod, int indentLevel, const ClassDef *inheritedFrom, const QCString &inheritId) const
void setAnonymousEnumType()
int countInheritableMembers(const ClassDef *inheritedFrom) const
void writeSimpleDocumentation(OutputList &ol, const Definition *container) const
MemberListType listType() const
Definition memberlist.h:130
void writeDocumentation(OutputList &ol, const QCString &scopeName, const Definition *container, const QCString &title, const QCString &anchor, bool showEnumValues=FALSE, bool showInline=FALSE) const
int numDecMembers(const ClassDef *inheritedFrom) const
Definition memberlist.h:133
bool declVisible() const
Wrapper class for the MemberListType type.
Definition types.h:346
constexpr const char * toLabel() const noexcept
Definition types.h:402
constexpr bool isInvalid() const noexcept
Definition types.h:372
static constexpr MemberListType Invalid() noexcept
Definition types.h:371
void push_back(Ptr &&p)
Definition membername.h:54
bool empty() const
Definition membername.h:135
void push_back(Ptr &&p)
Definition membername.h:141
iterator begin()
Definition membername.h:131
iterator end()
Definition membername.h:132
typename Vec::iterator iterator
Definition membername.h:125
iterator erase(iterator pos)
Definition membername.h:142
Class representing a list of output generators that are written to in parallel.
Definition outputlist.h:315
void writeDoc(const IDocNodeAST *ast, const Definition *ctx, const MemberDef *md, int sectionLevel=-1)
Definition outputlist.h:383
void endTextBlock(bool paraBreak=FALSE)
Definition outputlist.h:672
void endIndent()
Definition outputlist.h:584
void writeString(const QCString &text)
Definition outputlist.h:411
void startMemberDeclaration()
Definition outputlist.h:569
void startMemberDoc(const QCString &clName, const QCString &memName, const QCString &anchor, const QCString &title, int memCount, int memTotal, bool showInline)
Definition outputlist.h:531
void startMemberDocName(bool align)
Definition outputlist.h:680
void startClassDiagram()
Definition outputlist.h:594
void startItemList()
Definition outputlist.h:429
void disable(OutputType o)
void endMemberDocName()
Definition outputlist.h:682
void endMemberDoc(bool hasArgs)
Definition outputlist.h:535
void writeRuler()
Definition outputlist.h:521
void startGroupHeader(const QCString &id=QCString(), int extraLevels=0)
Definition outputlist.h:453
void enable(OutputType o)
void endContents()
Definition outputlist.h:620
void endMemberDescription()
Definition outputlist.h:567
void writeObjectLink(const QCString &ref, const QCString &file, const QCString &anchor, const QCString &name)
Definition outputlist.h:439
void startMemberDescription(const QCString &anchor, const QCString &inheritId=QCString(), bool typ=false)
Definition outputlist.h:565
void endCompoundTemplateParams()
Definition outputlist.h:503
void docify(const QCString &s)
Definition outputlist.h:437
void generateDoc(const QCString &fileName, int startLine, const Definition *ctx, const MemberDef *md, const QCString &docStr, const DocOptions &options)
void startIndent()
Definition outputlist.h:582
void startParagraph(const QCString &classDef=QCString())
Definition outputlist.h:407
void endDescForItem()
Definition outputlist.h:549
void startTextBlock(bool dense=FALSE)
Definition outputlist.h:670
void endExamples()
Definition outputlist.h:580
void endParagraph()
Definition outputlist.h:409
void addIndexItem(const QCString &s1, const QCString &s2)
Definition outputlist.h:590
void startExamples()
Definition outputlist.h:578
void startMemberSections()
Definition outputlist.h:461
void startMemberList()
Definition outputlist.h:481
void endTextLink()
Definition outputlist.h:444
void startItemListItem()
Definition outputlist.h:457
void endItemListItem()
Definition outputlist.h:459
void startBold()
Definition outputlist.h:561
void endMemberItem(OutputGenerator::MemberItemType type)
Definition outputlist.h:495
void writeSynopsis()
Definition outputlist.h:592
void startTypewriter()
Definition outputlist.h:449
void pushGeneratorState()
void insertMemberAlign(bool templ=FALSE)
Definition outputlist.h:517
void startDescForItem()
Definition outputlist.h:547
void disableAllBut(OutputType o)
void popGeneratorState()
void writeSummaryLink(const QCString &file, const QCString &anchor, const QCString &title, bool first)
Definition outputlist.h:614
void writeAnchor(const QCString &fileName, const QCString &name)
Definition outputlist.h:523
void endBold()
Definition outputlist.h:563
void endGroupHeader(int extraLevels=0)
Definition outputlist.h:455
void endClassDiagram(const ClassDiagram &d, const QCString &f, const QCString &n)
Definition outputlist.h:596
void endLabels()
Definition outputlist.h:742
void endQuickIndices()
Definition outputlist.h:604
void writePageOutline()
Definition outputlist.h:616
void endDotGraph(DotClassGraph &g)
Definition outputlist.h:650
void endItemList()
Definition outputlist.h:431
void startDotGraph()
Definition outputlist.h:648
void writeLabel(const QCString &l, bool isLast)
Definition outputlist.h:740
void startLabels()
Definition outputlist.h:738
void startContents()
Definition outputlist.h:618
void startCompoundTemplateParams()
Definition outputlist.h:501
void endMemberDeclaration(const QCString &anchor, const QCString &inheritId)
Definition outputlist.h:571
void enableAll()
void endMemberHeader()
Definition outputlist.h:471
void startMemberItem(const QCString &anchor, OutputGenerator::MemberItemType type, const QCString &id=QCString())
Definition outputlist.h:493
void endTypewriter()
Definition outputlist.h:451
void lineBreak(const QCString &style=QCString())
Definition outputlist.h:559
void parseText(const QCString &textStr)
void startTextLink(const QCString &file, const QCString &anchor)
Definition outputlist.h:442
void startMemberHeader(const QCString &anchor, int typ=2)
Definition outputlist.h:469
void endMemberSections()
Definition outputlist.h:463
This is an alternative implementation of QCString.
Definition qcstring.h:101
int find(char c, int index=0, bool cs=TRUE) const
Definition qcstring.cpp:43
QCString & prepend(const char *s)
Definition qcstring.h:422
size_t length() const
Returns the length of the string, not counting the 0-terminator.
Definition qcstring.h:166
bool startsWith(const char *s) const
Definition qcstring.h:507
QCString mid(size_t index, size_t len=static_cast< size_t >(-1)) const
Definition qcstring.h:241
QCString lower() const
Definition qcstring.h:249
bool endsWith(const char *s) const
Definition qcstring.h:524
bool isEmpty() const
Returns TRUE iff the string is empty.
Definition qcstring.h:163
QCString stripWhiteSpace() const
returns a copy of this string with leading and trailing whitespace removed
Definition qcstring.h:260
QCString right(size_t len) const
Definition qcstring.h:234
const char * data() const
Returns a pointer to the contents of the string in the form of a 0-terminated C string.
Definition qcstring.h:172
QCString left(size_t len) const
Definition qcstring.h:229
void clear()
Definition qcstring.h:182
static RequirementManager & instance()
void addRequirementRefsForSymbol(const Definition *symbol)
ClassDefMutable * resolveClassMutable(const Definition *scope, const QCString &name, bool mayBeUnlinkable=false, bool mayBeHidden=false)
Wrapper around resolveClass that returns a mutable interface to the class object or a nullptr if the ...
Implements TextGeneratorIntf for an OutputDocInterface stream.
Definition util.h:76
Text streaming class that buffers data.
Definition textstream.h:36
Wrapper class for a number of boolean properties.
Definition types.h:654
@ ARCHITECTURECLASS
Definition vhdldocgen.h:77
static QCString getClassName(const ClassDef *)
static QCString getProtectionName(int prot)
static void writeInlineClassLink(const ClassDef *, OutputList &ol)
static void writeVhdlDeclarations(const MemberList *, OutputList &, const GroupDef *, const ClassDef *, const FileDef *, const NamespaceDef *, const ModuleDef *)
static VhdlClasses convert(Protection prot)
Definition vhdldocgen.h:80
static QCString getClassTitle(const ClassDef *)
static QCString makeQualifiedNameWithTemplateParameters(const ClassDef *cd, const ArgumentLists *actualParams, uint32_t *actualParamIndex)
Definition classdef.cpp:56
static QCString getCompoundTypeString(SrcLangExt lang, ClassDef::CompoundType compType, bool isJavaEnum)
Definition classdef.cpp:146
ClassDefMutable * toClassDefMutable(Definition *d)
static bool hasNonReferenceSuperClassRec(const ClassDef *cd, int level)
static QCString makeDisplayName(const ClassDef *cd, bool includeScope)
Definition classdef.cpp:107
int minClassDistance(const ClassDef *cd, const ClassDef *bcd, int level)
static bool isStandardFunc(const MemberDef *md)
ClassDef * getClass(const QCString &n)
std::unique_ptr< ClassDef > createClassDefAlias(const Definition *newScope, const ClassDef *cd)
Definition classdef.cpp:792
static void writeInheritanceSpecifier(OutputList &ol, const BaseClassDef &bcd)
bool classHasVisibleRoot(const BaseClassList &bcl)
std::unique_ptr< ClassDef > createClassDef(const QCString &fileName, int startLine, int startColumn, const QCString &name, ClassDef::CompoundType ct, const QCString &ref, const QCString &fName, bool isSymbol, bool isJavaEnum)
Factory method to create a new ClassDef object.
Definition classdef.cpp:563
static void searchTemplateSpecs(const Definition *d, ArgumentLists &result, QCString &name, SrcLangExt lang)
bool classVisibleInIndex(const ClassDef *cd)
ClassDef * toClassDef(Definition *d)
Protection classInheritedProtectionLevel(const ClassDef *cd, const ClassDef *bcd, Protection prot, int level)
bool classHasVisibleChildren(const ClassDef *cd)
std::vector< BaseClassDef > BaseClassList
Definition classdef.h:81
std::unordered_set< const ClassDef * > ClassDefSet
Definition classdef.h:95
std::map< std::string, int > TemplateNameMap
Definition classdef.h:93
std::vector< TemplateInstanceDef > TemplateInstanceList
Definition classdef.h:91
#define Config_getInt(name)
Definition config.h:34
#define Config_getList(name)
Definition config.h:38
#define Config_getBool(name)
Definition config.h:33
#define Config_getString(name)
Definition config.h:32
#define Config_getEnum(name)
Definition config.h:35
#define NON_COPYABLE(cls)
Macro to help implementing the rule of 5 for a non-copyable & movable class.
Definition construct.h:37
std::set< std::string > StringSet
Definition containers.h:31
std::vector< std::string > StringVector
Definition containers.h:33
std::unique_ptr< ArgumentList > stringToArgumentList(SrcLangExt lang, const QCString &argsString, QCString *extraTypeChars=nullptr)
Definition defargs.l:822
Definition * toDefinition(DefinitionMutable *dm)
#define AUTO_TRACE_ADD(...)
Definition docnode.cpp:48
#define AUTO_TRACE(...)
Definition docnode.cpp:47
#define AUTO_TRACE_EXIT(...)
Definition docnode.cpp:49
void docFindSections(const QCString &input, const Definition *d, const QCString &fileName)
IDocNodeASTPtr validatingParseDoc(IDocParser &parserIntf, const QCString &fileName, int startLine, const Definition *ctx, const MemberDef *md, const QCString &input, const DocOptions &options)
IDocParserPtr createDocParser()
factory function to create a parser
Definition docparser.cpp:55
@ Collaboration
Definition dotgraph.h:31
@ Inheritance
Definition dotgraph.h:31
static bool isSpecialization(const ArgumentLists &srcTempArgLists, const ArgumentLists &dstTempArgLists)
Definition doxygen.cpp:6010
static void writeTagFile()
QCString includeClose(SrcLangExt lang, IncludeKind kind)
Definition filedef.cpp:85
QCString includeStatement(SrcLangExt lang, IncludeKind kind)
Definition filedef.cpp:55
FileDef * toFileDef(Definition *d)
Definition filedef.cpp:1966
QCString includeOpen(SrcLangExt lang, IncludeKind kind)
Definition filedef.cpp:72
@ IncludeLocal
Definition filedef.h:50
@ IncludeSystem
Definition filedef.h:49
void startTitle(OutputList &ol, const QCString &fileName, const DefinitionMutable *def)
Definition index.cpp:386
void endFile(OutputList &ol, bool skipNavIndex, bool skipEndContents, const QCString &navPath)
Definition index.cpp:429
void endTitle(OutputList &ol, const QCString &fileName, const QCString &name)
Definition index.cpp:396
void startFile(OutputList &ol, const QCString &name, bool isSource, const QCString &manName, const QCString &title, HighlightedItem hli, bool additionalIndices, const QCString &altSidebarName, int hierarchyLevel, const QCString &allMembersFile)
Definition index.cpp:403
void endFileWithNavPath(OutputList &ol, const DefinitionMutable *d, bool showPageNavigation)
Definition index.cpp:450
HighlightedItem
Definition index.h:59
@ InterfaceVisible
Definition index.h:89
@ ExceptionVisible
Definition index.h:91
Translator * theTranslator
Definition language.cpp:71
MemberDefMutable * toMemberDefMutable(Definition *d)
void combineDeclarationAndDefinition(MemberDefMutable *mdec, MemberDefMutable *mdef)
#define warn_uncond(fmt,...)
Definition message.h:122
#define warn(file, line, fmt,...)
Definition message.h:97
#define msg(fmt,...)
Definition message.h:94
#define err(fmt,...)
Definition message.h:127
ModuleDef * toModuleDef(Definition *d)
int qstricmp(const char *s1, const char *s2)
Definition qcstring.cpp:530
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 TRUE
Definition qcstring.h:37
#define FALSE
Definition qcstring.h:34
Web server based search engine.
This class contains the information about the argument of a function or template.
Definition arguments.h:27
QCString type
Definition arguments.h:42
QCString name
Definition arguments.h:44
QCString defval
Definition arguments.h:46
Class that contains information about an inheritance relation.
Definition classdef.h:55
ClassDef * classDef
Class definition that this relation inherits from.
Definition classdef.h:60
QCString templSpecifiers
Template arguments used for the base class.
Definition classdef.h:78
Specifier virt
Virtualness of the inheritance relation: Normal, or Virtual.
Definition classdef.h:75
Protection prot
Protection level of the inheritance relation: Public, Protected, or Private.
Definition classdef.h:70
Data associated with an example.
Definition example.h:29
GroupPri_t
Grouping priority.
Definition types.h:230
Class representing the data associated with a #include statement.
Definition filedef.h:75
Represents of a member declaration list with configurable title and subtitle.
Definition layout.h:112
QCString title(SrcLangExt lang) const
Definition layout.cpp:1788
MemberListType type
Definition layout.h:118
QCString subtitle(SrcLangExt lang) const
Definition layout.cpp:1793
Represents of a member definition list with configurable title.
Definition layout.h:132
MemberListType type
Definition layout.h:137
QCString title(SrcLangExt lang) const
Definition layout.cpp:1800
Definition layout.h:102
QCString title(SrcLangExt lang) const
Definition layout.cpp:1781
This file contains a number of basic enums and types.
CodeSymbolType
Definition types.h:481
MemberType
Definition types.h:552
@ Enumeration
Definition types.h:557
@ EnumValue
Definition types.h:558
@ Interface
Definition types.h:565
@ Variable
Definition types.h:555
@ Property
Definition types.h:563
@ Typedef
Definition types.h:556
@ Function
Definition types.h:554
@ Service
Definition types.h:566
Protection
Definition types.h:32
SrcLangExt
Definition types.h:207
Specifier
Definition types.h:80
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:2021
QCString removeRedundantWhiteSpace(const QCString &s)
Definition util.cpp:567
SrcLangExt getLanguageFromFileName(const QCString &fileName, SrcLangExt defLang)
Definition util.cpp:5214
QCString insertTemplateSpecifierInScope(const QCString &scope, const QCString &templ)
Definition util.cpp:3750
bool protectionLevelVisible(Protection prot)
Definition util.cpp:5960
QCString convertToHtml(const QCString &s, bool keepEntities)
Definition util.cpp:3967
void writeTypeConstraints(OutputList &ol, const Definition *d, const ArgumentList &al)
Definition util.cpp:5462
QCString tempArgListToString(const ArgumentList &al, SrcLangExt lang, bool includeDefault)
Definition util.cpp:1299
void addRefItem(const RefItemVector &sli, const QCString &key, const QCString &prefix, const QCString &name, const QCString &title, const QCString &args, const Definition *scope)
Definition util.cpp:4828
void addGroupListToTitle(OutputList &ol, const Definition *d)
Definition util.cpp:4915
QCString demangleCSharpGenericName(const QCString &name, const QCString &templArgs)
Definition util.cpp:6946
QCString removeAnonymousScopes(const QCString &str)
Definition util.cpp:161
void createSubDirs(const Dir &d)
Definition util.cpp:3644
QCString stripScope(const QCString &name)
Definition util.cpp:3783
QCString inlineTemplateArgListToDoc(const ArgumentList &al)
Definition util.cpp:1227
QCString stripExtension(const QCString &fName)
Definition util.cpp:4947
static QCString stripFromPath(const QCString &p, const StringVector &l)
Definition util.cpp:298
QCString convertNameToFile(const QCString &name, bool allowDots, bool allowUnderscore)
Definition util.cpp:3508
QCString convertToXML(const QCString &s, bool keepEntities)
Definition util.cpp:3916
EntryType guessSection(const QCString &name)
Definition util.cpp:338
void convertProtectionLevel(MemberListType inListType, Protection inProt, MemberListType *outListType1, MemberListType *outListType2)
Computes for a given list type inListType, which are the the corresponding list type(s) in the base c...
Definition util.cpp:6252
QCString argListToString(const ArgumentList &al, bool useCanonicalType, bool showDefVals)
Definition util.cpp:1254
QCString getLanguageSpecificSeparator(SrcLangExt lang, bool classScope)
Returns the scope separator to use given the programming language lang.
Definition util.cpp:5920
void linkifyText(const TextGeneratorIntf &out, const QCString &text, const LinkifyTextOptions &options)
Definition util.cpp:893
void writeMarkerList(OutputList &ol, const std::string &markerText, size_t numMarkers, std::function< void(size_t)> replaceFunc)
Definition util.cpp:1124
QCString convertToId(const QCString &s)
Definition util.cpp:3876
void writeExamples(OutputList &ol, const ExampleList &list)
Definition util.cpp:1175
void addHtmlExtensionIfMissing(QCString &fName)
Definition util.cpp:4925
A bunch of utility functions.