summaryrefslogtreecommitdiffstats
path: root/Source/cmSetPropertiesCommand.cxx
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2008-01-17 20:54:49 (GMT)
committerBrad King <brad.king@kitware.com>2008-01-17 20:54:49 (GMT)
commitb8357db11d96eeb995b8443404e46466a493ab15 (patch)
tree9ccde29b2977a773527fed66ecb595e0b8282fbc /Source/cmSetPropertiesCommand.cxx
parent456631225b11163f52b82989c1824bcd9ca3471c (diff)
downloadCMake-b8357db11d96eeb995b8443404e46466a493ab15.zip
CMake-b8357db11d96eeb995b8443404e46466a493ab15.tar.gz
CMake-b8357db11d96eeb995b8443404e46466a493ab15.tar.bz2
ENH: Rename SET_PROPERITES command to SET_PROPERTY and give it a more powerful signature.
Diffstat (limited to 'Source/cmSetPropertiesCommand.cxx')
-rw-r--r--Source/cmSetPropertiesCommand.cxx210
1 files changed, 0 insertions, 210 deletions
diff --git a/Source/cmSetPropertiesCommand.cxx b/Source/cmSetPropertiesCommand.cxx
deleted file mode 100644
index 117d0df..0000000
--- a/Source/cmSetPropertiesCommand.cxx
+++ /dev/null
@@ -1,210 +0,0 @@
-/*=========================================================================
-
- Program: CMake - Cross-Platform Makefile Generator
- Module: $RCSfile$
- Language: C++
- Date: $Date$
- Version: $Revision$
-
- Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved.
- See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
-
- This software is distributed WITHOUT ANY WARRANTY; without even
- the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
- PURPOSE. See the above copyright notices for more information.
-
-=========================================================================*/
-#include "cmSetPropertiesCommand.h"
-#include "cmSetTargetPropertiesCommand.h"
-#include "cmSetTestsPropertiesCommand.h"
-#include "cmSetSourceFilesPropertiesCommand.h"
-
-// cmSetPropertiesCommand
-bool cmSetPropertiesCommand::InitialPass(
- std::vector<std::string> const& args)
-{
- if(args.size() < 2 )
- {
- this->SetError("called with incorrect number of arguments");
- return false;
- }
-
- // first collect up the list of files
- std::vector<std::string> propertyPairs;
- bool doingFiles = true;
- int numFiles = 0;
- std::vector<std::string>::const_iterator j;
- for(j= args.begin(); j != args.end();++j)
- {
- if(*j == "PROPERTIES")
- {
- doingFiles = false;
- // now loop through the rest of the arguments, new style
- ++j;
- while (j != args.end())
- {
- propertyPairs.push_back(*j);
- ++j;
- if(j == args.end())
- {
- this->SetError("called with incorrect number of arguments.");
- return false;
- }
- propertyPairs.push_back(*j);
- ++j;
- }
- // break out of the loop because j is already == end
- break;
- }
- else if (doingFiles)
- {
- numFiles++;
- }
- else
- {
- this->SetError("called with illegal arguments, maybe missing "
- "a PROPERTIES specifier?");
- return false;
- }
- }
- if(propertyPairs.size() == 0)
- {
- this->SetError("called with illegal arguments, maybe missing "
- "a PROPERTIES specifier?");
- return false;
- }
-
- cmProperty::ScopeType scope;
- const char *scopeName = 0;
- if (args[0] == "GLOBAL" && numFiles == 1)
- {
- scope = cmProperty::GLOBAL;
- }
- else if (args[0] == "DIRECTORY" && numFiles >= 1)
- {
- scope = cmProperty::DIRECTORY;
- if (numFiles == 2)
- {
- scopeName = args[1].c_str();
- }
- }
- else if (args[0] == "TARGET" && numFiles == 2)
- {
- scope = cmProperty::TARGET;
- scopeName = args[1].c_str();
- }
- else if (args[0] == "TEST" && numFiles == 2)
- {
- scope = cmProperty::TEST;
- scopeName = args[1].c_str();
- }
- else if (args[0] == "SOURCE_FILE" && numFiles == 2)
- {
- scope = cmProperty::SOURCE_FILE;
- scopeName = args[1].c_str();
- }
- else
- {
- this->SetError("called with illegal arguments.");
- return false;
- }
-
- switch (scope)
- {
- case cmProperty::TARGET:
- {
- bool ret = cmSetTargetPropertiesCommand::
- SetOneTarget(scopeName,propertyPairs, this->Makefile);
- if (!ret)
- {
- std::string message = "Can not find target to add properties to: ";
- message += scopeName;
- this->SetError(message.c_str());
- return ret;
- }
- }
- break;
- case cmProperty::DIRECTORY:
- {
- // lookup the makefile from the directory name
- cmLocalGenerator *lg = this->Makefile->GetLocalGenerator();
- if (numFiles == 2)
- {
- std::string sd = scopeName;
- // make sure the start dir is a full path
- if (!cmSystemTools::FileIsFullPath(sd.c_str()))
- {
- sd = this->Makefile->GetStartDirectory();
- sd += "/";
- sd += scopeName;
- }
-
- // The local generators are associated with collapsed paths.
- sd = cmSystemTools::CollapseFullPath(sd.c_str());
-
- lg = this->Makefile->GetLocalGenerator()->GetGlobalGenerator()->
- FindLocalGenerator(sd.c_str());
- }
- if (!lg)
- {
- this->SetError
- ("DIRECTORY argument provided but requested directory not found. "
- "This could be because the directory argument was invalid or, "
- "it is valid but has not been processed yet.");
- return false;
- }
-
- for(j= propertyPairs.begin(); j != propertyPairs.end(); ++j)
- {
- const char *pn = j->c_str();
- ++j;
- lg->GetMakefile()->SetProperty(pn,j->c_str());
- }
- }
- break;
- case cmProperty::GLOBAL:
- {
- for(j= propertyPairs.begin(); j != propertyPairs.end(); ++j)
- {
- const char *pn = j->c_str();
- ++j;
- this->Makefile->GetCMakeInstance()->SetProperty(pn, j->c_str());
- }
- }
- break;
- case cmProperty::TEST:
- {
- std::string errors;
- bool ret = cmSetTestsPropertiesCommand::
- SetOneTest(scopeName,propertyPairs, this->Makefile, errors);
- if (!ret)
- {
- this->SetError(errors.c_str());
- return ret;
- }
- }
- break;
- case cmProperty::SOURCE_FILE:
- {
- std::string errors;
- bool ret = cmSetSourceFilesPropertiesCommand::
- RunCommand(this->Makefile,
- args.begin()+1, args.begin()+2,
- args.begin() + 2, args.end(),
- errors);
- if (!ret)
- {
- this->SetError(errors.c_str());
- return ret;
- }
- }
- break;
- case cmProperty::VARIABLE:
- case cmProperty::CACHED_VARIABLE:
- // not handled by SetProperty
- break;
- }
-
- return true;
-}
-