Merge topic 'ExternalProject_CMAKE_CACHE_DEFAULT_ARGS'

609037f4 ExternalProject: Add unit tests for CMAKE_CACHE_DEFAULT_ARGS
98cdb658 ExternalProject: Add CMAKE_CACHE_DEFAULT_ARGS arguments
36cf8a1e Tests/Tutorial: Fix when USE_MYMATH is OFF
This commit is contained in:
Brad King 2014-10-31 11:35:07 -04:00 committed by CMake Topic Stage
commit 0b8db9ced1
14 changed files with 162 additions and 21 deletions

View File

@ -98,9 +98,27 @@ Create custom targets to build projects in external trees
``CMAKE_GENERATOR_TOOLSET <toolset>`` ``CMAKE_GENERATOR_TOOLSET <toolset>``
Generator-specific toolset name Generator-specific toolset name
``CMAKE_ARGS <arg>...`` ``CMAKE_ARGS <arg>...``
Arguments to CMake command line Arguments to CMake command line.
These arguments are passed to CMake command line, and can contain
arguments other than cache values, see also
:manual:`CMake Options <cmake(1)>`. Arguments in the form
``-Dvar:string=on`` are always passed to the command line, and
therefore cannot be changed by the user.
``CMAKE_CACHE_ARGS <arg>...`` ``CMAKE_CACHE_ARGS <arg>...``
Initial cache arguments, of the form ``-Dvar:string=on`` Initial cache arguments, of the form ``-Dvar:string=on``.
These arguments are written in a pre-load a script that populates
CMake cache, see also :manual:`cmake -C <cmake(1)>`. This allows to
overcome command line length limits.
These arguments are :command:`set` using the ``FORCE`` argument,
and therefore cannot be changed by the user.
``CMAKE_CACHE_DEFAULT_ARGS <arg>...``
Initial default cache arguments, of the form ``-Dvar:string=on``.
These arguments are written in a pre-load a script that populates
CMake cache, see also :manual:`cmake -C <cmake(1)>`. This allows to
overcome command line length limits.
These arguments can be used as default value that will be set if no
previous value is found in the cache, and that the user can change
later.
Build step options are: Build step options are:
@ -986,17 +1004,20 @@ macro(_ep_replace_location_tags target_name)
endmacro() endmacro()
function(_ep_write_initial_cache target_name script_filename args) function(_ep_command_line_to_initial_cache var args force)
# Write out values into an initial cache, that will be passed to CMake with -C
set(script_initial_cache "") set(script_initial_cache "")
set(regex "^([^:]+):([^=]+)=(.*)$") set(regex "^([^:]+):([^=]+)=(.*)$")
set(setArg "") set(setArg "")
set(forceArg "")
if(force)
set(forceArg "FORCE")
endif()
foreach(line ${args}) foreach(line ${args})
if("${line}" MATCHES "^-D(.*)") if("${line}" MATCHES "^-D(.*)")
set(line "${CMAKE_MATCH_1}") set(line "${CMAKE_MATCH_1}")
if(setArg) if(setArg)
# This is required to build up lists in variables, or complete an entry # This is required to build up lists in variables, or complete an entry
set(setArg "${setArg}${accumulator}\" CACHE ${type} \"Initial cache\" FORCE)") set(setArg "${setArg}${accumulator}\" CACHE ${type} \"Initial cache\" ${forceArg})")
set(script_initial_cache "${script_initial_cache}\n${setArg}") set(script_initial_cache "${script_initial_cache}\n${setArg}")
set(accumulator "") set(accumulator "")
set(setArg "") set(setArg "")
@ -1016,9 +1037,15 @@ function(_ep_write_initial_cache target_name script_filename args)
endforeach() endforeach()
# Catch the final line of the args # Catch the final line of the args
if(setArg) if(setArg)
set(setArg "${setArg}${accumulator}\" CACHE ${type} \"Initial cache\" FORCE)") set(setArg "${setArg}${accumulator}\" CACHE ${type} \"Initial cache\" ${forceArg})")
set(script_initial_cache "${script_initial_cache}\n${setArg}") set(script_initial_cache "${script_initial_cache}\n${setArg}")
endif() endif()
set(${var} ${script_initial_cache} PARENT_SCOPE)
endfunction()
function(_ep_write_initial_cache target_name script_filename script_initial_cache)
# Write out values into an initial cache, that will be passed to CMake with -C
# Replace location tags. # Replace location tags.
_ep_replace_location_tags(${target_name} script_initial_cache) _ep_replace_location_tags(${target_name} script_initial_cache)
# Write out the initial cache file to the location specified. # Write out the initial cache file to the location specified.
@ -1833,11 +1860,20 @@ function(_ep_add_configure_command name)
get_property(cmake_args TARGET ${name} PROPERTY _EP_CMAKE_ARGS) get_property(cmake_args TARGET ${name} PROPERTY _EP_CMAKE_ARGS)
list(APPEND cmd ${cmake_args}) list(APPEND cmd ${cmake_args})
# If there are any CMAKE_CACHE_ARGS, write an initial cache and use it # If there are any CMAKE_CACHE_ARGS or CMAKE_CACHE_DEFAULT_ARGS,
# write an initial cache and use it
get_property(cmake_cache_args TARGET ${name} PROPERTY _EP_CMAKE_CACHE_ARGS) get_property(cmake_cache_args TARGET ${name} PROPERTY _EP_CMAKE_CACHE_ARGS)
if(cmake_cache_args) get_property(cmake_cache_default_args TARGET ${name} PROPERTY _EP_CMAKE_CACHE_DEFAULT_ARGS)
if(cmake_cache_args OR cmake_cache_default_args)
set(_ep_cache_args_script "${tmp_dir}/${name}-cache.cmake") set(_ep_cache_args_script "${tmp_dir}/${name}-cache.cmake")
_ep_write_initial_cache(${name} "${_ep_cache_args_script}" "${cmake_cache_args}") if(cmake_cache_args)
_ep_command_line_to_initial_cache(script_initial_cache_force "${cmake_cache_args}" 1)
endif()
if(cmake_cache_default_args)
_ep_command_line_to_initial_cache(script_initial_cache_default "${cmake_cache_default_args}" 0)
endif()
_ep_write_initial_cache(${name} "${_ep_cache_args_script}" "${script_initial_cache_force}${script_initial_cache_default}")
list(APPEND cmd "-C${_ep_cache_args_script}") list(APPEND cmd "-C${_ep_cache_args_script}")
endif() endif()

