Speedup find_* commands (#11412)
Delay computation of the command documentation until it is needed. It is wasteful to do it in the constructor on every call. Inspired-By: Christian Ehrlicher <Ch.Ehrlicher@gmx.de>
This commit is contained in:
parent
e6975fe82f
commit
5303fbf09e
|
@ -13,11 +13,17 @@
|
||||||
|
|
||||||
cmFindBase::cmFindBase()
|
cmFindBase::cmFindBase()
|
||||||
{
|
{
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentationPathsOrder,
|
|
||||||
"FIND_ARGS_XXX", "<VAR> NAMES name");
|
|
||||||
this->AlreadyInCache = false;
|
this->AlreadyInCache = false;
|
||||||
this->AlreadyInCacheWithoutMetaInfo = false;
|
this->AlreadyInCacheWithoutMetaInfo = false;
|
||||||
this->GenericDocumentation =
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
void cmFindBase::GenerateDocumentation()
|
||||||
|
{
|
||||||
|
this->cmFindCommon::GenerateDocumentation();
|
||||||
|
cmSystemTools::ReplaceString(this->GenericDocumentationPathsOrder,
|
||||||
|
"FIND_ARGS_XXX", "<VAR> NAMES name");
|
||||||
|
this->GenericDocumentation =
|
||||||
" FIND_XXX(<VAR> name1 [path1 path2 ...])\n"
|
" FIND_XXX(<VAR> name1 [path1 path2 ...])\n"
|
||||||
"This is the short-hand signature for the command that "
|
"This is the short-hand signature for the command that "
|
||||||
"is sufficient in many cases. It is the same "
|
"is sufficient in many cases. It is the same "
|
||||||
|
@ -97,7 +103,18 @@ cmFindBase::cmFindBase()
|
||||||
this->GenericDocumentation += this->GenericDocumentationRootPath;
|
this->GenericDocumentation += this->GenericDocumentationRootPath;
|
||||||
this->GenericDocumentation += this->GenericDocumentationPathsOrder;
|
this->GenericDocumentation += this->GenericDocumentationPathsOrder;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
const char* cmFindBase::GetFullDocumentation()
|
||||||
|
{
|
||||||
|
if(this->GenericDocumentation.empty())
|
||||||
|
{
|
||||||
|
this->GenerateDocumentation();
|
||||||
|
}
|
||||||
|
return this->GenericDocumentation.c_str();
|
||||||
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
bool cmFindBase::ParseArguments(std::vector<std::string> const& argsIn)
|
bool cmFindBase::ParseArguments(std::vector<std::string> const& argsIn)
|
||||||
{
|
{
|
||||||
if(argsIn.size() < 2 )
|
if(argsIn.size() < 2 )
|
||||||
|
|
|
@ -31,10 +31,10 @@ public:
|
||||||
virtual bool ParseArguments(std::vector<std::string> const& args);
|
virtual bool ParseArguments(std::vector<std::string> const& args);
|
||||||
cmTypeMacro(cmFindBase, cmFindCommon);
|
cmTypeMacro(cmFindBase, cmFindCommon);
|
||||||
|
|
||||||
virtual const char* GetFullDocumentation()
|
virtual const char* GetFullDocumentation();
|
||||||
{return this->GenericDocumentation.c_str();}
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
virtual void GenerateDocumentation();
|
||||||
void PrintFindStuff();
|
void PrintFindStuff();
|
||||||
void ExpandPaths();
|
void ExpandPaths();
|
||||||
void AddPathSuffixes();
|
void AddPathSuffixes();
|
||||||
|
|
|
@ -34,7 +34,11 @@ cmFindCommon::cmFindCommon()
|
||||||
this->SearchFrameworkLast = false;
|
this->SearchFrameworkLast = false;
|
||||||
this->SearchAppBundleOnly = false;
|
this->SearchAppBundleOnly = false;
|
||||||
this->SearchAppBundleLast = false;
|
this->SearchAppBundleLast = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
void cmFindCommon::GenerateDocumentation()
|
||||||
|
{
|
||||||
// Documentation components.
|
// Documentation components.
|
||||||
this->GenericDocumentationMacPolicy =
|
this->GenericDocumentationMacPolicy =
|
||||||
"On Darwin or systems supporting OS X Frameworks, the cmake variable"
|
"On Darwin or systems supporting OS X Frameworks, the cmake variable"
|
||||||
|
|
|
@ -56,6 +56,8 @@ protected:
|
||||||
/** Compute the current default bundle/framework search policy. */
|
/** Compute the current default bundle/framework search policy. */
|
||||||
void SelectDefaultMacMode();
|
void SelectDefaultMacMode();
|
||||||
|
|
||||||
|
virtual void GenerateDocumentation();
|
||||||
|
|
||||||
cmStdString CMakePathName;
|
cmStdString CMakePathName;
|
||||||
RootPathMode FindRootPathMode;
|
RootPathMode FindRootPathMode;
|
||||||
|
|
||||||
|
|
|
@ -15,11 +15,16 @@
|
||||||
cmFindFileCommand::cmFindFileCommand()
|
cmFindFileCommand::cmFindFileCommand()
|
||||||
{
|
{
|
||||||
this->IncludeFileInPath = true;
|
this->IncludeFileInPath = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void cmFindFileCommand::GenerateDocumentation()
|
||||||
|
{
|
||||||
|
this->cmFindPathCommand::GenerateDocumentation();
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"find_path", "find_file");
|
"find_path", "find_file");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"directory containing the named file",
|
"directory containing the named file",
|
||||||
"full path to named file");
|
"full path to named file");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"file in a directory", "full path to a file");
|
"file in a directory", "full path to a file");
|
||||||
}
|
}
|
||||||
|
|
|
@ -44,6 +44,8 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
cmTypeMacro(cmFindFileCommand, cmFindPathCommand);
|
cmTypeMacro(cmFindFileCommand, cmFindPathCommand);
|
||||||
|
protected:
|
||||||
|
virtual void GenerateDocumentation();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -16,6 +16,13 @@
|
||||||
|
|
||||||
cmFindLibraryCommand::cmFindLibraryCommand()
|
cmFindLibraryCommand::cmFindLibraryCommand()
|
||||||
{
|
{
|
||||||
|
this->EnvironmentPath = "LIB";
|
||||||
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
void cmFindLibraryCommand::GenerateDocumentation()
|
||||||
|
{
|
||||||
|
this->cmFindBase::GenerateDocumentation();
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"FIND_XXX", "find_library");
|
"FIND_XXX", "find_library");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
|
@ -29,7 +36,7 @@ cmFindLibraryCommand::cmFindLibraryCommand()
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"XXX_SYSTEM", "LIB");
|
"XXX_SYSTEM", "LIB");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"CMAKE_SYSTEM_XXX_PATH",
|
"CMAKE_SYSTEM_XXX_PATH",
|
||||||
"CMAKE_SYSTEM_LIBRARY_PATH");
|
"CMAKE_SYSTEM_LIBRARY_PATH");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"SEARCH_XXX_DESC", "library");
|
"SEARCH_XXX_DESC", "library");
|
||||||
|
@ -38,11 +45,9 @@ cmFindLibraryCommand::cmFindLibraryCommand()
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"XXX_SUBDIR", "lib");
|
"XXX_SUBDIR", "lib");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"CMAKE_FIND_ROOT_PATH_MODE_XXX",
|
"CMAKE_FIND_ROOT_PATH_MODE_XXX",
|
||||||
"CMAKE_FIND_ROOT_PATH_MODE_LIBRARY");
|
"CMAKE_FIND_ROOT_PATH_MODE_LIBRARY");
|
||||||
|
this->GenericDocumentation +=
|
||||||
this->EnvironmentPath = "LIB";
|
|
||||||
this->GenericDocumentation +=
|
|
||||||
"\n"
|
"\n"
|
||||||
"If the library found is a framework, then VAR will be set to "
|
"If the library found is a framework, then VAR will be set to "
|
||||||
"the full path to the framework <fullPath>/A.framework. "
|
"the full path to the framework <fullPath>/A.framework. "
|
||||||
|
|
|
@ -64,6 +64,7 @@ protected:
|
||||||
void AddArchitecturePaths(const char* suffix);
|
void AddArchitecturePaths(const char* suffix);
|
||||||
void AddLib64Paths();
|
void AddLib64Paths();
|
||||||
std::string FindLibrary();
|
std::string FindLibrary();
|
||||||
|
virtual void GenerateDocumentation();
|
||||||
private:
|
private:
|
||||||
std::string FindNormalLibrary();
|
std::string FindNormalLibrary();
|
||||||
std::string FindFrameworkLibrary();
|
std::string FindFrameworkLibrary();
|
||||||
|
|
|
@ -51,13 +51,6 @@ void cmFindPackageNeedBackwardsCompatibility(const std::string& variable,
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
cmFindPackageCommand::cmFindPackageCommand()
|
cmFindPackageCommand::cmFindPackageCommand()
|
||||||
{
|
{
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentationRootPath,
|
|
||||||
"CMAKE_FIND_ROOT_PATH_MODE_XXX",
|
|
||||||
"CMAKE_FIND_ROOT_PATH_MODE_PACKAGE");
|
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentationPathsOrder,
|
|
||||||
"FIND_ARGS_XXX", "<package>");
|
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentationPathsOrder,
|
|
||||||
"FIND_XXX", "find_package");
|
|
||||||
this->CMakePathName = "PACKAGE";
|
this->CMakePathName = "PACKAGE";
|
||||||
this->Quiet = false;
|
this->Quiet = false;
|
||||||
this->Required = false;
|
this->Required = false;
|
||||||
|
@ -78,6 +71,19 @@ cmFindPackageCommand::cmFindPackageCommand()
|
||||||
this->VersionFoundPatch = 0;
|
this->VersionFoundPatch = 0;
|
||||||
this->VersionFoundTweak = 0;
|
this->VersionFoundTweak = 0;
|
||||||
this->VersionFoundCount = 0;
|
this->VersionFoundCount = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
void cmFindPackageCommand::GenerateDocumentation()
|
||||||
|
{
|
||||||
|
this->cmFindCommon::GenerateDocumentation();
|
||||||
|
cmSystemTools::ReplaceString(this->GenericDocumentationRootPath,
|
||||||
|
"CMAKE_FIND_ROOT_PATH_MODE_XXX",
|
||||||
|
"CMAKE_FIND_ROOT_PATH_MODE_PACKAGE");
|
||||||
|
cmSystemTools::ReplaceString(this->GenericDocumentationPathsOrder,
|
||||||
|
"FIND_ARGS_XXX", "<package>");
|
||||||
|
cmSystemTools::ReplaceString(this->GenericDocumentationPathsOrder,
|
||||||
|
"FIND_XXX", "find_package");
|
||||||
this->CommandDocumentation =
|
this->CommandDocumentation =
|
||||||
" find_package(<package> [version] [EXACT] [QUIET]\n"
|
" find_package(<package> [version] [EXACT] [QUIET]\n"
|
||||||
" [[REQUIRED|COMPONENTS] [components...]]\n"
|
" [[REQUIRED|COMPONENTS] [components...]]\n"
|
||||||
|
@ -318,6 +324,10 @@ cmFindPackageCommand::cmFindPackageCommand()
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
const char* cmFindPackageCommand::GetFullDocumentation()
|
const char* cmFindPackageCommand::GetFullDocumentation()
|
||||||
{
|
{
|
||||||
|
if(this->CommandDocumentation.empty())
|
||||||
|
{
|
||||||
|
this->GenerateDocumentation();
|
||||||
|
}
|
||||||
return this->CommandDocumentation.c_str();
|
return this->CommandDocumentation.c_str();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -65,6 +65,8 @@ public:
|
||||||
virtual const char* GetFullDocumentation();
|
virtual const char* GetFullDocumentation();
|
||||||
|
|
||||||
cmTypeMacro(cmFindPackageCommand, cmFindCommon);
|
cmTypeMacro(cmFindPackageCommand, cmFindCommon);
|
||||||
|
protected:
|
||||||
|
virtual void GenerateDocumentation();
|
||||||
private:
|
private:
|
||||||
void AppendSuccessInformation();
|
void AppendSuccessInformation();
|
||||||
void AppendToProperty(const char* propertyName);
|
void AppendToProperty(const char* propertyName);
|
||||||
|
|
|
@ -18,6 +18,11 @@ cmFindPathCommand::cmFindPathCommand()
|
||||||
{
|
{
|
||||||
this->EnvironmentPath = "INCLUDE";
|
this->EnvironmentPath = "INCLUDE";
|
||||||
this->IncludeFileInPath = false;
|
this->IncludeFileInPath = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void cmFindPathCommand::GenerateDocumentation()
|
||||||
|
{
|
||||||
|
this->cmFindBase::GenerateDocumentation();
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"FIND_XXX", "find_path");
|
"FIND_XXX", "find_path");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
|
@ -31,27 +36,21 @@ cmFindPathCommand::cmFindPathCommand()
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"XXX_SYSTEM", "INCLUDE");
|
"XXX_SYSTEM", "INCLUDE");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"CMAKE_SYSTEM_XXX_PATH",
|
"CMAKE_SYSTEM_XXX_PATH",
|
||||||
"CMAKE_SYSTEM_INCLUDE_PATH");
|
"CMAKE_SYSTEM_INCLUDE_PATH");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"SEARCH_XXX_DESC",
|
"SEARCH_XXX_DESC",
|
||||||
"directory containing the named file");
|
"directory containing the named file");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"SEARCH_XXX", "file in a directory");
|
"SEARCH_XXX", "file in a directory");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"XXX_SUBDIR", "include");
|
"XXX_SUBDIR", "include");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"CMAKE_FIND_ROOT_PATH_MODE_XXX",
|
"CMAKE_FIND_ROOT_PATH_MODE_XXX",
|
||||||
"CMAKE_FIND_ROOT_PATH_MODE_INCLUDE");
|
"CMAKE_FIND_ROOT_PATH_MODE_INCLUDE");
|
||||||
|
if(!this->IncludeFileInPath)
|
||||||
this->ExtraDocAdded = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const char* cmFindPathCommand::GetFullDocumentation()
|
|
||||||
{
|
|
||||||
if(!this->ExtraDocAdded && !this->IncludeFileInPath)
|
|
||||||
{
|
{
|
||||||
this->GenericDocumentation +=
|
this->GenericDocumentation +=
|
||||||
"\n"
|
"\n"
|
||||||
"When searching for frameworks, if the file is specified as "
|
"When searching for frameworks, if the file is specified as "
|
||||||
"A/b.h, then the framework search will look for "
|
"A/b.h, then the framework search will look for "
|
||||||
|
@ -59,9 +58,7 @@ const char* cmFindPathCommand::GetFullDocumentation()
|
||||||
"If that is found the path will be set to the path to the framework. "
|
"If that is found the path will be set to the path to the framework. "
|
||||||
"CMake will convert this to the correct -F option to include the "
|
"CMake will convert this to the correct -F option to include the "
|
||||||
"file. ";
|
"file. ";
|
||||||
this->ExtraDocAdded = true;
|
|
||||||
}
|
}
|
||||||
return this->GenericDocumentation.c_str();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// cmFindPathCommand
|
// cmFindPathCommand
|
||||||
|
|
|
@ -59,10 +59,10 @@ public:
|
||||||
return "Find the directory containing a file.";
|
return "Find the directory containing a file.";
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual const char* GetFullDocumentation();
|
|
||||||
cmTypeMacro(cmFindPathCommand, cmFindBase);
|
cmTypeMacro(cmFindPathCommand, cmFindBase);
|
||||||
bool IncludeFileInPath;
|
bool IncludeFileInPath;
|
||||||
bool ExtraDocAdded;
|
protected:
|
||||||
|
virtual void GenerateDocumentation();
|
||||||
private:
|
private:
|
||||||
std::string FindHeaderInFramework(std::string const& file,
|
std::string FindHeaderInFramework(std::string const& file,
|
||||||
std::string const& dir);
|
std::string const& dir);
|
||||||
|
|
|
@ -16,9 +16,10 @@
|
||||||
#if defined(__APPLE__)
|
#if defined(__APPLE__)
|
||||||
#include <CoreFoundation/CoreFoundation.h>
|
#include <CoreFoundation/CoreFoundation.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
cmFindProgramCommand::cmFindProgramCommand()
|
void cmFindProgramCommand::GenerateDocumentation()
|
||||||
{
|
{
|
||||||
|
this->cmFindBase::GenerateDocumentation();
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"FIND_XXX", "find_program");
|
"FIND_XXX", "find_program");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
|
@ -32,8 +33,8 @@ cmFindProgramCommand::cmFindProgramCommand()
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"XXX_SYSTEM", "");
|
"XXX_SYSTEM", "");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"CMAKE_SYSTEM_XXX_PATH",
|
"CMAKE_SYSTEM_XXX_PATH",
|
||||||
"CMAKE_SYSTEM_PROGRAM_PATH");
|
"CMAKE_SYSTEM_PROGRAM_PATH");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"SEARCH_XXX_DESC", "program");
|
"SEARCH_XXX_DESC", "program");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
|
@ -41,7 +42,7 @@ cmFindProgramCommand::cmFindProgramCommand()
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"XXX_SUBDIR", "[s]bin");
|
"XXX_SUBDIR", "[s]bin");
|
||||||
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
cmSystemTools::ReplaceString(this->GenericDocumentation,
|
||||||
"CMAKE_FIND_ROOT_PATH_MODE_XXX",
|
"CMAKE_FIND_ROOT_PATH_MODE_XXX",
|
||||||
"CMAKE_FIND_ROOT_PATH_MODE_PROGRAM");
|
"CMAKE_FIND_ROOT_PATH_MODE_PROGRAM");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,6 @@
|
||||||
class cmFindProgramCommand : public cmFindBase
|
class cmFindProgramCommand : public cmFindBase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
cmFindProgramCommand();
|
|
||||||
/**
|
/**
|
||||||
* This is a virtual constructor for the command.
|
* This is a virtual constructor for the command.
|
||||||
*/
|
*/
|
||||||
|
@ -63,6 +62,7 @@ public:
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
std::string FindProgram(std::vector<std::string> names);
|
std::string FindProgram(std::vector<std::string> names);
|
||||||
|
virtual void GenerateDocumentation();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string FindAppBundle(std::vector<std::string> names);
|
std::string FindAppBundle(std::vector<std::string> names);
|
||||||
|
|
Loading…
Reference in New Issue