From aee7e4a03b8b410212e2eae23d1ecc182c8da817 Mon Sep 17 00:00:00 2001 From: Ben Boeckel Date: Mon, 20 Oct 2014 12:17:19 -0400 Subject: cmCacheManager: parse -D flags more strictly In the case of: -DCACHE_VARS=-DEXTERNAL_PROJECT_CMAKE_ARG:BOOL=TRUE the variable is parsed out as: CACHE_VARS=-DEXTERNAL_PROJECT_CMAKE_ARG because the parser allows '=' in the variable name. Disallow such a name on the command line. --- Source/cmCacheManager.cxx | 2 +- Tests/RunCMake/CommandLine/D_nested_cache-stderr.txt | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/Source/cmCacheManager.cxx b/Source/cmCacheManager.cxx index d6b84a0..17bfe4b 100644 --- a/Source/cmCacheManager.cxx +++ b/Source/cmCacheManager.cxx @@ -139,7 +139,7 @@ bool cmCacheManager::ParseEntry(const std::string& entry, { // input line is: key:type=value static cmsys::RegularExpression reg( - "^([^:]*):([^=]*)=(.*[^\r\t ]|[\r\t ]*)[\r\t ]*$"); + "^([^=:]*):([^=]*)=(.*[^\r\t ]|[\r\t ]*)[\r\t ]*$"); // input line is: "key":type=value static cmsys::RegularExpression regQuoted( "^\"([^\"]*)\":([^=]*)=(.*[^\r\t ]|[\r\t ]*)[\r\t ]*$"); diff --git a/Tests/RunCMake/CommandLine/D_nested_cache-stderr.txt b/Tests/RunCMake/CommandLine/D_nested_cache-stderr.txt index a1cc8d3..bba64bc 100644 --- a/Tests/RunCMake/CommandLine/D_nested_cache-stderr.txt +++ b/Tests/RunCMake/CommandLine/D_nested_cache-stderr.txt @@ -1 +1 @@ -^--><--$ +^-->-DBAR:BOOL=BAZ<--$ -- cgit v0.12