diff options
-rw-r--r-- | Source/cmTryCompileCommand.cxx | 23 | ||||
-rw-r--r-- | Source/cmTryCompileCommand.h | 10 |
2 files changed, 20 insertions, 13 deletions
diff --git a/Source/cmTryCompileCommand.cxx b/Source/cmTryCompileCommand.cxx index 2f9243a..77e061f 100644 --- a/Source/cmTryCompileCommand.cxx +++ b/Source/cmTryCompileCommand.cxx @@ -20,17 +20,26 @@ // cmExecutableCommand bool cmTryCompileCommand::InitialPass(std::vector<std::string> const& argv) { - if(argv.size() < 3) + if(argv.size() < 4) { - return true; + return false; } - const char* sourceDirectory = argv[0].c_str(); - const char* binaryDirectory = argv[1].c_str(); - const char* projectName = argv[2].c_str(); - - m_Makefile->TryCompile(sourceDirectory,binaryDirectory,projectName); + const char* sourceDirectory = argv[1].c_str(); + const char* binaryDirectory = argv[2].c_str(); + const char* projectName = argv[3].c_str(); + const char* targetName = 0; + + if (argv.size() == 5) + { + targetName = argv[4].c_str(); + } + + int res = m_Makefile->TryCompile(sourceDirectory, binaryDirectory, + projectName, targetName); + // set the result var to the return value to indicate success or failure + m_Makefile->AddDefinition(argv[0].c_str(), (res == 0 ? "TRUE" : "FALSE")); return true; } diff --git a/Source/cmTryCompileCommand.h b/Source/cmTryCompileCommand.h index d029b1e..4226da1 100644 --- a/Source/cmTryCompileCommand.h +++ b/Source/cmTryCompileCommand.h @@ -62,16 +62,14 @@ public: virtual const char* GetFullDocumentation() { return - "TRY_COMPILE(RESULT_VAR CMakeListFile )\n" - "TRY_COMPILE(RESULT_VAR sourceCode)\n" - "Try compiling a program. Return the success or failure in result"; + "TRY_COMPILE(RESULT_VAR srcdir bindir projectName <targetName>)\n" + "Try compiling a program. Return the success or failure in RESULT_VAR " + "If <target name> is specified then build just that target " + "otherwise the all or ALL_BUILD target is built."; } cmTypeMacro(cmTryCompileCommand, cmCommand); - private: - std::string m_TargetName; - std::vector<std::string> m_FinalArgs; }; |