Doxygen
Loading...
Searching...
No Matches
dirdef.h File Reference
#include <vector>
#include <map>
#include "qcstring.h"
#include "linkedmap.h"
#include "definition.h"
Include dependency graph for dirdef.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Classes

class  FilePair
 Class representing a pair of FileDef objects. More...
class  FilePairLinkedMap
 A linked map of file pairs. More...
class  UsedDir
 Usage information of a directory. More...
class  DirDef
 A model of a directory symbol. More...
class  DirDef::UsedDirLinkedMap
class  DirRelation
 A usage relation between two directories. More...
class  DirLinkedMap
 A linked map of directories. More...
class  DirList
 A list of directories. More...
class  DirRelationLinkedMap

Functions

bool compareDirDefs (const DirDef *item1, const DirDef *item2)
DirDeftoDirDef (Definition *d)
const DirDeftoDirDef (const Definition *d)
void buildDirectories ()
void generateDirDocs (OutputList &ol)
void computeDirDependencies ()

Function Documentation

◆ buildDirectories()

void buildDirectories ( )

Definition at line 1070 of file dirdef.cpp.

1071{
1072 AUTO_TRACE();
1073 // for each input file
1074 for (const auto &fn : *Doxygen::inputNameLinkedMap)
1075 {
1076 for (const auto &fd : *fn)
1077 {
1078 if (fd->getReference().isEmpty())
1079 {
1080 DirDef *dir=Doxygen::dirLinkedMap->find(fd->getPath());
1081 if (dir==nullptr) // new directory
1082 {
1083 dir = DirDefImpl::mergeDirectoryInTree(fd->getPath());
1084 }
1085 if (dir && !fd->isDocumentationFile()) dir->addFile(fd.get());
1086 }
1087 else
1088 {
1089 // do something for file imported via tag files.
1090 }
1091 }
1092 }
1093
1094 // compute relations between directories => introduce container dirs.
1095 for (const auto &dir : *Doxygen::dirLinkedMap)
1096 {
1097 QCString name = dir->name();
1098 int i=name.findRev('/',static_cast<int>(name.length())-2);
1099 if (i>0)
1100 {
1101 DirDef *parent = Doxygen::dirLinkedMap->find(name.left(i+1));
1102 //if (parent==0) parent=root;
1103 if (parent)
1104 {
1105 parent->addSubDir(dir.get());
1106 AUTO_TRACE_ADD("DirDefImpl::addSubdir(): Adding subdir {} to {}",
1107 dir->displayName(), parent->displayName());
1108 }
1109 }
1110 }
1111
1112 // sort the directory contents
1113 for (const auto &dir : *Doxygen::dirLinkedMap)
1114 {
1115 dir->sort();
1116 }
1117
1118 // short the directories themselves
1119 std::stable_sort(Doxygen::dirLinkedMap->begin(),
1121 [](const auto &d1,const auto &d2)
1122 {
1123 QCString s1 = d1->shortName(), s2 = d2->shortName();
1124 int i = qstricmp_sort(s1,s2);
1125 if (i==0) // if sort name are equal, sort on full path
1126 {
1127 QCString n1 = d1->name(), n2 = d2->name();
1128 int n = qstricmp_sort(n1,n2);
1129 return n < 0;
1130 }
1131 return i < 0;
1132 });
1133
1134 // set the directory index identifier
1135 int dirIndex=0;
1136 for (const auto &dir : *Doxygen::dirLinkedMap)
1137 {
1138 dir->setDirIndex(dirIndex++);
1139 }
1140
1142}
virtual QCString displayName(bool includeScope=TRUE) const =0
virtual const QCString & name() const =0
A model of a directory symbol.
Definition dirdef.h:110
virtual void sort()=0
virtual void addFile(FileDef *fd)=0
virtual void setDirIndex(int index)=0
static DirDef * mergeDirectoryInTree(const QCString &path)
Definition dirdef.cpp:869
static FileNameLinkedMap * inputNameLinkedMap
Definition doxygen.h:105
static DirLinkedMap * dirLinkedMap
Definition doxygen.h:129
This is an alternative implementation of QCString.
Definition qcstring.h:101
size_t length() const
Returns the length of the string, not counting the 0-terminator.
Definition qcstring.h:153
int findRev(char c, int index=-1, bool cs=TRUE) const
Definition qcstring.cpp:91
QCString left(size_t len) const
Definition qcstring.h:214
DirIterator begin(DirIterator it) noexcept
Definition dir.cpp:170
DirIterator end(const DirIterator &) noexcept
Definition dir.cpp:175
static void computeCommonDirPrefix()
In order to create stable, but unique directory names, we compute the common part of the path shared ...
Definition dirdef.cpp:993
#define AUTO_TRACE_ADD(...)
Definition docnode.cpp:47
#define AUTO_TRACE(...)
Definition docnode.cpp:46
constexpr DocNodeVariant * parent(DocNodeVariant *n)
returns the parent node of a given node n or nullptr if the node has no parent.
Definition docnode.h:1324
int qstricmp_sort(const char *str1, const char *str2)
Definition qcstring.h:86

