diff options
author | Brad King <brad.king@kitware.com> | 2011-03-15 18:47:51 (GMT) |
---|---|---|
committer | CMake Topic Stage <kwrobot@kitware.com> | 2011-03-15 18:47:51 (GMT) |
commit | c7278633a7acfc4afc9d7976dc522fb4027e8cd2 (patch) | |
tree | d85aae96cdd30395d8e1a28c0e06107fa47ad433 | |
parent | 3b6dbf71149c47e1e391e3e0663ae8476a7deaa9 (diff) | |
parent | 339d5922d9baef98c3a19fd0712badeb3d9e2996 (diff) | |
download | CMake-c7278633a7acfc4afc9d7976dc522fb4027e8cd2.zip CMake-c7278633a7acfc4afc9d7976dc522fb4027e8cd2.tar.gz CMake-c7278633a7acfc4afc9d7976dc522fb4027e8cd2.tar.bz2 |
Merge topic 'validate-custom-commands-issue-11963'
339d592 Validate custom command arguments (#11963)
-rw-r--r-- | Source/cmMakefile.cxx | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx index 3fa846a..63bf03b 100644 --- a/Source/cmMakefile.cxx +++ b/Source/cmMakefile.cxx @@ -893,6 +893,20 @@ cmMakefile::AddCustomCommandToOutput(const std::vector<std::string>& outputs, return; } + // Validate custom commands. TODO: More strict? + for(cmCustomCommandLines::const_iterator i=commandLines.begin(); + i != commandLines.end(); ++i) + { + cmCustomCommandLine const& cl = *i; + if(!cl.empty() && !cl[0].empty() && cl[0][0] == '"') + { + cmOStringStream e; + e << "COMMAND may not contain literal quotes:\n " << cl[0] << "\n"; + this->IssueMessage(cmake::FATAL_ERROR, e.str()); + return; + } + } + // Choose a source file on which to store the custom command. cmSourceFile* file = 0; if(main_dependency && main_dependency[0]) |