diff options
author | Alexander Neundorf <neundorf@kde.org> | 2007-06-06 12:49:18 (GMT) |
---|---|---|
committer | Alexander Neundorf <neundorf@kde.org> | 2007-06-06 12:49:18 (GMT) |
commit | c9f1af3913eb9aa8fdc7d374bf38bac59a6bbf59 (patch) | |
tree | c781327d9488029424be61d50b358b4c26b5d670 /Source | |
parent | 1358009382fe8bac2fea64e31851c75f750274b9 (diff) | |
download | CMake-c9f1af3913eb9aa8fdc7d374bf38bac59a6bbf59.zip CMake-c9f1af3913eb9aa8fdc7d374bf38bac59a6bbf59.tar.gz CMake-c9f1af3913eb9aa8fdc7d374bf38bac59a6bbf59.tar.bz2 |
ENH: add IF(IS_ABSOLUTE path), so no regex matching is required in the cmake scripts
Alex
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmIfCommand.cxx | 16 | ||||
-rw-r--r-- | Source/cmIfCommand.h | 2 |
2 files changed, 18 insertions, 0 deletions
diff --git a/Source/cmIfCommand.cxx b/Source/cmIfCommand.cxx index 8faab58..cdcf79d 100644 --- a/Source/cmIfCommand.cxx +++ b/Source/cmIfCommand.cxx @@ -287,6 +287,22 @@ bool cmIfCommand::IsTrue(const std::vector<std::string> &args, IncrementArguments(newArgs,argP1,argP2); reducible = 1; } + // is the given path an absolute path ? + if (*arg == "IS_ABSOLUTE" && argP1 != newArgs.end()) + { + if(cmSystemTools::FileIsFullPath((argP1)->c_str())) + { + *arg = "1"; + } + else + { + *arg = "0"; + } + newArgs.erase(argP1); + argP1 = arg; + IncrementArguments(newArgs,argP1,argP2); + reducible = 1; + } // does a command exist if (*arg == "COMMAND" && argP1 != newArgs.end()) { diff --git a/Source/cmIfCommand.h b/Source/cmIfCommand.h index 1a89227..6b855a2 100644 --- a/Source/cmIfCommand.h +++ b/Source/cmIfCommand.h @@ -143,6 +143,8 @@ public: " IF(IS_DIRECTORY directory-name)\n" "True if the given name is a directory. " "Behavior is well-defined only for full paths.\n" + " IF(IS_ABSOLUTE path)\n" + "True if the given path is an absolute path.\n " " IF(variable MATCHES regex)\n" " IF(string MATCHES regex)\n" "True if the given string or variable's value matches the given " |