Doxygen
Loading...
Searching...
No Matches
filedef.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 <unordered_set>
19
20#include "memberlist.h"
21#include "classlist.h"
22#include "filedef.h"
23#include "doxygen.h"
24#include "memberdef.h"
25#include "classdef.h"
26#include "namespacedef.h"
27#include "util.h"
28#include "language.h"
29#include "outputlist.h"
30#include "dot.h"
31#include "dotincldepgraph.h"
32#include "message.h"
33#include "docparser.h"
34#include "searchindex.h"
35#include "htags.h"
36#include "parserintf.h"
37#include "portable.h"
38#include "vhdldocgen.h"
39#include "debug.h"
40#include "layout.h"
41#include "entry.h"
42#include "groupdef.h"
43#include "filename.h"
44#include "membergroup.h"
45#include "dirdef.h"
46#include "config.h"
47#include "clangparser.h"
48#include "settings.h"
49#include "definitionimpl.h"
50#include "conceptdef.h"
51#include "outputlist.h"
52#include "moduledef.h"
53
54//---------------------------------------------------------------------------
55
57{
58 bool isIDLorJava = lang==SrcLangExt::IDL || lang==SrcLangExt::Java;
59 if (isIDLorJava || (kind & IncludeKind_ImportMask))
60 {
61 return "import ";
62 }
63 else if (kind & IncludeKind_ObjCMask)
64 {
65 return "#import ";
66 }
67 else
68 {
69 return "#include ";
70 }
71}
72
74{
75 if (lang==SrcLangExt::Java || kind==IncludeKind::ImportModule) return "";
76 if ((kind & IncludeKind_LocalMask) || (lang==SrcLangExt::IDL))
77 {
78 return "\"";
79 }
80 else
81 {
82 return "<";
83 }
84}
85
87{
88 if (lang==SrcLangExt::IDL) return "\";";
89 else if (lang==SrcLangExt::Java) return ";";
90
91 switch (kind)
92 {
93 case IncludeKind::ImportLocal: return "\";";
94 case IncludeKind::ImportLocalObjC: return "\"";
95 case IncludeKind::IncludeLocal: return "\"";
96 case IncludeKind::ImportSystem: return ">;";
97 case IncludeKind::ImportSystemObjC: return ">";
98 case IncludeKind::IncludeSystem: return ">";
99 case IncludeKind::ImportModule: return ";";
100 }
101 return "";
102}
103
105{
106 QCString result;
107 bool isIDLorJava = lang==SrcLangExt::IDL || lang==SrcLangExt::Java;
108 result.sprintf("local=\"%s\" import=\"%s\" module=\"%s\" objc=\"%s\"",
109 (kind & IncludeKind_LocalMask) ? "yes" : "no",
110 (isIDLorJava || (kind & IncludeKind_ImportMask)) ? "yes" : "no",
111 (kind==IncludeKind::ImportModule) ? "yes" : "no",
112 (kind & IncludeKind_ObjCMask) ? "yes" : "no");
113 return result;
114}
115
116//---------------------------------------------------------------------------
117
118using DefinitionLineMap = std::unordered_map<int,const Definition *>;
119using MemberDefLineMap = std::unordered_map<int,const MemberDef *>;
120using IncludeInfoMap = std::unordered_map<std::string, const IncludeInfo *>;
121
122class FileDefImpl : public DefinitionMixin<FileDef>
123{
124 public:
125 FileDefImpl(const QCString &p,const QCString &n,const QCString &ref=QCString(),const QCString &dn=QCString());
126 ~FileDefImpl() override;
128
129 DefType definitionType() const override { return TypeFile; }
131 const QCString &name() const override;
132
133 QCString displayName(bool=TRUE) const override { return localName(); }
134 QCString fileName() const override { return m_fileName; }
135 QCString getOutputFileBase() const override;
136 QCString anchor() const override { return QCString(); }
137 QCString getSourceFileBase() const override;
138 QCString includeName() const override;
141 QCString absFilePath() const override { return m_filePath; }
142 const QCString &docName() const override { return m_docname; }
143 bool isSource() const override { return m_isSource; }
144 bool isDocumentationFile() const override;
145 const Definition *getSourceDefinition(int lineNr) const override;
146 const MemberDef *getSourceMember(int lineNr) const override;
147 QCString getPath() const override { return m_path; }
148 QCString getVersion() const override { return m_fileVersion; }
149 bool isLinkableInProject() const override;
150 bool isLinkable() const override { return isLinkableInProject() || isReference(); }
151 bool isIncluded(const QCString &name) const override;
152 DirDef *getDirDef() const override { return m_dir; }
153 ModuleDef *getModuleDef() const override { return m_moduleDef; }
154 const LinkedRefMap<NamespaceDef> &getUsedNamespaces() const override;
156 const IncludeInfoList &includeFileList() const override { return m_includeList; }
157 const IncludeInfoList &includedByFileList() const override { return m_includedByList; }
158 void getAllIncludeFilesRecursively(StringVector &incFiles) const override;
159 MemberList *getMemberList(MemberListType lt) const override;
160 const MemberLists &getMemberLists() const override { return m_memberLists; }
161 const MemberGroupList &getMemberGroups() const override { return m_memberGroups; }
162 const NamespaceLinkedRefMap &getNamespaces() const override { return m_namespaces; }
163 const ConceptLinkedRefMap &getConcepts() const override { return m_concepts; }
164 const ClassLinkedRefMap &getClasses() const override { return m_classes; }
165 QCString title() const override;
166 bool hasDetailedDescription() const override;
167 QCString fileVersion() const override;
168 bool subGrouping() const override { return m_subGrouping; }
169 void countMembers() override;
170 int numDocMembers() const override;
171 int numDecMembers() const override;
172 void addSourceRef(int line,const Definition *d,const MemberDef *md) override;
173 void writeDocumentation(OutputList &ol) override;
174 void writeMemberPages(OutputList &ol) override;
175 void writeQuickMemberLinks(OutputList &ol,const MemberDef *currentMd) const override;
176 void writeSummaryLinks(OutputList &ol) const override;
177 void writePageNavigation(OutputList &ol) const override;
178 void writeTagFile(TextStream &t) override;
179 void writeSourceHeader(OutputList &ol) override;
180 void writeSourceBody(OutputList &ol,ClangTUParser *clangParser) override;
181 void writeSourceFooter(OutputList &ol) override;
182 void parseSource(ClangTUParser *clangParser) override;
183 void setDiskName(const QCString &name) override;
184 void insertMember(MemberDef *md) override;
185 void removeMember(MemberDef *md) override;
186 void insertClass(ClassDef *cd) override;
187 void insertConcept(ConceptDef *cd) override;
188 void insertNamespace(NamespaceDef *nd) override;
189 void computeAnchors() override;
190 void setDirDef(DirDef *dd) override { m_dir=dd; }
191 void setModuleDef(ModuleDef *mod) override { m_moduleDef=mod; }
192 void addUsingDirective(NamespaceDef *nd) override;
193 void addUsingDeclaration(const Definition *d) override;
194 void combineUsingRelations() override;
195 bool generateSourceFile() const override;
196 void sortMemberLists() override;
197 void addIncludeDependency(const FileDef *fd,const QCString &incName,IncludeKind kind) override;
198 void addIncludedByDependency(const FileDef *fd,const QCString &incName,IncludeKind kind) override;
199 void addMembersToMemberGroup() override;
201 void findSectionsInDocumentation() override;
202 void addIncludedUsingDirectives(FileDefSet &visitedFiles) override;
203 void addListReferences() override;
204
205 bool hasIncludeGraph() const override;
206 bool hasIncludedByGraph() const override;
207 void overrideIncludeGraph(bool e) override;
208 void overrideIncludedByGraph(bool e) override;
209
210 private:
211 void setDiskNameLocal(const QCString &name);
212 void acquireFileVersion();
221 void writeSourceLink(OutputList &ol);
223 bool isConstantGroup);
225 void writeConcepts(OutputList &ol,const QCString &title);
235
253 DirDef *m_dir = nullptr;
264 bool m_hasIncludeGraph = Config_getBool(INCLUDE_GRAPH);
265 bool m_hasIncludedByGraph = Config_getBool(INCLUDED_BY_GRAPH);
266};
267
268std::unique_ptr<FileDef> createFileDef(const QCString &p,const QCString &n,const QCString &ref,const QCString &dn)
269{
270 return std::make_unique<FileDefImpl>(p,n,ref,dn);
271}
272
273
274//---------------------------------------------------------------------------
275
276/*! create a new file definition, where \a p is the file path,
277 \a nm the file name, and \a lref is an HTML anchor name if the
278 file was read from a tag file or nullptr otherwise
279*/
281 const QCString &lref,const QCString &dn)
282 : DefinitionMixin(QCString(p)+nm,1,1,nm,nullptr,nullptr,!p.isEmpty())
283{
285 m_filePath=p+nm;
286 m_fileName=nm;
287
288 setReference(lref);
289 setDiskNameLocal(!dn.isEmpty() ? dn : nm);
290 m_isSource = guessSection(nm).isSource();
291 m_docname = nm;
292 m_dir = nullptr;
293 if (Config_getBool(FULL_PATH_NAMES))
294 {
296 }
298 Config_getBool(FULL_PATH_NAMES) ? m_fileName : DefinitionMixin::name()));
300 m_subGrouping=Config_getBool(SUBGROUPING);
301}
302
303/*! destroy the file definition */
307
309{
310 if (isReference())
311 {
313 m_inclDepFileName = name+"_incl";
314 m_inclByDepFileName = name+"_dep_incl";
315 }
316 else
317 {
321 }
322}
323
328
329/*! Compute the HTML anchor names for all members in the class */
331{
332 MemberList *ml = getMemberList(MemberListType::AllMembersList());
333 if (ml) ml->setAnchors();
334}
335
337{
338 //printf("FileDefImpl::distributeMemberGroupDocumentation()\n");
339 for (const auto &mg : m_memberGroups)
340 {
341 mg->distributeMemberGroupDocumentation();
342 }
343}
344
346{
350 for (const auto &mg : m_memberGroups)
351 {
352 mg->findSectionsInDocumentation(this);
353 }
354
355 for (auto &ml : m_memberLists)
356 {
357 if (ml->listType().isDeclaration())
358 {
359 ml->findSectionsInDocumentation(this);
360 }
361 }
362}
363
365{
366 bool repeatBrief = Config_getBool(REPEAT_BRIEF);
367 bool sourceBrowser = Config_getBool(SOURCE_BROWSER);
368 return ((!briefDescription().isEmpty() && repeatBrief) ||
369 !documentation().stripWhiteSpace().isEmpty() || // avail empty section
370 (sourceBrowser && getStartBodyLine()!=-1 && getBodyDef())
371 );
372}
373
375{
378 tagFile << " <compound kind=\"file\">\n";
379 tagFile << " <name>" << convertToXML(name()) << "</name>\n";
380 tagFile << " <path>" << convertToXML(stripFromPath(getPath())) << "</path>\n";
381 tagFile << " <filename>" << fn << "</filename>\n";
382 for (const auto &ii : m_includeList)
383 {
384 const FileDef *fd=ii.fileDef;
385 if (fd && fd->isLinkable() && !fd->isReference())
386 {
387 QCString attr = includeTagFileAttributes(fd->getLanguage(),ii.kind);
388 tagFile << " <includes id=\""
389 << convertToXML(fd->getOutputFileBase()) << "\" "
390 << "name=\"" << convertToXML(fd->name()) << "\" "
391 << attr << ">"
392 << convertToXML(ii.includeName)
393 << "</includes>\n";
394 }
395 }
396 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::File))
397 {
398 switch (lde->kind())
399 {
400 case LayoutDocEntry::FileClasses:
401 {
403 }
404 break;
405 case LayoutDocEntry::FileInterfaces:
406 {
408 }
409 break;
410 case LayoutDocEntry::FileStructs:
411 {
413 }
414 break;
415 case LayoutDocEntry::FileExceptions:
416 {
418 }
419 break;
420 case LayoutDocEntry::FileConcepts:
421 {
422 for (const auto *nd : m_concepts)
423 {
424 if (nd->isLinkableInProject())
425 {
426 tagFile << " <concept>" << convertToXML(nd->name()) << "</concept>\n";
427 }
428 }
429 }
430 break;
431 case LayoutDocEntry::FileNamespaces:
432 {
433 for (const auto *nd : m_namespaces)
434 {
435 if (nd->isLinkableInProject())
436 {
437 tagFile << " <namespace>" << convertToXML(nd->name()) << "</namespace>\n";
438 }
439 }
440 }
441 break;
442 case LayoutDocEntry::MemberDecl:
443 {
444 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
445 if (lmd)
446 {
447 MemberList * ml = getMemberList(lmd->type);
448 if (ml)
449 {
450 ml->writeTagFile(tagFile,false,false);
451 }
452 }
453 }
454 break;
455 case LayoutDocEntry::MemberGroups:
456 {
457 for (const auto &mg : m_memberGroups)
458 {
459 mg->writeTagFile(tagFile);
460 }
461 }
462 break;
463 default:
464 break;
465 }
466 }
467
469 tagFile << " </compound>\n";
470}
471
473{
475 {
478 ol.writeRuler();
482 ol.writeAnchor(QCString(),"details");
484 ol.startGroupHeader("details");
485 ol.parseText(title);
486 ol.endGroupHeader();
487
488 ol.startTextBlock();
489 if (!briefDescription().isEmpty() && Config_getBool(REPEAT_BRIEF))
490 {
492 QCString(),FALSE,FALSE,Config_getBool(MARKDOWN_SUPPORT));
493 }
494 if (!briefDescription().isEmpty() && Config_getBool(REPEAT_BRIEF) &&
495 !documentation().isEmpty())
496 {
500 ol.enableAll();
503 ol.writeString("\n\n");
505 }
506 if (!documentation().isEmpty())
507 {
508 ol.generateDoc(docFile(),docLine(),this,nullptr,documentation()+"\n",TRUE,FALSE,
509 QCString(),FALSE,FALSE,Config_getBool(MARKDOWN_SUPPORT));
510 }
511 //printf("Writing source ref for file %s\n",qPrint(name()));
512 if (Config_getBool(SOURCE_BROWSER))
513 {
514 ol.startParagraph("definition");
515 QCString refText = theTranslator->trDefinedInSourceFile();
516 int fileMarkerPos = refText.find("@0");
517 if (fileMarkerPos!=-1) // should always pass this.
518 {
519 ol.parseText(refText.left(fileMarkerPos)); //text left from marker 1
521 ol.parseText(refText.right(
522 refText.length()-fileMarkerPos-2)); // text right from marker 2
523 }
524 else
525 {
526 err("translation error: invalid marker in trDefinedInSourceFile()\n");
527 }
528 ol.endParagraph();
529 }
530 ol.endTextBlock();
531 }
532}
533
535{
537 {
538 auto parser { createDocParser() };
539 auto ast { validatingParseDoc(*parser.get(),
540 briefFile(),briefLine(),this,nullptr,
542 QCString(),TRUE,FALSE,Config_getBool(MARKDOWN_SUPPORT)) };
543 if (!ast->isEmpty())
544 {
545 ol.startParagraph();
548 ol.writeString(" - ");
550 ol.writeDoc(ast.get(),this,nullptr);
553 ol.writeString(" \n");
555
556 if (Config_getBool(REPEAT_BRIEF) ||
557 !documentation().stripWhiteSpace().isEmpty()
558 )
559 {
561 ol.startTextLink(QCString(),"details");
562 ol.parseText(theTranslator->trMore());
563 ol.endTextLink();
564 }
566 ol.endParagraph();
567 }
568 }
569 ol.writeSynopsis();
570}
571
573{
574 for (const auto &cd : list)
575 {
576 if (cd->isLinkableInProject())
577 {
578 tagFile << " <class kind=\"" << cd->compoundTypeString() <<
579 "\">" << convertToXML(cd->name()) << "</class>\n";
580 }
581 }
582}
583
585{
586 if (!m_includeList.empty())
587 {
589 for (const auto &ii : m_includeList)
590 {
591 const FileDef *fd=ii.fileDef;
592 ol.startTypewriter();
593 SrcLangExt lang = fd ? fd->getLanguage() : SrcLangExt::Cpp;
594 ol.docify(::includeStatement(lang,ii.kind));
595 ol.docify(::includeOpen(lang,ii.kind));
597 ol.docify(ii.includeName);
598 ol.enableAll();
600
601 // Here we use the include file name as it appears in the file.
602 // we could also we the name as it is used within doxygen,
603 // then we should have used fd->docName() instead of ii->includeName
604 if (fd && fd->isLinkable())
605 {
608 QCString(),ii.includeName);
609 }
610 else
611 {
613 if (ii.kind==IncludeKind::ImportModule && mod && mod->isLinkable())
614 {
616 QCString(),ii.includeName);
617 }
618 else
619 {
620 ol.docify(ii.includeName);
621 }
622 }
623
624 ol.enableAll();
625 ol.docify(::includeClose(lang,ii.kind));
626 ol.endTypewriter();
627 ol.lineBreak();
628 }
629 ol.endTextBlock();
630 }
631}
632
634{
635 if (Config_getBool(HAVE_DOT) && m_hasIncludeGraph /*&& Config_getBool(INCLUDE_GRAPH)*/)
636 {
637 //printf("Graph for file %s\n",qPrint(name()));
638 DotInclDepGraph incDepGraph(this,FALSE);
639 if (incDepGraph.isTooBig())
640 {
641 warn_uncond("Include graph for '{}' not generated, too many nodes ({}), threshold is {}. Consider increasing DOT_GRAPH_MAX_NODES.\n",
642 qPrint(name()), incDepGraph.numNodes(), Config_getInt(DOT_GRAPH_MAX_NODES));
643 }
644 else if (!incDepGraph.isTrivial())
645 {
646 ol.startTextBlock();
649 ol.parseText(theTranslator->trInclDepGraph(name()));
650 ol.endInclDepGraph(incDepGraph);
651 ol.enableAll();
652 ol.endTextBlock(TRUE);
653 }
654 //incDepGraph.writeGraph(Config_getString(HTML_OUTPUT),fd->getOutputFileBase());
655 }
656}
657
659{
660 if (Config_getBool(HAVE_DOT) && m_hasIncludedByGraph /*&& Config_getBool(INCLUDED_BY_GRAPH)*/)
661 {
662 //printf("Graph for file %s\n",qPrint(name()));
663 DotInclDepGraph incDepGraph(this,TRUE);
664 if (incDepGraph.isTooBig())
665 {
666 warn_uncond("Included by graph for '{}' not generated, too many nodes ({}), threshold is {}. Consider increasing DOT_GRAPH_MAX_NODES.\n",
667 qPrint(name()), incDepGraph.numNodes(), Config_getInt(DOT_GRAPH_MAX_NODES));
668 }
669 else if (!incDepGraph.isTrivial())
670 {
671 ol.startTextBlock();
674 ol.parseText(theTranslator->trInclByDepGraph());
675 ol.endInclDepGraph(incDepGraph);
676 ol.enableAll();
677 ol.endTextBlock(TRUE);
678 }
679 //incDepGraph.writeGraph(Config_getString(HTML_OUTPUT),fd->getOutputFileBase());
680 }
681}
682
683
685{
686 //printf("%s: generateSourceFile()=%d\n",qPrint(name()),generateSourceFile());
687 if (generateSourceFile())
688 {
690 ol.startParagraph();
692 ol.parseText(theTranslator->trGotoSourceCode());
693 ol.endTextLink();
694 ol.endParagraph();
695 ol.enableAll();
696 }
697}
698
700 bool const isConstantGroup)
701{
702 // write list of namespaces
703 m_namespaces.writeDeclaration(ol,title,isConstantGroup);
704}
705
707{
708 // write list of classes
709 list.writeDeclaration(ol,nullptr,title,FALSE);
710}
711
713{
714 // write list of classes
715 m_concepts.writeDeclaration(ol,title,FALSE);
716}
717
719{
720 // temporarily undo the disabling could be done by startMemberDocumentation()
721 // as a result of setting SEPARATE_MEMBER_PAGES to YES; see bug730512
722 bool isEnabled = ol.isEnabled(OutputType::Html);
724
725 m_classes.writeDocumentation(ol,this);
726
727 // restore the initial state if needed
728 if (!isEnabled) ol.disable(OutputType::Html);
729}
730
735
740
742{
743 if (Config_getBool(SEPARATE_MEMBER_PAGES))
744 {
747 }
748}
749
751{
752 if (Config_getBool(SEPARATE_MEMBER_PAGES))
753 {
756 }
757}
758
760{
761 /* write user defined member groups */
762 for (const auto &mg : m_memberGroups)
763 {
764 if (!mg->allMembersInSameSection() || !m_subGrouping)
765 {
766 mg->writeDeclarations(ol,nullptr,nullptr,this,nullptr,nullptr);
767 }
768 }
769}
770
772{
773 // write Author section (Man only)
776 ol.startGroupHeader();
777 ol.parseText(theTranslator->trAuthor(TRUE,TRUE));
778 ol.endGroupHeader();
779 ol.parseText(theTranslator->trGeneratedAutomatically(Config_getString(PROJECT_NAME)));
781}
782
784{
787 bool first=TRUE;
788 SrcLangExt lang=getLanguage();
789 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::File))
790 {
791 const LayoutDocEntrySection *ls = dynamic_cast<const LayoutDocEntrySection*>(lde.get());
792 if (lde->kind()==LayoutDocEntry::FileClasses && m_classes.declVisible() && ls)
793 {
794 QCString label = "nested-classes";
795 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
796 first=FALSE;
797 }
798 else if (lde->kind()==LayoutDocEntry::FileInterfaces && m_interfaces.declVisible() && ls)
799 {
800 QCString label = "interfaces";
801 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
802 first=FALSE;
803 }
804 else if (lde->kind()==LayoutDocEntry::FileStructs && m_structs.declVisible() && ls)
805 {
806 QCString label = "structs";
807 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
808 first=FALSE;
809 }
810 else if (lde->kind()==LayoutDocEntry::FileExceptions && m_exceptions.declVisible() && ls)
811 {
812 QCString label = "exceptions";
813 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
814 first=FALSE;
815 }
816 else if (lde->kind()==LayoutDocEntry::FileNamespaces && m_namespaces.declVisible(false) && ls)
817 {
818 QCString label = "namespaces";
819 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
820 first=FALSE;
821 }
822 else if (lde->kind()==LayoutDocEntry::FileConcepts && m_concepts.declVisible() && ls)
823 {
824 QCString label = "concepts";
825 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
826 first=FALSE;
827 }
828 else if (lde->kind()==LayoutDocEntry::MemberDecl)
829 {
830 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
831 if (lmd)
832 {
833 MemberList * ml = getMemberList(lmd->type);
834 if (ml && ml->declVisible())
835 {
836 ol.writeSummaryLink(QCString(),ml->listType().toLabel(),lmd->title(lang),first);
837 first=FALSE;
838 }
839 }
840 }
841 }
842 if (!first)
843 {
844 ol.writeString(" </div>\n");
845 }
847}
848
853
854/*! Write the documentation page for this file to the file of output
855 generators \a ol.
856*/
858{
859 bool generateTreeView = Config_getBool(GENERATE_TREEVIEW);
860 //funcList->countDecMembers();
861
862 //QCString fn = name();
863 //if (Config_getBool(FULL_PATH_NAMES))
864 //{
865 // fn.prepend(stripFromPath(getPath()));
866 //}
867
868 //printf("WriteDocumentation diskname=%s\n",qPrint(diskname));
869
870 QCString versionTitle;
871 if (!m_fileVersion.isEmpty())
872 {
873 versionTitle=("("+m_fileVersion+")");
874 }
875 QCString title = m_docname+versionTitle;
876 QCString pageTitle;
877 if (Config_getBool(HIDE_COMPOUND_REFERENCE))
878 {
879 pageTitle=m_docname;
880 }
881 else
882 {
883 pageTitle=theTranslator->trFileReference(m_docname);
884 }
885
886 if (getDirDef())
887 {
888 startFile(ol,getOutputFileBase(),name(),pageTitle,HighlightedItem::FileVisible,!generateTreeView);
889 if (!generateTreeView)
890 {
892 ol.endQuickIndices();
893 }
894 startTitle(ol,getOutputFileBase(),this);
897 if (Config_getBool(HIDE_COMPOUND_REFERENCE))
898 {
899 ol.parseText(displayName()); // Html only
900 }
901 else
902 {
903 ol.parseText(theTranslator->trFileReference(displayName())); // Html only
904 }
905 ol.enableAll();
907 if (Config_getBool(HIDE_COMPOUND_REFERENCE))
908 {
909 ol.parseText(Config_getBool(FULL_PATH_NAMES) ? // other output formats
910 pageTitle :
911 name());
912 }
913 else
914 {
915 ol.parseText(Config_getBool(FULL_PATH_NAMES) ? // other output formats
916 pageTitle :
917 theTranslator->trFileReference(name()));
918 }
920 addGroupListToTitle(ol,this);
922 }
923 else
924 {
925 startFile(ol,getOutputFileBase(),name(),pageTitle,HighlightedItem::FileVisible,!generateTreeView);
926 if (!generateTreeView)
927 {
928 ol.endQuickIndices();
929 }
930 startTitle(ol,getOutputFileBase(),this);
931 ol.parseText(pageTitle);
932 addGroupListToTitle(ol,this);
934 }
935
936 ol.startContents();
937
938 if (!m_fileVersion.isEmpty())
939 {
942 ol.docify(versionTitle);
943 ol.endProjectNumber();
944 ol.enableAll();
945 }
946
947 //---------------------------------------- start flexible part -------------------------------
948
949 SrcLangExt lang = getLanguage();
950 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::File))
951 {
952 const LayoutDocEntrySection *ls = dynamic_cast<const LayoutDocEntrySection*>(lde.get());
953 switch (lde->kind())
954 {
955 case LayoutDocEntry::BriefDesc:
957 break;
958 case LayoutDocEntry::MemberDeclStart:
960 break;
961 case LayoutDocEntry::FileIncludes:
963 break;
964 case LayoutDocEntry::FileIncludeGraph:
966 break;
967 case LayoutDocEntry::FileIncludedByGraph:
969 break;
970 case LayoutDocEntry::FileSourceLink:
971 writeSourceLink(ol);
972 break;
973 case LayoutDocEntry::FileClasses:
974 if (ls) writeClassDeclarations(ol,ls->title(lang),m_classes);
975 break;
976 case LayoutDocEntry::FileInterfaces:
977 if (ls) writeClassDeclarations(ol,ls->title(lang),m_interfaces);
978 break;
979 case LayoutDocEntry::FileStructs:
980 if (ls) writeClassDeclarations(ol,ls->title(lang),m_structs);
981 break;
982 case LayoutDocEntry::FileExceptions:
983 if (ls) writeClassDeclarations(ol,ls->title(lang),m_exceptions);
984 break;
985 case LayoutDocEntry::FileConcepts:
986 if (ls) writeConcepts(ol,ls->title(lang));
987 break;
988 case LayoutDocEntry::FileNamespaces:
989 if (ls) writeNamespaceDeclarations(ol,ls->title(lang),false);
990 break;
991 case LayoutDocEntry::FileConstantGroups:
992 if (ls) writeNamespaceDeclarations(ol,ls->title(lang),true);
993 break;
994 case LayoutDocEntry::MemberGroups:
996 break;
997 case LayoutDocEntry::MemberDecl:
998 {
999 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
1000 if (lmd) writeMemberDeclarations(ol,lmd->type,lmd->title(lang));
1001 }
1002 break;
1003 case LayoutDocEntry::MemberDeclEnd:
1005 break;
1006 case LayoutDocEntry::DetailedDesc:
1007 if (ls) writeDetailedDescription(ol,ls->title(lang));
1008 break;
1009 case LayoutDocEntry::MemberDefStart:
1011 break;
1012 case LayoutDocEntry::FileInlineClasses:
1014 break;
1015 case LayoutDocEntry::MemberDef:
1016 {
1017 const LayoutDocEntryMemberDef *lmd = dynamic_cast<const LayoutDocEntryMemberDef*>(lde.get());
1018 if (lmd) writeMemberDocumentation(ol,lmd->type,lmd->title(lang));
1019 }
1020 break;
1021 case LayoutDocEntry::MemberDefEnd:
1023 break;
1024 case LayoutDocEntry::AuthorSection:
1026 break;
1027 case LayoutDocEntry::ClassIncludes:
1028 case LayoutDocEntry::ClassInheritanceGraph:
1029 case LayoutDocEntry::ClassNestedClasses:
1030 case LayoutDocEntry::ClassCollaborationGraph:
1031 case LayoutDocEntry::ClassAllMembersLink:
1032 case LayoutDocEntry::ClassUsedFiles:
1033 case LayoutDocEntry::ClassInlineClasses:
1034 case LayoutDocEntry::NamespaceNestedNamespaces:
1035 case LayoutDocEntry::NamespaceNestedConstantGroups:
1036 case LayoutDocEntry::NamespaceClasses:
1037 case LayoutDocEntry::NamespaceConcepts:
1038 case LayoutDocEntry::NamespaceInterfaces:
1039 case LayoutDocEntry::NamespaceStructs:
1040 case LayoutDocEntry::NamespaceExceptions:
1041 case LayoutDocEntry::NamespaceInlineClasses:
1042 case LayoutDocEntry::ConceptDefinition:
1043 case LayoutDocEntry::GroupClasses:
1044 case LayoutDocEntry::GroupConcepts:
1045 case LayoutDocEntry::GroupModules:
1046 case LayoutDocEntry::GroupInlineClasses:
1047 case LayoutDocEntry::GroupNamespaces:
1048 case LayoutDocEntry::GroupDirs:
1049 case LayoutDocEntry::GroupNestedGroups:
1050 case LayoutDocEntry::GroupFiles:
1051 case LayoutDocEntry::GroupGraph:
1052 case LayoutDocEntry::GroupPageDocs:
1053 case LayoutDocEntry::ModuleExports:
1054 case LayoutDocEntry::ModuleClasses:
1055 case LayoutDocEntry::ModuleConcepts:
1056 case LayoutDocEntry::ModuleUsedFiles:
1057 case LayoutDocEntry::DirSubDirs:
1058 case LayoutDocEntry::DirFiles:
1059 case LayoutDocEntry::DirGraph:
1060 err("Internal inconsistency: member '{}' should not be part of "
1061 "LayoutDocManager::File entry list\n",lde->entryToString());
1062 break;
1063 }
1064 }
1065
1066 //---------------------------------------- end flexible part -------------------------------
1067
1068 ol.endContents();
1069
1070 endFileWithNavPath(ol,this);
1071
1072 if (Config_getBool(SEPARATE_MEMBER_PAGES))
1073 {
1074 MemberList *ml = getMemberList(MemberListType::AllMembersList());
1075 if (ml) ml->sort();
1076 writeMemberPages(ol);
1077 }
1078}
1079
1081{
1082 ol.pushGeneratorState();
1084
1085 for (const auto &ml : m_memberLists)
1086 {
1087 if (ml->listType().isDocumentation())
1088 {
1089 ml->writeDocumentationPage(ol,name(),this);
1090 }
1091 }
1092
1093 ol.popGeneratorState();
1094}
1095
1097{
1098 bool createSubDirs=Config_getBool(CREATE_SUBDIRS);
1099
1100 ol.writeString(" <div class=\"navtab\">\n");
1101 ol.writeString(" <table>\n");
1102
1103 MemberList *allMemberList = getMemberList(MemberListType::AllMembersList());
1104 if (allMemberList)
1105 {
1106 for (const auto &md : *allMemberList)
1107 {
1108 if (md->getFileDef()==this && md->getNamespaceDef()==nullptr && md->isLinkable() && !md->isEnumValue())
1109 {
1110 if (md->isLinkableInProject())
1111 {
1112 QCString fn=md->getOutputFileBase();
1114 if (md==currentMd) // selected item => highlight
1115 {
1116 ol.writeString(" <tr><td class=\"navtabHL\">");
1117 }
1118 else
1119 {
1120 ol.writeString(" <tr><td class=\"navtab\">");
1121 }
1122 ol.writeString("<span class=\"label\"><a ");
1123 ol.writeString("href=\"");
1124 if (createSubDirs) ol.writeString("../../");
1125 ol.writeString(fn+"#"+md->anchor());
1126 ol.writeString("\">");
1127 ol.writeString(convertToHtml(md->localName()));
1128 ol.writeString("</a></span>");
1129 ol.writeString("</td></tr>\n");
1130 }
1131 }
1132 }
1133 }
1134
1135 ol.writeString(" </table>\n");
1136 ol.writeString(" </div>\n");
1137}
1138
1139/*! Write a source listing of this file to the output */
1141{
1142 bool generateTreeView = Config_getBool(GENERATE_TREEVIEW);
1144 if (!m_fileVersion.isEmpty())
1145 {
1146 title+=(" ("+m_fileVersion+")");
1147 }
1148 QCString pageTitle = theTranslator->trSourceFile(title);
1150
1151 bool isDocFile = isDocumentationFile();
1152 bool genSourceFile = !isDocFile && generateSourceFile();
1153 if (getDirDef())
1154 {
1156 !generateTreeView,
1157 !isDocFile && genSourceFile ? QCString() : getOutputFileBase(),
1158 0);
1159 if (!generateTreeView)
1160 {
1162 ol.endQuickIndices();
1163 }
1165 ol.parseText(name());
1167 }
1168 else
1169 {
1171 !isDocFile && genSourceFile ? QCString() : getOutputFileBase(),
1172 0);
1174 ol.parseText(title);
1176 }
1177
1178 ol.startContents();
1179
1180 if (isLinkable())
1181 {
1183 ol.parseText(theTranslator->trGotoDocumentation());
1184 ol.endTextLink();
1185
1186 ol.pushGeneratorState();
1188 ol.writeString("\\par\n");
1189 ol.popGeneratorState();
1190 }
1191}
1192
1193void FileDefImpl::writeSourceBody(OutputList &ol,[[maybe_unused]] ClangTUParser *clangParser)
1194{
1195 bool filterSourceFiles = Config_getBool(FILTER_SOURCE_FILES);
1196 OutputCodeList devNullList;
1197 devNullList.add<DevNullCodeGenerator>();
1198#if USE_LIBCLANG
1199 if (Doxygen::clangAssistedParsing && clangParser &&
1200 (getLanguage()==SrcLangExt::Cpp || getLanguage()==SrcLangExt::ObjC))
1201 {
1202 auto &codeOL = ol.codeGenerators();
1203 codeOL.startCodeFragment("DoxyCode");
1204 clangParser->switchToFile(this);
1205 clangParser->writeSources(codeOL,this);
1206 codeOL.endCodeFragment("DoxyCode");
1207 }
1208 else
1209#endif
1210 {
1211 auto intf = Doxygen::parserManager->getCodeParser(getDefFileExtension());
1212 intf->resetCodeParserState();
1213 auto &codeOL = ol.codeGenerators();
1214 codeOL.startCodeFragment("DoxyCode");
1215 bool needs2PassParsing =
1216 Doxygen::parseSourcesNeeded && // we need to parse (filtered) sources for cross-references
1217 !filterSourceFiles && // but user wants to show sources as-is
1218 !getFileFilter(absFilePath(),TRUE).isEmpty(); // and there is a filter used while parsing
1219
1220 if (needs2PassParsing)
1221 {
1222 // parse code for cross-references only (see bug707641)
1223 intf->parseCode(devNullList,QCString(),
1225 getLanguage(),
1226 Config_getBool(STRIP_CODE_COMMENTS),
1227 FALSE,QCString(),this
1228 );
1229 }
1230 intf->parseCode(codeOL,QCString(),
1231 fileToString(absFilePath(),filterSourceFiles,TRUE),
1232 getLanguage(), // lang
1233 Config_getBool(STRIP_CODE_COMMENTS),
1234 FALSE, // isExampleBlock
1235 QCString(), // exampleName
1236 this, // fileDef
1237 -1, // startLine
1238 -1, // endLine
1239 FALSE, // inlineFragment
1240 nullptr, // memberDef
1241 TRUE, // showLineNumbers
1242 nullptr, // searchCtx
1243 !needs2PassParsing // collectXRefs
1244 );
1245 codeOL.endCodeFragment("DoxyCode");
1246 }
1247}
1248
1250{
1251 ol.endContents();
1252 endFileWithNavPath(ol,this,false);
1253 ol.enableAll();
1254}
1255
1256void FileDefImpl::parseSource([[maybe_unused]] ClangTUParser *clangParser)
1257{
1258 bool filterSourceFiles = Config_getBool(FILTER_SOURCE_FILES);
1259 OutputCodeList devNullList;
1260 devNullList.add<DevNullCodeGenerator>();
1261#if USE_LIBCLANG
1262 if (Doxygen::clangAssistedParsing && clangParser &&
1263 (getLanguage()==SrcLangExt::Cpp || getLanguage()==SrcLangExt::ObjC))
1264 {
1265 clangParser->switchToFile(this);
1266 clangParser->writeSources(devNullList,this);
1267 }
1268 else
1269#endif
1270 {
1271 auto intf = Doxygen::parserManager->getCodeParser(getDefFileExtension());
1272 intf->resetCodeParserState();
1273 intf->parseCode(
1274 devNullList,QCString(),
1275 fileToString(absFilePath(),filterSourceFiles,TRUE),
1276 getLanguage(),
1277 Config_getBool(STRIP_CODE_COMMENTS),
1278 FALSE,QCString(),this
1279 );
1280 }
1281}
1282
1284{
1285 for (auto &ml : m_memberLists)
1286 {
1287 if (ml->listType().isDeclaration())
1288 {
1290 }
1291 }
1292
1293 // add members inside sections to their groups
1294 for (const auto &mg : m_memberGroups)
1295 {
1296 if (mg->allMembersInSameSection() && m_subGrouping)
1297 {
1298 //printf("----> addToDeclarationSection(%s)\n",qPrint(mg->header()));
1299 mg->addToDeclarationSection();
1300 }
1301 }
1302}
1303
1304/*! Adds member definition \a md to the list of all members of this file */
1306{
1307 if (md->isHidden()) return;
1308 MemberList *allMemberList = getMemberList(MemberListType::AllMembersList());
1309 //printf("%s:FileDefImpl::insertMember(%s (=%p) list has %zu elements)\n",
1310 // qPrint(name()),qPrint(md->name()),(void*)md,allMemberList ? allMemberList->size() : 0);
1311 if (allMemberList && allMemberList->contains(md))
1312 {
1313 //printf("already added\n");
1314 return;
1315 }
1316
1317 if (allMemberList==nullptr)
1318 {
1319 m_memberLists.emplace_back(std::make_unique<MemberList>(MemberListType::AllMembersList(),MemberListContainer::File));
1320 allMemberList = m_memberLists.back().get();
1321 }
1322 allMemberList->push_back(md);
1323 switch (md->memberType())
1324 {
1326 if (md->getLanguage() == SrcLangExt::Python)
1327 {
1328 addMemberToList(MemberListType::PropertyMembers(),md);
1329 addMemberToList(MemberListType::Properties(),md);
1330 break;
1331 }
1332 // fallthrough, explicitly no break here
1334 addMemberToList(MemberListType::DecVarMembers(),md);
1335 addMemberToList(MemberListType::DocVarMembers(),md);
1336 break;
1338 addMemberToList(MemberListType::DecFuncMembers(),md);
1339 addMemberToList(MemberListType::DocFuncMembers(),md);
1340 break;
1342 addMemberToList(MemberListType::DecTypedefMembers(),md);
1343 addMemberToList(MemberListType::DocTypedefMembers(),md);
1344 break;
1346 addMemberToList(MemberListType::DecSequenceMembers(),md);
1347 addMemberToList(MemberListType::DocSequenceMembers(),md);
1348 break;
1350 addMemberToList(MemberListType::DecDictionaryMembers(),md);
1351 addMemberToList(MemberListType::DocDictionaryMembers(),md);
1352 break;
1354 addMemberToList(MemberListType::DecEnumMembers(),md);
1355 addMemberToList(MemberListType::DocEnumMembers(),md);
1356 break;
1357 case MemberType::EnumValue: // enum values are shown inside their enums
1358 break;
1359 case MemberType::Define:
1360 addMemberToList(MemberListType::DecDefineMembers(),md);
1361 addMemberToList(MemberListType::DocDefineMembers(),md);
1362 break;
1363 default:
1364 err("FileDefImpl::insertMembers(): "
1365 "member '{}' with class scope '{}' inserted in file scope '{}'!\n",
1366 md->name(),
1367 md->getClassDef() ? md->getClassDef()->name() : "<global>",
1368 name());
1369 }
1370 //addMemberToGroup(md,groupId);
1371}
1372
1374{
1375 MemberList *ml = getMemberList(lt);
1376 if (ml) ml->remove(md);
1377}
1378
1380{
1381 removeMemberFromList(MemberListType::AllMembersList(),md);
1382 switch(md->memberType())
1383 {
1385 if (md->getLanguage() == SrcLangExt::Python)
1386 {
1387 removeMemberFromList(MemberListType::PropertyMembers(),md);
1388 removeMemberFromList(MemberListType::Properties(),md);
1389 break;
1390 }
1391 // fallthrough, explicitly no break here
1393 removeMemberFromList(MemberListType::DecVarMembers(),md);
1394 removeMemberFromList(MemberListType::DocVarMembers(),md);
1395 break;
1397 removeMemberFromList(MemberListType::DecFuncMembers(),md);
1398 removeMemberFromList(MemberListType::DocFuncMembers(),md);
1399 break;
1401 removeMemberFromList(MemberListType::DecTypedefMembers(),md);
1402 removeMemberFromList(MemberListType::DocTypedefMembers(),md);
1403 break;
1405 removeMemberFromList(MemberListType::DecSequenceMembers(),md);
1406 removeMemberFromList(MemberListType::DocSequenceMembers(),md);
1407 break;
1409 removeMemberFromList(MemberListType::DecDictionaryMembers(),md);
1410 removeMemberFromList(MemberListType::DocDictionaryMembers(),md);
1411 break;
1413 removeMemberFromList(MemberListType::DecEnumMembers(),md);
1414 removeMemberFromList(MemberListType::DocEnumMembers(),md);
1415 break;
1416 case MemberType::EnumValue: // enum values are shown inside their enums
1417 break;
1418 case MemberType::Define:
1419 removeMemberFromList(MemberListType::DecDefineMembers(),md);
1420 removeMemberFromList(MemberListType::DocDefineMembers(),md);
1421 break;
1422 default:
1423 err("FileDefImpl::removeMember(): unexpected member remove in file!\n");
1424 }
1425}
1426
1427/*! Adds compound definition \a cd to the list of all compounds of this file */
1429{
1430 if (cd->isHidden()) return;
1431
1433
1434 if (Config_getBool(OPTIMIZE_OUTPUT_SLICE))
1435 {
1437 {
1438 list = &m_interfaces;
1439 }
1440 else if (cd->compoundType()==ClassDef::Struct)
1441 {
1442 list = &m_structs;
1443 }
1444 else if (cd->compoundType()==ClassDef::Exception)
1445 {
1446 list = &m_exceptions;
1447 }
1448 }
1449
1450 list->add(cd->name(),cd);
1451}
1452
1454{
1455 if (cd->isHidden()) return;
1456 m_concepts.add(cd->name(),cd);
1457}
1458
1459/*! Adds namespace definition \a nd to the list of all compounds of this file */
1461{
1462 if (nd->isHidden()) return;
1463 m_namespaces.add(nd->name(),nd);
1464}
1465
1467{
1468 if (Config_getBool(FULL_PATH_NAMES))
1469 return m_fileName;
1470 else
1471 return DefinitionMixin::name();
1472}
1473
1474void FileDefImpl::addSourceRef(int line,const Definition *d,const MemberDef *md)
1475{
1476 //printf("FileDefImpl::addSourceRef(%d,%s,%s)\n",line,qPrint(d?d->name():"nullptr"),qPrint(md?md->name():"nullptr"));
1477 if (d)
1478 {
1479 m_srcDefMap.emplace(line,d);
1480 if (md) m_srcMemberMap.emplace(line,md);
1481 //printf("Adding member %s with anchor %s at line %d to file %s\n",
1482 // md?qPrint(md->name()):"<none>",md?qPrint(md->anchor()):"<none>",line,qPrint(name()));
1483 }
1484}
1485
1487{
1488 auto it = m_srcDefMap.find(lineNr);
1489 //printf("%s::getSourceDefinition(%d)=%s\n",qPrint(name()),lineNr,it!=m_srcDefMap.end()?qPrint(it->second->name()):"none");
1490 return it!=m_srcDefMap.end() ? it->second : nullptr;
1491}
1492
1494{
1495 auto it = m_srcMemberMap.find(lineNr);
1496 //printf("%s::getSourceMember(%d)=%s\n",qPrint(name()),lineNr,it!=m_srcMemberMap.end()?qPrint(it->second->name()):"none");
1497 return it!=m_srcMemberMap.end() ? it->second : nullptr;
1498}
1499
1500
1502{
1503 m_usingDirList.add(nd->qualifiedName(),nd);
1504 //printf("%p: FileDefImpl::addUsingDirective: %s:%d\n",this,qPrint(name()),usingDirList->count());
1505}
1506
1508{
1509 //printf("%p: FileDefImpl::getUsedNamespace: %s:%d\n",this,qPrint(name()),usingDirList?usingDirList->count():0);
1510 return m_usingDirList;
1511}
1512
1517
1519{
1520 //printf("FileDefImpl::addIncludeDependency(%p,%s,%d)\n",(void*)fd,qPrint(incName),kind);
1521 QCString iName = fd ? fd->absFilePath() : incName;
1522 if (!iName.isEmpty() && m_includeMap.find(iName.str())==m_includeMap.end())
1523 {
1524 m_includeList.emplace_back(fd,incName,kind);
1525 m_includeMap.emplace(iName.str(),&m_includeList.back());
1526 }
1527}
1528
1530{
1531 if (visitedFiles.find(this)!=visitedFiles.end()) return; // file already processed
1532 visitedFiles.insert(this);
1533 //printf("( FileDefImpl::addIncludedUsingDirectives for file %s\n",qPrint(name()));
1534
1535 if (!m_includeList.empty()) // file contains #includes
1536 {
1537 {
1538 for (const auto &ii : m_includeList) // foreach #include...
1539 {
1540 if (ii.fileDef) // ...that is a known file
1541 {
1542 // recurse into this file
1543 const_cast<FileDef*>(ii.fileDef)->addIncludedUsingDirectives(visitedFiles);
1544 }
1545 }
1546 }
1547 {
1548 // iterate through list from last to first
1549 for (auto ii_it = m_includeList.rbegin(); ii_it!=m_includeList.rend(); ++ii_it)
1550 {
1551 auto &ii = *ii_it;
1552 if (ii.fileDef && ii.fileDef!=this)
1553 {
1554 // add using directives
1555 auto unl = ii.fileDef->getUsedNamespaces();
1556 for (auto it = unl.rbegin(); it!=unl.rend(); ++it)
1557 {
1558 auto *nd = *it;
1559 //printf(" adding using directive for %s\n",qPrint(nd->qualifiedName()));
1560 m_usingDirList.prepend(nd->qualifiedName(),nd);
1561 }
1562 // add using declarations
1563 auto udl = ii.fileDef->getUsedDefinitions();
1564 for (auto it = udl.rbegin(); it!=udl.rend(); ++it)
1565 {
1566 auto *d = *it;
1567 m_usingDeclList.prepend(d->qualifiedName(),d);
1568 }
1569 }
1570 }
1571 }
1572 }
1573 //printf(") end FileDefImpl::addIncludedUsingDirectives for file %s\n",qPrint(name()));
1574}
1575
1576
1578{
1579 //printf("FileDefImpl::addIncludedByDependency(%p,%s,%d)\n",fd,incName,local);
1580 QCString iName = fd ? fd->absFilePath() : incName;
1581 if (!iName.isEmpty() && m_includedByMap.find(iName.str())==m_includedByMap.end())
1582 {
1583 m_includedByList.emplace_back(fd,incName,kind);
1584 m_includedByMap.emplace(iName.str(),&m_includedByList.back());
1585 }
1586}
1587
1589{
1590 if (name.isEmpty()) return FALSE;
1591 return m_includeMap.find(name.str())!=m_includeMap.end();
1592}
1593
1595{
1596 bool sourceBrowser = Config_getBool(SOURCE_BROWSER);
1597 bool verbatimHeaders = Config_getBool(VERBATIM_HEADERS);
1598 return !isReference() &&
1599 (sourceBrowser ||
1600 (verbatimHeaders && (guessSection(name()).isHeader() || !m_includedByMap.empty()))
1601 ) &&
1603}
1604
1605
1607{
1608 {
1609 const RefItemVector &xrefItems = xrefListItems();
1610 addRefItem(xrefItems,
1612 theTranslator->trFile(TRUE,TRUE),
1614 QCString(),
1615 nullptr
1616 );
1617 }
1618 for (const auto &mg : m_memberGroups)
1619 {
1620 mg->addListReferences(this);
1621 }
1622 for (auto &ml : m_memberLists)
1623 {
1624 if (ml->listType().isDocumentation())
1625 {
1626 ml->addListReferences(this);
1627 }
1628 }
1629}
1630
1631//-------------------------------------------------------------------
1632
1634{
1636 NamespaceDefSet visitedNamespaces;
1637 for (auto &nd : usingDirList)
1638 {
1640 if (ndm)
1641 {
1642 ndm->combineUsingRelations(visitedNamespaces);
1643 }
1644 }
1645
1646 for (auto &nd : usingDirList)
1647 {
1648 // add used namespaces of namespace nd to this namespace
1649 for (const auto &und : nd->getUsedNamespaces())
1650 {
1651 addUsingDirective(und);
1652 }
1653 // add used classes of namespace nd to this namespace
1654 for (const auto &ud : nd->getUsedDefinitions())
1655 {
1657 }
1658 }
1659}
1660
1662{
1663 static const std::unordered_set<std::string> docExtensions =
1664 { "doc", "txt", "dox", "md", "markdown" };
1665
1666 int lastDot = name().findRev('.');
1667 return (lastDot!=-1 && docExtensions.find(name().mid(lastDot+1).str())!=docExtensions.end()) ||
1668 getLanguageFromFileName(getFileNameExtension(name())) == SrcLangExt::Markdown;
1669}
1670
1672{
1673 QCString vercmd = Config_getString(FILE_VERSION_FILTER);
1674 if (!vercmd.isEmpty() && !m_filePath.isEmpty() && !isReference() &&
1675 m_filePath!="generated" && m_filePath!="graph_legend.dox")
1676 {
1677 msg("Version of {} : ",m_filePath);
1678 QCString cmd = vercmd+" \""+m_filePath+"\"";
1679 Debug::print(Debug::ExtCmd,0,"Executing popen(`{}`)\n",cmd);
1680 FILE *f=Portable::popen(cmd,"r");
1681 if (!f)
1682 {
1683 err("could not execute {}\n",vercmd);
1684 return;
1685 }
1686 const int bufSize=1024;
1687 char buf[bufSize];
1688 int numRead = static_cast<int>(fread(buf,1,bufSize-1,f));
1690 if (numRead>0 && numRead<bufSize)
1691 {
1692 buf[numRead]='\0';
1693 m_fileVersion=QCString(buf,numRead).stripWhiteSpace();
1694 if (!m_fileVersion.isEmpty())
1695 {
1696 msg("{}\n",m_fileVersion);
1697 return;
1698 }
1699 }
1700 msg("no version available\n");
1701 }
1702}
1703
1704
1706{
1707 if (Htags::useHtags)
1708 {
1710 }
1711 else
1712 {
1713 return m_outputDiskName+"_source";
1714 }
1715}
1716
1721
1722/*! Returns the name of the verbatim copy of this file (if any). */
1724{
1725 return getSourceFileBase();
1726}
1727
1729{
1730 bool sortBriefDocs = Config_getBool(SORT_BRIEF_DOCS);
1731 bool sortMemberDocs = Config_getBool(SORT_MEMBER_DOCS);
1732 const auto &ml = m_memberLists.get(lt,MemberListContainer::File);
1733 ml->setNeedsSorting(
1734 (ml->listType().isDeclaration() && sortBriefDocs) ||
1735 (ml->listType().isDocumentation() && sortMemberDocs));
1736 ml->push_back(md);
1737 if (ml->listType().isDeclaration())
1738 {
1740 if (mdm)
1741 {
1742 mdm->setSectionList(this,ml.get());
1743 }
1744 }
1745}
1746
1748{
1749 for (auto &ml : m_memberLists)
1750 {
1751 if (ml->needsSorting()) { ml->sort(); ml->setNeedsSorting(FALSE); }
1752 }
1753
1754 for (const auto &mg : m_memberGroups)
1755 {
1756 MemberList &mlg = const_cast<MemberList&>(mg->members());
1757 if (mlg.needsSorting()) { mlg.sort(); mlg.setNeedsSorting(FALSE); }
1758 }
1759
1760 std::stable_sort(m_includedByList.begin(),m_includedByList.end(),
1761 [](const auto &fi1,const auto &fi2) { return fi1.includeName < fi2.includeName; });
1762
1763 if (Config_getBool(SORT_BRIEF_DOCS))
1764 {
1765 auto classComp = [](const ClassLinkedRefMap::Ptr &c1,const ClassLinkedRefMap::Ptr &c2)
1766 {
1767 return Config_getBool(SORT_BY_SCOPE_NAME) ?
1768 qstricmp_sort(c1->name(), c2->name())<0 :
1769 qstricmp_sort(c1->className(), c2->className())<0;
1770 };
1771
1772 std::stable_sort(m_classes.begin(), m_classes.end(), classComp);
1773 std::stable_sort(m_interfaces.begin(),m_interfaces.end(),classComp);
1774 std::stable_sort(m_structs.begin(), m_structs.end(), classComp);
1775 std::stable_sort(m_exceptions.begin(),m_exceptions.end(),classComp);
1776
1777 auto namespaceComp = [](const NamespaceLinkedRefMap::Ptr &n1,const NamespaceLinkedRefMap::Ptr &n2)
1778 {
1779 return qstricmp_sort(n1->name(),n2->name())<0;
1780 };
1781
1782 std::stable_sort(m_namespaces.begin(),m_namespaces.end(),namespaceComp);
1783 }
1784}
1785
1787{
1788 for (auto &ml : m_memberLists)
1789 {
1790 if (ml->listType()==lt)
1791 {
1792 return ml.get();
1793 }
1794 }
1795 return nullptr;
1796}
1797
1799{
1800 bool optVhdl = Config_getBool(OPTIMIZE_OUTPUT_VHDL);
1801 MemberList * ml = getMemberList(lt);
1802 if (ml)
1803 {
1804 if (optVhdl) // use specific declarations function
1805 {
1806
1807 VhdlDocGen::writeVhdlDeclarations(ml,ol,nullptr,nullptr,this,nullptr,nullptr);
1808 }
1809 else
1810 {
1811 ml->writeDeclarations(ol,nullptr,nullptr,this,nullptr,nullptr,title,QCString());
1812 }
1813 }
1814}
1815
1817{
1818 MemberList * ml = getMemberList(lt);
1819 if (ml) ml->writeDocumentation(ol,name(),this,title,ml->listType().toLabel());
1820}
1821
1823{
1824 bool showFiles = Config_getBool(SHOW_FILES);
1825 return hasDocumentation() && !isReference() && (showFiles || isLinkableViaGroup());
1826}
1827
1829 StringUnorderedSet &filesVisited,const FileDef *fd,StringVector &incFiles)
1830{
1831 for (const auto &ii : fd->includeFileList())
1832 {
1833 if (ii.fileDef && !ii.fileDef->isReference() &&
1834 filesVisited.find(ii.fileDef->absFilePath().str())==filesVisited.end())
1835 {
1836 //printf("FileDefImpl::addIncludeDependency(%s)\n",qPrint(ii->fileDef->absFilePath()));
1837 incFiles.push_back(ii.fileDef->absFilePath().str());
1838 filesVisited.insert(ii.fileDef->absFilePath().str());
1839 getAllIncludeFilesRecursively(filesVisited,ii.fileDef,incFiles);
1840 }
1841 }
1842}
1843
1845{
1846 StringUnorderedSet includes;
1847 ::getAllIncludeFilesRecursively(includes,this,incFiles);
1848}
1849
1851{
1852 if (Config_getBool(HIDE_COMPOUND_REFERENCE))
1853 {
1854 return name();
1855 }
1856 else
1857 {
1858 return theTranslator->trFileReference(name());
1859 }
1860}
1861
1863{
1864 return m_fileVersion;
1865}
1866
1871
1876
1878{
1879 for (auto &ml : m_memberLists)
1880 {
1881 ml->countDecMembers();
1882 ml->countDocMembers();
1883 }
1884 for (const auto &mg : m_memberGroups)
1885 {
1886 mg->countDecMembers();
1887 mg->countDocMembers();
1888 }
1889}
1890
1892{
1893 MemberList *ml = getMemberList(MemberListType::AllMembersList());
1894 return ml ? ml->numDocMembers() : 0;
1895}
1896
1898{
1899 MemberList *ml = getMemberList(MemberListType::AllMembersList());
1900 return ml ? ml->numDecMembers() : 0;
1901}
1902
1907
1912
1914{
1915 return m_hasIncludeGraph;
1916}
1917
1919{
1920 return m_hasIncludedByGraph;
1921}
1922
1923// -----------------------
1924
1925bool compareFileDefs(const FileDef *fd1, const FileDef *fd2)
1926{
1927 return qstricmp_sort(fd1->name(),fd2->name()) < 0;
1928}
1929
1930// --- Cast functions
1931
1933{
1934 if (d==nullptr) return nullptr;
1935 if (d && typeid(*d)==typeid(FileDefImpl))
1936 {
1937 return static_cast<FileDef*>(d);
1938 }
1939 else
1940 {
1941 return nullptr;
1942 }
1943}
1944
1946{
1947 if (d==nullptr) return nullptr;
1948 if (d && typeid(*d)==typeid(FileDefImpl))
1949 {
1950 return static_cast<const FileDef*>(d);
1951 }
1952 else
1953 {
1954 return nullptr;
1955 }
1956}
1957
Clang parser object for a single translation unit, which consists of a source file and the directly o...
Definition clangparser.h:25
A abstract class representing of a compound symbol.
Definition classdef.h:104
virtual QCString className() const =0
Returns the name of the class including outer classes, but not including namespaces.
@ Interface
Definition classdef.h:112
@ Exception
Definition classdef.h:115
virtual CompoundType compoundType() const =0
Returns the type of compound this is, i.e.
void writeDeclaration(OutputList &ol, const ClassDef::CompoundType *filter, const QCString &header, bool localNames) const
Definition classlist.cpp:53
@ ExtCmd
Definition debug.h:36
static void print(DebugMask mask, int prio, fmt::format_string< Args... > fmt, Args &&... args)
Definition debug.h:76
The common base class of all entity definitions found in the sources.
Definition definition.h:76
virtual SrcLangExt getLanguage() const =0
Returns the programming language this definition was written in.
virtual bool isLinkable() const =0
virtual bool isHidden() const =0
virtual QCString getReference() const =0
virtual QCString qualifiedName() const =0
virtual QCString getOutputFileBase() const =0
virtual bool isReference() const =0
virtual const QCString & name() const =0
bool isReference() const override
const QCString & name() const override
bool isLinkableViaGroup() const override
bool hasBriefDescription() const override
QCString docFile() const override
QCString getDefFileExtension() const override
QCString briefFile() const override
void setLanguage(SrcLangExt lang) override
void setReference(const QCString &r) override
const RefItemVector & xrefListItems() const override
QCString briefDescription(bool abbreviate=FALSE) 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 FileDef * getBodyDef() const override
int getStartBodyLine() const override
QCString inbodyDocumentation() const override
int docLine() const override
int briefLine() const override
QCString documentation() const override
void writeDocAnchorsToTagFile(TextStream &fs) const override
bool hasDocumentation() const override
SrcLangExt getLanguage() const override
virtual void writeNavigationPath(OutputList &ol) const =0
Class implementing OutputCodeIntf by throwing away everything.
Definition devnullgen.h:21
A model of a directory symbol.
Definition dirdef.h:110
Representation of an include dependency graph.
bool isTooBig() const
bool isTrivial() const
static bool suppressDocWarnings
Definition doxygen.h:132
static bool parseSourcesNeeded
Definition doxygen.h:123
static bool clangAssistedParsing
Definition doxygen.h:138
static ParserManager * parserManager
Definition doxygen.h:131
A model of a file symbol.
Definition filedef.h:99
virtual QCString includeName() const =0
virtual bool generateSourceFile() const =0
virtual QCString absFilePath() const =0
virtual const IncludeInfoList & includeFileList() const =0
bool isDocumentationFile() const override
Definition filedef.cpp:1661
void findSectionsInDocumentation() override
Definition filedef.cpp:345
void setModuleDef(ModuleDef *mod) override
Definition filedef.cpp:191
void addIncludedUsingDirectives(FileDefSet &visitedFiles) override
Definition filedef.cpp:1529
void writeBriefDescription(OutputList &ol)
Definition filedef.cpp:534
const LinkedRefMap< const Definition > & getUsedDefinitions() const override
Definition filedef.cpp:155
void setDiskName(const QCString &name) override
Definition filedef.cpp:324
void addSourceRef(int line, const Definition *d, const MemberDef *md) override
Definition filedef.cpp:1474
LinkedRefMap< const Definition > m_usingDeclList
Definition filedef.cpp:241
DirDef * m_dir
Definition filedef.cpp:253
QCString getOutputFileBase() const override
Definition filedef.cpp:1717
void insertNamespace(NamespaceDef *nd) override
Definition filedef.cpp:1460
ModuleDef * getModuleDef() const override
Definition filedef.cpp:153
void writeQuickMemberLinks(OutputList &ol, const MemberDef *currentMd) const override
Definition filedef.cpp:1096
void writeSourceLink(OutputList &ol)
Definition filedef.cpp:684
void writeSummaryLinks(OutputList &ol) const override
Definition filedef.cpp:783
QCString absFilePath() const override
Definition filedef.cpp:141
QCString m_path
Definition filedef.cpp:242
ClassLinkedRefMap m_interfaces
Definition filedef.cpp:259
const ConceptLinkedRefMap & getConcepts() const override
Definition filedef.cpp:163
QCString m_inclDepFileName
Definition filedef.cpp:244
ClassLinkedRefMap m_structs
Definition filedef.cpp:260
void sortMemberLists() override
Definition filedef.cpp:1747
void parseSource(ClangTUParser *clangParser) override
Definition filedef.cpp:1256
void setDiskNameLocal(const QCString &name)
Definition filedef.cpp:308
void addMemberToList(MemberListType lt, MemberDef *md)
Definition filedef.cpp:1728
void acquireFileVersion()
Definition filedef.cpp:1671
QCString m_fileVersion
Definition filedef.cpp:252
void addUsingDirective(NamespaceDef *nd) override
Definition filedef.cpp:1501
void writeNamespaceDeclarations(OutputList &ol, const QCString &title, bool isConstantGroup)
Definition filedef.cpp:699
void countMembers() override
Definition filedef.cpp:1877
void distributeMemberGroupDocumentation() override
Definition filedef.cpp:336
MemberDefLineMap m_srcMemberMap
Definition filedef.cpp:250
ConceptLinkedRefMap m_concepts
Definition filedef.cpp:262
void insertClass(ClassDef *cd) override
Definition filedef.cpp:1428
DefinitionLineMap m_srcDefMap
Definition filedef.cpp:249
QCString getSourceFileBase() const override
Definition filedef.cpp:1705
NamespaceLinkedRefMap m_namespaces
Definition filedef.cpp:257
ModuleDef * m_moduleDef
Definition filedef.cpp:254
IncludeInfoList m_includedByList
Definition filedef.cpp:239
CodeSymbolType codeSymbolType() const override
Definition filedef.cpp:130
void writeClassDeclarations(OutputList &ol, const QCString &title, const ClassLinkedRefMap &list)
Definition filedef.cpp:706
QCString anchor() const override
Definition filedef.cpp:136
bool m_hasIncludeGraph
Definition filedef.cpp:264
const NamespaceLinkedRefMap & getNamespaces() const override
Definition filedef.cpp:162
void removeMember(MemberDef *md) override
Definition filedef.cpp:1379
void addUsingDeclaration(const Definition *d) override
Definition filedef.cpp:1513
ClassLinkedRefMap m_exceptions
Definition filedef.cpp:261
QCString includeName() const override
Definition filedef.cpp:1723
void writeTagFile(TextStream &t) override
Definition filedef.cpp:374
void endMemberDeclarations(OutputList &ol)
Definition filedef.cpp:736
void addListReferences() override
Definition filedef.cpp:1606
void writeMemberDeclarations(OutputList &ol, MemberListType lt, const QCString &title)
Definition filedef.cpp:1798
const MemberGroupList & getMemberGroups() const override
Definition filedef.cpp:161
IncludeInfoMap m_includedByMap
Definition filedef.cpp:238
void insertMember(MemberDef *md) override
Definition filedef.cpp:1305
const LinkedRefMap< NamespaceDef > & getUsedNamespaces() const override
Definition filedef.cpp:1507
void writeInlineClasses(OutputList &ol)
Definition filedef.cpp:718
const QCString & docName() const override
Definition filedef.cpp:142
void writeIncludeFiles(OutputList &ol)
Definition filedef.cpp:584
MemberGroupList m_memberGroups
Definition filedef.cpp:256
void computeAnchors() override
Definition filedef.cpp:330
void writeDetailedDescription(OutputList &ol, const QCString &title)
Definition filedef.cpp:472
QCString m_fileName
Definition filedef.cpp:247
void writeMemberPages(OutputList &ol) override
Definition filedef.cpp:1080
void writeSourceFooter(OutputList &ol) override
Definition filedef.cpp:1249
QCString fileVersion() const override
Definition filedef.cpp:1862
void writeConcepts(OutputList &ol, const QCString &title)
Definition filedef.cpp:712
bool generateSourceFile() const override
Definition filedef.cpp:1594
void writeIncludedByGraph(OutputList &ol)
Definition filedef.cpp:658
const QCString & name() const override
Definition filedef.cpp:1466
bool m_isSource
Definition filedef.cpp:251
const MemberDef * getSourceMember(int lineNr) const override
Definition filedef.cpp:1493
QCString m_outputDiskName
Definition filedef.cpp:246
bool isIncluded(const QCString &name) const override
Definition filedef.cpp:1588
~FileDefImpl() override
Definition filedef.cpp:304
const IncludeInfoList & includeFileList() const override
Definition filedef.cpp:156
void removeMemberFromList(MemberListType lt, MemberDef *md)
Definition filedef.cpp:1373
void getAllIncludeFilesRecursively(StringVector &incFiles) const override
Definition filedef.cpp:1844
MemberLists m_memberLists
Definition filedef.cpp:255
LinkedRefMap< NamespaceDef > m_usingDirList
Definition filedef.cpp:240
QCString getVersion() const override
Definition filedef.cpp:148
void writeAuthorSection(OutputList &ol)
Definition filedef.cpp:771
void insertConcept(ConceptDef *cd) override
Definition filedef.cpp:1453
const MemberLists & getMemberLists() const override
Definition filedef.cpp:160
void addIncludedByDependency(const FileDef *fd, const QCString &incName, IncludeKind kind) override
Definition filedef.cpp:1577
IncludeInfoMap m_includeMap
Definition filedef.cpp:236
bool m_subGrouping
Definition filedef.cpp:263
QCString m_inclByDepFileName
Definition filedef.cpp:245
DirDef * getDirDef() const override
Definition filedef.cpp:152
void overrideIncludeGraph(bool e) override
Definition filedef.cpp:1903
ClassLinkedRefMap m_classes
Definition filedef.cpp:258
QCString m_docname
Definition filedef.cpp:248
void overrideIncludedByGraph(bool e) override
Definition filedef.cpp:1908
const IncludeInfoList & includedByFileList() const override
Definition filedef.cpp:157
bool hasIncludedByGraph() const override
Definition filedef.cpp:1918
void writePageNavigation(OutputList &ol) const override
Definition filedef.cpp:849
QCString displayName(bool=TRUE) const override
Definition filedef.cpp:133
bool subGrouping() const override
Definition filedef.cpp:168
QCString m_filePath
Definition filedef.cpp:243
void writeMemberDocumentation(OutputList &ol, MemberListType lt, const QCString &title)
Definition filedef.cpp:1816
void writeSourceHeader(OutputList &ol) override
Definition filedef.cpp:1140
FileDefImpl(const QCString &p, const QCString &n, const QCString &ref=QCString(), const QCString &dn=QCString())
Definition filedef.cpp:280
void writeSourceBody(OutputList &ol, ClangTUParser *clangParser) override
Definition filedef.cpp:1193
void writeIncludeGraph(OutputList &ol)
Definition filedef.cpp:633
QCString title() const override
Definition filedef.cpp:1850
void addMembersToMemberGroup() override
Definition filedef.cpp:1283
int numDocMembers() const override
Definition filedef.cpp:1891
QCString getPath() const override
Definition filedef.cpp:147
bool m_hasIncludedByGraph
Definition filedef.cpp:265
IncludeInfoList m_includeList
Definition filedef.cpp:237
void startMemberDocumentation(OutputList &ol)
Definition filedef.cpp:741
int numDecMembers() const override
Definition filedef.cpp:1897
void writeClassesToTagFile(TextStream &t, const ClassLinkedRefMap &list)
Definition filedef.cpp:572
MemberList * getMemberList(MemberListType lt) const override
Definition filedef.cpp:1786
void startMemberDeclarations(OutputList &ol)
Definition filedef.cpp:731
bool isSource() const override
Definition filedef.cpp:143
void combineUsingRelations() override
Definition filedef.cpp:1633
bool isLinkableInProject() const override
Definition filedef.cpp:1822
void endMemberDocumentation(OutputList &ol)
Definition filedef.cpp:750
QCString includedByDependencyGraphFileName() const override
Definition filedef.cpp:1872
const ClassLinkedRefMap & getClasses() const override
Definition filedef.cpp:164
QCString fileName() const override
Definition filedef.cpp:134
bool hasIncludeGraph() const override
Definition filedef.cpp:1913
void writeDocumentation(OutputList &ol) override
Definition filedef.cpp:857
bool isLinkable() const override
Definition filedef.cpp:150
void addIncludeDependency(const FileDef *fd, const QCString &incName, IncludeKind kind) override
Definition filedef.cpp:1518
DefType definitionType() const override
Definition filedef.cpp:129
bool hasDetailedDescription() const override
Definition filedef.cpp:364
QCString includeDependencyGraphFileName() const override
Definition filedef.cpp:1867
void setDirDef(DirDef *dd) override
Definition filedef.cpp:190
void writeMemberGroups(OutputList &ol)
Definition filedef.cpp:759
const Definition * getSourceDefinition(int lineNr) const override
Definition filedef.cpp:1486
static LayoutDocManager & instance()
Returns a reference to this singleton.
Definition layout.cpp:1435
Container class representing a vector of objects with keys.
Definition linkedmap.h:232
bool add(const char *k, T *obj)
Definition linkedmap.h:284
A model of a class/file/namespace member symbol.
Definition memberdef.h:48
virtual const ClassDef * getClassDef() const =0
virtual MemberType memberType() const =0
virtual void setSectionList(const Definition *container, const MemberList *sl)=0
A list of MemberDef objects as shown in documentation sections.
Definition memberlist.h:109
bool needsSorting() const
Definition memberlist.h:124
int numDocMembers() const
Definition memberlist.h:122
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 setNeedsSorting(bool b)
MemberListType listType() const
Definition memberlist.h:114
void writeDocumentation(OutputList &ol, const QCString &scopeName, const Definition *container, const QCString &title, const QCString &anchor, bool showEnumValues=FALSE, bool showInline=FALSE) const
void setAnchors()
int numDecMembers(const ClassDef *inheritedFrom) const
Definition memberlist.h:117
bool declVisible() const
Wrapper class for the MemberListType type.
Definition types.h:346
constexpr const char * toLabel() const
Definition types.h:402
void remove(const MemberDef *md)
Definition memberlist.h:84
void sort()
Definition memberlist.h:76
bool contains(const MemberDef *md) const
Definition memberlist.h:89
void push_back(const T &value)
Definition memberlist.h:48
static ModuleManager & instance()
ModuleDef * getPrimaryInterface(const QCString &moduleName) const
An abstract interface of a namespace symbol.
virtual void combineUsingRelations(NamespaceDefSet &visitedNamespace)=0
Class representing a list of different code generators.
Definition outputlist.h:164
void add(OutputCodeIntfPtr &&p)
Definition outputlist.h:194
void startCodeFragment(const QCString &style)
Definition outputlist.h:278
Class representing a list of output generators that are written to in parallel.
Definition outputlist.h:314
bool isEnabled(OutputType o)
void endTextBlock(bool paraBreak=FALSE)
Definition outputlist.h:673
void writeString(const QCString &text)
Definition outputlist.h:412
void disable(OutputType o)
void startInclDepGraph()
Definition outputlist.h:653
void writeRuler()
Definition outputlist.h:522
const OutputCodeList & codeGenerators() const
Definition outputlist.h:357
void startGroupHeader(const QCString &id=QCString(), int extraLevels=0)
Definition outputlist.h:454
void enable(OutputType o)
void endContents()
Definition outputlist.h:621
void writeObjectLink(const QCString &ref, const QCString &file, const QCString &anchor, const QCString &name)
Definition outputlist.h:440
void writeDoc(const IDocNodeAST *ast, const Definition *ctx, const MemberDef *md)
Definition outputlist.h:384
void docify(const QCString &s)
Definition outputlist.h:438
void startParagraph(const QCString &classDef=QCString())
Definition outputlist.h:408
void startProjectNumber()
Definition outputlist.h:392
void startTextBlock(bool dense=FALSE)
Definition outputlist.h:671
void endParagraph()
Definition outputlist.h:410
void endInclDepGraph(DotInclDepGraph &g)
Definition outputlist.h:655
void startMemberSections()
Definition outputlist.h:462
void endTextLink()
Definition outputlist.h:445
void writeSynopsis()
Definition outputlist.h:593
void startTypewriter()
Definition outputlist.h:450
void generateDoc(const QCString &fileName, int startLine, const Definition *ctx, const MemberDef *md, const QCString &docStr, bool indexWords, bool isExample, const QCString &exampleName, bool singleLine, bool linkFromIndex, bool markdownSupport)
void pushGeneratorState()
void disableAllBut(OutputType o)
void popGeneratorState()
void writeSummaryLink(const QCString &file, const QCString &anchor, const QCString &title, bool first)
Definition outputlist.h:615
void writeAnchor(const QCString &fileName, const QCString &name)
Definition outputlist.h:524
void endGroupHeader(int extraLevels=0)
Definition outputlist.h:456
void endQuickIndices()
Definition outputlist.h:605
void writePageOutline()
Definition outputlist.h:617
void startContents()
Definition outputlist.h:619
void enableAll()
void endProjectNumber()
Definition outputlist.h:394
void endTypewriter()
Definition outputlist.h:452
void lineBreak(const QCString &style=QCString())
Definition outputlist.h:560
void parseText(const QCString &textStr)
void startTextLink(const QCString &file, const QCString &anchor)
Definition outputlist.h:443
void endMemberSections()
Definition outputlist.h:464
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
size_t length() const
Returns the length of the string, not counting the 0-terminator.
Definition qcstring.h:153
bool isEmpty() const
Returns TRUE iff the string is empty.
Definition qcstring.h:150
QCString stripWhiteSpace() const
returns a copy of this string with leading and trailing whitespace removed
Definition qcstring.h:245
const std::string & str() const
Definition qcstring.h:537
QCString right(size_t len) const
Definition qcstring.h:219
QCString & sprintf(const char *format,...)
Definition qcstring.cpp:29
int findRev(char c, int index=-1, bool cs=TRUE) const
Definition qcstring.cpp:91
QCString & insert(size_t index, const QCString &s)
Definition qcstring.h:317
QCString left(size_t len) const
Definition qcstring.h:214
Text streaming class that buffers data.
Definition textstream.h:36
static void writeVhdlDeclarations(const MemberList *, OutputList &, const GroupDef *, const ClassDef *, const FileDef *, const NamespaceDef *, const ModuleDef *)
#define Config_getInt(name)
Definition config.h:34
#define Config_getBool(name)
Definition config.h:33
#define Config_getString(name)
Definition config.h:32
#define NON_COPYABLE(cls)
Macro to help implementing the rule of 5 for a non-copyable & movable class.
Definition construct.h:37
std::unordered_set< std::string > StringUnorderedSet
Definition containers.h:29
std::vector< std::string > StringVector
Definition containers.h:33
void docFindSections(const QCString &input, const Definition *d, const QCString &fileName)
IDocParserPtr createDocParser()
factory function to create a parser
Definition docparser.cpp:55
IDocNodeASTPtr validatingParseDoc(IDocParser &parserIntf, const QCString &fileName, int startLine, const Definition *ctx, const MemberDef *md, const QCString &input, bool indexWords, bool isExample, const QCString &exampleName, bool singleLine, bool linkFromIndex, bool markdownSupport)
static void writeTagFile()
std::unordered_map< std::string, const IncludeInfo * > IncludeInfoMap
Definition filedef.cpp:120
QCString includeClose(SrcLangExt lang, IncludeKind kind)
Definition filedef.cpp:86
std::unordered_map< int, const Definition * > DefinitionLineMap
Definition filedef.cpp:118
QCString includeStatement(SrcLangExt lang, IncludeKind kind)
Definition filedef.cpp:56
std::unique_ptr< FileDef > createFileDef(const QCString &p, const QCString &n, const QCString &ref, const QCString &dn)
Definition filedef.cpp:268
bool compareFileDefs(const FileDef *fd1, const FileDef *fd2)
Definition filedef.cpp:1925
FileDef * toFileDef(Definition *d)
Definition filedef.cpp:1932
std::unordered_map< int, const MemberDef * > MemberDefLineMap
Definition filedef.cpp:119
QCString includeOpen(SrcLangExt lang, IncludeKind kind)
Definition filedef.cpp:73
QCString includeTagFileAttributes(SrcLangExt lang, IncludeKind kind)
Definition filedef.cpp:104
static void getAllIncludeFilesRecursively(StringUnorderedSet &filesVisited, const FileDef *fd, StringVector &incFiles)
Definition filedef.cpp:1828
constexpr uint32_t IncludeKind_ObjCMask
Definition filedef.h:67
IncludeKind
Definition filedef.h:47
@ ImportLocal
Definition filedef.h:54
@ ImportModule
Definition filedef.h:55
@ IncludeLocal
Definition filedef.h:50
@ ImportSystemObjC
Definition filedef.h:51
@ ImportLocalObjC
Definition filedef.h:52
@ IncludeSystem
Definition filedef.h:49
@ ImportSystem
Definition filedef.h:53
constexpr uint32_t IncludeKind_ImportMask
Definition filedef.h:65
constexpr uint32_t IncludeKind_LocalMask
Definition filedef.h:63
std::unordered_set< const FileDef * > FileDefSet
Definition filedef.h:44
void startTitle(OutputList &ol, const QCString &fileName, const DefinitionMutable *def)
Definition index.cpp:384
void endTitle(OutputList &ol, const QCString &fileName, const QCString &name)
Definition index.cpp:394
void startFile(OutputList &ol, const QCString &name, const QCString &manName, const QCString &title, HighlightedItem hli, bool additionalIndices, const QCString &altSidebarName, int hierarchyLevel, const QCString &allMembersFile)
Definition index.cpp:401
void endFileWithNavPath(OutputList &ol, const DefinitionMutable *d, bool showPageNavigation)
Definition index.cpp:448
Translator * theTranslator
Definition language.cpp:71
MemberDefMutable * toMemberDefMutable(Definition *d)
#define warn_uncond(fmt,...)
Definition message.h:122
#define msg(fmt,...)
Definition message.h:94
#define err(fmt,...)
Definition message.h:127
FILE * popen(const QCString &name, const QCString &type)
Definition portable.cpp:496
int pclose(FILE *stream)
Definition portable.cpp:505
NamespaceDefMutable * toNamespaceDefMutable(Definition *d)
std::unordered_set< const NamespaceDef * > NamespaceDefSet
Portable versions of functions that are platform dependent.
int qstricmp_sort(const char *str1, const char *str2)
Definition qcstring.h:86
const char * qPrint(const char *s)
Definition qcstring.h:672
#define TRUE
Definition qcstring.h:37
#define FALSE
Definition qcstring.h:34
std::vector< RefItem * > RefItemVector
Definition reflist.h:133
Web server based search engine.
std::string_view stripWhiteSpace(std::string_view s)
Given a string view s, returns a new, narrower view on that string, skipping over any leading or trai...
Definition stringutil.h:72
static QCString path2URL(const QCString &path)
Definition htags.cpp:157
static bool useHtags
Definition htags.h:23
Represents of a member declaration list with configurable title and subtitle.
Definition layout.h:112
QCString title(SrcLangExt lang) const
Definition layout.cpp:1786
MemberListType type
Definition layout.h:118
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:1798
Definition layout.h:102
QCString title(SrcLangExt lang) const
Definition layout.cpp:1779
CodeSymbolType
Definition types.h:481
@ Enumeration
Definition types.h:557
@ EnumValue
Definition types.h:558
@ Dictionary
Definition types.h:568
@ Sequence
Definition types.h:567
@ Variable
Definition types.h:555
@ Property
Definition types.h:563
@ Typedef
Definition types.h:556
@ Function
Definition types.h:554
SrcLangExt
Definition types.h:207
SrcLangExt getLanguageFromFileName(const QCString &fileName, SrcLangExt defLang)
Definition util.cpp:5721
QCString convertToHtml(const QCString &s, bool keepEntities)
Definition util.cpp:4479
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:5318
void addGroupListToTitle(OutputList &ol, const Definition *d)
Definition util.cpp:5405
QCString fileToString(const QCString &name, bool filter, bool isSourceCode)
Definition util.cpp:1441
void createSubDirs(const Dir &d)
Definition util.cpp:4156
static QCString stripFromPath(const QCString &p, const StringVector &l)
Definition util.cpp:309
QCString convertNameToFile(const QCString &name, bool allowDots, bool allowUnderscore)
Definition util.cpp:4020
QCString convertToXML(const QCString &s, bool keepEntities)
Definition util.cpp:4428
EntryType guessSection(const QCString &name)
Definition util.cpp:349
QCString removeLongPathMarker(QCString path)
Definition util.cpp:298
QCString getFileFilter(const QCString &name, bool isSourceCode)
Definition util.cpp:1369
QCString getFileNameExtension(const QCString &fn)
Definition util.cpp:5763
void addHtmlExtensionIfMissing(QCString &fName)
Definition util.cpp:5415
A bunch of utility functions.