summaryrefslogtreecommitdiff
path: root/Source/cmGetDirectoryPropertyCommand.cxx
diff options
context:
space:
mode:
authorKen Martin <ken.martin@kitware.com>2007-07-10 13:52:41 -0400
committerKen Martin <ken.martin@kitware.com>2007-07-10 13:52:41 -0400
commit8c641677e996bd2434233f37da39b34d9000a740 (patch)
treef8c96aef5e4b11ecbb777051a8beb2b5c78d24b9 /Source/cmGetDirectoryPropertyCommand.cxx
parent15f21aa74c0b11e8d6b7eef010ed6067a09ed799 (diff)
downloadcmake-8c641677e996bd2434233f37da39b34d9000a740.tar.gz
ENH: some cleanup of get property commands
Diffstat (limited to 'Source/cmGetDirectoryPropertyCommand.cxx')
-rw-r--r--Source/cmGetDirectoryPropertyCommand.cxx84
1 files changed, 7 insertions, 77 deletions
diff --git a/Source/cmGetDirectoryPropertyCommand.cxx b/Source/cmGetDirectoryPropertyCommand.cxx
index 278e2aef65..0f0fcca138 100644
--- a/Source/cmGetDirectoryPropertyCommand.cxx
+++ b/Source/cmGetDirectoryPropertyCommand.cxx
@@ -28,7 +28,6 @@ bool cmGetDirectoryPropertyCommand::InitialPass(
return false;
}
- std::vector<std::string>::size_type cc;
std::vector<std::string>::const_iterator i = args.begin();
std::string variable = *i;
++i;
@@ -76,72 +75,7 @@ bool cmGetDirectoryPropertyCommand::InitialPass(
// OK, now we have the directory to process, we just get the requested
// information out of it
- if ( *i == "VARIABLES" || *i == "CACHE_VARIABLES" )
- {
- int cacheonly = 0;
- if ( *i == "CACHE_VARIABLES" )
- {
- cacheonly = 1;
- }
- std::vector<std::string> vars = dir->GetDefinitions(cacheonly);
- for ( cc = 0; cc < vars.size(); cc ++ )
- {
- if ( cc > 0 )
- {
- output += ";";
- }
- output += vars[cc];
- }
- }
- else if ( *i == "MACROS" )
- {
- dir->GetListOfMacros(output);
- }
- else if ( *i == "DEFINITIONS" )
- {
- output = dir->GetDefineFlags();
- }
- else if ( *i == "INCLUDE_DIRECTORIES" )
- {
- std::vector<std::string>::iterator it;
- int first = 1;
- cmOStringStream str;
- for ( it = dir->GetIncludeDirectories().begin();
- it != dir->GetIncludeDirectories().end();
- ++ it )
- {
- if ( !first )
- {
- str << ";";
- }
- str << it->c_str();
- first = 0;
- }
- output = str.str();
- }
- else if ( *i == "INCLUDE_REGULAR_EXPRESSION" )
- {
- output = dir->GetIncludeRegularExpression();
- }
- else if ( *i == "LINK_DIRECTORIES" )
- {
- std::vector<std::string>::iterator it;
- int first = 1;
- cmOStringStream str;
- for ( it = dir->GetLinkDirectories().begin();
- it != dir->GetLinkDirectories().end();
- ++ it )
- {
- if ( !first )
- {
- str << ";";
- }
- str << it->c_str();
- first = 0;
- }
- output = str.str();
- }
- else if ( *i == "DEFINITION" )
+ if ( *i == "DEFINITION" )
{
++i;
if (i == args.end())
@@ -151,20 +85,16 @@ bool cmGetDirectoryPropertyCommand::InitialPass(
return false;
}
output = dir->GetSafeDefinition(i->c_str());
+ this->Makefile->AddDefinition(variable.c_str(), output.c_str());
}
- else
+
+ const char *prop = dir->GetProperty(i->c_str());
+ if (prop)
{
- const char *prop = dir->GetProperty(i->c_str());
- if (prop)
- {
- this->Makefile->AddDefinition(variable.c_str(), prop);
- return true;
- }
- this->Makefile->AddDefinition(variable.c_str(), "");
+ this->Makefile->AddDefinition(variable.c_str(), prop);
return true;
}
- this->Makefile->AddDefinition(variable.c_str(), output.c_str());
-
+ this->Makefile->AddDefinition(variable.c_str(), "");
return true;
}