diff options
author | Brad King <brad.king@kitware.com> | 2009-03-30 15:36:32 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2009-03-30 15:36:32 (GMT) |
commit | d2175580e746b8ed07a35efe8c13f8518e9127ff (patch) | |
tree | 2197cd7225ba1bc8ab7279ef520409c667c197f8 /Modules/AddExternalProject.cmake | |
parent | c45c862ef4c3689d7d01af5ff3a54efa2ea0d922 (diff) | |
download | CMake-d2175580e746b8ed07a35efe8c13f8518e9127ff.zip CMake-d2175580e746b8ed07a35efe8c13f8518e9127ff.tar.gz CMake-d2175580e746b8ed07a35efe8c13f8518e9127ff.tar.bz2 |
ENH: Generalize AddExternalProject step creation
This creates function 'add_external_project_step' to centralize creation
of external project steps. Users may call it to add custom steps to
external project builds.
Diffstat (limited to 'Modules/AddExternalProject.cmake')
-rw-r--r-- | Modules/AddExternalProject.cmake | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/Modules/AddExternalProject.cmake b/Modules/AddExternalProject.cmake index b67da84..1c28c82 100644 --- a/Modules/AddExternalProject.cmake +++ b/Modules/AddExternalProject.cmake @@ -15,6 +15,7 @@ function(_aep_parse_arguments f name ns args) set(key) foreach(arg IN LISTS args) if(arg MATCHES "^[A-Z][A-Z_][A-Z_]+$" AND + NOT ((arg STREQUAL "${key}") AND (key STREQUAL "COMMAND")) AND NOT arg MATCHES "^(TRUE|FALSE)$") # Keyword set(key "${arg}") @@ -158,6 +159,87 @@ function(mkdir d) endif() endfunction(mkdir) +# Pre-compute a regex to match known keywords. +set(_aep_keyword_regex "^(") +set(_aep_keyword_sep) +foreach(key IN ITEMS + COMMAND + COMMENT + DEPENDEES + DEPENDERS + DEPENDS + SYMBOLIC + WORKING_DIRECTORY + ) + set(_aep_keyword_regex "${_aep_keyword_regex}${_aep_keyword_sep}${key}") + set(_aep_keyword_sep "|") +endforeach(key) +set(_aep_keyword_regex "${_aep_keyword_regex})$") +set(_aep_keyword_sep) +set(_aep_keywords_add_external_project_step "${_aep_keyword_regex}") + +function(add_external_project_step name step) + get_external_project_directories(base_dir build_dir downloads_dir install_dir + sentinels_dir source_dir tmp_dir) + add_custom_command(APPEND + OUTPUT ${sentinels_dir}/${name}-complete + DEPENDS ${sentinels_dir}/${name}-${step} + ) + _aep_parse_arguments(add_external_project_step + ${name} AEP_${step}_ "${ARGN}") + + # Steps depending on this step. + get_property(dependers TARGET ${name} PROPERTY AEP_${step}_DEPENDERS) + foreach(depender IN LISTS dependers) + add_custom_command(APPEND + OUTPUT ${sentinels_dir}/${name}-${depender} + DEPENDS ${sentinels_dir}/${name}-${step} + ) + endforeach() + + # Dependencies on files. + get_property(depends TARGET ${name} PROPERTY AEP_${step}_DEPENDS) + + # Dependencies on steps. + get_property(dependees TARGET ${name} PROPERTY AEP_${step}_DEPENDEES) + foreach(dependee IN LISTS dependees) + list(APPEND depends ${sentinels_dir}/${name}-${dependee}) + endforeach() + + # The command to run. + get_property(command TARGET ${name} PROPERTY AEP_${step}_COMMAND) + if(command) + set(comment "Performing ${step} step for '${name}'") + else() + set(comment "No ${step} step for '${name}'") + endif() + get_property(work_dir TARGET ${name} PROPERTY AEP_${step}_WORKING_DIRECTORY) + + # Custom comment? + get_property(comment_set TARGET ${name} PROPERTY AEP_${step}_COMMENT SET) + if(comment_set) + get_property(comment TARGET ${name} PROPERTY AEP_${step}_COMMENT) + endif() + + # Run every time? + get_property(symbolic TARGET ${name} PROPERTY AEP_${step}_SYMBOLIC) + if(symbolic) + set_property(SOURCE ${sentinels_dir}/${name}-${step} PROPERTY SYMBOLIC 1) + set(touch) + else() + set(touch ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-${step}) + endif() + + add_custom_command( + OUTPUT ${sentinels_dir}/${name}-${step} + COMMENT ${comment} + COMMAND ${command} + COMMAND ${touch} + DEPENDS ${depends} + WORKING_DIRECTORY ${work_dir} + VERBATIM + ) +endfunction(add_external_project_step) function(add_external_project_download_command name) get_external_project_directories(base_dir build_dir downloads_dir install_dir |