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

1103{
1104 AUTO_TRACE();
1105 // for each input file
1106 for (const auto &fn : *Doxygen::inputNameLinkedMap)
1107 {
1108 for (const auto &fd : *fn)
1109 {
1110 if (fd->getReference().isEmpty())
1111 {
1112 DirDef *dir=Doxygen::dirLinkedMap->find(fd->getPath());
1113 if (dir==nullptr) // new directory
1114 {
1115 dir = DirDefImpl::mergeDirectoryInTree(fd->getPath());
1116 }
1117 if (dir && !fd->isDocumentationFile()) dir->addFile(fd.get());
1118 }
1119 else
1120 {
1121 // do something for file imported via tag files.
1122 }
1123 }
1124 }
1125
1126 // compute relations between directories => introduce container dirs.
1127 for (const auto &dir : *Doxygen::dirLinkedMap)
1128 {
1129 QCString name = dir->name();
1130 int i=name.findRev('/',static_cast<int>(name.length())-2);
1131 if (i>0)
1132 {
1133 DirDef *parent = Doxygen::dirLinkedMap->find(name.left(i+1));
1134 //if (parent==0) parent=root;
1135 if (parent)
1136 {
1137 parent->addSubDir(dir.get());
1138 AUTO_TRACE_ADD("DirDefImpl::addSubdir(): Adding subdir {} to {}",
1139 dir->displayName(), parent->displayName());
1140 }
1141 }
1142 }
1143
1144 // sort the directory contents
1145 for (const auto &dir : *Doxygen::dirLinkedMap)
1146 {
1147 dir->sort();
1148 }
1149
1150 // short the directories themselves
1151 std::stable_sort(Doxygen::dirLinkedMap->begin(),
1153 [](const auto &d1,const auto &d2)
1154 {
1155 QCString s1 = d1->shortName(), s2 = d2->shortName();
1156 int i = qstricmp_sort(s1,s2);
1157 if (i==0) // if sort name are equal, sort on full path
1158 {
1159 QCString n1 = d1->name(), n2 = d2->name();
1160 int n = qstricmp_sort(n1,n2);
1161 return n < 0;
1162 }
1163 return i < 0;
1164 });
1165
1166 // set the directory index identifier
1167 int dirIndex=0;
1168 for (const auto &dir : *Doxygen::dirLinkedMap)
1169 {
1170 dir->setDirIndex(dirIndex++);
1171 }
1172
1174}
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:901
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: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:1025
#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:1330
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 1215 of file dirdef.cpp.

1216{
1217 return qstricmp_sort(item1->shortName(),item2->shortName()) < 0;
1218}
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 1176 of file dirdef.cpp.

1177{
1178 AUTO_TRACE();
1179 // compute nesting level for each directory
1180 for (const auto &dir : *Doxygen::dirLinkedMap)
1181 {
1182 dir->setLevel();
1183 }
1184
1185 // compute uses dependencies between directories
1186 for (const auto &dir : *Doxygen::dirLinkedMap)
1187 {
1188 AUTO_TRACE_ADD("computeDependencies for {}: #dirs={}",dir->name(),Doxygen::dirLinkedMap->size());
1189 dir->computeDependencies();
1190 }
1191}

References AUTO_TRACE, AUTO_TRACE_ADD, and Doxygen::dirLinkedMap.

Referenced by parseInput().

◆ generateDirDocs()

void generateDirDocs ( OutputList & ol)

Definition at line 1193 of file dirdef.cpp.

1194{
1195 AUTO_TRACE();
1196 for (const auto &dir : *Doxygen::dirLinkedMap)
1197 {
1198 ol.pushGeneratorState();
1199 if (!dir->hasDocumentation())
1200 {
1202 }
1203 dir->writeDocumentation(ol);
1204 ol.popGeneratorState();
1205 }
1206 //if (Config_getBool(DIRECTORY_GRAPH))
1207 {
1208 for (const auto &dr : Doxygen::dirRelations)
1209 {
1210 dr->writeDocumentation(ol);
1211 }
1212 }
1213}
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 1235 of file dirdef.cpp.

1236{
1237 if (d==nullptr) return nullptr;
1238 if (d && typeid(*d)==typeid(DirDefImpl))
1239 {
1240 return static_cast<const DirDef*>(d);
1241 }
1242 else
1243 {
1244 return nullptr;
1245 }
1246}

◆ toDirDef() [2/2]

DirDef * toDirDef ( Definition * d)

Definition at line 1222 of file dirdef.cpp.

1223{
1224 if (d==nullptr) return nullptr;
1225 if (d && typeid(*d)==typeid(DirDefImpl))
1226 {
1227 return static_cast<DirDef*>(d);
1228 }
1229 else
1230 {
1231 return nullptr;
1232 }
1233}