diff options
author | Brad King <brad.king@kitware.com> | 2002-10-02 21:22:56 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2002-10-02 21:22:56 (GMT) |
commit | 6c2944b6fe8ae264bcb107cb11512ed36d90a586 (patch) | |
tree | b74531db3c5f3847b42cc5c32055a0d9e7ffe241 /Source | |
parent | f549a2bac88e000fc7ef4bfc45477449255c9d9d (diff) | |
download | CMake-6c2944b6fe8ae264bcb107cb11512ed36d90a586.zip CMake-6c2944b6fe8ae264bcb107cb11512ed36d90a586.tar.gz CMake-6c2944b6fe8ae264bcb107cb11512ed36d90a586.tar.bz2 |
BUG: STRLESS and STRGREATER need to treat non-existent definitions as strings.
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmIfCommand.cxx | 41 | ||||
-rw-r--r-- | Source/cmIfCommand.h | 5 |
2 files changed, 25 insertions, 21 deletions
diff --git a/Source/cmIfCommand.cxx b/Source/cmIfCommand.cxx index ffcd901..7baba12 100644 --- a/Source/cmIfCommand.cxx +++ b/Source/cmIfCommand.cxx @@ -200,11 +200,7 @@ bool cmIfCommand::IsTrue(const std::vector<std::string> &args, bool &isValid, if (args.size() == 3 && (args[1] == "MATCHES")) { - def = makefile->GetDefinition(args[0].c_str()); - if (!def) - { - def = args[0].c_str(); - } + def = cmIfCommand::GetVariableOrString(args[0].c_str(), makefile); cmRegularExpression regEntry(args[2].c_str()); // check for black line or comment @@ -217,8 +213,8 @@ bool cmIfCommand::IsTrue(const std::vector<std::string> &args, bool &isValid, if (args.size() == 3 && (args[1] == "LESS")) { - def = makefile->GetDefinition(args[0].c_str()); - def2 = makefile->GetDefinition(args[2].c_str()); + def = cmIfCommand::GetVariableOrString(args[0].c_str(), makefile); + def2 = cmIfCommand::GetVariableOrString(args[2].c_str(), makefile); if (!def) { def = args[0].c_str(); @@ -236,16 +232,8 @@ bool cmIfCommand::IsTrue(const std::vector<std::string> &args, bool &isValid, if (args.size() == 3 && (args[1] == "GREATER")) { - def = makefile->GetDefinition(args[0].c_str()); - def2 = makefile->GetDefinition(args[2].c_str()); - if (!def) - { - def = args[0].c_str(); - } - if (!def2) - { - def2 = args[2].c_str(); - } + def = cmIfCommand::GetVariableOrString(args[0].c_str(), makefile); + def2 = cmIfCommand::GetVariableOrString(args[2].c_str(), makefile); if(atof(def) <= atof(def2)) { isTrue = false; @@ -255,8 +243,8 @@ bool cmIfCommand::IsTrue(const std::vector<std::string> &args, bool &isValid, if (args.size() == 3 && (args[1] == "STRLESS")) { - def = makefile->GetDefinition(args[0].c_str()); - def2 = makefile->GetDefinition(args[2].c_str()); + def = cmIfCommand::GetVariableOrString(args[0].c_str(), makefile); + def2 = cmIfCommand::GetVariableOrString(args[2].c_str(), makefile); if(strcmp(def,def2) >= 0) { isTrue = false; @@ -266,8 +254,8 @@ bool cmIfCommand::IsTrue(const std::vector<std::string> &args, bool &isValid, if (args.size() == 3 && (args[1] == "STRGREATER")) { - def = makefile->GetDefinition(args[0].c_str()); - def2 = makefile->GetDefinition(args[2].c_str()); + def = cmIfCommand::GetVariableOrString(args[0].c_str(), makefile); + def2 = cmIfCommand::GetVariableOrString(args[2].c_str(), makefile); if(strcmp(def,def2) <= 0) { isTrue = false; @@ -277,3 +265,14 @@ bool cmIfCommand::IsTrue(const std::vector<std::string> &args, bool &isValid, return isTrue; } + +const char* cmIfCommand::GetVariableOrString(const char* str, + const cmMakefile* mf) +{ + const char* def = mf->GetDefinition(str); + if(!def) + { + def = str; + } + return def; +} diff --git a/Source/cmIfCommand.h b/Source/cmIfCommand.h index b5647c8..f14192a 100644 --- a/Source/cmIfCommand.h +++ b/Source/cmIfCommand.h @@ -105,6 +105,11 @@ public: static bool IsTrue(const std::vector<std::string> &args, bool &isValid, const cmMakefile *mf); + // Get a definition from the makefile. If it doesn't exist, + // return the original string. + static const char* GetVariableOrString(const char* str, + const cmMakefile* mf); + cmTypeMacro(cmIfCommand, cmCommand); }; |