diff options
author | Brad King <brad.king@kitware.com> | 2001-08-03 19:47:19 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2001-08-03 19:47:19 (GMT) |
commit | 9cce8359001491aea51ce2effa817fdf5571c4d6 (patch) | |
tree | e9ba2ede118846552172a4d882aa9e3c20986f84 | |
parent | d76f84f70e89a2161d691142a458b403fe4a20af (diff) | |
download | CMake-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.cxx | 38 | ||||
-rw-r--r-- | Source/cmConfigureFileCommand.h | 14 |
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; }; |