diff options
author | Ken Martin <ken.martin@kitware.com> | 2006-12-07 14:45:32 (GMT) |
---|---|---|
committer | Ken Martin <ken.martin@kitware.com> | 2006-12-07 14:45:32 (GMT) |
commit | 27379d7b081be852c2b290a98db548cffffbff04 (patch) | |
tree | fcc9e19282bdfb71bf4bf9b1f8fcea1401c2fbd5 /Source/cmake.cxx | |
parent | 833548f53a2ed799bb0df23fd7d973c30b423d1b (diff) | |
download | CMake-27379d7b081be852c2b290a98db548cffffbff04.zip CMake-27379d7b081be852c2b290a98db548cffffbff04.tar.gz CMake-27379d7b081be852c2b290a98db548cffffbff04.tar.bz2 |
ENH: make properties a bit more formal with documentation and chaining
Diffstat (limited to 'Source/cmake.cxx')
-rw-r--r-- | Source/cmake.cxx | 140 |
1 files changed, 140 insertions, 0 deletions
diff --git a/Source/cmake.cxx b/Source/cmake.cxx index db91e21..2d813f5 100644 --- a/Source/cmake.cxx +++ b/Source/cmake.cxx @@ -23,7 +23,9 @@ #include "cmCommand.h" #include "cmFileTimeComparison.h" #include "cmGeneratedFileStream.h" +#include "cmSourceFile.h" #include "cmVersion.h" +#include "cmTest.h" #if defined(CMAKE_BUILD_WITH_CMAKE) # include "cmDependsFortran.h" // For -E cmake_copy_f90_mod callback. @@ -116,6 +118,14 @@ cmake::cmake() this->ClearBuildSystem = false; this->FileComparison = new cmFileTimeComparison; + this->Properties.SetCMakeInstance(this); + + // initialize properties + cmSourceFile::DefineProperties(this); + cmTarget::DefineProperties(this); + cmMakefile::DefineProperties(this); + cmTest::DefineProperties(this); + #ifdef __APPLE__ struct rlimit rlp; if(!getrlimit(RLIMIT_STACK, &rlp)) @@ -1990,6 +2000,28 @@ void cmake::GetCommandDocumentation( v.push_back(empty); } +void cmake::GetPropertiesDocumentation(std::vector<cmDocumentationEntry>& v) +{ + // get the properties for cmake + + // get them for any generators + + // get them for Directories + this->DirectoryProperties.GetPropertiesDocumentation(v); + + // get them for targets + this->TargetProperties.GetPropertiesDocumentation(v); + + // get them for source files + this->SourceFileProperties.GetPropertiesDocumentation(v); + + // get them for tests + this->TestProperties.GetPropertiesDocumentation(v); + + cmDocumentationEntry empty = {0,0,0}; + v.push_back(empty); +} + void cmake::GetGeneratorDocumentation(std::vector<cmDocumentationEntry>& v) { for(RegisteredGeneratorsMap::const_iterator i = this->Generators.begin(); @@ -2766,3 +2798,111 @@ int cmake::ExecuteLinkScript(std::vector<std::string>& args) // Return the final resulting return value. return result; } + +void cmake::DefineProperty(const char *name, cmProperty::ScopeType scope, + const char *ShortDescription, + const char *FullDescription, + bool chained) +{ + switch (scope) + { + case cmProperty::GLOBAL: + this->GlobalProperties.DefineProperty(name,scope,ShortDescription, + FullDescription, chained); + break; + case cmProperty::TARGET: + this->TargetProperties.DefineProperty(name,scope,ShortDescription, + FullDescription, chained); + break; + case cmProperty::SOURCE_FILE: + this->SourceFileProperties.DefineProperty(name,scope,ShortDescription, + FullDescription, chained); + break; + case cmProperty::DIRECTORY: + this->DirectoryProperties.DefineProperty(name,scope,ShortDescription, + FullDescription, chained); + break; + case cmProperty::TEST: + this->TestProperties.DefineProperty(name,scope,ShortDescription, + FullDescription, chained); + break; + } +} + +bool cmake::IsPropertyDefined(const char *name, cmProperty::ScopeType scope) +{ + switch (scope) + { + case cmProperty::GLOBAL: + return this->GlobalProperties.IsPropertyDefined(name); + break; + case cmProperty::TARGET: + return this->TargetProperties.IsPropertyDefined(name); + break; + case cmProperty::SOURCE_FILE: + return this->SourceFileProperties.IsPropertyDefined(name); + break; + case cmProperty::DIRECTORY: + return this->DirectoryProperties.IsPropertyDefined(name); + break; + case cmProperty::TEST: + return this->TestProperties.IsPropertyDefined(name); + break; + } + + return false; +} + +bool cmake::IsPropertyChained(const char *name, cmProperty::ScopeType scope) +{ + switch (scope) + { + case cmProperty::GLOBAL: + return this->GlobalProperties.IsPropertyChained(name); + break; + case cmProperty::TARGET: + return this->TargetProperties.IsPropertyChained(name); + break; + case cmProperty::SOURCE_FILE: + return this->SourceFileProperties.IsPropertyChained(name); + break; + case cmProperty::DIRECTORY: + return this->DirectoryProperties.IsPropertyChained(name); + break; + case cmProperty::TEST: + return this->DirectoryProperties.IsPropertyChained(name); + break; + } + + return false; +} + +void cmake::SetProperty(const char* prop, const char* value) +{ + if (!prop) + { + return; + } + if (!value) + { + value = "NOTFOUND"; + } + + this->Properties.SetProperty(prop, value, cmProperty::TARGET); +} + +const char *cmake::GetProperty(const char* prop) +{ + return this->GetProperty(prop, cmProperty::GLOBAL); +} + +const char *cmake::GetProperty(const char* prop, cmProperty::ScopeType scope) +{ + bool chain = false; + return this->Properties.GetPropertyValue(prop, scope, chain); +} + +bool cmake::GetPropertyAsBool(const char* prop) +{ + return cmSystemTools::IsOn(this->GetProperty(prop)); +} |