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 writeTagFile(TextStream &t) override;
178 void writeSourceHeader(OutputList &ol) override;
179 void writeSourceBody(OutputList &ol,ClangTUParser *clangParser) override;
180 void writeSourceFooter(OutputList &ol) override;
181 void parseSource(ClangTUParser *clangParser) override;
182 void setDiskName(const QCString &name) override;
183 void insertMember(MemberDef *md) override;
184 void removeMember(MemberDef *md) override;
185 void insertClass(ClassDef *cd) override;
186 void insertConcept(ConceptDef *cd) override;
187 void insertNamespace(NamespaceDef *nd) override;
188 void computeAnchors() override;
189 void setDirDef(DirDef *dd) override { m_dir=dd; }
190 void setModuleDef(ModuleDef *mod) override { m_moduleDef=mod; }
191 void addUsingDirective(NamespaceDef *nd) override;
192 void addUsingDeclaration(const Definition *d) override;
193 void combineUsingRelations() override;
194 bool generateSourceFile() const override;
195 void sortMemberLists() override;
196 void addIncludeDependency(const FileDef *fd,const QCString &incName,IncludeKind kind) override;
197 void addIncludedByDependency(const FileDef *fd,const QCString &incName,IncludeKind kind) override;
198 void addMembersToMemberGroup() override;
200 void findSectionsInDocumentation() override;
201 void addIncludedUsingDirectives(FileDefSet &visitedFiles) override;
202 void addListReferences() override;
203
204 bool hasIncludeGraph() const override;
205 bool hasIncludedByGraph() const override;
206 void overrideIncludeGraph(bool e) override;
207 void overrideIncludedByGraph(bool e) override;
208
209 private:
210 void setDiskNameLocal(const QCString &name);
211 void acquireFileVersion();
220 void writeSourceLink(OutputList &ol);
222 bool isConstantGroup);
224 void writeConcepts(OutputList &ol,const QCString &title);
234
252 DirDef *m_dir = nullptr;
263 bool m_hasIncludeGraph = Config_getBool(INCLUDE_GRAPH);
264 bool m_hasIncludedByGraph = Config_getBool(INCLUDED_BY_GRAPH);
265};
266
267std::unique_ptr<FileDef> createFileDef(const QCString &p,const QCString &n,const QCString &ref,const QCString &dn)
268{
269 return std::make_unique<FileDefImpl>(p,n,ref,dn);
270}
271
272
273//---------------------------------------------------------------------------
274
275/*! create a new file definition, where \a p is the file path,
276 \a nm the file name, and \a lref is an HTML anchor name if the
277 file was read from a tag file or nullptr otherwise
278*/
280 const QCString &lref,const QCString &dn)
281 : DefinitionMixin(QCString(p)+nm,1,1,nm,nullptr,nullptr,!p.isEmpty())
282{
284 m_filePath=p+nm;
285 m_fileName=nm;
286
287 setReference(lref);
288 setDiskNameLocal(!dn.isEmpty() ? dn : nm);
289 m_isSource = guessSection(nm).isSource();
290 m_docname = nm;
291 m_dir = nullptr;
292 if (Config_getBool(FULL_PATH_NAMES))
293 {
295 }
297 Config_getBool(FULL_PATH_NAMES) ? m_fileName : DefinitionMixin::name()));
299 m_subGrouping=Config_getBool(SUBGROUPING);
300}
301
302/*! destroy the file definition */
306
308{
309 if (isReference())
310 {
312 m_inclDepFileName = name+"_incl";
313 m_inclByDepFileName = name+"_dep_incl";
314 }
315 else
316 {
320 }
321}
322
327
328/*! Compute the HTML anchor names for all members in the class */
330{
331 MemberList *ml = getMemberList(MemberListType::AllMembersList());
332 if (ml) ml->setAnchors();
333}
334
336{
337 //printf("FileDefImpl::distributeMemberGroupDocumentation()\n");
338 for (const auto &mg : m_memberGroups)
339 {
340 mg->distributeMemberGroupDocumentation();
341 }
342}
343
345{
349 for (const auto &mg : m_memberGroups)
350 {
351 mg->findSectionsInDocumentation(this);
352 }
353
354 for (auto &ml : m_memberLists)
355 {
356 if (ml->listType().isDeclaration())
357 {
358 ml->findSectionsInDocumentation(this);
359 }
360 }
361}
362
364{
365 bool repeatBrief = Config_getBool(REPEAT_BRIEF);
366 bool sourceBrowser = Config_getBool(SOURCE_BROWSER);
367 return ((!briefDescription().isEmpty() && repeatBrief) ||
368 !documentation().stripWhiteSpace().isEmpty() || // avail empty section
369 (sourceBrowser && getStartBodyLine()!=-1 && getBodyDef())
370 );
371}
372
374{
377 tagFile << " <compound kind=\"file\">\n";
378 tagFile << " <name>" << convertToXML(name()) << "</name>\n";
379 tagFile << " <path>" << convertToXML(stripFromPath(getPath())) << "</path>\n";
380 tagFile << " <filename>" << fn << "</filename>\n";
381 for (const auto &ii : m_includeList)
382 {
383 const FileDef *fd=ii.fileDef;
384 if (fd && fd->isLinkable() && !fd->isReference())
385 {
386 QCString attr = includeTagFileAttributes(fd->getLanguage(),ii.kind);
387 tagFile << " <includes id=\""
388 << convertToXML(fd->getOutputFileBase()) << "\" "
389 << "name=\"" << convertToXML(fd->name()) << "\" "
390 << attr << ">"
391 << convertToXML(ii.includeName)
392 << "</includes>\n";
393 }
394 }
395 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::File))
396 {
397 switch (lde->kind())
398 {
399 case LayoutDocEntry::FileClasses:
400 {
402 }
403 break;
404 case LayoutDocEntry::FileInterfaces:
405 {
407 }
408 break;
409 case LayoutDocEntry::FileStructs:
410 {
412 }
413 break;
414 case LayoutDocEntry::FileExceptions:
415 {
417 }
418 break;
419 case LayoutDocEntry::FileConcepts:
420 {
421 for (const auto *nd : m_concepts)
422 {
423 if (nd->isLinkableInProject())
424 {
425 tagFile << " <concept>" << convertToXML(nd->name()) << "</concept>\n";
426 }
427 }
428 }
429 break;
430 case LayoutDocEntry::FileNamespaces:
431 {
432 for (const auto *nd : m_namespaces)
433 {
434 if (nd->isLinkableInProject())
435 {
436 tagFile << " <namespace>" << convertToXML(nd->name()) << "</namespace>\n";
437 }
438 }
439 }
440 break;
441 case LayoutDocEntry::MemberDecl:
442 {
443 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
444 if (lmd)
445 {
446 MemberList * ml = getMemberList(lmd->type);
447 if (ml)
448 {
449 ml->writeTagFile(tagFile,false,false);
450 }
451 }
452 }
453 break;
454 case LayoutDocEntry::MemberGroups:
455 {
456 for (const auto &mg : m_memberGroups)
457 {
458 mg->writeTagFile(tagFile);
459 }
460 }
461 break;
462 default:
463 break;
464 }
465 }
466
468 tagFile << " </compound>\n";
469}
470
472{
474 {
477 ol.writeRuler();
481 ol.writeAnchor(QCString(),"details");
483 ol.startGroupHeader();
484 ol.parseText(title);
485 ol.endGroupHeader();
486
487 ol.startTextBlock();
488 if (!briefDescription().isEmpty() && Config_getBool(REPEAT_BRIEF))
489 {
491 QCString(),FALSE,FALSE,Config_getBool(MARKDOWN_SUPPORT));
492 }
493 if (!briefDescription().isEmpty() && Config_getBool(REPEAT_BRIEF) &&
494 !documentation().isEmpty())
495 {
499 ol.enableAll();
502 ol.writeString("\n\n");
504 }
505 if (!documentation().isEmpty())
506 {
507 ol.generateDoc(docFile(),docLine(),this,nullptr,documentation()+"\n",TRUE,FALSE,
508 QCString(),FALSE,FALSE,Config_getBool(MARKDOWN_SUPPORT));
509 }
510 //printf("Writing source ref for file %s\n",qPrint(name()));
511 if (Config_getBool(SOURCE_BROWSER))
512 {
513 ol.startParagraph("definition");
514 QCString refText = theTranslator->trDefinedInSourceFile();
515 int fileMarkerPos = refText.find("@0");
516 if (fileMarkerPos!=-1) // should always pass this.
517 {
518 ol.parseText(refText.left(fileMarkerPos)); //text left from marker 1
520 ol.parseText(refText.right(
521 refText.length()-fileMarkerPos-2)); // text right from marker 2
522 }
523 else
524 {
525 err("translation error: invalid marker in trDefinedInSourceFile()\n");
526 }
527 ol.endParagraph();
528 }
529 ol.endTextBlock();
530 }
531}
532
534{
536 {
537 auto parser { createDocParser() };
538 auto ast { validatingParseDoc(*parser.get(),
539 briefFile(),briefLine(),this,nullptr,
541 QCString(),TRUE,FALSE,Config_getBool(MARKDOWN_SUPPORT)) };
542 if (!ast->isEmpty())
543 {
544 ol.startParagraph();
547 ol.writeString(" - ");
549 ol.writeDoc(ast.get(),this,nullptr);
552 ol.writeString(" \n");
554
555 if (Config_getBool(REPEAT_BRIEF) ||
556 !documentation().stripWhiteSpace().isEmpty()
557 )
558 {
560 ol.startTextLink(QCString(),"details");
561 ol.parseText(theTranslator->trMore());
562 ol.endTextLink();
563 }
565 ol.endParagraph();
566 }
567 }
568 ol.writeSynopsis();
569}
570
572{
573 for (const auto &cd : list)
574 {
575 if (cd->isLinkableInProject())
576 {
577 tagFile << " <class kind=\"" << cd->compoundTypeString() <<
578 "\">" << convertToXML(cd->name()) << "</class>\n";
579 }
580 }
581}
582
584{
585 if (!m_includeList.empty())
586 {
588 for (const auto &ii : m_includeList)
589 {
590 const FileDef *fd=ii.fileDef;
591 ol.startTypewriter();
592 SrcLangExt lang = fd ? fd->getLanguage() : SrcLangExt::Cpp;
593 ol.docify(::includeStatement(lang,ii.kind));
594 ol.docify(::includeOpen(lang,ii.kind));
596 ol.docify(ii.includeName);
597 ol.enableAll();
599
600 // Here we use the include file name as it appears in the file.
601 // we could also we the name as it is used within doxygen,
602 // then we should have used fd->docName() instead of ii->includeName
603 if (fd && fd->isLinkable())
604 {
607 QCString(),ii.includeName);
608 }
609 else
610 {
612 if (ii.kind==IncludeKind::ImportModule && mod && mod->isLinkable())
613 {
615 QCString(),ii.includeName);
616 }
617 else
618 {
619 ol.docify(ii.includeName);
620 }
621 }
622
623 ol.enableAll();
624 ol.docify(::includeClose(lang,ii.kind));
625 ol.endTypewriter();
626 ol.lineBreak();
627 }
628 ol.endTextBlock();
629 }
630}
631
633{
634 if (Config_getBool(HAVE_DOT) && m_hasIncludeGraph /*&& Config_getBool(INCLUDE_GRAPH)*/)
635 {
636 //printf("Graph for file %s\n",qPrint(name()));
637 DotInclDepGraph incDepGraph(this,FALSE);
638 if (incDepGraph.isTooBig())
639 {
640 warn_uncond("Include graph for '{}' not generated, too many nodes ({}), threshold is {}. Consider increasing DOT_GRAPH_MAX_NODES.\n",
641 qPrint(name()), incDepGraph.numNodes(), Config_getInt(DOT_GRAPH_MAX_NODES));
642 }
643 else if (!incDepGraph.isTrivial())
644 {
645 ol.startTextBlock();
648 ol.parseText(theTranslator->trInclDepGraph(name()));
649 ol.endInclDepGraph(incDepGraph);
650 ol.enableAll();
651 ol.endTextBlock(TRUE);
652 }
653 //incDepGraph.writeGraph(Config_getString(HTML_OUTPUT),fd->getOutputFileBase());
654 }
655}
656
658{
659 if (Config_getBool(HAVE_DOT) && m_hasIncludedByGraph /*&& Config_getBool(INCLUDED_BY_GRAPH)*/)
660 {
661 //printf("Graph for file %s\n",qPrint(name()));
662 DotInclDepGraph incDepGraph(this,TRUE);
663 if (incDepGraph.isTooBig())
664 {
665 warn_uncond("Included by graph for '{}' not generated, too many nodes ({}), threshold is {}. Consider increasing DOT_GRAPH_MAX_NODES.\n",
666 qPrint(name()), incDepGraph.numNodes(), Config_getInt(DOT_GRAPH_MAX_NODES));
667 }
668 else if (!incDepGraph.isTrivial())
669 {
670 ol.startTextBlock();
673 ol.parseText(theTranslator->trInclByDepGraph());
674 ol.endInclDepGraph(incDepGraph);
675 ol.enableAll();
676 ol.endTextBlock(TRUE);
677 }
678 //incDepGraph.writeGraph(Config_getString(HTML_OUTPUT),fd->getOutputFileBase());
679 }
680}
681
682
684{
685 //printf("%s: generateSourceFile()=%d\n",qPrint(name()),generateSourceFile());
686 if (generateSourceFile())
687 {
689 ol.startParagraph();
691 ol.parseText(theTranslator->trGotoSourceCode());
692 ol.endTextLink();
693 ol.endParagraph();
694 ol.enableAll();
695 }
696}
697
699 bool const isConstantGroup)
700{
701 // write list of namespaces
702 m_namespaces.writeDeclaration(ol,title,isConstantGroup);
703}
704
706{
707 // write list of classes
708 list.writeDeclaration(ol,nullptr,title,FALSE);
709}
710
712{
713 // write list of classes
714 m_concepts.writeDeclaration(ol,title,FALSE);
715}
716
718{
719 // temporarily undo the disabling could be done by startMemberDocumentation()
720 // as a result of setting SEPARATE_MEMBER_PAGES to YES; see bug730512
721 bool isEnabled = ol.isEnabled(OutputType::Html);
723
724 m_classes.writeDocumentation(ol,this);
725
726 // restore the initial state if needed
727 if (!isEnabled) ol.disable(OutputType::Html);
728}
729
734
739
741{
742 if (Config_getBool(SEPARATE_MEMBER_PAGES))
743 {
746 }
747}
748
750{
751 if (Config_getBool(SEPARATE_MEMBER_PAGES))
752 {
755 }
756}
757
759{
760 /* write user defined member groups */
761 for (const auto &mg : m_memberGroups)
762 {
763 if (!mg->allMembersInSameSection() || !m_subGrouping)
764 {
765 mg->writeDeclarations(ol,nullptr,nullptr,this,nullptr,nullptr);
766 }
767 }
768}
769
771{
772 // write Author section (Man only)
775 ol.startGroupHeader();
776 ol.parseText(theTranslator->trAuthor(TRUE,TRUE));
777 ol.endGroupHeader();
778 ol.parseText(theTranslator->trGeneratedAutomatically(Config_getString(PROJECT_NAME)));
780}
781
783{
786 bool first=TRUE;
787 SrcLangExt lang=getLanguage();
788 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::File))
789 {
790 const LayoutDocEntrySection *ls = dynamic_cast<const LayoutDocEntrySection*>(lde.get());
791 if (lde->kind()==LayoutDocEntry::FileClasses && m_classes.declVisible() && ls)
792 {
793 QCString label = "nested-classes";
794 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
795 first=FALSE;
796 }
797 else if (lde->kind()==LayoutDocEntry::FileInterfaces && m_interfaces.declVisible() && ls)
798 {
799 QCString label = "interfaces";
800 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
801 first=FALSE;
802 }
803 else if (lde->kind()==LayoutDocEntry::FileStructs && m_structs.declVisible() && ls)
804 {
805 QCString label = "structs";
806 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
807 first=FALSE;
808 }
809 else if (lde->kind()==LayoutDocEntry::FileExceptions && m_exceptions.declVisible() && ls)
810 {
811 QCString label = "exceptions";
812 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
813 first=FALSE;
814 }
815 else if (lde->kind()==LayoutDocEntry::FileNamespaces && m_namespaces.declVisible(false) && ls)
816 {
817 QCString label = "namespaces";
818 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
819 first=FALSE;
820 }
821 else if (lde->kind()==LayoutDocEntry::FileConcepts && m_concepts.declVisible() && ls)
822 {
823 QCString label = "concepts";
824 ol.writeSummaryLink(QCString(),label,ls->title(lang),first);
825 first=FALSE;
826 }
827 else if (lde->kind()==LayoutDocEntry::MemberDecl)
828 {
829 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
830 if (lmd)
831 {
832 MemberList * ml = getMemberList(lmd->type);
833 if (ml && ml->declVisible())
834 {
835 ol.writeSummaryLink(QCString(),ml->listType().toLabel(),lmd->title(lang),first);
836 first=FALSE;
837 }
838 }
839 }
840 }
841 if (!first)
842 {
843 ol.writeString(" </div>\n");
844 }
846}
847
848/*! Write the documentation page for this file to the file of output
849 generators \a ol.
850*/
852{
853 bool generateTreeView = Config_getBool(GENERATE_TREEVIEW);
854 //funcList->countDecMembers();
855
856 //QCString fn = name();
857 //if (Config_getBool(FULL_PATH_NAMES))
858 //{
859 // fn.prepend(stripFromPath(getPath()));
860 //}
861
862 //printf("WriteDocumentation diskname=%s\n",qPrint(diskname));
863
864 QCString versionTitle;
865 if (!m_fileVersion.isEmpty())
866 {
867 versionTitle=("("+m_fileVersion+")");
868 }
869 QCString title = m_docname+versionTitle;
870 QCString pageTitle;
871 if (Config_getBool(HIDE_COMPOUND_REFERENCE))
872 {
873 pageTitle=m_docname;
874 }
875 else
876 {
877 pageTitle=theTranslator->trFileReference(m_docname);
878 }
879
880 if (getDirDef())
881 {
882 startFile(ol,getOutputFileBase(),name(),pageTitle,HighlightedItem::FileVisible,!generateTreeView);
883 if (!generateTreeView)
884 {
886 ol.endQuickIndices();
887 }
888 startTitle(ol,getOutputFileBase(),this);
891 if (Config_getBool(HIDE_COMPOUND_REFERENCE))
892 {
893 ol.parseText(displayName()); // Html only
894 }
895 else
896 {
897 ol.parseText(theTranslator->trFileReference(displayName())); // Html only
898 }
899 ol.enableAll();
901 if (Config_getBool(HIDE_COMPOUND_REFERENCE))
902 {
903 ol.parseText(Config_getBool(FULL_PATH_NAMES) ? // other output formats
904 pageTitle :
905 name());
906 }
907 else
908 {
909 ol.parseText(Config_getBool(FULL_PATH_NAMES) ? // other output formats
910 pageTitle :
911 theTranslator->trFileReference(name()));
912 }
914 addGroupListToTitle(ol,this);
916 }
917 else
918 {
919 startFile(ol,getOutputFileBase(),name(),pageTitle,HighlightedItem::FileVisible,!generateTreeView);
920 if (!generateTreeView)
921 {
922 ol.endQuickIndices();
923 }
924 startTitle(ol,getOutputFileBase(),this);
925 ol.parseText(pageTitle);
926 addGroupListToTitle(ol,this);
928 }
929
930 ol.startContents();
931
932 if (!m_fileVersion.isEmpty())
933 {
936 ol.docify(versionTitle);
937 ol.endProjectNumber();
938 ol.enableAll();
939 }
940
941 //---------------------------------------- start flexible part -------------------------------
942
943 SrcLangExt lang = getLanguage();
944 for (const auto &lde : LayoutDocManager::instance().docEntries(LayoutDocManager::File))
945 {
946 const LayoutDocEntrySection *ls = dynamic_cast<const LayoutDocEntrySection*>(lde.get());
947 switch (lde->kind())
948 {
949 case LayoutDocEntry::BriefDesc:
951 break;
952 case LayoutDocEntry::MemberDeclStart:
954 break;
955 case LayoutDocEntry::FileIncludes:
957 break;
958 case LayoutDocEntry::FileIncludeGraph:
960 break;
961 case LayoutDocEntry::FileIncludedByGraph:
963 break;
964 case LayoutDocEntry::FileSourceLink:
965 writeSourceLink(ol);
966 break;
967 case LayoutDocEntry::FileClasses:
968 if (ls) writeClassDeclarations(ol,ls->title(lang),m_classes);
969 break;
970 case LayoutDocEntry::FileInterfaces:
971 if (ls) writeClassDeclarations(ol,ls->title(lang),m_interfaces);
972 break;
973 case LayoutDocEntry::FileStructs:
974 if (ls) writeClassDeclarations(ol,ls->title(lang),m_structs);
975 break;
976 case LayoutDocEntry::FileExceptions:
977 if (ls) writeClassDeclarations(ol,ls->title(lang),m_exceptions);
978 break;
979 case LayoutDocEntry::FileConcepts:
980 if (ls) writeConcepts(ol,ls->title(lang));
981 break;
982 case LayoutDocEntry::FileNamespaces:
983 if (ls) writeNamespaceDeclarations(ol,ls->title(lang),false);
984 break;
985 case LayoutDocEntry::FileConstantGroups:
986 if (ls) writeNamespaceDeclarations(ol,ls->title(lang),true);
987 break;
988 case LayoutDocEntry::MemberGroups:
990 break;
991 case LayoutDocEntry::MemberDecl:
992 {
993 const LayoutDocEntryMemberDecl *lmd = dynamic_cast<const LayoutDocEntryMemberDecl*>(lde.get());
994 if (lmd) writeMemberDeclarations(ol,lmd->type,lmd->title(lang));
995 }
996 break;
997 case LayoutDocEntry::MemberDeclEnd:
999 break;
1000 case LayoutDocEntry::DetailedDesc:
1001 if (ls) writeDetailedDescription(ol,ls->title(lang));
1002 break;
1003 case LayoutDocEntry::MemberDefStart:
1005 break;
1006 case LayoutDocEntry::FileInlineClasses:
1008 break;
1009 case LayoutDocEntry::MemberDef:
1010 {
1011 const LayoutDocEntryMemberDef *lmd = dynamic_cast<const LayoutDocEntryMemberDef*>(lde.get());
1012 if (lmd) writeMemberDocumentation(ol,lmd->type,lmd->title(lang));
1013 }
1014 break;
1015 case LayoutDocEntry::MemberDefEnd:
1017 break;
1018 case LayoutDocEntry::AuthorSection:
1020 break;
1021 case LayoutDocEntry::ClassIncludes:
1022 case LayoutDocEntry::ClassInheritanceGraph:
1023 case LayoutDocEntry::ClassNestedClasses:
1024 case LayoutDocEntry::ClassCollaborationGraph:
1025 case LayoutDocEntry::ClassAllMembersLink:
1026 case LayoutDocEntry::ClassUsedFiles:
1027 case LayoutDocEntry::ClassInlineClasses:
1028 case LayoutDocEntry::NamespaceNestedNamespaces:
1029 case LayoutDocEntry::NamespaceNestedConstantGroups:
1030 case LayoutDocEntry::NamespaceClasses:
1031 case LayoutDocEntry::NamespaceConcepts:
1032 case LayoutDocEntry::NamespaceInterfaces:
1033 case LayoutDocEntry::NamespaceStructs:
1034 case LayoutDocEntry::NamespaceExceptions:
1035 case LayoutDocEntry::NamespaceInlineClasses:
1036 case LayoutDocEntry::ConceptDefinition:
1037 case LayoutDocEntry::GroupClasses:
1038 case LayoutDocEntry::GroupConcepts:
1039 case LayoutDocEntry::GroupModules:
1040 case LayoutDocEntry::GroupInlineClasses:
1041 case LayoutDocEntry::GroupNamespaces:
1042 case LayoutDocEntry::GroupDirs:
1043 case LayoutDocEntry::GroupNestedGroups:
1044 case LayoutDocEntry::GroupFiles:
1045 case LayoutDocEntry::GroupGraph:
1046 case LayoutDocEntry::GroupPageDocs:
1047 case LayoutDocEntry::ModuleExports:
1048 case LayoutDocEntry::ModuleClasses:
1049 case LayoutDocEntry::ModuleConcepts:
1050 case LayoutDocEntry::ModuleUsedFiles:
1051 case LayoutDocEntry::DirSubDirs:
1052 case LayoutDocEntry::DirFiles:
1053 case LayoutDocEntry::DirGraph:
1054 err("Internal inconsistency: member '{}' should not be part of "
1055 "LayoutDocManager::File entry list\n",lde->entryToString());
1056 break;
1057 }
1058 }
1059
1060 //---------------------------------------- end flexible part -------------------------------
1061
1062 ol.endContents();
1063
1064 endFileWithNavPath(ol,this);
1065
1066 if (Config_getBool(SEPARATE_MEMBER_PAGES))
1067 {
1068 MemberList *ml = getMemberList(MemberListType::AllMembersList());
1069 if (ml) ml->sort();
1070 writeMemberPages(ol);
1071 }
1072}
1073
1075{
1076 ol.pushGeneratorState();
1078
1079 for (const auto &ml : m_memberLists)
1080 {
1081 if (ml->listType().isDocumentation())
1082 {
1083 ml->writeDocumentationPage(ol,name(),this);
1084 }
1085 }
1086
1087 ol.popGeneratorState();
1088}
1089
1091{
1092 bool createSubDirs=Config_getBool(CREATE_SUBDIRS);
1093
1094 ol.writeString(" <div class=\"navtab\">\n");
1095 ol.writeString(" <table>\n");
1096
1097 MemberList *allMemberList = getMemberList(MemberListType::AllMembersList());
1098 if (allMemberList)
1099 {
1100 for (const auto &md : *allMemberList)
1101 {
1102 if (md->getFileDef()==this && md->getNamespaceDef()==nullptr && md->isLinkable() && !md->isEnumValue())
1103 {
1104 if (md->isLinkableInProject())
1105 {
1106 QCString fn=md->getOutputFileBase();
1108 if (md==currentMd) // selected item => highlight
1109 {
1110 ol.writeString(" <tr><td class=\"navtabHL\">");
1111 }
1112 else
1113 {
1114 ol.writeString(" <tr><td class=\"navtab\">");
1115 }
1116 ol.writeString("<span class=\"label\"><a ");
1117 ol.writeString("href=\"");
1118 if (createSubDirs) ol.writeString("../../");
1119 ol.writeString(fn+"#"+md->anchor());
1120 ol.writeString("\">");
1121 ol.writeString(convertToHtml(md->localName()));
1122 ol.writeString("</a></span>");
1123 ol.writeString("</td></tr>\n");
1124 }
1125 }
1126 }
1127 }
1128
1129 ol.writeString(" </table>\n");
1130 ol.writeString(" </div>\n");
1131}
1132
1133/*! Write a source listing of this file to the output */
1135{
1136 bool generateTreeView = Config_getBool(GENERATE_TREEVIEW);
1138 if (!m_fileVersion.isEmpty())
1139 {
1140 title+=(" ("+m_fileVersion+")");
1141 }
1142 QCString pageTitle = theTranslator->trSourceFile(title);
1144
1145 bool isDocFile = isDocumentationFile();
1146 bool genSourceFile = !isDocFile && generateSourceFile();
1147 if (getDirDef())
1148 {
1150 !generateTreeView,
1151 !isDocFile && genSourceFile ? QCString() : getOutputFileBase(),
1152 0);
1153 if (!generateTreeView)
1154 {
1156 ol.endQuickIndices();
1157 }
1159 ol.parseText(name());
1161 }
1162 else
1163 {
1165 !isDocFile && genSourceFile ? QCString() : getOutputFileBase(),
1166 0);
1168 ol.parseText(title);
1170 }
1171
1172 ol.startContents();
1173
1174 if (isLinkable())
1175 {
1177 ol.parseText(theTranslator->trGotoDocumentation());
1178 ol.endTextLink();
1179
1180 ol.pushGeneratorState();
1182 ol.writeString("\\par\n");
1183 ol.popGeneratorState();
1184 }
1185}
1186
1187void FileDefImpl::writeSourceBody(OutputList &ol,[[maybe_unused]] ClangTUParser *clangParser)
1188{
1189 bool filterSourceFiles = Config_getBool(FILTER_SOURCE_FILES);
1190 OutputCodeList devNullList;
1191 devNullList.add<DevNullCodeGenerator>();
1192#if USE_LIBCLANG
1193 if (Doxygen::clangAssistedParsing && clangParser &&
1194 (getLanguage()==SrcLangExt::Cpp || getLanguage()==SrcLangExt::ObjC))
1195 {
1196 auto &codeOL = ol.codeGenerators();
1197 codeOL.startCodeFragment("DoxyCode");
1198 clangParser->switchToFile(this);
1199 clangParser->writeSources(codeOL,this);
1200 codeOL.endCodeFragment("DoxyCode");
1201 }
1202 else
1203#endif
1204 {
1205 auto intf = Doxygen::parserManager->getCodeParser(getDefFileExtension());
1206 intf->resetCodeParserState();
1207 auto &codeOL = ol.codeGenerators();
1208 codeOL.startCodeFragment("DoxyCode");
1209 bool needs2PassParsing =
1210 Doxygen::parseSourcesNeeded && // we need to parse (filtered) sources for cross-references
1211 !filterSourceFiles && // but user wants to show sources as-is
1212 !getFileFilter(absFilePath(),TRUE).isEmpty(); // and there is a filter used while parsing
1213
1214 if (needs2PassParsing)
1215 {
1216 // parse code for cross-references only (see bug707641)
1217 intf->parseCode(devNullList,QCString(),
1219 getLanguage(),
1220 Config_getBool(STRIP_CODE_COMMENTS),
1221 FALSE,QCString(),this
1222 );
1223 }
1224 intf->parseCode(codeOL,QCString(),
1225 fileToString(absFilePath(),filterSourceFiles,TRUE),
1226 getLanguage(), // lang
1227 Config_getBool(STRIP_CODE_COMMENTS),
1228 FALSE, // isExampleBlock
1229 QCString(), // exampleName
1230 this, // fileDef
1231 -1, // startLine
1232 -1, // endLine
1233 FALSE, // inlineFragment
1234 nullptr, // memberDef
1235 TRUE, // showLineNumbers
1236 nullptr, // searchCtx
1237 !needs2PassParsing // collectXRefs
1238 );
1239 codeOL.endCodeFragment("DoxyCode");
1240 }
1241}
1242
1244{
1245 ol.endContents();
1246 endFileWithNavPath(ol,this);
1247 ol.enableAll();
1248}
1249
1250void FileDefImpl::parseSource([[maybe_unused]] ClangTUParser *clangParser)
1251{
1252 bool filterSourceFiles = Config_getBool(FILTER_SOURCE_FILES);
1253 OutputCodeList devNullList;
1254 devNullList.add<DevNullCodeGenerator>();
1255#if USE_LIBCLANG
1256 if (Doxygen::clangAssistedParsing && clangParser &&
1257 (getLanguage()==SrcLangExt::Cpp || getLanguage()==SrcLangExt::ObjC))
1258 {
1259 clangParser->switchToFile(this);
1260 clangParser->writeSources(devNullList,this);
1261 }
1262 else
1263#endif
1264 {
1265 auto intf = Doxygen::parserManager->getCodeParser(getDefFileExtension());
1266 intf->resetCodeParserState();
1267 intf->parseCode(
1268 devNullList,QCString(),
1269 fileToString(absFilePath(),filterSourceFiles,TRUE),
1270 getLanguage(),
1271 Config_getBool(STRIP_CODE_COMMENTS),
1272 FALSE,QCString(),this
1273 );
1274 }
1275}
1276
1278{
1279 for (auto &ml : m_memberLists)
1280 {
1281 if (ml->listType().isDeclaration())
1282 {
1284 }
1285 }
1286
1287 // add members inside sections to their groups
1288 for (const auto &mg : m_memberGroups)
1289 {
1290 if (mg->allMembersInSameSection() && m_subGrouping)
1291 {
1292 //printf("----> addToDeclarationSection(%s)\n",qPrint(mg->header()));
1293 mg->addToDeclarationSection();
1294 }
1295 }
1296}
1297
1298/*! Adds member definition \a md to the list of all members of this file */
1300{
1301 if (md->isHidden()) return;
1302 MemberList *allMemberList = getMemberList(MemberListType::AllMembersList());
1303 //printf("%s:FileDefImpl::insertMember(%s (=%p) list has %zu elements)\n",
1304 // qPrint(name()),qPrint(md->name()),(void*)md,allMemberList ? allMemberList->size() : 0);
1305 if (allMemberList && allMemberList->contains(md))
1306 {
1307 //printf("already added\n");
1308 return;
1309 }
1310
1311 if (allMemberList==nullptr)
1312 {
1313 m_memberLists.emplace_back(std::make_unique<MemberList>(MemberListType::AllMembersList(),MemberListContainer::File));
1314 allMemberList = m_memberLists.back().get();
1315 }
1316 allMemberList->push_back(md);
1317 switch (md->memberType())
1318 {
1320 if (md->getLanguage() == SrcLangExt::Python)
1321 {
1322 addMemberToList(MemberListType::PropertyMembers(),md);
1323 addMemberToList(MemberListType::Properties(),md);
1324 break;
1325 }
1326 // fallthrough, explicitly no break here
1328 addMemberToList(MemberListType::DecVarMembers(),md);
1329 addMemberToList(MemberListType::DocVarMembers(),md);
1330 break;
1332 addMemberToList(MemberListType::DecFuncMembers(),md);
1333 addMemberToList(MemberListType::DocFuncMembers(),md);
1334 break;
1336 addMemberToList(MemberListType::DecTypedefMembers(),md);
1337 addMemberToList(MemberListType::DocTypedefMembers(),md);
1338 break;
1340 addMemberToList(MemberListType::DecSequenceMembers(),md);
1341 addMemberToList(MemberListType::DocSequenceMembers(),md);
1342 break;
1344 addMemberToList(MemberListType::DecDictionaryMembers(),md);
1345 addMemberToList(MemberListType::DocDictionaryMembers(),md);
1346 break;
1348 addMemberToList(MemberListType::DecEnumMembers(),md);
1349 addMemberToList(MemberListType::DocEnumMembers(),md);
1350 break;
1351 case MemberType::EnumValue: // enum values are shown inside their enums
1352 break;
1353 case MemberType::Define:
1354 addMemberToList(MemberListType::DecDefineMembers(),md);
1355 addMemberToList(MemberListType::DocDefineMembers(),md);
1356 break;
1357 default:
1358 err("FileDefImpl::insertMembers(): "
1359 "member '{}' with class scope '{}' inserted in file scope '{}'!\n",
1360 md->name(),
1361 md->getClassDef() ? md->getClassDef()->name() : "<global>",
1362 name());
1363 }
1364 //addMemberToGroup(md,groupId);
1365}
1366
1368{
1369 MemberList *ml = getMemberList(lt);
1370 if (ml) ml->remove(md);
1371}
1372
1374{
1375 removeMemberFromList(MemberListType::AllMembersList(),md);
1376 switch(md->memberType())
1377 {
1379 if (md->getLanguage() == SrcLangExt::Python)
1380 {
1381 removeMemberFromList(MemberListType::PropertyMembers(),md);
1382 removeMemberFromList(MemberListType::Properties(),md);
1383 break;
1384 }
1385 // fallthrough, explicitly no break here
1387 removeMemberFromList(MemberListType::DecVarMembers(),md);
1388 removeMemberFromList(MemberListType::DocVarMembers(),md);
1389 break;
1391 removeMemberFromList(MemberListType::DecFuncMembers(),md);
1392 removeMemberFromList(MemberListType::DocFuncMembers(),md);
1393 break;
1395 removeMemberFromList(MemberListType::DecTypedefMembers(),md);
1396 removeMemberFromList(MemberListType::DocTypedefMembers(),md);
1397 break;
1399 removeMemberFromList(MemberListType::DecSequenceMembers(),md);
1400 removeMemberFromList(MemberListType::DocSequenceMembers(),md);
1401 break;
1403 removeMemberFromList(MemberListType::DecDictionaryMembers(),md);
1404 removeMemberFromList(MemberListType::DocDictionaryMembers(),md);
1405 break;
1407 removeMemberFromList(MemberListType::DecEnumMembers(),md);
1408 removeMemberFromList(MemberListType::DocEnumMembers(),md);
1409 break;
1410 case MemberType::EnumValue: // enum values are shown inside their enums
1411 break;
1412 case MemberType::Define:
1413 removeMemberFromList(MemberListType::DecDefineMembers(),md);
1414 removeMemberFromList(MemberListType::DocDefineMembers(),md);
1415 break;
1416 default:
1417 err("FileDefImpl::removeMember(): unexpected member remove in file!\n");
1418 }
1419}
1420
1421/*! Adds compound definition \a cd to the list of all compounds of this file */
1423{
1424 if (cd->isHidden()) return;
1425
1427
1428 if (Config_getBool(OPTIMIZE_OUTPUT_SLICE))
1429 {
1431 {
1432 list = &m_interfaces;
1433 }
1434 else if (cd->compoundType()==ClassDef::Struct)
1435 {
1436 list = &m_structs;
1437 }
1438 else if (cd->compoundType()==ClassDef::Exception)
1439 {
1440 list = &m_exceptions;
1441 }
1442 }
1443
1444 list->add(cd->name(),cd);
1445}
1446
1448{
1449 if (cd->isHidden()) return;
1450 m_concepts.add(cd->name(),cd);
1451}
1452
1453/*! Adds namespace definition \a nd to the list of all compounds of this file */
1455{
1456 if (nd->isHidden()) return;
1457 m_namespaces.add(nd->name(),nd);
1458}
1459
1461{
1462 if (Config_getBool(FULL_PATH_NAMES))
1463 return m_fileName;
1464 else
1465 return DefinitionMixin::name();
1466}
1467
1468void FileDefImpl::addSourceRef(int line,const Definition *d,const MemberDef *md)
1469{
1470 //printf("FileDefImpl::addSourceRef(%d,%s,%s)\n",line,qPrint(d?d->name():"nullptr"),qPrint(md?md->name():"nullptr"));
1471 if (d)
1472 {
1473 m_srcDefMap.emplace(line,d);
1474 if (md) m_srcMemberMap.emplace(line,md);
1475 //printf("Adding member %s with anchor %s at line %d to file %s\n",
1476 // md?qPrint(md->name()):"<none>",md?qPrint(md->anchor()):"<none>",line,qPrint(name()));
1477 }
1478}
1479
1481{
1482 auto it = m_srcDefMap.find(lineNr);
1483 //printf("%s::getSourceDefinition(%d)=%s\n",qPrint(name()),lineNr,it!=m_srcDefMap.end()?qPrint(it->second->name()):"none");
1484 return it!=m_srcDefMap.end() ? it->second : nullptr;
1485}
1486
1488{
1489 auto it = m_srcMemberMap.find(lineNr);
1490 //printf("%s::getSourceMember(%d)=%s\n",qPrint(name()),lineNr,it!=m_srcMemberMap.end()?qPrint(it->second->name()):"none");
1491 return it!=m_srcMemberMap.end() ? it->second : nullptr;
1492}
1493
1494
1496{
1497 m_usingDirList.add(nd->qualifiedName(),nd);
1498 //printf("%p: FileDefImpl::addUsingDirective: %s:%d\n",this,qPrint(name()),usingDirList->count());
1499}
1500
1502{
1503 //printf("%p: FileDefImpl::getUsedNamespace: %s:%d\n",this,qPrint(name()),usingDirList?usingDirList->count():0);
1504 return m_usingDirList;
1505}
1506
1511
1513{
1514 //printf("FileDefImpl::addIncludeDependency(%p,%s,%d)\n",(void*)fd,qPrint(incName),kind);
1515 QCString iName = fd ? fd->absFilePath() : incName;
1516 if (!iName.isEmpty() && m_includeMap.find(iName.str())==m_includeMap.end())
1517 {
1518 m_includeList.emplace_back(fd,incName,kind);
1519 m_includeMap.emplace(iName.str(),&m_includeList.back());
1520 }
1521}
1522
1524{
1525 if (visitedFiles.find(this)!=visitedFiles.end()) return; // file already processed
1526 visitedFiles.insert(this);
1527 //printf("( FileDefImpl::addIncludedUsingDirectives for file %s\n",qPrint(name()));
1528
1529 if (!m_includeList.empty()) // file contains #includes
1530 {
1531 {
1532 for (const auto &ii : m_includeList) // foreach #include...
1533 {
1534 if (ii.fileDef) // ...that is a known file
1535 {
1536 // recurse into this file
1537 const_cast<FileDef*>(ii.fileDef)->addIncludedUsingDirectives(visitedFiles);
1538 }
1539 }
1540 }
1541 {
1542 // iterate through list from last to first
1543 for (auto ii_it = m_includeList.rbegin(); ii_it!=m_includeList.rend(); ++ii_it)
1544 {
1545 auto &ii = *ii_it;
1546 if (ii.fileDef && ii.fileDef!=this)
1547 {
1548 // add using directives
1549 auto unl = ii.fileDef->getUsedNamespaces();
1550 for (auto it = unl.rbegin(); it!=unl.rend(); ++it)
1551 {
1552 auto *nd = *it;
1553 //printf(" adding using directive for %s\n",qPrint(nd->qualifiedName()));
1554 m_usingDirList.prepend(nd->qualifiedName(),nd);
1555 }
1556 // add using declarations
1557 auto udl = ii.fileDef->getUsedDefinitions();
1558 for (auto it = udl.rbegin(); it!=udl.rend(); ++it)
1559 {
1560 auto *d = *it;
1561 m_usingDeclList.prepend(d->qualifiedName(),d);
1562 }
1563 }
1564 }
1565 }
1566 }
1567 //printf(") end FileDefImpl::addIncludedUsingDirectives for file %s\n",qPrint(name()));
1568}
1569
1570
1572{
1573 //printf("FileDefImpl::addIncludedByDependency(%p,%s,%d)\n",fd,incName,local);
1574 QCString iName = fd ? fd->absFilePath() : incName;
1575 if (!iName.isEmpty() && m_includedByMap.find(iName.str())==m_includedByMap.end())
1576 {
1577 m_includedByList.emplace_back(fd,incName,kind);
1578 m_includedByMap.emplace(iName.str(),&m_includedByList.back());
1579 }
1580}
1581
1583{
1584 if (name.isEmpty()) return FALSE;
1585 return m_includeMap.find(name.str())!=m_includeMap.end();
1586}
1587
1589{
1590 bool sourceBrowser = Config_getBool(SOURCE_BROWSER);
1591 bool verbatimHeaders = Config_getBool(VERBATIM_HEADERS);
1592 return !isReference() &&
1593 (sourceBrowser ||
1594 (verbatimHeaders && (guessSection(name()).isHeader() || !m_includedByMap.empty()))
1595 ) &&
1597}
1598
1599
1601{
1602 {
1603 const RefItemVector &xrefItems = xrefListItems();
1604 addRefItem(xrefItems,
1606 theTranslator->trFile(TRUE,TRUE),
1608 QCString(),
1609 nullptr
1610 );
1611 }
1612 for (const auto &mg : m_memberGroups)
1613 {
1614 mg->addListReferences(this);
1615 }
1616 for (auto &ml : m_memberLists)
1617 {
1618 if (ml->listType().isDocumentation())
1619 {
1620 ml->addListReferences(this);
1621 }
1622 }
1623}
1624
1625//-------------------------------------------------------------------
1626
1628{
1630 NamespaceDefSet visitedNamespaces;
1631 for (auto &nd : usingDirList)
1632 {
1634 if (ndm)
1635 {
1636 ndm->combineUsingRelations(visitedNamespaces);
1637 }
1638 }
1639
1640 for (auto &nd : usingDirList)
1641 {
1642 // add used namespaces of namespace nd to this namespace
1643 for (const auto &und : nd->getUsedNamespaces())
1644 {
1645 addUsingDirective(und);
1646 }
1647 // add used classes of namespace nd to this namespace
1648 for (const auto &ud : nd->getUsedDefinitions())
1649 {
1651 }
1652 }
1653}
1654
1656{
1657 static const std::unordered_set<std::string> docExtensions =
1658 { "doc", "txt", "dox", "md", "markdown" };
1659
1660 int lastDot = name().findRev('.');
1661 return (lastDot!=-1 && docExtensions.find(name().mid(lastDot+1).str())!=docExtensions.end()) ||
1662 getLanguageFromFileName(getFileNameExtension(name())) == SrcLangExt::Markdown;
1663}
1664
1666{
1667 QCString vercmd = Config_getString(FILE_VERSION_FILTER);
1668 if (!vercmd.isEmpty() && !m_filePath.isEmpty() && !isReference() &&
1669 m_filePath!="generated" && m_filePath!="graph_legend.dox")
1670 {
1671 msg("Version of {} : ",m_filePath);
1672 QCString cmd = vercmd+" \""+m_filePath+"\"";
1673 Debug::print(Debug::ExtCmd,0,"Executing popen(`{}`)\n",cmd);
1674 FILE *f=Portable::popen(cmd,"r");
1675 if (!f)
1676 {
1677 err("could not execute {}\n",vercmd);
1678 return;
1679 }
1680 const int bufSize=1024;
1681 char buf[bufSize];
1682 int numRead = static_cast<int>(fread(buf,1,bufSize-1,f));
1684 if (numRead>0 && numRead<bufSize)
1685 {
1686 buf[numRead]='\0';
1687 m_fileVersion=QCString(buf,numRead).stripWhiteSpace();
1688 if (!m_fileVersion.isEmpty())
1689 {
1690 msg("{}\n",m_fileVersion);
1691 return;
1692 }
1693 }
1694 msg("no version available\n");
1695 }
1696}
1697
1698
1700{
1701 if (Htags::useHtags)
1702 {
1704 }
1705 else
1706 {
1707 return m_outputDiskName+"_source";
1708 }
1709}
1710
1715
1716/*! Returns the name of the verbatim copy of this file (if any). */
1718{
1719 return getSourceFileBase();
1720}
1721
1723{
1724 bool sortBriefDocs = Config_getBool(SORT_BRIEF_DOCS);
1725 bool sortMemberDocs = Config_getBool(SORT_MEMBER_DOCS);
1726 const auto &ml = m_memberLists.get(lt,MemberListContainer::File);
1727 ml->setNeedsSorting(
1728 (ml->listType().isDeclaration() && sortBriefDocs) ||
1729 (ml->listType().isDocumentation() && sortMemberDocs));
1730 ml->push_back(md);
1731 if (ml->listType().isDeclaration())
1732 {
1734 if (mdm)
1735 {
1736 mdm->setSectionList(this,ml.get());
1737 }
1738 }
1739}
1740
1742{
1743 for (auto &ml : m_memberLists)
1744 {
1745 if (ml->needsSorting()) { ml->sort(); ml->setNeedsSorting(FALSE); }
1746 }
1747
1748 for (const auto &mg : m_memberGroups)
1749 {
1750 MemberList &mlg = const_cast<MemberList&>(mg->members());
1751 if (mlg.needsSorting()) { mlg.sort(); mlg.setNeedsSorting(FALSE); }
1752 }
1753
1754 std::stable_sort(m_includedByList.begin(),m_includedByList.end(),
1755 [](const auto &fi1,const auto &fi2) { return fi1.includeName < fi2.includeName; });
1756
1757 if (Config_getBool(SORT_BRIEF_DOCS))
1758 {
1759 auto classComp = [](const ClassLinkedRefMap::Ptr &c1,const ClassLinkedRefMap::Ptr &c2)
1760 {
1761 return Config_getBool(SORT_BY_SCOPE_NAME) ?
1762 qstricmp_sort(c1->name(), c2->name())<0 :
1763 qstricmp_sort(c1->className(), c2->className())<0;
1764 };
1765
1766 std::stable_sort(m_classes.begin(), m_classes.end(), classComp);
1767 std::stable_sort(m_interfaces.begin(),m_interfaces.end(),classComp);
1768 std::stable_sort(m_structs.begin(), m_structs.end(), classComp);
1769 std::stable_sort(m_exceptions.begin(),m_exceptions.end(),classComp);
1770
1771 auto namespaceComp = [](const NamespaceLinkedRefMap::Ptr &n1,const NamespaceLinkedRefMap::Ptr &n2)
1772 {
1773 return qstricmp_sort(n1->name(),n2->name())<0;
1774 };
1775
1776 std::stable_sort(m_namespaces.begin(),m_namespaces.end(),namespaceComp);
1777 }
1778}
1779
1781{
1782 for (auto &ml : m_memberLists)
1783 {
1784 if (ml->listType()==lt)
1785 {
1786 return ml.get();
1787 }
1788 }
1789 return nullptr;
1790}
1791
1793{
1794 bool optVhdl = Config_getBool(OPTIMIZE_OUTPUT_VHDL);
1795 MemberList * ml = getMemberList(lt);
1796 if (ml)
1797 {
1798 if (optVhdl) // use specific declarations function
1799 {
1800
1801 VhdlDocGen::writeVhdlDeclarations(ml,ol,nullptr,nullptr,this,nullptr,nullptr);
1802 }
1803 else
1804 {
1805 ml->writeDeclarations(ol,nullptr,nullptr,this,nullptr,nullptr,title,QCString());
1806 }
1807 }
1808}
1809
1811{
1812 MemberList * ml = getMemberList(lt);
1813 if (ml) ml->writeDocumentation(ol,name(),this,title);
1814}
1815
1817{
1818 bool showFiles = Config_getBool(SHOW_FILES);
1819 return hasDocumentation() && !isReference() && (showFiles || isLinkableViaGroup());
1820}
1821
1823 StringUnorderedSet &filesVisited,const FileDef *fd,StringVector &incFiles)
1824{
1825 for (const auto &ii : fd->includeFileList())
1826 {
1827 if (ii.fileDef && !ii.fileDef->isReference() &&
1828 filesVisited.find(ii.fileDef->absFilePath().str())==filesVisited.end())
1829 {
1830 //printf("FileDefImpl::addIncludeDependency(%s)\n",qPrint(ii->fileDef->absFilePath()));
1831 incFiles.push_back(ii.fileDef->absFilePath().str());
1832 filesVisited.insert(ii.fileDef->absFilePath().str());
1833 getAllIncludeFilesRecursively(filesVisited,ii.fileDef,incFiles);
1834 }
1835 }
1836}
1837
1839{
1840 StringUnorderedSet includes;
1841 ::getAllIncludeFilesRecursively(includes,this,incFiles);
1842}
1843
1845{
1846 if (Config_getBool(HIDE_COMPOUND_REFERENCE))
1847 {
1848 return name();
1849 }
1850 else
1851 {
1852 return theTranslator->trFileReference(name());
1853 }
1854}
1855
1857{
1858 return m_fileVersion;
1859}
1860
1865
1870
1872{
1873 for (auto &ml : m_memberLists)
1874 {
1875 ml->countDecMembers();
1876 ml->countDocMembers();
1877 }
1878 for (const auto &mg : m_memberGroups)
1879 {
1880 mg->countDecMembers();
1881 mg->countDocMembers();
1882 }
1883}
1884
1886{
1887 MemberList *ml = getMemberList(MemberListType::AllMembersList());
1888 return ml ? ml->numDocMembers() : 0;
1889}
1890
1892{
1893 MemberList *ml = getMemberList(MemberListType::AllMembersList());
1894 return ml ? ml->numDecMembers() : 0;
1895}
1896
1901
1906
1908{
1909 return m_hasIncludeGraph;
1910}
1911
1913{
1914 return m_hasIncludedByGraph;
1915}
1916
1917// -----------------------
1918
1919bool compareFileDefs(const FileDef *fd1, const FileDef *fd2)
1920{
1921 return qstricmp_sort(fd1->name(),fd2->name()) < 0;
1922}
1923
1924// --- Cast functions
1925
1927{
1928 if (d==nullptr) return nullptr;
1929 if (d && typeid(*d)==typeid(FileDefImpl))
1930 {
1931 return static_cast<FileDef*>(d);
1932 }
1933 else
1934 {
1935 return nullptr;
1936 }
1937}
1938
1940{
1941 if (d==nullptr) return nullptr;
1942 if (d && typeid(*d)==typeid(FileDefImpl))
1943 {
1944 return static_cast<const FileDef*>(d);
1945 }
1946 else
1947 {
1948 return nullptr;
1949 }
1950}
1951
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:1655
void findSectionsInDocumentation() override
Definition filedef.cpp:344
void setModuleDef(ModuleDef *mod) override
Definition filedef.cpp:190
void addIncludedUsingDirectives(FileDefSet &visitedFiles) override
Definition filedef.cpp:1523
void writeBriefDescription(OutputList &ol)
Definition filedef.cpp:533
const LinkedRefMap< const Definition > & getUsedDefinitions() const override
Definition filedef.cpp:155
void setDiskName(const QCString &name) override
Definition filedef.cpp:323
void addSourceRef(int line, const Definition *d, const MemberDef *md) override
Definition filedef.cpp:1468
LinkedRefMap< const Definition > m_usingDeclList
Definition filedef.cpp:240
DirDef * m_dir
Definition filedef.cpp:252
QCString getOutputFileBase() const override
Definition filedef.cpp:1711
void insertNamespace(NamespaceDef *nd) override
Definition filedef.cpp:1454
ModuleDef * getModuleDef() const override
Definition filedef.cpp:153
void writeQuickMemberLinks(OutputList &ol, const MemberDef *currentMd) const override
Definition filedef.cpp:1090
void writeSourceLink(OutputList &ol)
Definition filedef.cpp:683
void writeSummaryLinks(OutputList &ol) const override
Definition filedef.cpp:782
QCString absFilePath() const override
Definition filedef.cpp:141
QCString m_path
Definition filedef.cpp:241
ClassLinkedRefMap m_interfaces
Definition filedef.cpp:258
const ConceptLinkedRefMap & getConcepts() const override
Definition filedef.cpp:163
QCString m_inclDepFileName
Definition filedef.cpp:243
ClassLinkedRefMap m_structs
Definition filedef.cpp:259
void sortMemberLists() override
Definition filedef.cpp:1741
void parseSource(ClangTUParser *clangParser) override
Definition filedef.cpp:1250
void setDiskNameLocal(const QCString &name)
Definition filedef.cpp:307
void addMemberToList(MemberListType lt, MemberDef *md)
Definition filedef.cpp:1722
void acquireFileVersion()
Definition filedef.cpp:1665
QCString m_fileVersion
Definition filedef.cpp:251
void addUsingDirective(NamespaceDef *nd) override
Definition filedef.cpp:1495
void writeNamespaceDeclarations(OutputList &ol, const QCString &title, bool isConstantGroup)
Definition filedef.cpp:698
void countMembers() override
Definition filedef.cpp:1871
void distributeMemberGroupDocumentation() override
Definition filedef.cpp:335
MemberDefLineMap m_srcMemberMap
Definition filedef.cpp:249
ConceptLinkedRefMap m_concepts
Definition filedef.cpp:261
void insertClass(ClassDef *cd) override
Definition filedef.cpp:1422
DefinitionLineMap m_srcDefMap
Definition filedef.cpp:248
QCString getSourceFileBase() const override
Definition filedef.cpp:1699
NamespaceLinkedRefMap m_namespaces
Definition filedef.cpp:256
ModuleDef * m_moduleDef
Definition filedef.cpp:253
IncludeInfoList m_includedByList
Definition filedef.cpp:238
CodeSymbolType codeSymbolType() const override
Definition filedef.cpp:130
void writeClassDeclarations(OutputList &ol, const QCString &title, const ClassLinkedRefMap &list)
Definition filedef.cpp:705
QCString anchor() const override
Definition filedef.cpp:136
bool m_hasIncludeGraph
Definition filedef.cpp:263
const NamespaceLinkedRefMap & getNamespaces() const override
Definition filedef.cpp:162
void removeMember(MemberDef *md) override
Definition filedef.cpp:1373
void addUsingDeclaration(const Definition *d) override
Definition filedef.cpp:1507
ClassLinkedRefMap m_exceptions
Definition filedef.cpp:260
QCString includeName() const override
Definition filedef.cpp:1717
void writeTagFile(TextStream &t) override
Definition filedef.cpp:373
void endMemberDeclarations(OutputList &ol)
Definition filedef.cpp:735
void addListReferences() override
Definition filedef.cpp:1600
void writeMemberDeclarations(OutputList &ol, MemberListType lt, const QCString &title)
Definition filedef.cpp:1792
const MemberGroupList & getMemberGroups() const override
Definition filedef.cpp:161
IncludeInfoMap m_includedByMap
Definition filedef.cpp:237
void insertMember(MemberDef *md) override
Definition filedef.cpp:1299
const LinkedRefMap< NamespaceDef > & getUsedNamespaces() const override
Definition filedef.cpp:1501
void writeInlineClasses(OutputList &ol)
Definition filedef.cpp:717
const QCString & docName() const override
Definition filedef.cpp:142
void writeIncludeFiles(OutputList &ol)
Definition filedef.cpp:583
MemberGroupList m_memberGroups
Definition filedef.cpp:255
void computeAnchors() override
Definition filedef.cpp:329
void writeDetailedDescription(OutputList &ol, const QCString &title)
Definition filedef.cpp:471
QCString m_fileName
Definition filedef.cpp:246
void writeMemberPages(OutputList &ol) override
Definition filedef.cpp:1074
void writeSourceFooter(OutputList &ol) override
Definition filedef.cpp:1243
QCString fileVersion() const override
Definition filedef.cpp:1856
void writeConcepts(OutputList &ol, const QCString &title)
Definition filedef.cpp:711
bool generateSourceFile() const override
Definition filedef.cpp:1588
void writeIncludedByGraph(OutputList &ol)
Definition filedef.cpp:657
const QCString & name() const override
Definition filedef.cpp:1460
bool m_isSource
Definition filedef.cpp:250
const MemberDef * getSourceMember(int lineNr) const override
Definition filedef.cpp:1487
QCString m_outputDiskName
Definition filedef.cpp:245
bool isIncluded(const QCString &name) const override
Definition filedef.cpp:1582
~FileDefImpl() override
Definition filedef.cpp:303
const IncludeInfoList & includeFileList() const override
Definition filedef.cpp:156
void removeMemberFromList(MemberListType lt, MemberDef *md)
Definition filedef.cpp:1367
void getAllIncludeFilesRecursively(StringVector &incFiles) const override
Definition filedef.cpp:1838
MemberLists m_memberLists
Definition filedef.cpp:254
LinkedRefMap< NamespaceDef > m_usingDirList
Definition filedef.cpp:239
QCString getVersion() const override
Definition filedef.cpp:148
void writeAuthorSection(OutputList &ol)
Definition filedef.cpp:770
void insertConcept(ConceptDef *cd) override
Definition filedef.cpp:1447
const MemberLists & getMemberLists() const override
Definition filedef.cpp:160
void addIncludedByDependency(const FileDef *fd, const QCString &incName, IncludeKind kind) override
Definition filedef.cpp:1571
IncludeInfoMap m_includeMap
Definition filedef.cpp:235
bool m_subGrouping
Definition filedef.cpp:262
QCString m_inclByDepFileName
Definition filedef.cpp:244
DirDef * getDirDef() const override
Definition filedef.cpp:152
void overrideIncludeGraph(bool e) override
Definition filedef.cpp:1897
ClassLinkedRefMap m_classes
Definition filedef.cpp:257
QCString m_docname
Definition filedef.cpp:247
void overrideIncludedByGraph(bool e) override
Definition filedef.cpp:1902
const IncludeInfoList & includedByFileList() const override
Definition filedef.cpp:157
bool hasIncludedByGraph() const override
Definition filedef.cpp:1912
QCString displayName(bool=TRUE) const override
Definition filedef.cpp:133
bool subGrouping() const override
Definition filedef.cpp:168
QCString m_filePath
Definition filedef.cpp:242
void writeMemberDocumentation(OutputList &ol, MemberListType lt, const QCString &title)
Definition filedef.cpp:1810
void writeSourceHeader(OutputList &ol) override
Definition filedef.cpp:1134
FileDefImpl(const QCString &p, const QCString &n, const QCString &ref=QCString(), const QCString &dn=QCString())
Definition filedef.cpp:279
void writeSourceBody(OutputList &ol, ClangTUParser *clangParser) override
Definition filedef.cpp:1187
void writeIncludeGraph(OutputList &ol)
Definition filedef.cpp:632
QCString title() const override
Definition filedef.cpp:1844
void addMembersToMemberGroup() override
Definition filedef.cpp:1277
int numDocMembers() const override
Definition filedef.cpp:1885
QCString getPath() const override
Definition filedef.cpp:147
bool m_hasIncludedByGraph
Definition filedef.cpp:264
IncludeInfoList m_includeList
Definition filedef.cpp:236
void startMemberDocumentation(OutputList &ol)
Definition filedef.cpp:740
int numDecMembers() const override
Definition filedef.cpp:1891
void writeClassesToTagFile(TextStream &t, const ClassLinkedRefMap &list)
Definition filedef.cpp:571
MemberList * getMemberList(MemberListType lt) const override
Definition filedef.cpp:1780
void startMemberDeclarations(OutputList &ol)
Definition filedef.cpp:730
bool isSource() const override
Definition filedef.cpp:143
void combineUsingRelations() override
Definition filedef.cpp:1627
bool isLinkableInProject() const override
Definition filedef.cpp:1816
void endMemberDocumentation(OutputList &ol)
Definition filedef.cpp:749
QCString includedByDependencyGraphFileName() const override
Definition filedef.cpp:1866
const ClassLinkedRefMap & getClasses() const override
Definition filedef.cpp:164
QCString fileName() const override
Definition filedef.cpp:134
bool hasIncludeGraph() const override
Definition filedef.cpp:1907
void writeDocumentation(OutputList &ol) override
Definition filedef.cpp:851
bool isLinkable() const override
Definition filedef.cpp:150
void addIncludeDependency(const FileDef *fd, const QCString &incName, IncludeKind kind) override
Definition filedef.cpp:1512
DefType definitionType() const override
Definition filedef.cpp:129
bool hasDetailedDescription() const override
Definition filedef.cpp:363
QCString includeDependencyGraphFileName() const override
Definition filedef.cpp:1861
void setDirDef(DirDef *dd) override
Definition filedef.cpp:189
void writeMemberGroups(OutputList &ol)
Definition filedef.cpp:758
const Definition * getSourceDefinition(int lineNr) const override
Definition filedef.cpp:1480
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, 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:671
void writeString(const QCString &text)
Definition outputlist.h:412
void startGroupHeader(int extraLevels=0)
Definition outputlist.h:454
void disable(OutputType o)
void startInclDepGraph()
Definition outputlist.h:651
void writeRuler()
Definition outputlist.h:522
const OutputCodeList & codeGenerators() const
Definition outputlist.h:357
void enable(OutputType o)
void endContents()
Definition outputlist.h:619
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:669
void endParagraph()
Definition outputlist.h:410
void endInclDepGraph(DotInclDepGraph &g)
Definition outputlist.h:653
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 startContents()
Definition outputlist.h:617
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:267
bool compareFileDefs(const FileDef *fd1, const FileDef *fd2)
Definition filedef.cpp:1919
FileDef * toFileDef(Definition *d)
Definition filedef.cpp:1926
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:1822
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:393
void startFile(OutputList &ol, const QCString &name, const QCString &manName, const QCString &title, HighlightedItem hli, bool additionalIndices, const QCString &altSidebarName, int hierarchyLevel)
Definition index.cpp:400
void endFileWithNavPath(OutputList &ol, const Definition *d)
Definition index.cpp:446
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:5714
QCString convertToHtml(const QCString &s, bool keepEntities)
Definition util.cpp:4472
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:5311
void addGroupListToTitle(OutputList &ol, const Definition *d)
Definition util.cpp:5398
QCString fileToString(const QCString &name, bool filter, bool isSourceCode)
Definition util.cpp:1441
void createSubDirs(const Dir &d)
Definition util.cpp:4149
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:4013
QCString convertToXML(const QCString &s, bool keepEntities)
Definition util.cpp:4421
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:5756
void addHtmlExtensionIfMissing(QCString &fName)
Definition util.cpp:5408
A bunch of utility functions.