View File

@ -66,6 +66,7 @@ if(can_build_tutorial_step5)
ExternalProject_Add(${proj} ExternalProject_Add(${proj}
URL "${CMAKE_CURRENT_SOURCE_DIR}/../Tutorial/Step5" URL "${CMAKE_CURRENT_SOURCE_DIR}/../Tutorial/Step5"
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=<INSTALL_DIR> -G ${CMAKE_GENERATOR} <SOURCE_DIR> CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=<INSTALL_DIR> -G ${CMAKE_GENERATOR} <SOURCE_DIR>
CMAKE_CACHE_DEFAULT_ARGS -DUSE_MYMATH:BOOL=OFF
TEST_AFTER_INSTALL 1 TEST_AFTER_INSTALL 1
LOG_TEST 1 LOG_TEST 1
) )

View File

@ -153,3 +153,4 @@ add_RunCMake_test(CommandLine)
add_RunCMake_test(install) add_RunCMake_test(install)
add_RunCMake_test(CPackInstallProperties) add_RunCMake_test(CPackInstallProperties)
add_RunCMake_test(ExternalProject)

View File

@ -0,0 +1,21 @@
include(ExternalProject)
set(_tmp_dir "${CMAKE_CURRENT_BINARY_DIR}/tmp")
set(_cache_file "${_tmp_dir}/FOO-cache.cmake")
ExternalProject_Add(FOO TMP_DIR "${_tmp_dir}"
DOWNLOAD_COMMAND ""
CMAKE_CACHE_ARGS "-DFOO:STRING=BAR")
if(NOT EXISTS "${_cache_file}")
message(FATAL_ERROR "Initial cache not created")
endif()
file(READ "${_cache_file}" _cache)
if(NOT "${_cache}" MATCHES "set\\(FOO \"BAR\".+\\)") # \(\)
message(FATAL_ERROR "Cannot find FOO argument in cache")
endif()
if(NOT "${CMAKE_MATCH_0}" MATCHES FORCE)
message(FATAL_ERROR "Expected forced FOO argument")
endif()

View File

@ -0,0 +1,21 @@
include(ExternalProject)
set(_tmp_dir "${CMAKE_CURRENT_BINARY_DIR}/tmp")
set(_cache_file "${_tmp_dir}/FOO-cache.cmake")
ExternalProject_Add(FOO TMP_DIR "${_tmp_dir}"
DOWNLOAD_COMMAND ""
CMAKE_CACHE_DEFAULT_ARGS "-DFOO:STRING=BAR")
if(NOT EXISTS "${_cache_file}")
message(FATAL_ERROR "Initial cache not created")
endif()
file(READ "${_cache_file}" _cache)
if(NOT "${_cache}" MATCHES "set\\(FOO \"BAR\".+\\)") # \(\)
message(FATAL_ERROR "Cannot find FOO argument in cache")
endif()
if("${CMAKE_MATCH_0}" MATCHES FORCE)
message(FATAL_ERROR "Expected not forced FOO argument")
endif()

View File

