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/cmTarget.h | |
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/cmTarget.h')
-rw-r--r-- | Source/cmTarget.h | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/Source/cmTarget.h b/Source/cmTarget.h index d6e3f8d..de70c49 100644 --- a/Source/cmTarget.h +++ b/Source/cmTarget.h @@ -18,7 +18,9 @@ #define cmTarget_h #include "cmCustomCommand.h" +#include "cmPropertyMap.h" +class cmake; class cmMakefile; class cmSourceFile; class cmGlobalGenerator; @@ -165,6 +167,7 @@ public: ///! Set/Get a property of this target file void SetProperty(const char *prop, const char *value); const char *GetProperty(const char *prop); + const char *GetProperty(const char *prop, cmProperty::ScopeType scope); bool GetPropertyAsBool(const char *prop); /** Get the directory in which this target will be built. If the @@ -249,6 +252,12 @@ public: std::string GetInstallNameDirForBuildTree(const char* config); std::string GetInstallNameDirForInstallTree(const char* config); + // Get the properties + cmPropertyMap &GetProperties() { return this->Properties; }; + + // Define the properties + static void DefineProperties(cmake *cm); + private: /** * A list of direct dependencies. Use in conjunction with DependencyMap. @@ -320,6 +329,7 @@ private: // Use a makefile variable to set a default for the given property. // If the variable is not defined use the given default instead. void SetPropertyDefault(const char* property, const char* default_value); + private: std::string Name; std::vector<cmCustomCommand> PreBuildCommands; @@ -342,7 +352,7 @@ private: std::string Location; std::set<cmStdString> Utilities; bool RecordDependencies; - std::map<cmStdString,cmStdString> Properties; + cmPropertyMap Properties; LinkLibraryVectorType OriginalLinkLibraries; // The cmMakefile instance that owns this target. This should |