Merge topic 'cmake_parse_arguments-PARSE_ARGV-multi-value'
66c70cd9
cmake_parse_arguments: Add additional unit tests41291b20
cmake_parse_arguments: Fix PARSE_ARGV multi-value argument handling
This commit is contained in:
commit
5d29506811
|
@ -4,6 +4,19 @@
|
||||||
|
|
||||||
#include "cmAlgorithms.h"
|
#include "cmAlgorithms.h"
|
||||||
|
|
||||||
|
static std::string escape_arg(const std::string& arg)
|
||||||
|
{
|
||||||
|
// replace ";" with "\;" so output argument lists will split correctly
|
||||||
|
std::string escapedArg;
|
||||||
|
for (size_t i = 0; i < arg.size(); ++i) {
|
||||||
|
if (arg[i] == ';') {
|
||||||
|
escapedArg += '\\';
|
||||||
|
}
|
||||||
|
escapedArg += arg[i];
|
||||||
|
}
|
||||||
|
return escapedArg;
|
||||||
|
}
|
||||||
|
|
||||||
bool cmParseArgumentsCommand::InitialPass(std::vector<std::string> const& args,
|
bool cmParseArgumentsCommand::InitialPass(std::vector<std::string> const& args,
|
||||||
cmExecutionStatus&)
|
cmExecutionStatus&)
|
||||||
{
|
{
|
||||||
|
@ -165,10 +178,18 @@ bool cmParseArgumentsCommand::InitialPass(std::vector<std::string> const& args,
|
||||||
insideValues = NONE;
|
insideValues = NONE;
|
||||||
break;
|
break;
|
||||||
case MULTI:
|
case MULTI:
|
||||||
multi[currentArgName].push_back(*argIter);
|
if (parseFromArgV) {
|
||||||
|
multi[currentArgName].push_back(escape_arg(*argIter));
|
||||||
|
} else {
|
||||||
|
multi[currentArgName].push_back(*argIter);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
unparsed.push_back(*argIter);
|
if (parseFromArgV) {
|
||||||
|
unparsed.push_back(escape_arg(*argIter));
|
||||||
|
} else {
|
||||||
|
unparsed.push_back(*argIter);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,8 +23,16 @@ function(test2 arg1)
|
||||||
TEST(pref_OPT2 FALSE)
|
TEST(pref_OPT2 FALSE)
|
||||||
TEST(pref_SINGLE1 "foo;bar")
|
TEST(pref_SINGLE1 "foo;bar")
|
||||||
TEST(pref_SINGLE2 UNDEFINED)
|
TEST(pref_SINGLE2 UNDEFINED)
|
||||||
TEST(pref_MULTI1 bar foo bar)
|
TEST(pref_MULTI1 bar "foo;bar")
|
||||||
TEST(pref_MULTI2 UNDEFINED)
|
TEST(pref_MULTI2 UNDEFINED)
|
||||||
TEST(pref_UNPARSED_ARGUMENTS UNDEFINED)
|
TEST(pref_UNPARSED_ARGUMENTS UNDEFINED)
|
||||||
endfunction()
|
endfunction()
|
||||||
test2("first named" OPT1 SINGLE1 "foo;bar" MULTI1 bar foo bar)
|
test2("first named" OPT1 SINGLE1 "foo;bar" MULTI1 bar "foo;bar")
|
||||||
|
|
||||||
|
function(test3 arg1)
|
||||||
|
cmake_parse_arguments(PARSE_ARGV 0
|
||||||
|
pref "" "" "")
|
||||||
|
|
||||||
|
TEST(pref_UNPARSED_ARGUMENTS "foo;bar" dog cat)
|
||||||
|
endfunction()
|
||||||
|
test3("foo;bar" dog cat)
|
||||||
|
|
|
@ -0,0 +1,53 @@
|
||||||
|
include(${CMAKE_CURRENT_LIST_DIR}/test_utils.cmake)
|
||||||
|
|
||||||
|
function(test1)
|
||||||
|
cmake_parse_arguments(PARSE_ARGV 0
|
||||||
|
mpref "" "" "MULTI")
|
||||||
|
|
||||||
|
TEST(mpref_MULTI foo "foo\;bar")
|
||||||
|
|
||||||
|
cmake_parse_arguments(PARSE_ARGV 1
|
||||||
|
upref "" "" "MULTI")
|
||||||
|
|
||||||
|
TEST(upref_UNPARSED_ARGUMENTS foo "foo\;bar")
|
||||||
|
endfunction()
|
||||||
|
test1(MULTI foo "foo\;bar")
|
||||||
|
|
||||||
|
function(test2)
|
||||||
|
cmake_parse_arguments(PARSE_ARGV 0
|
||||||
|
mpref "" "" "MULTI")
|
||||||
|
|
||||||
|
TEST(mpref_MULTI "foo;" "bar;")
|
||||||
|
|
||||||
|
cmake_parse_arguments(PARSE_ARGV 1
|
||||||
|
upref "" "" "MULTI")
|
||||||
|
|
||||||
|
TEST(upref_UNPARSED_ARGUMENTS "foo;" "bar;")
|
||||||
|
endfunction()
|
||||||
|
test2(MULTI "foo;" "bar;")
|
||||||
|
|
||||||
|
function(test3)
|
||||||
|
cmake_parse_arguments(PARSE_ARGV 0
|
||||||
|
mpref "" "" "MULTI")
|
||||||
|
|
||||||
|
TEST(mpref_MULTI "[foo;]" "bar\\")
|
||||||
|
|
||||||
|
cmake_parse_arguments(PARSE_ARGV 1
|
||||||
|
upref "" "" "MULTI")
|
||||||
|
|
||||||
|
TEST(upref_UNPARSED_ARGUMENTS "[foo;]" "bar\\")
|
||||||
|
endfunction()
|
||||||
|
test3(MULTI "[foo;]" "bar\\")
|
||||||
|
|
||||||
|
function(test4)
|
||||||
|
cmake_parse_arguments(PARSE_ARGV 0
|
||||||
|
mpref "" "" "MULTI")
|
||||||
|
|
||||||
|
TEST(mpref_MULTI foo "bar;none")
|
||||||
|
|
||||||
|
cmake_parse_arguments(PARSE_ARGV 1
|
||||||
|
upref "" "" "MULTI")
|
||||||
|
|
||||||
|
TEST(upref_UNPARSED_ARGUMENTS foo "bar;none")
|
||||||
|
endfunction()
|
||||||
|
test4(MULTI foo bar\\ none)
|
|
@ -10,3 +10,4 @@ run_cmake(BadArgvN1)
|
||||||
run_cmake(BadArgvN2)
|
run_cmake(BadArgvN2)
|
||||||
run_cmake(BadArgvN3)
|
run_cmake(BadArgvN3)
|
||||||
run_cmake(BadArgvN4)
|
run_cmake(BadArgvN4)
|
||||||
|
run_cmake(CornerCasesArgvN)
|
||||||
|
|
|
@ -17,4 +17,5 @@ SET (asdf "some value")
|
||||||
TEST(asdf "some value")
|
TEST(asdf "some value")
|
||||||
|
|
||||||
SET (asdf some list)
|
SET (asdf some list)
|
||||||
|
TEST(asdf some list)
|
||||||
TEST(asdf "some;list")
|
TEST(asdf "some;list")
|
||||||
|
|
|
@ -1,20 +1,30 @@
|
||||||
macro(TEST variable)
|
function(TEST variable)
|
||||||
SET(expected "${ARGN}")
|
if(ARGC GREATER 2)
|
||||||
if ( "${expected}" STREQUAL "UNDEFINED" )
|
set(i 0)
|
||||||
if (DEFINED ${variable})
|
foreach(value IN LISTS ${variable})
|
||||||
message(FATAL_ERROR "'${variable}' shall be undefined but has value '${${variable}}'")
|
math(EXPR j "${i} + 1")
|
||||||
endif()
|
set(${variable}[${i}] "${value}")
|
||||||
elseif( "${expected}" STREQUAL "FALSE" )
|
TEST(${variable}[${i}] "${ARGV${j}}")
|
||||||
if (NOT ${variable} STREQUAL "FALSE")
|
set(i ${j})
|
||||||
message(FATAL_ERROR "'${variable}' shall be FALSE")
|
endforeach()
|
||||||
endif()
|
|
||||||
elseif( "${expected}" STREQUAL "TRUE" )
|
|
||||||
if (NOT ${variable} STREQUAL "TRUE")
|
|
||||||
message(FATAL_ERROR "'${variable}' shall be TRUE")
|
|
||||||
endif()
|
|
||||||
else()
|
else()
|
||||||
if (NOT ${variable} STREQUAL "${expected}")
|
set(expected "${ARGN}")
|
||||||
message(FATAL_ERROR "'${variable}' shall be '${expected}'")
|
if("${expected}" STREQUAL "UNDEFINED")
|
||||||
|
if(DEFINED ${variable})
|
||||||
|
message(FATAL_ERROR "'${variable}' shall be undefined but has value '${${variable}}'")
|
||||||
|
endif()
|
||||||
|
elseif("${expected}" STREQUAL "FALSE")
|
||||||
|
if(NOT ${variable} STREQUAL "FALSE")
|
||||||
|
message(FATAL_ERROR "'${variable}' shall be FALSE")
|
||||||
|
endif()
|
||||||
|
elseif("${expected}" STREQUAL "TRUE")
|
||||||
|
if(NOT ${variable} STREQUAL "TRUE")
|
||||||
|
message(FATAL_ERROR "'${variable}' shall be TRUE")
|
||||||
|
endif()
|
||||||
|
else()
|
||||||
|
if(NOT ${variable} STREQUAL "${expected}")
|
||||||
|
message(FATAL_ERROR "'${variable}' shall be '${expected}'")
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endmacro()
|
endfunction()
|
||||||
|
|
Loading…
Reference in New Issue