References DirDef::addFile(), AUTO_TRACE, AUTO_TRACE_ADD, begin(), computeCommonDirPrefix(), Doxygen::dirLinkedMap, end(), QCString::findRev(), Doxygen::inputNameLinkedMap, QCString::left(), QCString::length(), DirDefImpl::mergeDirectoryInTree(), parent(), and qstricmp_sort().

Referenced by parseInput().

◆ compareDirDefs()

bool compareDirDefs ( const DirDef * item1,
const DirDef * item2 )

Definition at line 1183 of file dirdef.cpp.

1184{
1185 return qstricmp_sort(item1->shortName(),item2->shortName()) < 0;
1186}
virtual const QCString shortName() const =0

References qstricmp_sort(), and DirDef::shortName().

Referenced by DirDefImpl::sort(), and GroupDefImpl::sortMemberLists().

◆ computeDirDependencies()

void computeDirDependencies ( )

Definition at line 1144 of file dirdef.cpp.

1145{
1146 AUTO_TRACE();
1147 // compute nesting level for each directory
1148 for (const auto &dir : *Doxygen::dirLinkedMap)
1149 {
1150 dir->setLevel();
1151 }
1152
1153 // compute uses dependencies between directories
1154 for (const auto &dir : *Doxygen::dirLinkedMap)
1155 {
1156 AUTO_TRACE_ADD("computeDependencies for {}: #dirs={}",dir->name(),Doxygen::dirLinkedMap->size());
1157 dir->computeDependencies();
1158 }
1159}

References AUTO_TRACE, AUTO_TRACE_ADD, and Doxygen::dirLinkedMap.

Referenced by parseInput().

◆ generateDirDocs()

void generateDirDocs ( OutputList & ol)

Definition at line 1161 of file dirdef.cpp.

1162{
1163 AUTO_TRACE();
1164 for (const auto &dir : *Doxygen::dirLinkedMap)
1165 {
1166 ol.pushGeneratorState();
1167 if (!dir->hasDocumentation())
1168 {
1170 }
1171 dir->writeDocumentation(ol);
1172 ol.popGeneratorState();
1173 }
1174 //if (Config_getBool(DIRECTORY_GRAPH))
1175 {
1176 for (const auto &dr : Doxygen::dirRelations)
1177 {
1178 dr->writeDocumentation(ol);
1179 }
1180 }
1181}
static DirRelationLinkedMap dirRelations
Definition doxygen.h:130
void pushGeneratorState()
void disableAllBut(OutputType o)
void popGeneratorState()

References AUTO_TRACE, Doxygen::dirLinkedMap, Doxygen::dirRelations, OutputList::disableAllBut(), Html, OutputList::popGeneratorState(), and OutputList::pushGeneratorState().

Referenced by generateOutput().

◆ toDirDef() [1/2]

const DirDef * toDirDef ( const Definition * d)

Definition at line 1203 of file dirdef.cpp.

1204{
1205 if (d==nullptr) return nullptr;
1206 if (d && typeid(*d)==typeid(DirDefImpl))
1207 {
1208 return static_cast<const DirDef*>(d);
1209 }
1210 else
1211 {
1212 return nullptr;
1213 }
1214}

◆ toDirDef() [2/2]

DirDef * toDirDef ( Definition * d)

Definition at line 1190 of file dirdef.cpp.

1191{
1192 if (d==nullptr) return nullptr;
1193 if (d && typeid(*d)==typeid(DirDefImpl))
1194 {
1195 return static_cast<DirDef*>(d);
1196 }
1197 else
1198 {
1199 return nullptr;
1200 }
1201}