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 1119 of file dirdef.cpp.

1120{
1121 AUTO_TRACE();
1122 // for each input file
1123 for (const auto &fn : *Doxygen::inputNameLinkedMap)
1124 {
1125 for (const auto &fd : *fn)
1126 {
1127 if (fd->getReference().isEmpty())
1128 {
1129 DirDef *dir=Doxygen::dirLinkedMap->find(fd->getPath());
1130 if (dir==nullptr) // new directory
1131 {
1132 dir = DirDefImpl::mergeDirectoryInTree(fd->getPath());
1133 }
1134 if (dir && !fd->isDocumentationFile()) dir->addFile(fd.get());
1135 }
1136 else
1137 {
1138 // do something for file imported via tag files.
1139 }
1140 }
1141 }
1142
1143 // compute relations between directories => introduce container dirs.
1144 for (const auto &dir : *Doxygen::dirLinkedMap)
1145 {
1146 QCString name = dir->name();
1147 int i=name.findRev('/',static_cast<int>(name.length())-2);
1148 if (i>0)
1149 {
1150 DirDef *parent = Doxygen::dirLinkedMap->find(name.left(i+1));
1151 //if (parent==0) parent=root;
1152 if (parent)
1153 {
1154 parent->addSubDir(dir.get());
1155 AUTO_TRACE_ADD("DirDefImpl::addSubdir(): Adding subdir {} to {}",
1156 dir->displayName(), parent->displayName());
1157 }
1158 }
1159 }
1160
1161 // sort the directory contents
1162 for (const auto &dir : *Doxygen::dirLinkedMap)
1163 {
1164 dir->sort();
1165 }
1166
1167 // short the directories themselves
1168 std::stable_sort(Doxygen::dirLinkedMap->begin(),
1170 [](const auto &d1,const auto &d2)
1171 {
1172 QCString s1 = d1->shortName(), s2 = d2->shortName();
1173 int i = qstricmp_sort(s1,s2);
1174 if (i==0) // if sort name are equal, sort on full path
1175 {
1176 QCString n1 = d1->name(), n2 = d2->name();
1177 int n = qstricmp_sort(n1,n2);
1178 return n < 0;
1179 }
1180 return i < 0;
1181 });
1182
1183 // set the directory index identifier
1184 int dirIndex=0;
1185 for (const auto &dir : *Doxygen::dirLinkedMap)
1186 {
1187 dir->setDirIndex(dirIndex++);
1188 }
1189
1191}
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:918
static FileNameLinkedMap * inputNameLinkedMap
Definition doxygen.h:104
static DirLinkedMap * dirLinkedMap
Definition doxygen.h:128
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:166
int findRev(char c, int index=-1, bool cs=TRUE) const
Definition qcstring.cpp:96
QCString left(size_t len) const
Definition qcstring.h:229
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:1042
#define AUTO_TRACE_ADD(...)
Definition docnode.cpp:48
#define AUTO_TRACE(...)
Definition docnode.cpp:47
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:1328
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 1232 of file dirdef.cpp.

1233{
1234 return qstricmp_sort(item1->shortName(),item2->shortName()) < 0;
1235}
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 1193 of file dirdef.cpp.

1194{
1195 AUTO_TRACE();
1196 // compute nesting level for each directory
1197 for (const auto &dir : *Doxygen::dirLinkedMap)
1198 {
1199 dir->setLevel();
1200 }
1201
1202 // compute uses dependencies between directories
1203 for (const auto &dir : *Doxygen::dirLinkedMap)
1204 {
1205 AUTO_TRACE_ADD("computeDependencies for {}: #dirs={}",dir->name(),Doxygen::dirLinkedMap->size());
1206 dir->computeDependencies();
1207 }
1208}

References AUTO_TRACE, AUTO_TRACE_ADD, and Doxygen::dirLinkedMap.

Referenced by parseInput().

◆ generateDirDocs()

void generateDirDocs ( OutputList & ol)

Definition at line 1210 of file dirdef.cpp.

1211{
1212 AUTO_TRACE();
1213 for (const auto &dir : *Doxygen::dirLinkedMap)
1214 {
1215 ol.pushGeneratorState();
1216 if (!dir->hasDocumentation())
1217 {
1219 }
1220 dir->writeDocumentation(ol);
1221 ol.popGeneratorState();
1222 }
1223 //if (Config_getBool(DIRECTORY_GRAPH))
1224 {
1225 for (const auto &dr : Doxygen::dirRelations)
1226 {
1227 dr->writeDocumentation(ol);
1228 }
1229 }
1230}
static DirRelationLinkedMap dirRelations
Definition doxygen.h:129
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 1252 of file dirdef.cpp.

1253{
1254 if (d==nullptr) return nullptr;
1255 if (d && typeid(*d)==typeid(DirDefImpl))
1256 {
1257 return static_cast<const DirDef*>(d);
1258 }
1259 else
1260 {
1261 return nullptr;
1262 }
1263}

◆ toDirDef() [2/2]

DirDef * toDirDef ( Definition * d)

Definition at line 1239 of file dirdef.cpp.

1240{
1241 if (d==nullptr) return nullptr;
1242 if (d && typeid(*d)==typeid(DirDefImpl))
1243 {
1244 return static_cast<DirDef*>(d);
1245 }
1246 else
1247 {
1248 return nullptr;
1249 }
1250}