summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Modules/DownloadFile.cmake31
-rw-r--r--Modules/ExternalProject.cmake133
-rw-r--r--Modules/UntarFile.cmake83
3 files changed, 130 insertions, 117 deletions
diff --git a/Modules/DownloadFile.cmake b/Modules/DownloadFile.cmake
deleted file mode 100644
index db45db9..0000000
--- a/Modules/DownloadFile.cmake
+++ /dev/null
@@ -1,31 +0,0 @@
-#
-# Use 'cmake -Dremote=${url} -Dlocal=${filename} -Dtimeout=${seconds}
-# -P DownloadFile.cmake' to call this script...
-#
-if(NOT DEFINED remote)
- message(FATAL_ERROR "error: required variable 'remote' not defined...")
-endif()
-
-if(NOT DEFINED local)
- message(FATAL_ERROR "error: required variable 'local' not defined...")
-endif()
-
-if(NOT DEFINED timeout)
- set(timeout 30)
-endif(NOT DEFINED timeout)
-
-message(STATUS "info: downloading '${remote}'...")
-file(DOWNLOAD "${remote}" "${local}" TIMEOUT ${timeout} STATUS status LOG log)
-
-list(GET status 0 status_code)
-list(GET status 1 status_string)
-
-if(NOT status_code EQUAL 0)
- message(FATAL_ERROR "error: download of '${remote}' failed
-status_code: ${status_code}
-status_string: ${status_string}
-log: ${log}
-")
-endif()
-
-message(STATUS "info: done downloading '${remote}'...")
diff --git a/Modules/ExternalProject.cmake b/Modules/ExternalProject.cmake
index 1adcd79..eab83de 100644
--- a/Modules/ExternalProject.cmake
+++ b/Modules/ExternalProject.cmake
@@ -54,7 +54,7 @@
# BINARY_DIR = <base>/Build/<name>
# INSTALL_DIR = <base>/Install/<name>
# If no PREFIX, EP_PREFIX, or EP_BASE is specified then the default
-# is to set PREIFX to "<name>-prefix".
+# is to set PREFIX to "<name>-prefix".
# Relative paths are interpreted with respect to the build directory
# corresponding to the source directory in which ep_add is invoked.
#
@@ -88,6 +88,7 @@
# It stores property values in variables of the same name.
# Property names correspond to the keyword argument names of 'ep_add'.
+
# Pre-compute a regex to match documented keywords for each command.
file(STRINGS "${CMAKE_CURRENT_LIST_FILE}" lines LIMIT_COUNT 100
REGEX "^# ( \\[[A-Z_]+ [^]]*\\] +#.*$|[a-z_]+\\()")
@@ -112,6 +113,7 @@ if(_ep_func)
set(_ep_keywords_${_ep_func} "${_ep_keywords_${_ep_func}})$")
endif()
+
function(_ep_parse_arguments f name ns args)
# Transfer the arguments to this function into target properties for the
# new custom target we just added so that we can set up all the build steps
@@ -164,6 +166,7 @@ function(_ep_parse_arguments f name ns args)
endforeach()
endfunction(_ep_parse_arguments)
+
define_property(DIRECTORY PROPERTY "EP_BASE" INHERITED
BRIEF_DOCS "Base directory for External Project storage."
FULL_DOCS
@@ -178,6 +181,121 @@ define_property(DIRECTORY PROPERTY "EP_PREFIX" INHERITED
"ExternalProject module."
)
+
+function(_ep_write_downloadfile_script script_filename remote local timeout)
+ if(NOT timeout)
+ set(timeout 30)
+ endif()
+
+ file(WRITE ${script_filename}
+"message(STATUS \"downloading...
+ src='${remote}'
+ dst='${local}'\")
+
+file(DOWNLOAD
+ \"${remote}\"
+ \"${local}\"
+ TIMEOUT ${timeout}
+ STATUS status
+ LOG log)
+
+list(GET status 0 status_code)
+list(GET status 1 status_string)
+
+if(NOT status_code EQUAL 0)
+ message(FATAL_ERROR \"error: downloading '${remote}' failed
+ status_code: \${status_code}
+ status_string: \${status_string}
+ log: \${log}
+\")
+endif()
+
+message(STATUS \"downloading... done\")
+"
+)
+
+endfunction(_ep_write_downloadfile_script)
+
+
+function(_ep_write_extractfile_script script_filename filename tmp directory)
+ set(args "")
+
+ if(filename MATCHES ".tar$")
+ set(args xf)
+ endif()
+
+ if(filename MATCHES ".tgz$")
+ set(args xfz)
+ endif()
+
+ if(filename MATCHES ".tar.gz$")
+ set(args xfz)
+ endif()
+
+ if(args STREQUAL "")
+ message(SEND_ERROR "error: do not know how to extract '${filename}' -- known types are .tar, .tgz and .tar.gz")
+ return()
+ endif()
+
+ file(WRITE ${script_filename}
+"# Make file names absolute:
+#
+get_filename_component(filename \"${filename}\" ABSOLUTE)
+get_filename_component(tmp \"${tmp}\" ABSOLUTE)
+get_filename_component(directory \"${directory}\" ABSOLUTE)
+
+message(STATUS \"extracting...
+ src='\${filename}'
+ dst='\${directory}'\")
+
+# Prepare a space for extracting:
+#
+set(i 1)
+while(EXISTS \"\${tmp}/extract\${i}\")
+ math(EXPR i \"\${i} + 1\")
+endwhile()
+set(ut_dir \"\${tmp}/extract\${i}\")
+file(MAKE_DIRECTORY \"\${ut_dir}\")
+
+# Extract it:
+#
+message(STATUS \"extracting... [tar ${args}]\")
+execute_process(COMMAND \${CMAKE_COMMAND} -E tar ${args} \${filename}
+ WORKING_DIRECTORY \${ut_dir}
+ RESULT_VARIABLE rv)
+
+if(NOT rv EQUAL 0)
+ message(STATUS \"extracting... [error clean up]\")
+ file(REMOVE_RECURSE \"\${ut_dir}\")
+ message(FATAL_ERROR \"error: extract of '\${filename}' failed\")
+endif()
+
+# Analyze what came out of the tar file:
+#
+message(STATUS \"extracting... [analysis]\")
+file(GLOB contents \"\${ut_dir}/*\")
+list(LENGTH contents n)
+if(NOT n EQUAL 1 OR NOT IS_DIRECTORY \"\${contents}\")
+ set(contents \"\${ut_dir}\")
+endif()
+
+# Copy \"the one\" directory to the final directory:
+#
+message(STATUS \"extracting... [copy]\")
+file(COPY \"\${contents}/\" DESTINATION \${directory})
+
+# Clean up:
+#
+message(STATUS \"extracting... [clean up]\")
+file(REMOVE_RECURSE \"\${ut_dir}\")
+
+message(STATUS \"extracting... done\")
+"
+)
+
+endfunction(_ep_write_extractfile_script)
+
+
function(_ep_set_directories name)
get_property(prefix TARGET ${name} PROPERTY _EP_PREFIX)
if(NOT prefix)
@@ -248,6 +366,7 @@ function(_ep_set_directories name)
endforeach()
endfunction(_ep_set_directories)
+
function(ep_get name)
foreach(var ${ARGN})
string(TOUPPER "${var}" VAR)
@@ -259,6 +378,7 @@ function(ep_get name)
endforeach()
endfunction(ep_get)
+
function(_ep_get_configure_command_id name cfg_cmd_id_var)
get_target_property(cmd ${name} _EP_CONFIGURE_COMMAND)
@@ -284,6 +404,7 @@ function(_ep_get_configure_command_id name cfg_cmd_id_var)
endif()
endfunction(_ep_get_configure_command_id)
+
function(_ep_get_build_command name step cmd_var)
set(cmd "${${cmd_var}}")
if(NOT cmd)
@@ -332,6 +453,7 @@ function(_ep_get_build_command name step cmd_var)
set(${cmd_var} "${cmd}" PARENT_SCOPE)
endfunction(_ep_get_build_command)
+
function(ep_add_step name step)
set(cmf_dir ${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles)
ep_get(${name} stamp_dir)
@@ -412,6 +534,7 @@ function(ep_add_step name step)
)
endfunction(ep_add_step)
+
function(_ep_add_mkdir_command name)
ep_get(${name}
source_dir binary_dir install_dir stamp_dir download_dir tmp_dir)
@@ -426,6 +549,7 @@ function(_ep_add_mkdir_command name)
)
endfunction(_ep_add_mkdir_command)
+
function(_ep_add_download_command name)
ep_get(${name} source_dir stamp_dir download_dir tmp_dir)
@@ -517,7 +641,8 @@ function(_ep_add_download_command name)
message(FATAL_ERROR "Could not extract tarball filename from url:\n ${url}")
endif()
set(file ${download_dir}/${fname})
- set(cmd ${CMAKE_COMMAND} -Dremote=${url} -Dlocal=${file} -P ${CMAKE_ROOT}/Modules/DownloadFile.cmake
+ _ep_write_downloadfile_script("${stamp_dir}/download-${name}.cmake" "${url}" "${file}")
+ set(cmd ${CMAKE_COMMAND} -P ${stamp_dir}/download-${name}.cmake
COMMAND)
set(comment "Performing download step (download and extract) for '${name}'")
else()
@@ -525,7 +650,8 @@ function(_ep_add_download_command name)
set(comment "Performing download step (extract) for '${name}'")
endif()
# TODO: Support other archive formats.
- list(APPEND cmd ${CMAKE_COMMAND} -Dfilename=${file} -Dtmp=${tmp_dir} -Ddirectory=${source_dir} -P ${CMAKE_ROOT}/Modules/UntarFile.cmake)
+ _ep_write_extractfile_script("${stamp_dir}/extract-${name}.cmake" "${file}" "${tmp_dir}" "${source_dir}")
+ list(APPEND cmd ${CMAKE_COMMAND} -P ${stamp_dir}/extract-${name}.cmake)
endif()
else()
message(SEND_ERROR "error: no download info for '${name}'")
@@ -679,6 +805,7 @@ function(_ep_add_install_command name)
)
endfunction(_ep_add_install_command)
+
function(ep_add name)
# Add a custom target for the external project.
set(cmf_dir ${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles)
diff --git a/Modules/UntarFile.cmake b/Modules/UntarFile.cmake
deleted file mode 100644
index df33db8..0000000
--- a/Modules/UntarFile.cmake
+++ /dev/null
@@ -1,83 +0,0 @@
-#
-# Use 'cmake -Dfilename=${tar_or_tgz_file} -Dtmp=${tmp_directory} -Ddirectory=${final_directory}
-# -P UntarFile.cmake' to call this script...
-#
-if(NOT DEFINED filename)
- message(FATAL_ERROR "error: required variable 'filename' not defined...")
-endif()
-
-if(NOT DEFINED tmp)
- message(FATAL_ERROR "error: required variable 'tmp' not defined...")
-endif()
-
-if(NOT DEFINED directory)
- message(FATAL_ERROR "error: required variable 'directory' not defined...")
-endif()
-
-if(NOT DEFINED args)
- if(filename MATCHES ".tar$")
- set(args xf)
- endif()
-
- if(filename MATCHES ".tgz$")
- set(args xfz)
- endif()
-
- if(filename MATCHES ".tar.gz$")
- set(args xfz)
- endif()
-endif()
-
-
-# Make file names absolute:
-#
-get_filename_component(filename "${filename}" ABSOLUTE)
-get_filename_component(tmp "${tmp}" ABSOLUTE)
-get_filename_component(directory "${directory}" ABSOLUTE)
-message(STATUS "filename='${filename}'")
-message(STATUS "tmp='${tmp}'")
-message(STATUS "directory='${directory}'")
-
-
-# Prepare a space for untarring:
-#
-#message(STATUS "info: creating empty subdir of '${tmp}'...")
-set(i 1)
-while(EXISTS "${tmp}/untar${i}")
- math(EXPR i "${i} + 1")
-endwhile()
-set(ut_dir "${tmp}/untar${i}")
-message(STATUS "ut_dir='${ut_dir}'")
-file(MAKE_DIRECTORY "${ut_dir}")
-
-
-# Untar it:
-#
-#message(STATUS "info: untarring '${filename}' in '${ut_dir}' with '${args}'...")
-execute_process(COMMAND ${CMAKE_COMMAND} -E tar ${args} ${filename}
- WORKING_DIRECTORY ${ut_dir}
- RESULT_VARIABLE rv)
-
-if(NOT rv EQUAL 0)
- file(REMOVE_RECURSE "${ut_dir}")
- message(FATAL_ERROR "error: untar of '${filename}' failed")
-endif()
-
-
-# Analyze what came out of the tar file:
-#
-file(GLOB contents "${ut_dir}/*")
-list(LENGTH contents n)
-if(NOT n EQUAL 1 OR NOT IS_DIRECTORY "${contents}")
- set(contents "${ut_dir}")
-endif()
-
-
-# Copy "the one" directory to the final directory:
-#
-file(COPY "${contents}/" DESTINATION ${directory})
-
-
-# Clean up:
-#
-file(REMOVE_RECURSE "${ut_dir}")