summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2009-03-18 15:01:02 (GMT)
committerBrad King <brad.king@kitware.com>2009-03-18 15:01:02 (GMT)
commit2cc46c12f8d1a9b37a24e0cdcb0f31b8a0a8d6ae (patch)
treeeae24e7fe267784667bebe9799a1cf66ab5d02f0
parent6ae0ff626a67a2a81481bf127d07543d1f0cca16 (diff)
downloadCMake-2cc46c12f8d1a9b37a24e0cdcb0f31b8a0a8d6ae.zip
CMake-2cc46c12f8d1a9b37a24e0cdcb0f31b8a0a8d6ae.tar.gz
CMake-2cc46c12f8d1a9b37a24e0cdcb0f31b8a0a8d6ae.tar.bz2
ENH: Add patch step for add_external_project
The patch step runs parallel to the update step since it does not make sense to have both. Configuration of the step requires specification of a PATCH_COMMAND argument to add_external_project.
-rw-r--r--Modules/AddExternalProject.cmake32
-rw-r--r--Tests/ExternalProject/CMakeLists.txt4
-rw-r--r--Tests/ExternalProject/Step1Patch.cmake21
3 files changed, 56 insertions, 1 deletions
diff --git a/Modules/AddExternalProject.cmake b/Modules/AddExternalProject.cmake
index b89f64e..eaf4c88 100644
--- a/Modules/AddExternalProject.cmake
+++ b/Modules/AddExternalProject.cmake
@@ -448,6 +448,35 @@ function(add_external_project_update_command name)
endfunction(add_external_project_update_command)
+function(add_external_project_patch_command name)
+ get_external_project_directories(base_dir build_dir downloads_dir install_dir
+ sentinels_dir source_dir tmp_dir)
+
+ get_target_property(cmd ${name} AEP_PATCH_COMMAND)
+ if(cmd)
+ add_custom_command(
+ OUTPUT ${sentinels_dir}/${name}-patch
+ COMMAND ${cmd}
+ COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-patch
+ WORKING_DIRECTORY ${source_dir}/${name}
+ COMMENT "Performing patch step for '${name}'"
+ DEPENDS ${sentinels_dir}/${name}-download
+ VERBATIM
+ )
+ return()
+ endif()
+
+ add_custom_command(
+ OUTPUT ${sentinels_dir}/${name}-patch
+ COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-patch
+ WORKING_DIRECTORY ${sentinels_dir}
+ COMMENT "No patch step for '${name}'"
+ DEPENDS ${sentinels_dir}/${name}-download
+ VERBATIM
+ )
+endfunction(add_external_project_patch_command)
+
+
function(add_external_project_configure_command name)
get_external_project_directories(base_dir build_dir downloads_dir install_dir
sentinels_dir source_dir tmp_dir)
@@ -464,6 +493,7 @@ function(add_external_project_configure_command name)
COMMAND ${CMAKE_COMMAND} -E make_directory ${working_dir}
COMMAND ${CMAKE_COMMAND} -E touch ${sentinels_dir}/${name}-working_dir
DEPENDS ${sentinels_dir}/${name}-update
+ ${sentinels_dir}/${name}-patch
${file_deps}
VERBATIM
)
@@ -635,6 +665,7 @@ foreach(key IN ITEMS
DOWNLOAD_COMMAND
INSTALL_ARGS
INSTALL_COMMAND
+ PATCH_COMMAND
SVN_REPOSITORY
SVN_TAG
TAR
@@ -721,6 +752,7 @@ function(add_external_project name)
#
add_external_project_download_command(${name})
add_external_project_update_command(${name})
+ add_external_project_patch_command(${name})
add_external_project_configure_command(${name})
add_external_project_build_command(${name})
add_external_project_install_command(${name})
diff --git a/Tests/ExternalProject/CMakeLists.txt b/Tests/ExternalProject/CMakeLists.txt
index 856a713..813cd4d 100644
--- a/Tests/ExternalProject/CMakeLists.txt
+++ b/Tests/ExternalProject/CMakeLists.txt
@@ -90,6 +90,7 @@ add_external_project(${proj}
DOWNLOAD_COMMAND ""
INSTALL_ARGS ""
INSTALL_COMMAND ""
+ PATCH_COMMAND ""
SVN_REPOSITORY ""
SVN_TAG ""
TAR ""
@@ -116,6 +117,7 @@ endif()
set(proj TutorialStep1-LocalTAR)
add_external_project(${proj}
TAR "${CMAKE_CURRENT_SOURCE_DIR}/Step1.tar"
+ PATCH_COMMAND ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_SOURCE_DIR}/Step1Patch.cmake
CMAKE_GENERATOR "${CMAKE_GENERATOR}"
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${prefix}
INSTALL_COMMAND ""
@@ -263,7 +265,7 @@ if(can_build_tutorial_step5)
endif()
add_test(TutorialStep1-LocalTAR-BuildTreeTest
- "${build_dir}/TutorialStep1-LocalTAR/Tutorial" 36)
+ "${build_dir}/TutorialStep1-LocalTAR/EP-Tutorial" 36)
add_test(TutorialStep1-LocalNoDirTAR-BuildTreeTest
"${build_dir}/TutorialStep1-LocalNoDirTAR/Tutorial" 25)
diff --git a/Tests/ExternalProject/Step1Patch.cmake b/Tests/ExternalProject/Step1Patch.cmake
new file mode 100644
index 0000000..1a1920a
--- /dev/null
+++ b/Tests/ExternalProject/Step1Patch.cmake
@@ -0,0 +1,21 @@
+# Verify the current working directory.
+if(NOT EXISTS CMakeLists.txt)
+ message(FATAL_ERROR "File does not exist:\n ${CMAKE_CURRENT_SOURCE_DIR}/CMakeLists.txt")
+endif()
+if(NOT EXISTS tutorial.cxx)
+ message(FATAL_ERROR "File does not exist:\n ${CMAKE_CURRENT_SOURCE_DIR}/tutorial.cxx")
+endif()
+
+# Check if the patch is already applied.
+file(STRINGS CMakeLists.txt prop_line REGEX "^set_property")
+if(prop_line)
+ message(STATUS "Patch already applied!")
+ return()
+endif()
+
+# Apply the patch.
+file(APPEND CMakeLists.txt "
+# Patch by ExternalProject test:
+set_property(TARGET Tutorial PROPERTY OUTPUT_NAME EP-Tutorial)
+")
+message(STATUS "Patched ${CMAKE_CURRENT_SOURCE_DIR}/CMakeLists.txt")