@ -0,0 +1,29 @@
include(ExternalProject)
set(_tmp_dir "${CMAKE_CURRENT_BINARY_DIR}/tmp")
set(_cache_file "${_tmp_dir}/FOO-cache.cmake")
ExternalProject_Add(FOO TMP_DIR "${_tmp_dir}"
DOWNLOAD_COMMAND ""
CMAKE_CACHE_ARGS "-DFOO:STRING=BAR"
CMAKE_CACHE_DEFAULT_ARGS "-DBAR:STRING=BAZ")
if(NOT EXISTS "${_cache_file}")
message(FATAL_ERROR "Initial cache not created")
endif()
file(READ "${_cache_file}" _cache)
if(NOT "${_cache}" MATCHES "set\\(FOO \"BAR\".+\\)") # \(\)
message(FATAL_ERROR "Cannot find FOO argument in cache")
endif()
if(NOT "${CMAKE_MATCH_0}" MATCHES FORCE)
message(FATAL_ERROR "Expected forced FOO argument")
endif()
if(NOT "${_cache}" MATCHES "set\\(BAR \"BAZ\".+\\)") # \(\)
message(FATAL_ERROR "Cannot find BAR argument in cache")
endif()
if("${CMAKE_MATCH_0}" MATCHES FORCE)
message(FATAL_ERROR "Expected not forced BAR argument")
endif()

View File

@ -0,0 +1,3 @@
cmake_minimum_required(VERSION ${CMAKE_VERSION})
project(${RunCMake_TEST} NONE)
include(${RunCMake_TEST}.cmake)

View File

@ -0,0 +1,5 @@
include(RunCMake)
run_cmake(CMAKE_CACHE_ARGS)
run_cmake(CMAKE_CACHE_DEFAULT_ARGS)
run_cmake(CMAKE_CACHE_mix)

View File

@ -21,12 +21,16 @@ int main (int argc, char *argv[])
} }
double inputValue = atof(argv[1]); double inputValue = atof(argv[1]);
double outputValue = 0;
if(inputValue >= 0)
{
#ifdef USE_MYMATH #ifdef USE_MYMATH
double outputValue = mysqrt(inputValue); outputValue = mysqrt(inputValue);
#else #else
double outputValue = sqrt(inputValue); outputValue = sqrt(inputValue);
#endif #endif
}
fprintf(stdout,"The square root of %g is %g\n", fprintf(stdout,"The square root of %g is %g\n",
inputValue, outputValue); inputValue, outputValue);

View File

@ -21,12 +21,16 @@ int main (int argc, char *argv[])
} }
double inputValue = atof(argv[1]); double inputValue = atof(argv[1]);
double outputValue = 0;
if(inputValue >= 0)
{
#ifdef USE_MYMATH #ifdef USE_MYMATH
double outputValue = mysqrt(inputValue); outputValue = mysqrt(inputValue);
#else #else
double outputValue = sqrt(inputValue); outputValue = sqrt(inputValue);
#endif #endif
}
fprintf(stdout,"The square root of %g is %g\n", fprintf(stdout,"The square root of %g is %g\n",
inputValue, outputValue); inputValue, outputValue);

View File

@ -21,12 +21,16 @@ int main (int argc, char *argv[])
} }
double inputValue = atof(argv[1]); double inputValue = atof(argv[1]);
double outputValue = 0;
if(inputValue >= 0)
{
#ifdef USE_MYMATH #ifdef USE_MYMATH
double outputValue = mysqrt(inputValue); outputValue = mysqrt(inputValue);
#else #else
double outputValue = sqrt(inputValue); outputValue = sqrt(inputValue);
#endif #endif
}
fprintf(stdout,"The square root of %g is %g\n", fprintf(stdout,"The square root of %g is %g\n",
inputValue, outputValue); inputValue, outputValue);

View File

@ -21,12 +21,16 @@ int main (int argc, char *argv[])
} }
double inputValue = atof(argv[1]); double inputValue = atof(argv[1]);
double outputValue = 0;
if(inputValue >= 0)
{
#ifdef USE_MYMATH #ifdef USE_MYMATH
double outputValue = mysqrt(inputValue); outputValue = mysqrt(inputValue);
#else #else
double outputValue = sqrt(inputValue); outputValue = sqrt(inputValue);
#endif #endif
}
fprintf(stdout,"The square root of %g is %g\n", fprintf(stdout,"The square root of %g is %g\n",
inputValue, outputValue); inputValue, outputValue);

View File

@ -21,12 +21,16 @@ int main (int argc, char *argv[])
} }
double inputValue = atof(argv[1]); double inputValue = atof(argv[1]);
double outputValue = 0;
if(inputValue >= 0)
{
#ifdef USE_MYMATH #ifdef USE_MYMATH
double outputValue = mysqrt(inputValue); outputValue = mysqrt(inputValue);
#else #else
double outputValue = sqrt(inputValue); outputValue = sqrt(inputValue);
#endif #endif
}
fprintf(stdout,"The square root of %g is %g\n", fprintf(stdout,"The square root of %g is %g\n",
inputValue, outputValue); inputValue, outputValue);

View File

@ -21,12 +21,16 @@ int main (int argc, char *argv[])
} }
double inputValue = atof(argv[1]); double inputValue = atof(argv[1]);
double outputValue = 0;
if(inputValue >= 0)
{
#ifdef USE_MYMATH #ifdef USE_MYMATH
double outputValue = mysqrt(inputValue); outputValue = mysqrt(inputValue);
#else #else
double outputValue = sqrt(inputValue); outputValue = sqrt(inputValue);
#endif #endif
}
fprintf(stdout,"The square root of %g is %g\n", fprintf(stdout,"The square root of %g is %g\n",
inputValue, outputValue); inputValue, outputValue);