ENH: Improve add_external_project interface
This rewrites the keyword/argument parsing and handling in the AddExternalProject module to use arguments more literally: - The strict keyword-value pairing is gone in favor of keywords with arbitrary non-keyword values. This avoids requiring users to escape spaces and quotes in command lines. - Customized step command lines are now specified with a single keyword <step>_COMMAND instead of putting the arguments in a separate entry (previously called <step>_ARGS). - Build step custom commands now use VERBATIM mode so that arguments are correctly escaped on the command line during builds.
This commit is contained in:
parent
431c456cf5
commit
6ae0ff626a
|
@ -65,12 +65,10 @@ function(get_configure_command_id name cfg_cmd_id_var)
|
||||||
endif()
|
endif()
|
||||||
endfunction(get_configure_command_id)
|
endfunction(get_configure_command_id)
|
||||||
|
|
||||||
function(_aep_get_build_command name step cmd_var args_var)
|
function(_aep_get_build_command name step cmd_var)
|
||||||
# No default arguments if command is user-specified.
|
|
||||||
set(args)
|
|
||||||
|
|
||||||
set(cmd "${${cmd_var}}")
|
set(cmd "${${cmd_var}}")
|
||||||
if(NOT cmd)
|
if(NOT cmd)
|
||||||
|
set(args)
|
||||||
get_configure_command_id(${name} cfg_cmd_id)
|
get_configure_command_id(${name} cfg_cmd_id)
|
||||||
if(cfg_cmd_id STREQUAL "cmake")
|
if(cfg_cmd_id STREQUAL "cmake")
|
||||||
# CMake project. Select build command based on generator.
|
# CMake project. Select build command based on generator.
|
||||||
|
@ -84,9 +82,9 @@ function(_aep_get_build_command name step cmd_var args_var)
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
# Drive the project with "cmake --build".
|
# Drive the project with "cmake --build".
|
||||||
get_target_property(cfg_cmd ${name} AEP_CONFIGURE_COMMAND)
|
get_target_property(cmake_command ${name} AEP_CMAKE_COMMAND)
|
||||||
if(cfg_cmd)
|
if(cmake_command)
|
||||||
set(cmd "${cfg_cmd}")
|
set(cmd "${cmake_command}")
|
||||||
else()
|
else()
|
||||||
set(cmd "${CMAKE_COMMAND}")
|
set(cmd "${CMAKE_COMMAND}")
|
||||||
endif()
|
endif()
|
||||||
|
@ -102,17 +100,17 @@ function(_aep_get_build_command name step cmd_var args_var)
|
||||||
set(args install)
|
set(args install)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
|
||||||
|
|
||||||
# Use user-specified build arguments, if any.
|
# Use user-specified arguments instead of default arguments, if any.
|
||||||
get_property(have_args TARGET ${name} PROPERTY AEP_${step}_ARGS SET)
|
get_property(have_args TARGET ${name} PROPERTY AEP_${step}_ARGS SET)
|
||||||
if(have_args)
|
if(have_args)
|
||||||
get_target_property(args ${name} AEP_${step}_ARGS)
|
get_target_property(args ${name} AEP_${step}_ARGS)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Return answers to caller.
|
list(APPEND cmd ${args})
|
||||||
|
endif()
|
||||||
|
|
||||||
set(${cmd_var} "${cmd}" PARENT_SCOPE)
|
set(${cmd_var} "${cmd}" PARENT_SCOPE)
|
||||||
set(${args_var} "${args}" PARENT_SCOPE)
|
|
||||||
endfunction(_aep_get_build_command)
|
endfunction(_aep_get_build_command)
|
||||||
|
|
||||||
function(mkdir d)
|
function(mkdir d)
|
||||||
|
@ -138,24 +136,19 @@ function(add_external_project_download_command name)
|
||||||
WORKING_DIRECTORY ${sentinels_dir}
|
WORKING_DIRECTORY ${sentinels_dir}
|
||||||
COMMENT "No download step for '${name}'"
|
COMMENT "No download step for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/CMakeExternals-directories
|
DEPENDS ${sentinels_dir}/CMakeExternals-directories
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
return()
|
return()
|
||||||
else()
|
else()
|
||||||
if(cmd)
|
if(cmd)
|
||||||
set(args "")
|
|
||||||
get_target_property(download_args ${name} AEP_DOWNLOAD_ARGS)
|
|
||||||
if(download_args)
|
|
||||||
set(args "${download_args}")
|
|
||||||
separate_arguments(args)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT ${sentinels_dir}/${name}-download
|
OUTPUT ${sentinels_dir}/${name}-download
|
||||||
COMMAND ${cmd} ${args}
|
COMMAND ${cmd}
|
||||||
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-download
|
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-download
|
||||||
WORKING_DIRECTORY ${downloads_dir}
|
WORKING_DIRECTORY ${downloads_dir}
|
||||||
COMMENT "Performing download step for '${name}'"
|
COMMENT "Performing download step for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/CMakeExternals-directories
|
DEPENDS ${sentinels_dir}/CMakeExternals-directories
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
return()
|
return()
|
||||||
else()
|
else()
|
||||||
|
@ -198,6 +191,7 @@ function(add_external_project_download_command name)
|
||||||
WORKING_DIRECTORY ${source_dir}
|
WORKING_DIRECTORY ${source_dir}
|
||||||
COMMENT "Performing download step (CVS checkout) for '${name}'"
|
COMMENT "Performing download step (CVS checkout) for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-cvsinfo.txt
|
DEPENDS ${sentinels_dir}/${name}-cvsinfo.txt
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
@ -231,6 +225,7 @@ function(add_external_project_download_command name)
|
||||||
WORKING_DIRECTORY ${source_dir}
|
WORKING_DIRECTORY ${source_dir}
|
||||||
COMMENT "Performing download step (SVN checkout) for '${name}'"
|
COMMENT "Performing download step (SVN checkout) for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-svninfo.txt
|
DEPENDS ${sentinels_dir}/${name}-svninfo.txt
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
@ -259,6 +254,7 @@ function(add_external_project_download_command name)
|
||||||
WORKING_DIRECTORY ${source_dir}
|
WORKING_DIRECTORY ${source_dir}
|
||||||
COMMENT "Performing download step (DIR copy) for '${name}'"
|
COMMENT "Performing download step (DIR copy) for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-dirinfo.txt
|
DEPENDS ${sentinels_dir}/${name}-dirinfo.txt
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
@ -274,6 +270,7 @@ function(add_external_project_download_command name)
|
||||||
WORKING_DIRECTORY ${source_dir}
|
WORKING_DIRECTORY ${source_dir}
|
||||||
COMMENT "Performing download step (TAR untar) for '${name}'"
|
COMMENT "Performing download step (TAR untar) for '${name}'"
|
||||||
DEPENDS ${tar}
|
DEPENDS ${tar}
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
@ -289,6 +286,7 @@ function(add_external_project_download_command name)
|
||||||
WORKING_DIRECTORY ${source_dir}
|
WORKING_DIRECTORY ${source_dir}
|
||||||
COMMENT "Performing download step (TGZ untar) for '${name}'"
|
COMMENT "Performing download step (TGZ untar) for '${name}'"
|
||||||
DEPENDS ${tgz}
|
DEPENDS ${tgz}
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
@ -315,6 +313,7 @@ function(add_external_project_download_command name)
|
||||||
WORKING_DIRECTORY ${source_dir}
|
WORKING_DIRECTORY ${source_dir}
|
||||||
COMMENT "Performing download step (TGZ_URL download and untar) for '${name}'"
|
COMMENT "Performing download step (TGZ_URL download and untar) for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-urlinfo.txt
|
DEPENDS ${sentinels_dir}/${name}-urlinfo.txt
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
@ -341,6 +340,7 @@ function(add_external_project_download_command name)
|
||||||
WORKING_DIRECTORY ${source_dir}
|
WORKING_DIRECTORY ${source_dir}
|
||||||
COMMENT "Performing download step (TAR_URL download and untar) for '${name}'"
|
COMMENT "Performing download step (TAR_URL download and untar) for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-urlinfo.txt
|
DEPENDS ${sentinels_dir}/${name}-urlinfo.txt
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
@ -368,20 +368,14 @@ function(add_external_project_update_command name)
|
||||||
return()
|
return()
|
||||||
else()
|
else()
|
||||||
if(cmd)
|
if(cmd)
|
||||||
set(args "")
|
|
||||||
get_target_property(update_args ${name} AEP_UPDATE_ARGS)
|
|
||||||
if(update_args)
|
|
||||||
set(args "${update_args}")
|
|
||||||
separate_arguments(args)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT ${sentinels_dir}/${name}-update
|
OUTPUT ${sentinels_dir}/${name}-update
|
||||||
COMMAND ${cmd} ${args}
|
COMMAND ${cmd}
|
||||||
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-update
|
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-update
|
||||||
WORKING_DIRECTORY ${source_dir}/${name}
|
WORKING_DIRECTORY ${source_dir}/${name}
|
||||||
COMMENT "Performing update step for '${name}'"
|
COMMENT "Performing update step for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-download
|
DEPENDS ${sentinels_dir}/${name}-download
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
return()
|
return()
|
||||||
else()
|
else()
|
||||||
|
@ -408,6 +402,7 @@ function(add_external_project_update_command name)
|
||||||
WORKING_DIRECTORY ${source_dir}/${name}
|
WORKING_DIRECTORY ${source_dir}/${name}
|
||||||
COMMENT "Performing update step (CVS update) for '${name}'"
|
COMMENT "Performing update step (CVS update) for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-download
|
DEPENDS ${sentinels_dir}/${name}-download
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
# Since the update sentinel is not actually written:
|
# Since the update sentinel is not actually written:
|
||||||
set_property(SOURCE ${sentinels_dir}/${name}-update
|
set_property(SOURCE ${sentinels_dir}/${name}-update
|
||||||
|
@ -433,6 +428,7 @@ function(add_external_project_update_command name)
|
||||||
WORKING_DIRECTORY ${source_dir}/${name}
|
WORKING_DIRECTORY ${source_dir}/${name}
|
||||||
COMMENT "Performing update step (SVN update) for '${name}'"
|
COMMENT "Performing update step (SVN update) for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-download
|
DEPENDS ${sentinels_dir}/${name}-download
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
# Since the update sentinel is not actually written:
|
# Since the update sentinel is not actually written:
|
||||||
set_property(SOURCE ${sentinels_dir}/${name}-update
|
set_property(SOURCE ${sentinels_dir}/${name}-update
|
||||||
|
@ -447,6 +443,7 @@ function(add_external_project_update_command name)
|
||||||
WORKING_DIRECTORY ${sentinels_dir}
|
WORKING_DIRECTORY ${sentinels_dir}
|
||||||
COMMENT "No update step for '${name}'"
|
COMMENT "No update step for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-download
|
DEPENDS ${sentinels_dir}/${name}-download
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
endfunction(add_external_project_update_command)
|
endfunction(add_external_project_update_command)
|
||||||
|
|
||||||
|
@ -468,6 +465,7 @@ function(add_external_project_configure_command name)
|
||||||
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-working_dir
|
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-working_dir
|
||||||
DEPENDS ${sentinels_dir}/${name}-update
|
DEPENDS ${sentinels_dir}/${name}-update
|
||||||
${file_deps}
|
${file_deps}
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
|
|
||||||
get_target_property(cmd ${name} AEP_CONFIGURE_COMMAND)
|
get_target_property(cmd ${name} AEP_CONFIGURE_COMMAND)
|
||||||
|
@ -479,34 +477,34 @@ function(add_external_project_configure_command name)
|
||||||
WORKING_DIRECTORY ${working_dir}
|
WORKING_DIRECTORY ${working_dir}
|
||||||
COMMENT "No configure step for '${name}'"
|
COMMENT "No configure step for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-working_dir
|
DEPENDS ${sentinels_dir}/${name}-working_dir
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
else()
|
else()
|
||||||
if(NOT cmd)
|
if(NOT cmd)
|
||||||
set(cmd ${CMAKE_COMMAND})
|
get_target_property(cmake_command ${name} AEP_CMAKE_COMMAND)
|
||||||
|
if(cmake_command)
|
||||||
|
set(cmd "${cmake_command}")
|
||||||
|
else()
|
||||||
|
set(cmd "${CMAKE_COMMAND}")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(args "")
|
get_property(cmake_args TARGET ${name} PROPERTY AEP_CMAKE_ARGS)
|
||||||
get_target_property(configure_args ${name} AEP_CONFIGURE_ARGS)
|
list(APPEND cmd ${cmake_args})
|
||||||
if(configure_args)
|
|
||||||
set(args "${configure_args}")
|
|
||||||
separate_arguments(args)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
get_target_property(cmake_generator ${name} AEP_CMAKE_GENERATOR)
|
get_target_property(cmake_generator ${name} AEP_CMAKE_GENERATOR)
|
||||||
if(cmake_generator)
|
if(cmake_generator)
|
||||||
get_configure_command_id(${name} cfg_cmd_id)
|
list(APPEND cmd "-G${cmake_generator}" "${source_dir}/${name}")
|
||||||
if(cfg_cmd_id STREQUAL "cmake")
|
|
||||||
list(APPEND args "-G${cmake_generator}" "${source_dir}/${name}")
|
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT ${sentinels_dir}/${name}-configure
|
OUTPUT ${sentinels_dir}/${name}-configure
|
||||||
COMMAND ${cmd} ${args}
|
COMMAND ${cmd}
|
||||||
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-configure
|
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-configure
|
||||||
WORKING_DIRECTORY ${working_dir}
|
WORKING_DIRECTORY ${working_dir}
|
||||||
COMMENT "Performing configure step for '${name}'"
|
COMMENT "Performing configure step for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-working_dir
|
DEPENDS ${sentinels_dir}/${name}-working_dir
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
endfunction(add_external_project_configure_command)
|
endfunction(add_external_project_configure_command)
|
||||||
|
@ -526,17 +524,19 @@ function(add_external_project_build_command name)
|
||||||
WORKING_DIRECTORY ${working_dir}
|
WORKING_DIRECTORY ${working_dir}
|
||||||
COMMENT "No build step for '${name}'"
|
COMMENT "No build step for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-configure
|
DEPENDS ${sentinels_dir}/${name}-configure
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
else()
|
else()
|
||||||
_aep_get_build_command(${name} BUILD cmd args)
|
_aep_get_build_command(${name} BUILD cmd)
|
||||||
|
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT ${sentinels_dir}/${name}-build
|
OUTPUT ${sentinels_dir}/${name}-build
|
||||||
COMMAND ${cmd} ${args}
|
COMMAND ${cmd}
|
||||||
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-build
|
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-build
|
||||||
WORKING_DIRECTORY ${working_dir}
|
WORKING_DIRECTORY ${working_dir}
|
||||||
COMMENT "Performing build step for '${name}'"
|
COMMENT "Performing build step for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-configure
|
DEPENDS ${sentinels_dir}/${name}-configure
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
endfunction(add_external_project_build_command)
|
endfunction(add_external_project_build_command)
|
||||||
|
@ -557,18 +557,20 @@ function(add_external_project_install_command name)
|
||||||
WORKING_DIRECTORY ${working_dir}
|
WORKING_DIRECTORY ${working_dir}
|
||||||
COMMENT "No install step for '${name}'"
|
COMMENT "No install step for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-build
|
DEPENDS ${sentinels_dir}/${name}-build
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
else()
|
else()
|
||||||
_aep_get_build_command(${name} INSTALL cmd args)
|
_aep_get_build_command(${name} INSTALL cmd)
|
||||||
|
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT ${sentinels_dir}/${name}-install
|
OUTPUT ${sentinels_dir}/${name}-install
|
||||||
COMMAND ${cmd} ${args}
|
COMMAND ${cmd}
|
||||||
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-install
|
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-install
|
||||||
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-complete
|
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-complete
|
||||||
WORKING_DIRECTORY ${working_dir}
|
WORKING_DIRECTORY ${working_dir}
|
||||||
COMMENT "Performing install step for '${name}'"
|
COMMENT "Performing install step for '${name}'"
|
||||||
DEPENDS ${sentinels_dir}/${name}-build
|
DEPENDS ${sentinels_dir}/${name}-build
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
endfunction(add_external_project_install_command)
|
endfunction(add_external_project_install_command)
|
||||||
|
@ -605,6 +607,7 @@ function(add_CMakeExternals_target)
|
||||||
COMMAND ${CMAKE_COMMAND} -E make_directory ${tmp_dir}
|
COMMAND ${CMAKE_COMMAND} -E make_directory ${tmp_dir}
|
||||||
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/CMakeExternals-directories
|
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/CMakeExternals-directories
|
||||||
COMMENT "Creating CMakeExternals directories"
|
COMMENT "Creating CMakeExternals directories"
|
||||||
|
VERBATIM
|
||||||
)
|
)
|
||||||
|
|
||||||
add_custom_target(CMakeExternals ALL
|
add_custom_target(CMakeExternals ALL
|
||||||
|
@ -613,19 +616,38 @@ function(add_CMakeExternals_target)
|
||||||
endif()
|
endif()
|
||||||
endfunction(add_CMakeExternals_target)
|
endfunction(add_CMakeExternals_target)
|
||||||
|
|
||||||
|
# Pre-compute a regex to match known keywords.
|
||||||
function(is_known_aep_property_key key result_var)
|
set(_aep_keyword_regex "^(")
|
||||||
set(${result_var} 0 PARENT_SCOPE)
|
set(_aep_keyword_sep)
|
||||||
|
foreach(key IN ITEMS
|
||||||
if(key MATCHES "^BUILD_ARGS|BUILD_COMMAND|CMAKE_GENERATOR|CONFIGURE_ARGS|CONFIGURE_COMMAND|CONFIGURE_DIR|CVS_REPOSITORY|CVS_MODULE|CVS_TAG|DEPENDS|DOWNLOAD_ARGS|DOWNLOAD_COMMAND|DIR|INSTALL_ARGS|INSTALL_COMMAND|SVN_REPOSITORY|SVN_TAG|TAR|TAR_URL|TGZ|TGZ_URL|UPDATE_ARGS|UPDATE_COMMAND$"
|
BUILD_ARGS
|
||||||
|
BUILD_COMMAND
|
||||||
|
CMAKE_ARGS
|
||||||
|
CMAKE_COMMAND
|
||||||
|
CMAKE_GENERATOR
|
||||||
|
CONFIGURE_COMMAND
|
||||||
|
CONFIGURE_DIR
|
||||||
|
CVS_MODULE
|
||||||
|
CVS_REPOSITORY
|
||||||
|
CVS_TAG
|
||||||
|
DEPENDS
|
||||||
|
DIR
|
||||||
|
DOWNLOAD_COMMAND
|
||||||
|
INSTALL_ARGS
|
||||||
|
INSTALL_COMMAND
|
||||||
|
SVN_REPOSITORY
|
||||||
|
SVN_TAG
|
||||||
|
TAR
|
||||||
|
TAR_URL
|
||||||
|
TGZ
|
||||||
|
TGZ_URL
|
||||||
|
UPDATE_COMMAND
|
||||||
)
|
)
|
||||||
#message(STATUS "info: recognized via MATCHES - key='${key}'")
|
set(_aep_keyword_regex "${_aep_keyword_regex}${_aep_keyword_sep}${key}")
|
||||||
set(${result_var} 1 PARENT_SCOPE)
|
set(_aep_keyword_sep "|")
|
||||||
else()
|
endforeach(key)
|
||||||
message(STATUS "warning: is_known_aep_property_key unknown key='${key}'")
|
set(_aep_keyword_regex "${_aep_keyword_regex})$")
|
||||||
endif()
|
set(_aep_keyword_sep)
|
||||||
endfunction(is_known_aep_property_key)
|
|
||||||
|
|
||||||
|
|
||||||
function(add_external_project name)
|
function(add_external_project name)
|
||||||
get_external_project_directories(base_dir build_dir downloads_dir install_dir
|
get_external_project_directories(base_dir build_dir downloads_dir install_dir
|
||||||
|
@ -652,37 +674,44 @@ function(add_external_project name)
|
||||||
# new custom target we just added so that we can set up all the build steps
|
# new custom target we just added so that we can set up all the build steps
|
||||||
# correctly based on target properties.
|
# correctly based on target properties.
|
||||||
#
|
#
|
||||||
# Loop over ARGN by 2's extracting key/value pairs from the non-explicit
|
# We loop through ARGN and consider the namespace starting with an
|
||||||
# arguments to this function:
|
# upper-case letter followed by at least two more upper-case letters
|
||||||
#
|
# or underscores to be keywords.
|
||||||
list(LENGTH ARGN n)
|
set(key)
|
||||||
set(i 0)
|
foreach(arg IN LISTS ARGN)
|
||||||
while(i LESS n)
|
if(arg MATCHES "^[A-Z][A-Z_][A-Z_]+$" AND
|
||||||
math(EXPR j ${i}+1)
|
NOT arg MATCHES "^(TRUE|FALSE)$")
|
||||||
|
# Keyword
|
||||||
list(GET ARGN ${i} key)
|
set(key "${arg}")
|
||||||
list(GET ARGN ${j} value)
|
if(NOT key MATCHES "${_aep_keyword_regex}")
|
||||||
|
message(AUTHOR_WARNING "unknown add_external_project keyword: ${key}")
|
||||||
is_known_aep_property_key("${key}" is_known_key)
|
endif()
|
||||||
|
elseif(key STREQUAL "DEPENDS")
|
||||||
if(is_known_key)
|
# Value for DEPENDS
|
||||||
if(key STREQUAL "DEPENDS")
|
if(NOT arg STREQUAL "")
|
||||||
if(NOT value STREQUAL "")
|
add_dependencies(${name} ${arg})
|
||||||
add_dependencies(${name} ${value})
|
set_property(TARGET ${name} APPEND PROPERTY AEP_FILE_DEPENDS "${sentinels_dir}/${arg}-complete")
|
||||||
set_property(TARGET ${name} APPEND PROPERTY AEP_FILE_DEPENDS "${sentinels_dir}/${value}-complete")
|
|
||||||
else()
|
else()
|
||||||
message(STATUS "warning: empty DEPENDS value in add_external_project")
|
message(AUTHOR_WARNING "empty DEPENDS value in add_external_project")
|
||||||
|
endif()
|
||||||
|
elseif(key)
|
||||||
|
# Value
|
||||||
|
if(NOT arg STREQUAL "")
|
||||||
|
set_property(TARGET ${name} APPEND PROPERTY AEP_${key} "${arg}")
|
||||||
|
else()
|
||||||
|
get_property(have_key TARGET ${name} PROPERTY AEP_${key} SET)
|
||||||
|
if(have_key)
|
||||||
|
get_property(value TARGET ${name} PROPERTY AEP_${key})
|
||||||
|
set_property(TARGET ${name} PROPERTY AEP_${key} "${value};${arg}")
|
||||||
|
else()
|
||||||
|
set_property(TARGET ${name} PROPERTY AEP_${key} "${arg}")
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
set_property(TARGET ${name} PROPERTY AEP_${key} "${value}")
|
# Missing Keyword
|
||||||
|
message(AUTHOR_WARNING "value with no keyword in add_external_project")
|
||||||
endif()
|
endif()
|
||||||
else()
|
endforeach()
|
||||||
message(SEND_ERROR "error: unknown add_external_project key with name='${name}' key='${key}' value='${value}'")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
math(EXPR i ${i}+2)
|
|
||||||
endwhile()
|
|
||||||
|
|
||||||
|
|
||||||
# Set up custom build steps based on the target properties.
|
# Set up custom build steps based on the target properties.
|
||||||
# Each step depends on the previous one.
|
# Each step depends on the previous one.
|
||||||
|
|
|
@ -79,7 +79,7 @@ set(proj EmptyNoOpProject)
|
||||||
add_external_project(${proj}
|
add_external_project(${proj}
|
||||||
BUILD_ARGS ""
|
BUILD_ARGS ""
|
||||||
BUILD_COMMAND ""
|
BUILD_COMMAND ""
|
||||||
CONFIGURE_ARGS ""
|
CMAKE_ARGS ""
|
||||||
CONFIGURE_COMMAND ""
|
CONFIGURE_COMMAND ""
|
||||||
CONFIGURE_DIR ""
|
CONFIGURE_DIR ""
|
||||||
CVS_REPOSITORY ""
|
CVS_REPOSITORY ""
|
||||||
|
@ -87,7 +87,6 @@ add_external_project(${proj}
|
||||||
CVS_TAG ""
|
CVS_TAG ""
|
||||||
DEPENDS "MinimalNoOpProject"
|
DEPENDS "MinimalNoOpProject"
|
||||||
DIR ""
|
DIR ""
|
||||||
DOWNLOAD_ARGS ""
|
|
||||||
DOWNLOAD_COMMAND ""
|
DOWNLOAD_COMMAND ""
|
||||||
INSTALL_ARGS ""
|
INSTALL_ARGS ""
|
||||||
INSTALL_COMMAND ""
|
INSTALL_COMMAND ""
|
||||||
|
@ -97,7 +96,6 @@ add_external_project(${proj}
|
||||||
TAR_URL ""
|
TAR_URL ""
|
||||||
TGZ ""
|
TGZ ""
|
||||||
TGZ_URL ""
|
TGZ_URL ""
|
||||||
UPDATE_ARGS ""
|
|
||||||
UPDATE_COMMAND ""
|
UPDATE_COMMAND ""
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -108,7 +106,7 @@ if(can_build_tutorial_step5)
|
||||||
set(proj TutorialStep5-Local)
|
set(proj TutorialStep5-Local)
|
||||||
add_external_project(${proj}
|
add_external_project(${proj}
|
||||||
DIR "${CMAKE_CURRENT_SOURCE_DIR}/../Tutorial/Step5"
|
DIR "${CMAKE_CURRENT_SOURCE_DIR}/../Tutorial/Step5"
|
||||||
CONFIGURE_ARGS "\"-DCMAKE_INSTALL_PREFIX:PATH=${prefix}\" -G \"${CMAKE_GENERATOR}\" \"${source_dir}/${proj}\""
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix} -G ${CMAKE_GENERATOR} ${source_dir}/${proj}
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
@ -119,14 +117,14 @@ set(proj TutorialStep1-LocalTAR)
|
||||||
add_external_project(${proj}
|
add_external_project(${proj}
|
||||||
TAR "${CMAKE_CURRENT_SOURCE_DIR}/Step1.tar"
|
TAR "${CMAKE_CURRENT_SOURCE_DIR}/Step1.tar"
|
||||||
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
||||||
CONFIGURE_ARGS "\"-DCMAKE_INSTALL_PREFIX:PATH=${prefix}\""
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix}
|
||||||
INSTALL_COMMAND ""
|
INSTALL_COMMAND ""
|
||||||
)
|
)
|
||||||
|
|
||||||
set(proj TutorialStep1-LocalNoDirTAR)
|
set(proj TutorialStep1-LocalNoDirTAR)
|
||||||
add_external_project(${proj}
|
add_external_project(${proj}
|
||||||
TAR "${CMAKE_CURRENT_SOURCE_DIR}/Step1NoDir.tar"
|
TAR "${CMAKE_CURRENT_SOURCE_DIR}/Step1NoDir.tar"
|
||||||
CONFIGURE_ARGS "\"-DCMAKE_INSTALL_PREFIX:PATH=${prefix}\" -G \"${CMAKE_GENERATOR}\" \"${source_dir}/${proj}\""
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix} -G ${CMAKE_GENERATOR} ${source_dir}/${proj}
|
||||||
INSTALL_COMMAND ""
|
INSTALL_COMMAND ""
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -136,7 +134,7 @@ add_external_project(${proj}
|
||||||
set(proj TutorialStep1-LocalTGZ)
|
set(proj TutorialStep1-LocalTGZ)
|
||||||
add_external_project(${proj}
|
add_external_project(${proj}
|
||||||
TGZ "${CMAKE_CURRENT_SOURCE_DIR}/Step1.tgz"
|
TGZ "${CMAKE_CURRENT_SOURCE_DIR}/Step1.tgz"
|
||||||
CONFIGURE_ARGS "\"-DCMAKE_INSTALL_PREFIX:PATH=${prefix}\" -G \"${CMAKE_GENERATOR}\" \"${source_dir}/${proj}\""
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix} -G ${CMAKE_GENERATOR} ${source_dir}/${proj}
|
||||||
INSTALL_COMMAND ""
|
INSTALL_COMMAND ""
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -144,7 +142,7 @@ set(proj TutorialStep1-LocalNoDirTGZ)
|
||||||
add_external_project(${proj}
|
add_external_project(${proj}
|
||||||
TGZ "${CMAKE_CURRENT_SOURCE_DIR}/Step1NoDir.tgz"
|
TGZ "${CMAKE_CURRENT_SOURCE_DIR}/Step1NoDir.tgz"
|
||||||
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
||||||
CONFIGURE_ARGS "\"-DCMAKE_INSTALL_PREFIX:PATH=${prefix}\""
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix}
|
||||||
INSTALL_COMMAND ""
|
INSTALL_COMMAND ""
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -168,9 +166,9 @@ if(can_use_cvs)
|
||||||
add_external_project(${proj}
|
add_external_project(${proj}
|
||||||
CVS_REPOSITORY ":pserver:anonymous:cmake@www.cmake.org:/cvsroot/CMake"
|
CVS_REPOSITORY ":pserver:anonymous:cmake@www.cmake.org:/cvsroot/CMake"
|
||||||
CVS_MODULE "CMake/Tests/Tutorial/Step1"
|
CVS_MODULE "CMake/Tests/Tutorial/Step1"
|
||||||
CVS_TAG "-D\;2008-12-01 01:00:00 UTC"
|
CVS_TAG "-D2008-12-01 01:00:00 UTC"
|
||||||
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
||||||
CONFIGURE_ARGS "\"-DCMAKE_INSTALL_PREFIX:PATH=${prefix}\""
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix}
|
||||||
INSTALL_COMMAND ""
|
INSTALL_COMMAND ""
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -180,9 +178,9 @@ if(can_use_cvs)
|
||||||
add_external_project(${proj}
|
add_external_project(${proj}
|
||||||
CVS_REPOSITORY ":pserver:anonymous:cmake@www.cmake.org:/cvsroot/CMake"
|
CVS_REPOSITORY ":pserver:anonymous:cmake@www.cmake.org:/cvsroot/CMake"
|
||||||
CVS_MODULE "CMake/Source/kwsys"
|
CVS_MODULE "CMake/Source/kwsys"
|
||||||
CVS_TAG "-r\;CMake-2-6-2"
|
CVS_TAG -rCMake-2-6-2
|
||||||
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
||||||
CONFIGURE_ARGS "\"-DCMAKE_INSTALL_PREFIX:PATH=${prefix}\""
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix}
|
||||||
INSTALL_COMMAND ""
|
INSTALL_COMMAND ""
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -194,7 +192,7 @@ if(can_use_cvs)
|
||||||
CVS_REPOSITORY ":pserver:anoncvs@public.kitware.com:/cvsroot/KWStyle"
|
CVS_REPOSITORY ":pserver:anoncvs@public.kitware.com:/cvsroot/KWStyle"
|
||||||
CVS_MODULE "KWStyle"
|
CVS_MODULE "KWStyle"
|
||||||
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
||||||
CONFIGURE_ARGS "\"-DCMAKE_INSTALL_PREFIX:PATH=${prefix}\""
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix}
|
||||||
DEPENDS "EmptyNoOpProject"
|
DEPENDS "EmptyNoOpProject"
|
||||||
DEPENDS "TutorialStep1-LocalTAR"
|
DEPENDS "TutorialStep1-LocalTAR"
|
||||||
DEPENDS "TutorialStep1-LocalNoDirTAR"
|
DEPENDS "TutorialStep1-LocalNoDirTAR"
|
||||||
|
@ -215,9 +213,9 @@ if(can_use_svn)
|
||||||
set(proj gdcm-md5-20081204)
|
set(proj gdcm-md5-20081204)
|
||||||
add_external_project(${proj}
|
add_external_project(${proj}
|
||||||
SVN_REPOSITORY "http://gdcm.svn.sourceforge.net/svnroot/gdcm/trunk/Utilities/gdcmmd5"
|
SVN_REPOSITORY "http://gdcm.svn.sourceforge.net/svnroot/gdcm/trunk/Utilities/gdcmmd5"
|
||||||
SVN_TAG "-r\;{2008-12-04 01:00:00 +0000}"
|
SVN_TAG "-r{2008-12-04 01:00:00 +0000}"
|
||||||
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
||||||
CONFIGURE_ARGS "\"-DCMAKE_INSTALL_PREFIX:PATH=${prefix}\""
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix}
|
||||||
)
|
)
|
||||||
|
|
||||||
# SVN by revision number:
|
# SVN by revision number:
|
||||||
|
@ -225,9 +223,9 @@ if(can_use_svn)
|
||||||
set(proj gdcm-md5-r4824)
|
set(proj gdcm-md5-r4824)
|
||||||
add_external_project(${proj}
|
add_external_project(${proj}
|
||||||
SVN_REPOSITORY "http://gdcm.svn.sourceforge.net/svnroot/gdcm/trunk/Utilities/gdcmmd5"
|
SVN_REPOSITORY "http://gdcm.svn.sourceforge.net/svnroot/gdcm/trunk/Utilities/gdcmmd5"
|
||||||
SVN_TAG "-r\;4824"
|
SVN_TAG "-r4824"
|
||||||
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
||||||
CONFIGURE_ARGS "\"-DCMAKE_INSTALL_PREFIX:PATH=${prefix}\""
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix}
|
||||||
INSTALL_COMMAND ""
|
INSTALL_COMMAND ""
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -237,7 +235,7 @@ if(can_use_svn)
|
||||||
add_external_project(${proj}
|
add_external_project(${proj}
|
||||||
SVN_REPOSITORY "http://gdcm.svn.sourceforge.net/svnroot/gdcm/trunk/Utilities/gdcmmd5"
|
SVN_REPOSITORY "http://gdcm.svn.sourceforge.net/svnroot/gdcm/trunk/Utilities/gdcmmd5"
|
||||||
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
|
||||||
CONFIGURE_ARGS "\"-DCMAKE_INSTALL_PREFIX:PATH=${prefix}\""
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix}
|
||||||
INSTALL_COMMAND ""
|
INSTALL_COMMAND ""
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
Loading…
Reference in New Issue