Doxygen
Loading...
Searching...
No Matches
memberlist.cpp
Go to the documentation of this file.
1/******************************************************************************
2 *
3 *
4 *
5 * Copyright (C) 1997-2015 by Dimitri van Heesch.
6 *
7 * Permission to use, copy, modify, and distribute this software and its
8 * documentation under the terms of the GNU General Public License is hereby
9 * granted. No representations are made about the suitability of this software
10 * for any purpose. It is provided "as is" without express or implied warranty.
11 * See the GNU General Public License for more details.
12 *
13 * Documents produced by Doxygen are derivative works derived from the
14 * input used in their production; they are not affected by this license.
15 *
16 */
17
18#include "memberlist.h"
19#include "classdef.h"
20#include "message.h"
21#include "util.h"
22#include "language.h"
23#include "doxygen.h"
24#include "outputlist.h"
25#include "groupdef.h"
26#include "vhdldocgen.h"
27#include "namespacedef.h"
28#include "filedef.h"
29#include "membergroup.h"
30#include "config.h"
31#include "docparser.h"
32#include "moduledef.h"
33
35{
36 //printf("%p: MemberList::MemberList(%d)\n",this,lt);
37 m_numDecMembers=-1; // special value indicating that value needs to be computed
39 m_numDocMembers=-1; // special value indicating that value needs to be computed
42}
43
47
49{
50 bool sortConstructorsFirst = Config_getBool(SORT_MEMBERS_CTORS_1ST);
51 if (sortConstructorsFirst)
52 {
53 int ord1 = c1->isConstructor() ? 2 : (c1->isDestructor() ? 1 : 0);
54 int ord2 = c2->isConstructor() ? 2 : (c2->isDestructor() ? 1 : 0);
55 if (ord1 > ord2)
56 return -1;
57 else if (ord2 > ord1)
58 return 1;
59 }
60 // sort on name, first case in-sensitive
61 int cmp = qstricmp_sort(c1->name(),c2->name());
62 // then on qualified name
63 if (cmp==0)
64 {
65 cmp = qstricmp_sort(c1->qualifiedName(),c2->qualifiedName());
66 }
67 // then on argument list
68 if (cmp==0 && !c1->argsString().isEmpty() && !c2->argsString().isEmpty())
69 {
70 cmp = qstricmp_sort(c1->argsString(),c2->argsString());
71 }
72 // then on file in which the item is defined
73 if (cmp==0)
74 {
76 }
77 // then on line number at which the member is defined
78 if (cmp==0)
79 {
80 cmp = c2->getDefLine()-c1->getDefLine();
81 }
82 return cmp;
83}
84
85int MemberList::countInheritableMembers(const ClassDef *inheritedFrom) const
86{
87 int count=0;
88 for (const auto &md : m_members)
89 {
90 if (md->isBriefSectionVisible())
91 {
92 if (md->memberType()!=MemberType::Friend &&
93 md->memberType()!=MemberType::EnumValue)
94 {
95 //printf("member %s: isReimplementedBy(%s)=%d\n",qPrint(md->name()),
96 // qPrint(inheritedFrom->name()),
97 // md->isReimplementedBy(inheritedFrom));
98 if (md->memberType()==MemberType::Function)
99 {
100 if (!md->isReimplementedBy(inheritedFrom)) count++;
101 }
102 else
103 {
104 count++;
105 }
106 }
107 }
108 }
109 for (const auto &mg : m_memberGroupRefList)
110 {
111 count+=mg->countInheritableMembers(inheritedFrom);
112 }
113 //printf("%s::countInheritableMembers(%s)=%d\n",
114 // qPrint(m_listType.toLabel()),
115 // qPrint(inheritedFrom->name()),count);
116 return count;
117}
118
119/*! Count the number of members in this list that are visible in
120 * the declaration part of a compound's documentation page.
121 */
122std::pair<int,int> MemberList::countDecMembers(const ClassDef *inheritedFrom) const
123{
124 //printf("----- countDecMembers count=%d ----\n",count());
125 int numDecMembers=0;
126 int numDecEnumValues=0;
127 for (const auto &md : m_members)
128 {
129 //printf("MemberList::countDecMembers(md=%s,%d)\n",qPrint(md->name()),md->isBriefSectionVisible());
130 if ((inheritedFrom==nullptr || !md->isReimplementedBy(inheritedFrom)) &&
131 md->isBriefSectionVisible())
132 {
133 switch(md->memberType())
134 {
135 case MemberType::Variable: // fall through
136 case MemberType::Event: // fall through
137 case MemberType::Property: numDecMembers++;
138 break;
139// apparently necessary to get this to show up in declarations section?
140 case MemberType::Interface: // fall through
141 case MemberType::Service: // fall through
142 case MemberType::Function: // fall through
143 case MemberType::Signal: // fall through
144 case MemberType::DCOP: // fall through
145 case MemberType::Slot: if (!md->isRelated() || md->getClassDef())
147 break;
148 case MemberType::Enumeration:
150 break;
151 case MemberType::EnumValue: numDecEnumValues++;
153 break;
154 case MemberType::Typedef: numDecMembers++;
155 break;
156 case MemberType::Sequence: numDecMembers++;
157 break;
158 case MemberType::Dictionary: numDecMembers++;
159 break;
160 case MemberType::Define: if (Config_getBool(EXTRACT_ALL) ||
161 !md->argsString().isEmpty() ||
162 !md->initializer().isEmpty() ||
163 md->hasDocumentation()
164 ) numDecMembers++;
165 break;
166 case MemberType::Friend: numDecMembers++;
167 break;
168 default:
169 err("Unknown member type found for member '{}'!\n",md->name());
170 }
171 }
172 }
173 for (const auto &mg : m_memberGroupRefList)
174 {
175 mg->countDecMembers();
176 numDecMembers+=mg->numDecMembers();
177 numDecEnumValues+=mg->numDecEnumValues();
178 }
179 //printf("----- end countDecMembers ----\n");
180
181 return std::make_pair(numDecMembers,numDecEnumValues);
182}
183
185{
186 if (m_numDecMembers!=-1) return; // already cached
187 std::tie(m_numDecMembers, m_numDecEnumValues) = countDecMembers(nullptr); // cache new values
188}
189
191{
192 if (m_numDocMembers!=-1) return; // used cached value
194 for (const auto &md : m_members)
195 {
196 if (md->isDetailedSectionVisible(m_container) && !md->isAlias())
197 {
198 // do not count enum values, since they do not produce entries of their own
199 if (md->memberType()==MemberType::EnumValue)
200 {
202 }
204 }
205 }
206 for (const auto &mg : m_memberGroupRefList)
207 {
208 mg->countDocMembers();
209 m_numDocMembers+=mg->numDocMembers();
210 m_numDocEnumValues+=mg->numDocEnumValues();
211 }
212 //printf("MemberList::countDocMembers()=%d memberGroupList=%p\n",m_numDocMembers,memberGroupList);
213}
214
216{
217 //printf("MemberList(%p)::setAnonymousEnumType()\n",this);
218 for (const auto &md : m_members)
219 {
220 if (md->isBriefSectionVisible())
221 {
222 QCString name(md->name());
223 int i=name.findRev("::");
224 if (i!=-1) name=name.right(name.length()-i-2);
225 if (md->memberType()==MemberType::Enumeration && name[0]=='@')
226 {
227 for (const auto &vmd : md->enumFieldList())
228 {
230 if (vmdm)
231 {
232 QCString vtype=vmd->typeString();
233 if ((vtype.find(name))!=-1)
234 {
235 vmdm->setAnonymousEnumType(md);
236 }
237 }
238 }
239 }
240 }
241 }
242 for (const auto &mg : m_memberGroupRefList)
243 {
244 mg->setAnonymousEnumType();
245 }
246}
247
249{
250 int numEnumValues=0;
251 QCString name(md->name());
252 int i=name.findRev("::");
253 if (i!=-1) name=name.right(name.length()-i-2);
254 if (name[0]=='@')
255 {
256 for (const auto &vmd : m_members)
257 {
258 QCString vtype=vmd->typeString();
259 if ((vtype.find(name))!=-1)
260 {
261 numEnumValues++;
262 }
263 }
264 }
265 return numEnumValues;
266}
267
269{
270 for (const auto &md : m_members)
271 {
272 if (md->isBriefSectionVisible())
273 {
274 switch (md->memberType())
275 {
276 case MemberType::Define: // fall through
277 case MemberType::Typedef: // fall through
278 case MemberType::Variable: // fall through
279 case MemberType::Function: // fall through
280 case MemberType::Signal: // fall through
281 case MemberType::Slot: // fall through
282 case MemberType::DCOP: // fall through
283 case MemberType::Property: // fall through
284 case MemberType::Interface: // fall through
285 case MemberType::Service: // fall through
286 case MemberType::Sequence: // fall through
287 case MemberType::Dictionary: // fall through
288 case MemberType::Event:
289 return TRUE;
290 case MemberType::Enumeration:
291 {
292 // if this is an anonymous enum and there are variables of this
293 // enum type (i.e. enumVars>0), then we do not show the enum here.
294 if (countEnumValues(md)==0) // show enum here
295 {
296 return TRUE;
297 }
298 }
299 break;
300 case MemberType::Friend:
301 return TRUE;
302 case MemberType::EnumValue:
303 {
305 {
306 return TRUE;
307 }
308 }
309 break;
310 }
311 }
312 }
313 return FALSE;
314}
315
317 const ClassDef *cd,const NamespaceDef *nd,const FileDef *fd, const GroupDef *gd,const ModuleDef *mod,
318 int indentLevel, const ClassDef *inheritedFrom,const QCString &inheritId
319 ) const
320{
321 //printf("----- writePlainDeclaration() ----\n");
322 if (numDecMembers()==-1)
323 {
324 err("MemberList::numDecMembers()==-1, so the members of this list have not been counted. Please report as a bug.\n");
325 abort();
326 }
328 {
329 //printf(" --> no members!\n");
330 return; // no members in this list
331 }
332 //printf(" --> writePlainDeclaration() numDecMembers()=%d\n",
333 // numDecMembers());
334
336
337 bool first=TRUE;
338 for (const auto &md : m_members)
339 {
340 //printf(">>> Member '%s' type=%d visible=%d inheritedFrom=%p inheritId=%s\n",
341 // qPrint(md->name()),md->memberType(),md->isBriefSectionVisible(),(void*)inheritedFrom,qPrint(inheritId));
342 if ((inheritedFrom==nullptr || !md->isReimplementedBy(inheritedFrom)) &&
343 md->isBriefSectionVisible())
344 {
345 //printf(">>> rendering\n");
346 switch(md->memberType())
347 {
348 case MemberType::Define: // fall through
349 //case MemberType::Prototype: // fall through
350 case MemberType::Typedef: // fall through
351 case MemberType::Variable: // fall through
352 case MemberType::Function: // fall through
353 case MemberType::Signal: // fall through
354 case MemberType::Slot: // fall through
355 case MemberType::DCOP: // fall through
356 case MemberType::Property: // fall through
357 case MemberType::Interface: // fall through
358 case MemberType::Service: // fall through
359 case MemberType::Sequence: // fall through
360 case MemberType::Dictionary: // fall through
361 case MemberType::Event:
362 {
363 if (first) ol.startMemberList(),first=FALSE;
364 md->writeDeclaration(ol,cd,nd,fd,gd,mod,inGroup,indentLevel,inheritedFrom,inheritId);
365 break;
366 }
367 case MemberType::Enumeration:
368 {
369 // if this is an anonymous enum and there are variables of this
370 // enum type (i.e. enumVars>0), then we do not show the enum here.
371 if (countEnumValues(md)==0) // show enum here
372 {
373 //printf("Enum!!\n");
374 if (first)
375 {
376 ol.startMemberList();
377 first=FALSE;
378 }
381 bool detailsLinkable = md->hasDetailedDescription();
382 if (!detailsLinkable)
383 {
384 ol.startDoxyAnchor(md->getOutputFileBase(),QCString(),md->anchor(),md->name(),QCString());
385 ol.addLabel(md->getOutputFileBase(),md->anchor());
386 }
387 if (md->isSliceLocal())
388 {
389 ol.writeString("local ");
390 }
391 ol.writeString("enum ");
392 if (md->getLanguage()==SrcLangExt::Cpp && md->isStrong())
393 {
394 if (md->isEnumStruct())
395 {
396 ol.writeString("struct ");
397 }
398 else
399 {
400 ol.writeString("class ");
401 }
402 }
404 md->writeEnumDeclaration(ol,cd,nd,fd,gd,mod);
405 if (!detailsLinkable)
406 {
407 ol.endDoxyAnchor(md->getOutputFileBase(),md->anchor());
408 }
410 if (!md->briefDescription().isEmpty() && Config_getBool(BRIEF_MEMBER_DESC))
411 {
412 auto parser { createDocParser() };
413 auto ast { validatingParseDoc(*parser.get(),
414 md->briefFile(),
415 md->briefLine(),
416 cd ? cd : md->getOuterScope(),
417 md,
418 md->briefDescription(),
419 DocOptions()
420 .setIndexWords(true)
421 .setSingleLine(true))
422 };
423 if (!ast->isEmpty())
424 {
425 ol.startMemberDescription(md->anchor(),inheritId);
426 ol.writeDoc(ast.get(),cd,md);
427 if (md->hasDetailedDescription())
428 {
430 ol.docify(" ");
431 ol.startTextLink(md->getOutputFileBase(),
432 md->anchor());
433 ol.parseText(theTranslator->trMore());
434 ol.endTextLink();
435 ol.enableAll();
436 }
438 }
439 }
440 ol.endMemberDeclaration(md->anchor(),inheritId);
441 }
442 md->warnIfUndocumented();
443 break;
444 }
445 case MemberType::Friend:
446 if (inheritedFrom==nullptr)
447 {
448 if (first)
449 {
450 ol.startMemberList();
451 first=FALSE;
452 }
453 md->writeDeclaration(ol,cd,nd,fd,gd,mod,inGroup,indentLevel,inheritedFrom,inheritId);
454 break;
455 }
456 case MemberType::EnumValue:
457 {
458 if (inGroup)
459 {
460 //printf("EnumValue!\n");
461 if (first) ol.startMemberList(),first=FALSE;
462 md->writeDeclaration(ol,cd,nd,fd,gd,mod,true,indentLevel,inheritedFrom,inheritId);
463 }
464 }
465 break;
466 }
467 }
468 }
469
470 if (!first)
471 {
472 ol.endMemberList();
473 }
474
476 //printf("----- end writePlainDeclaration() ----\n");
477}
478
479/** Writes the list of members to the output.
480 * @param ol Output list to write to
481 * @param cd non-null if this list is part of class documentation.
482 * @param nd non-null if this list is part of namespace documentation.
483 * @param fd non-null if this list is part of file documentation.
484 * @param gd non-null if this list is part of group documentation.
485 * @param mod non-null if this list is part of module documentation.
486 * @param title Title to use for the member list.
487 * @param subtitle Sub title to use for the member list.
488 * @param showEnumValues Obsolete, always set to FALSE.
489 * @param showInline if set to TRUE if title is rendered differently
490 * @param inheritedFrom if not 0, the list is shown inside the
491 * given class as inherited members, parameter cd points to the
492 * class containing the members.
493 * @param lt Type of list that is inherited from.
494 * @param showSectionTitle do we show the "additional members" header or not?
495 * When combining public and protected inherited members under a single header only for the first list it should be shown
496 */
498 const ClassDef *cd,const NamespaceDef *nd,const FileDef *fd,const GroupDef *gd,const ModuleDef *mod,
499 const QCString &title,const QCString &subtitle, bool /*showEnumValues*/,
500 bool showInline,const ClassDef *inheritedFrom,MemberListType lt,bool showSectionTitle) const
501{
502 //printf("----- writeDeclaration() this=%p ---- inheritedFrom=%p\n",this,inheritedFrom);
503 bool optimizeVhdl = Config_getBool(OPTIMIZE_OUTPUT_VHDL);
504 QCString inheritId;
505
506 const Definition *ctx = cd;
507 if (ctx==nullptr && nd) ctx = nd;
508 if (ctx==nullptr && gd) ctx = gd;
509 if (ctx==nullptr && mod) ctx = mod;
510 if (ctx==nullptr && fd) ctx = fd;
511
512 //printf("%p: MemberList::writeDeclaration(title='%s',subtitle='%s')=%d inheritedFrom=%p\n",
513 // (void*)this,qPrint(title),qPrint(subtitle),numDecMembers(),(void*)inheritedFrom);
514
515 int num = numDecMembers(inheritedFrom);
516 int numEnumValues = numDecEnumValues();
517 if (inheritedFrom && num>0)
518 {
519 if (cd && !optimizeVhdl)
520 {
521 inheritId = substitute(lt.toLabel(),"-","_")+"_"+
523 if (showSectionTitle && !title.isEmpty())
524 {
525 ol.writeInheritedSectionTitle(inheritId,cd->getReference(),
526 cd->getOutputFileBase(),
527 cd->anchor(),title,cd->displayName());
528 }
529 }
530 }
531 else if (num>numEnumValues)
532 {
533 if (!title.isEmpty())
534 {
535 if (showInline)
536 {
538 }
539 else
540 {
541 ol.startMemberHeader(m_listType.toLabel());
542 }
543 ol.parseText(title);
544 if (showInline)
545 {
546 ol.endInlineHeader();
547 }
548 else
549 {
550 ol.endMemberHeader();
551 }
552 }
553 if (!subtitle.stripWhiteSpace().isEmpty())
554 {
556 ol.generateDoc("[generated]", -1, ctx, nullptr, subtitle, DocOptions());
558 }
559 }
560 if (num>numEnumValues)
561 {
563 // TODO: Two things need to be worked out for proper VHDL output:
564 // 1. Signals and types under the group need to be
565 // formatted to associate them with the group somehow
566 // indentation, or at the very least, extra space after
567 // the group is done
568 // 2. This might need to be repeated below for memberGroupLists
569 if (optimizeVhdl) // use specific declarations function
570 {
571 VhdlDocGen::writeVhdlDeclarations(this,ol,nullptr,cd,nullptr,nullptr,nullptr);
572 }
573 else
574 {
575 writePlainDeclarations(ol,inGroup,cd,nd,fd,gd,mod,0,inheritedFrom,inheritId);
576 }
577
578 //printf("memberGroupList=%p\n",memberGroupList);
579 int groupId=0;
580 for (const auto &mg : m_memberGroupRefList)
581 {
582 bool hasHeader=!mg->header().isEmpty();
583 if (inheritId.isEmpty())
584 {
585 QCString groupAnchor = QCString(listType().toLabel())+"-"+QCString().setNum(groupId++);
586 //printf("mg->header=%s hasHeader=%d\n",qPrint(mg->header()),hasHeader);
587 ol.startMemberGroupHeader(groupAnchor,hasHeader);
588 if (hasHeader)
589 {
590 ol.parseText(mg->header());
591 }
592 ol.endMemberGroupHeader(hasHeader);
593 if (!mg->documentation().isEmpty())
594 {
595 //printf("Member group has docs!\n");
597 ol.generateDoc(mg->docFile(),
598 mg->docLine(),
599 mg->memberContainer(),
600 nullptr,
601 mg->documentation()+"\n",
602 DocOptions());
604 }
605 ol.startMemberGroup();
606 }
607 //printf("--- mg->writePlainDeclarations ---\n");
608 mg->writePlainDeclarations(ol,inGroup,cd,nd,fd,gd,mod,0,inheritedFrom,inheritId);
609 if (inheritId.isEmpty())
610 {
611 ol.endMemberGroup(hasHeader);
612 }
613 }
614 }
615 if (inheritedFrom && cd)
616 {
617 // also add members that of this list type, that are grouped together
618 // in a separate list in class 'inheritedFrom'
619 cd->addGroupedInheritedMembers(ol,m_listType,inheritedFrom,inheritId);
620 }
621 //printf("----- end writeDeclaration() ----\n");
622}
623
625 const QCString &scopeName, const Definition *container,
626 const QCString &title,const QCString &anchor,
627 bool showEnumValues,bool showInline) const
628{
629 if (numDocMembers()==-1)
630 {
631 err("MemberList::numDocMembers()==-1, so the members of this list have not been counted. Please report as a bug.\n");
632 abort();
633 }
634
635 if (numDocMembers()==0) return;
636 if (!showEnumValues && numDocMembers()<=numDocEnumValues()) return;
637
638 if (!title.isEmpty())
639 {
642 ol.writeRuler();
644 if (container) ol.writeAnchor(container->getOutputFileBase(),anchor);
645 ol.startGroupHeader(anchor,showInline ? 2 : 0);
646 ol.parseText(title);
647 ol.endGroupHeader(showInline ? 2 : 0);
648 }
650
651 struct OverloadInfo
652 {
653 uint32_t count = 1;
654 uint32_t total = 0;
655 };
656 std::unordered_map<std::string,OverloadInfo> overloadInfo;
657 // count the number of overloaded members
658 for (const auto &md : m_members)
659 {
660 if (md->isDetailedSectionVisible(m_container) &&
661 !(md->isEnumValue() && !showInline))
662 {
663 auto it = overloadInfo.emplace(md->name().str(),OverloadInfo()).first;
664 it->second.total++;
665 }
666 }
667
668 for (const auto &md : m_members)
669 {
670 if (md->isDetailedSectionVisible(m_container) &&
671 !(md->isEnumValue() && !showInline))
672 {
673 auto it = overloadInfo.find(md->name().str());
674 uint32_t overloadCount = it->second.total;
675 uint32_t &count = it->second.count;
677 if (mdm)
678 {
679 mdm->writeDocumentation(this,count++,overloadCount,ol,scopeName,container,
680 m_container==MemberListContainer::Group,showEnumValues,showInline);
681 }
682 }
683 }
684 //printf("MemberList::writeDocumentation() -- member groups %d\n",memberGroupList->count());
685 for (const auto &mg : m_memberGroupRefList)
686 {
687 mg->writeDocumentation(ol,scopeName,container,showEnumValues,showInline);
688 }
689 ol.endMemberDocList();
690}
691
692// members in a table
694 const Definition *container) const
695{
696 //printf("MemberList count=%d enumValues=%d\n",numDocMembers(),numDocEnumValues());
697 if (numDocMembers()<=numDocEnumValues()) return; // only enum values and they should be excluded
698
699 const ClassDef *cd = nullptr;
700 if (container && container->definitionType()==Definition::TypeClass)
701 {
702 cd = toClassDef(container);
703 }
704 ol.startMemberDocSimple(cd && cd->isJavaEnum());
705 for (const auto &md : m_members)
706 {
708 if (mdm)
709 {
711 }
712 }
713 ol.endMemberDocSimple(cd && cd->isJavaEnum());
714}
715
716// separate member pages
718 const QCString &scopeName, const DefinitionMutable *container, int hierarchyLevel) const
719{
720 bool generateTreeView = Config_getBool(GENERATE_TREEVIEW);
721
722 struct OverloadInfo
723 {
724 uint32_t count = 1;
725 uint32_t total = 0;
726 };
727 std::unordered_map<std::string,OverloadInfo> overloadInfo;
728
729 // count the number of overloaded members
730 for (const auto &imd : m_members)
731 {
733
734 if (md && md->hasDetailedDescription())
735 {
736 auto it = overloadInfo.emplace(md->name().str(),OverloadInfo()).first;
737 it->second.total++;
738 }
739 }
740
741 for (const auto &imd : m_members)
742 {
743 Definition *container_d = toDefinition(const_cast<DefinitionMutable*>(container));
745 if (md && md->hasDetailedDescription())
746 {
747 auto it = overloadInfo.find(md->name().str());
748 uint32_t overloadCount = it->second.total;
749 uint32_t &count = it->second.count;
750 QCString diskName=md->getOutputFileBase();
751 QCString title=md->qualifiedName();
752 startFile(ol,diskName,false,md->name(),title,HighlightedItem::None,!generateTreeView,diskName, hierarchyLevel);
753 if (!generateTreeView)
754 {
755 container->writeNavigationPath(ol);
756 ol.endQuickIndices();
757 }
758 ol.startContents();
759
760 if (generateTreeView)
761 {
762 md->writeDocumentation(this,count++,overloadCount,ol,scopeName,container_d,m_container==MemberListContainer::Group);
763
764 ol.endContents();
766 }
767 else
768 {
769 ol.writeString("<table cellspacing=\"0\" cellpadding=\"0\" border=\"0\">\n"
770 " <tr>\n"
771 " <td valign=\"top\">\n");
772
773 container->writeQuickMemberLinks(ol,md);
774
775 ol.writeString(" </td>\n");
776 ol.writeString(" <td valign=\"top\" class=\"mempage\">\n");
777
778 md->writeDocumentation(this,count++,overloadCount,ol,scopeName,container_d,m_container==MemberListContainer::Group);
779
780 ol.writeString(" </td>\n");
781 ol.writeString(" </tr>\n");
782 ol.writeString("</table>\n");
783
784 endFile(ol);
785 }
786 }
787 }
788 for (const auto &mg : m_memberGroupRefList)
789 {
790 mg->writeDocumentationPage(ol,scopeName,container);
791 }
792}
793
795{
796 m_memberGroupRefList.push_back(mg);
797}
798
800{
801 for (const auto &imd : m_members)
802 {
804 if (md && !md->isAlias() && (md->getGroupDef()==nullptr || def->definitionType()==Definition::TypeGroup))
805 {
806 md->addListReference(def);
807 const MemberVector &enumFields = md->enumFieldList();
808 if (md->memberType()==MemberType::Enumeration && !enumFields.empty())
809 {
810 //printf(" Adding enum values!\n");
811 for (const auto &vmd : enumFields)
812 {
814 if (vmdm)
815 {
816 //printf(" adding %s\n",qPrint(vmd->name()));
817 vmdm->addListReference(def);
818 }
819 }
820 }
821 }
822 }
823 for (const auto &mg : m_memberGroupRefList)
824 {
825 mg->addListReferences(def);
826 }
827}
828
830{
831 for (const auto &imd : m_members)
832 {
834 if (md && !md->isAlias() && (md->getGroupDef()==nullptr || def->definitionType()==Definition::TypeGroup))
835 {
837 const MemberVector &enumFields = md->enumFieldList();
838 if (md->memberType()==MemberType::Enumeration && !enumFields.empty())
839 {
840 //printf(" Adding enum values!\n");
841 for (const auto &vmd : enumFields)
842 {
844 if (vmdm)
845 {
846 //printf(" adding %s\n",qPrint(vmd->name()));
847 vmdm->addRequirementReferences(def);
848 }
849 }
850 }
851 }
852 }
853 for (const auto &mg : m_memberGroupRefList)
854 {
855 mg->addRequirementReferences(def);
856 }
857}
858
860{
861 for (const auto &imd : m_members)
862 {
864 if (md)
865 {
867 }
868 }
869 for (const auto &mg : m_memberGroupRefList)
870 {
871 mg->findSectionsInDocumentation(d);
872 }
873}
874
876{
877 m_needsSorting = b;
878}
879
880void MemberList::writeTagFile(TextStream &tagFile,bool useQualifiedName,bool showNamespaceMembers)
881{
882 for (const auto &imd : m_members)
883 {
885 if (md)
886 {
887 if (md->getLanguage()!=SrcLangExt::VHDL)
888 {
889 md->writeTagFile(tagFile,useQualifiedName,showNamespaceMembers);
890 if (md->memberType()==MemberType::Enumeration && !md->isStrong())
891 {
892 for (const auto &ivmd : md->enumFieldList())
893 {
895 if (vmd)
896 {
897 vmd->writeTagFile(tagFile,useQualifiedName,showNamespaceMembers);
898 }
899 }
900 }
901 }
902 else
903 {
904 VhdlDocGen::writeTagFile(md,tagFile);
905 }
906 }
907 }
908 for (const auto &mg : m_memberGroupRefList)
909 {
910 mg->writeTagFile(tagFile,useQualifiedName);
911 }
912}
913
914// compute the HTML anchors for a list of members
916{
917 //int count=0;
918 for (const auto &md : m_members)
919 {
921 if (mdm && !md->isReference())
922 {
923 mdm->setAnchor();
924 }
925 }
926}
927
A abstract class representing of a compound symbol.
Definition classdef.h:104
virtual bool isJavaEnum() const =0
virtual void addGroupedInheritedMembers(OutputList &ol, MemberListType lt, const ClassDef *inheritedFrom, const QCString &inheritId) const =0
The common base class of all entity definitions found in the sources.
Definition definition.h:77
virtual SrcLangExt getLanguage() const =0
Returns the programming language this definition was written in.
virtual QCString getDefFileName() const =0
virtual int getDefLine() const =0
virtual DefType definitionType() const =0
virtual QCString anchor() const =0
virtual QCString briefDescription(bool abbreviate=FALSE) const =0
virtual QCString getReference() const =0
virtual QCString qualifiedName() const =0
virtual QCString displayName(bool includeScope=TRUE) const =0
virtual bool isAlias() const =0
virtual QCString getOutputFileBase() const =0
virtual Definition * getOuterScope() const =0
virtual bool isReference() const =0
virtual const QCString & name() const =0
A model of a file symbol.
Definition filedef.h:99
A model of a group of symbols.
Definition groupdef.h:52
A model of a class/file/namespace member symbol.
Definition memberdef.h:48
virtual bool isDestructor() const =0
virtual bool hasDetailedDescription() const =0
virtual bool isConstructor() const =0
virtual GroupDef * getGroupDef()=0
virtual const MemberVector & enumFieldList() const =0
virtual MemberType memberType() const =0
virtual bool isStrong() const =0
virtual QCString argsString() const =0
virtual void writeMemberDocSimple(OutputList &ol, const Definition *container) const =0
virtual void writeDocumentation(const MemberList *ml, int memCount, int memTotal, OutputList &ol, const QCString &scopeName, const Definition *container, bool inGroup, bool showEnumValues=FALSE, bool showInline=FALSE) const =0
virtual void addListReference(const Definition *)=0
virtual void findSectionsInDocumentation()=0
virtual void setAnonymousEnumType(const MemberDef *md)=0
virtual void writeTagFile(TextStream &, bool useQualifiedName, bool showNamespaceMembers) const =0
virtual void addRequirementReferences(const Definition *)=0
virtual void setAnchor()=0
A class representing a group of members.
Definition membergroup.h:44
void addListReferences(const Definition *def)
int numDecEnumValues() const
Definition memberlist.h:137
int m_numDecEnumValues
Definition memberlist.h:173
int numDocMembers() const
Definition memberlist.h:138
int numDocEnumValues() const
Definition memberlist.h:139
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.
int countEnumValues(const MemberDef *md) const
void writeTagFile(TextStream &, bool useQualifiedName=false, bool showNamespaceMembers=true)
int m_numDocMembers
Definition memberlist.h:174
int m_numDecMembers
Definition memberlist.h:172
MemberListContainer container() const
Definition memberlist.h:131
MemberList(MemberListType lt, MemberListContainer container)
int numDecMembers() const
Definition memberlist.h:135
MemberGroupRefList m_memberGroupRefList
Definition memberlist.h:176
bool m_needsSorting
Definition memberlist.h:179
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
int m_numDocEnumValues
Definition memberlist.h:175
MemberListContainer m_container
Definition memberlist.h:177
void setNeedsSorting(bool b)
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
void addRequirementReferences(const Definition *def)
void countDecMembers() const
void countDocMembers()
MemberListType m_listType
Definition memberlist.h:178
void findSectionsInDocumentation(const Definition *d)
void addMemberGroup(MemberGroup *mg)
void setAnchors()
int numDecMembers(const ClassDef *inheritedFrom) const
Definition memberlist.h:133
void writeDocumentationPage(OutputList &ol, const QCString &scopeName, const DefinitionMutable *container, int hierarchyLevel=0) const
bool declVisible() const
Wrapper class for the MemberListType type.
Definition types.h:346
constexpr const char * toLabel() const noexcept
Definition types.h:402
A vector of MemberDef object.
Definition memberlist.h:35
bool empty() const noexcept
Definition memberlist.h:60
An abstract interface of a namespace symbol.
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 writeString(const QCString &text)
Definition outputlist.h:411
void startMemberDeclaration()
Definition outputlist.h:569
void disable(OutputType o)
void writeRuler()
Definition outputlist.h:521
void startGroupHeader(const QCString &id=QCString(), int extraLevels=0)
Definition outputlist.h:453
void endContents()
Definition outputlist.h:620
void endMemberDescription()
Definition outputlist.h:567
void endInlineHeader()
Definition outputlist.h:487
void endMemberGroupDocs()
Definition outputlist.h:511
void startMemberDescription(const QCString &anchor, const QCString &inheritId=QCString(), bool typ=false)
Definition outputlist.h:565
void endMemberGroupHeader(bool b)
Definition outputlist.h:507
void endDoxyAnchor(const QCString &fn, const QCString &anchor)
Definition outputlist.h:541
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 endMemberDocList()
Definition outputlist.h:479
void startMemberGroup()
Definition outputlist.h:513
void startMemberList()
Definition outputlist.h:481
void endTextLink()
Definition outputlist.h:444
void endMemberItem(OutputGenerator::MemberItemType type)
Definition outputlist.h:495
void endMemberList()
Definition outputlist.h:483
void addLabel(const QCString &fName, const QCString &anchor)
Definition outputlist.h:543
void pushGeneratorState()
void insertMemberAlign(bool templ=FALSE)
Definition outputlist.h:517
void startInlineHeader()
Definition outputlist.h:485
void disableAllBut(OutputType o)
void popGeneratorState()
void writeAnchor(const QCString &fileName, const QCString &name)
Definition outputlist.h:523
void endGroupHeader(int extraLevels=0)
Definition outputlist.h:455
void startDoxyAnchor(const QCString &fName, const QCString &manName, const QCString &anchor, const QCString &name, const QCString &args)
Definition outputlist.h:537
void endQuickIndices()
Definition outputlist.h:604
void endMemberGroup(bool last)
Definition outputlist.h:515
void startMemberGroupDocs()
Definition outputlist.h:509
void startContents()
Definition outputlist.h:618
void startMemberDocSimple(bool b)
Definition outputlist.h:722
void endMemberDeclaration(const QCString &anchor, const QCString &inheritId)
Definition outputlist.h:571
void enableAll()
void endMemberHeader()
Definition outputlist.h:471
void endMemberSubtitle()
Definition outputlist.h:475
void startMemberItem(const QCString &anchor, OutputGenerator::MemberItemType type, const QCString &id=QCString())
Definition outputlist.h:493
void startMemberDocList()
Definition outputlist.h:477
void endMemberDocSimple(bool b)
Definition outputlist.h:724
void startMemberSubtitle()
Definition outputlist.h:473
void parseText(const QCString &textStr)
void writeInheritedSectionTitle(const QCString &id, const QCString &ref, const QCString &file, const QCString &anchor, const QCString &title, const QCString &name)
Definition outputlist.h:573
void startMemberGroupHeader(const QCString &id, bool b)
Definition outputlist.h:505
void startTextLink(const QCString &file, const QCString &anchor)
Definition outputlist.h:442
void startMemberHeader(const QCString &anchor, int typ=2)
Definition outputlist.h:469
This is an alternative implementation of QCString.
Definition qcstring.h:103
int find(char c, int index=0, bool cs=TRUE) const
Definition qcstring.cpp:43
size_t length() const
Returns the length of the string, not counting the 0-terminator.
Definition qcstring.h:170
bool isEmpty() const
Returns TRUE iff the string is empty.
Definition qcstring.h:167
QCString stripWhiteSpace() const
returns a copy of this string with leading and trailing whitespace removed
Definition qcstring.h:264
const std::string & str() const
Definition qcstring.h:556
QCString & setNum(short n)
Definition qcstring.h:463
QCString right(size_t len) const
Definition qcstring.h:238
int findRev(char c, int index=-1, bool cs=TRUE) const
Definition qcstring.cpp:96
Text streaming class that buffers data.
Definition textstream.h:36
static void writeTagFile(MemberDefMutable *mdef, TextStream &tagFile)
static void writeVhdlDeclarations(const MemberList *, OutputList &, const GroupDef *, const ClassDef *, const FileDef *, const NamespaceDef *, const ModuleDef *)
ClassDef * toClassDef(Definition *d)
#define Config_getBool(name)
Definition config.h:33
Definition * toDefinition(DefinitionMutable *dm)
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
void endFile(OutputList &ol, bool skipNavIndex, bool skipEndContents, const QCString &navPath)
Definition index.cpp:429
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
Translator * theTranslator
Definition language.cpp:71
MemberDefMutable * toMemberDefMutable(Definition *d)
int genericCompareMembers(const MemberDef *c1, const MemberDef *c2)
#define err(fmt,...)
Definition message.h:127
QCString substitute(const QCString &s, const QCString &src, const QCString &dst)
substitute all occurrences of src in s by dst
Definition qcstring.cpp:571
int qstricmp_sort(const char *str1, const char *str2)
Definition qcstring.h:86
#define TRUE
Definition qcstring.h:37
#define FALSE
Definition qcstring.h:34
MemberListContainer
Definition types.h:472
QCString stripPath(const QCString &s)
Definition util.cpp:4969
A bunch of utility functions.