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

1086{
1087 AUTO_TRACE();
1088 // for each input file
1089 for (const auto &fn : *Doxygen::inputNameLinkedMap)
1090 {
1091 for (const auto &fd : *fn)
1092 {
1093 if (fd->getReference().isEmpty())
1094 {
1095 DirDef *dir=Doxygen::dirLinkedMap->find(fd->getPath());
1096 if (dir==nullptr) // new directory
1097 {
1098 dir = DirDefImpl::mergeDirectoryInTree(fd->getPath());
1099 }
1100 if (dir && !fd->isDocumentationFile()) dir->addFile(fd.get());
1101 }
1102 else
1103 {
1104 // do something for file imported via tag files.
1105 }
1106 }
1107 }
1108
1109 // compute relations between directories => introduce container dirs.
1110 for (const auto &dir : *Doxygen::dirLinkedMap)
1111 {
1112 QCString name = dir->name();
1113 int i=name.findRev('/',static_cast<int>(name.length())-2);
1114 if (i>0)
1115 {
1116 DirDef *parent = Doxygen::dirLinkedMap->find(name.left(i+1));
1117 //if (parent==0) parent=root;
1118 if (parent)
1119 {
1120 parent->addSubDir(dir.get());
1121 AUTO_TRACE_ADD("DirDefImpl::addSubdir(): Adding subdir {} to {}",
1122 dir->displayName(), parent->displayName());
1123 }
1124 }
1125 }
1126
1127 // sort the directory contents
1128 for (const auto &dir : *Doxygen::dirLinkedMap)
1129 {
1130 dir->sort();
1131 }
1132
1133 // short the directories themselves
1134 std::stable_sort(Doxygen::dirLinkedMap->begin(),
1136 [](const auto &d1,const auto &d2)
1137 {
1138 QCString s1 = d1->shortName(), s2 = d2->shortName();
1139 int i = qstricmp_sort(s1,s2);
1140 if (i==0) // if sort name are equal, sort on full path
1141 {
1142 QCString n1 = d1->name(), n2 = d2->name();
1143 int n = qstricmp_sort(n1,n2);
1144 return n < 0;
1145 }
1146 return i < 0;
1147 });
1148
1149 // set the directory index identifier
1150 int dirIndex=0;
1151 for (const auto &dir : *Doxygen::dirLinkedMap)
1152 {
1153 dir->setDirIndex(dirIndex++);
1154 }
1155
1157}
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:884
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:1008
#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 1198 of file dirdef.cpp.

1199{
1200 return qstricmp_sort(item1->shortName(),item2->shortName()) < 0;
1201}
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 1159 of file dirdef.cpp.

1160{
1161 AUTO_TRACE();
1162 // compute nesting level for each directory
1163 for (const auto &dir : *Doxygen::dirLinkedMap)
1164 {
1165 dir->setLevel();
1166 }
1167
1168 // compute uses dependencies between directories
1169 for (const auto &dir : *Doxygen::dirLinkedMap)
1170 {
1171 AUTO_TRACE_ADD("computeDependencies for {}: #dirs={}",dir->name(),Doxygen::dirLinkedMap->size());
1172 dir->computeDependencies();
1173 }
1174}

References AUTO_TRACE, AUTO_TRACE_ADD, and Doxygen::dirLinkedMap.

Referenced by parseInput().

◆ generateDirDocs()

void generateDirDocs ( OutputList & ol)

Definition at line 1176 of file dirdef.cpp.

1177{
1178 AUTO_TRACE();
1179 for (const auto &dir : *Doxygen::dirLinkedMap)
1180 {
1181 ol.pushGeneratorState();
1182 if (!dir->hasDocumentation())
1183 {
1185 }
1186 dir->writeDocumentation(ol);
1187 ol.popGeneratorState();
1188 }
1189 //if (Config_getBool(DIRECTORY_GRAPH))
1190 {
1191 for (const auto &dr : Doxygen::dirRelations)
1192 {
1193 dr->writeDocumentation(ol);
1194 }
1195 }
1196}
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 1218 of file dirdef.cpp.

1219{
1220 if (d==nullptr) return nullptr;
1221 if (d && typeid(*d)==typeid(DirDefImpl))
1222 {
1223 return static_cast<const DirDef*>(d);
1224 }
1225 else
1226 {
1227 return nullptr;
1228 }
1229}

◆ toDirDef() [2/2]

DirDef * toDirDef ( Definition * d)

Definition at line 1205 of file dirdef.cpp.

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