summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmDocumentation.cxx19
1 files changed, 14 insertions, 5 deletions
diff --git a/Source/cmDocumentation.cxx b/Source/cmDocumentation.cxx
index 8affbe3..7fbdfda 100644
--- a/Source/cmDocumentation.cxx
+++ b/Source/cmDocumentation.cxx
@@ -445,14 +445,23 @@ void cmDocumentation
::CreateModuleDocsForDir(cmsys::Directory& dir,
cmDocumentationSection &moduleSection)
{
+ // sort the files alphabetically, so the docs for one module are easier
+ // to find than if they are in random order
+ std::vector<std::string> sortedFiles;
for(unsigned int i = 0; i < dir.GetNumberOfFiles(); ++i)
+ {
+ sortedFiles.push_back(dir.GetFile(i));
+ }
+ std::sort(sortedFiles.begin(), sortedFiles.end());
+
+ for(std::vector<std::string>::const_iterator fname = sortedFiles.begin();
+ fname!=sortedFiles.end(); ++fname)
{
- std::string fname = dir.GetFile(i);
- if(fname.length() > 6)
+ if(fname->length() > 6)
{
- if(fname.substr(fname.length()-6, 6) == ".cmake")
+ if(fname->substr(fname->length()-6, 6) == ".cmake")
{
- std::string moduleName = fname.substr(0, fname.length()-6);
+ std::string moduleName = fname->substr(0, fname->length()-6);
// this check is to avoid creating documentation for the modules with
// the same name in multiple directories of CMAKE_MODULE_PATH
if (this->ModulesFound.find(moduleName) == this->ModulesFound.end())
@@ -460,7 +469,7 @@ void cmDocumentation
this->ModulesFound.insert(moduleName);
std::string path = dir.GetPath();
path += "/";
- path += fname;
+ path += (*fname);
this->CreateSingleModule(path.c_str(), moduleName.c_str(),
moduleSection);
}