summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2001-08-03 19:47:19 (GMT)
committerBrad King <brad.king@kitware.com>2001-08-03 19:47:19 (GMT)
commit9cce8359001491aea51ce2effa817fdf5571c4d6 (patch)
treee9ba2ede118846552172a4d882aa9e3c20986f84
parentd76f84f70e89a2161d691142a458b403fe4a20af (diff)
downloadCMake-9cce8359001491aea51ce2effa817fdf5571c4d6.zip
CMake-9cce8359001491aea51ce2effa817fdf5571c4d6.tar.gz
CMake-9cce8359001491aea51ce2effa817fdf5571c4d6.tar.bz2
ENH: Added 'IMMEDIATE' option to CONFIGURE_FILE command to force file copy and configuration on the initial pass so that current variable values are used.
-rw-r--r--Source/cmConfigureFileCommand.cxx38
-rw-r--r--Source/cmConfigureFileCommand.h14
2 files changed, 32 insertions, 20 deletions
diff --git a/Source/cmConfigureFileCommand.cxx b/Source/cmConfigureFileCommand.cxx
index 58878a5..bf49a82 100644
--- a/Source/cmConfigureFileCommand.cxx
+++ b/Source/cmConfigureFileCommand.cxx
@@ -52,33 +52,43 @@ bool cmConfigureFileCommand::InitialPass(std::vector<std::string>& args)
m_OuputFile = args[1];
m_CopyOnly = false;
m_EscapeQuotes = false;
- if(args.size() >= 3)
+ m_Immediate = false;
+ for(unsigned int i=2;i < args.size();++i)
{
- if(args[2] == "COPYONLY")
+ if(args[i] == "COPYONLY")
{
- m_CopyOnly = true;
+ m_CopyOnly = true;
}
- if(args[2] == "ESCAPE_QUOTES")
+ else if(args[i] == "ESCAPE_QUOTES")
{
- m_EscapeQuotes = true;
+ m_EscapeQuotes = true;
}
- }
- if(args.size() >= 4)
- {
- if(args[3] == "COPYONLY")
- {
- m_CopyOnly = true;
- }
- if(args[3] == "ESCAPE_QUOTES")
+ else if(args[i] == "IMMEDIATE")
{
- m_EscapeQuotes = true;
+ m_Immediate = true;
}
}
+
+ // If we were told to copy the file immediately, then do it on the
+ // first pass (now).
+ if(m_Immediate)
+ {
+ this->ConfigureFile();
+ }
+
return true;
}
void cmConfigureFileCommand::FinalPass()
{
+ if(!m_Immediate)
+ {
+ this->ConfigureFile();
+ }
+}
+
+void cmConfigureFileCommand::ConfigureFile()
+{
m_Makefile->ExpandVariablesInString(m_InputFile);
m_Makefile->ExpandVariablesInString(m_OuputFile);
cmSystemTools::ConvertToUnixSlashes(m_OuputFile);
diff --git a/Source/cmConfigureFileCommand.h b/Source/cmConfigureFileCommand.h
index bc6390b..ab624b0 100644
--- a/Source/cmConfigureFileCommand.h
+++ b/Source/cmConfigureFileCommand.h
@@ -77,26 +77,28 @@ public:
virtual const char* GetFullDocumentation()
{
return
- "CONFIGURE_FILE(InputFile OutputFile [COPYONLY] [ESCAPE_QUOTES])\n"
+ "CONFIGURE_FILE(InputFile OutputFile [COPYONLY] [ESCAPE_QUOTES] [IMMEDIATE])\n"
"The Input and Ouput files have to have full paths.\n"
"They can also use variables like CMAKE_BINARY_DIR,CMAKE_SOURCE_DIR. "
"This command replaces any variables in the input file with their "
"values as determined by CMake. If a variables in not defined, it "
"will be replaced with nothing. If COPYONLY is passed in, then "
"then no varible expansion will take place. If ESCAPE_QUOTES is "
- "passed in then any substitued quotes will be C style escaped.";
+ "passed in then any substitued quotes will be C style escaped. "
+ "If IMMEDIATE is specified, then the file will be configured with "
+ "the current values of CMake variables instead of waiting until the "
+ "end of CMakeLists processing.";
}
- /**
- * Create the header files in this pass. This is so
- * all varibles can be expaned.
- */
virtual void FinalPass();
private:
+ void ConfigureFile();
+
std::string m_InputFile;
std::string m_OuputFile;
bool m_CopyOnly;
bool m_EscapeQuotes;
+ bool m_Immediate;
};