mirror of
https://github.com/neovim/neovim.git
synced 2025-01-01 17:23:36 -07:00
8404e8df20
This is meant to handle the common case of failing to download libtermkey: FAILED: cd /home/travis/build/neovim/neovim/deps-downloads/libtermkey && /usr/local/cmake-3.12.4/bin/cmake -DPREFIX=/home/travis/nvim-deps/build -DDOWNLOAD_DIR=/home/travis/build/neovim/neovim/deps-downloads/libtermkey -DURL=http://www.leonerd.org.uk/code/libtermkey/libtermkey-0.21.1.tar.gz -DEXPECTED_SHA256=cecbf737f35d18f433c8d7864f63c0f878af41f8bd0255a3ebb16010dc044d5f -DTARGET=libtermkey -DUSE_EXISTING_SRC_DIR=OFF -P /home/travis/build/neovim/neovim/third-party/cmake/DownloadAndExtractFile.cmake && /usr/local/cmake-3.12.4/bin/cmake -E touch /home/travis/nvim-deps/build/src/libtermkey-stamp/libtermkey-download -- file: /home/travis/build/neovim/neovim/deps-downloads/libtermkey/libtermkey-0.21.1.tar.gz -- downloading... src='http://www.leonerd.org.uk/code/libtermkey/libtermkey-0.21.1.tar.gz' dst='/home/travis/build/neovim/neovim/deps-downloads/libtermkey/libtermkey-0.21.1.tar.gz' timeout='none' CMake Error at /home/travis/build/neovim/neovim/third-party/cmake/DownloadAndExtractFile.cmake:77 (message): error: downloading 'http://www.leonerd.org.uk/code/libtermkey/libtermkey-0.21.1.tar.gz' failed status_code: 6 status_string: "Couldn't resolve host name" log: Curl_ipv4_resolve_r failed for www.leonerd.org.uk Couldn't resolve host 'www.leonerd.org.uk' Closing connection 0 Co-Authored-By: Justin M. Keyes <justinkz@gmail.com>
188 lines
5.7 KiB
CMake
188 lines
5.7 KiB
CMake
if(NOT DEFINED PREFIX)
|
|
message(FATAL_ERROR "PREFIX must be defined.")
|
|
endif()
|
|
|
|
if(NOT DEFINED URL)
|
|
message(FATAL_ERROR "URL must be defined.")
|
|
endif()
|
|
|
|
if(NOT DEFINED DOWNLOAD_DIR)
|
|
message(FATAL_ERROR "DOWNLOAD_DIR must be defined.")
|
|
endif()
|
|
|
|
if(NOT DEFINED EXPECTED_SHA256)
|
|
message(FATAL_ERROR "EXPECTED_SHA256 must be defined.")
|
|
endif()
|
|
|
|
if(NOT DEFINED TARGET)
|
|
message(FATAL_ERROR "TARGET must be defined.")
|
|
endif()
|
|
|
|
if(NOT DEFINED SRC_DIR)
|
|
set(SRC_DIR ${PREFIX}/src/${TARGET})
|
|
endif()
|
|
set(BINARY_DIR ${PREFIX}/src/${TARGET}-build)
|
|
|
|
# Check whether the source has been downloaded. If true, skip it.
|
|
# Useful for external downloads like homebrew.
|
|
if(USE_EXISTING_SRC_DIR)
|
|
if(EXISTS "${SRC_DIR}" AND IS_DIRECTORY "${SRC_DIR}")
|
|
file(GLOB EXISTED_FILES "${SRC_DIR}/*")
|
|
if(EXISTED_FILES)
|
|
message(STATUS "${SRC_DIR} is found and not empty, skipping download and extraction. ")
|
|
return()
|
|
endif()
|
|
endif()
|
|
message(FATAL_ERROR "USE_EXISTING_SRC_DIR set to ON, but '${SRC_DIR}' does not exist or is empty.")
|
|
endif()
|
|
|
|
# Taken from ExternalProject_Add. Let's hope we can drop this one day when
|
|
# ExternalProject_Add allows you to disable SHOW_PROGRESS on the file download.
|
|
if(TIMEOUT)
|
|
set(timeout_args TIMEOUT ${timeout})
|
|
set(timeout_msg "${timeout} seconds")
|
|
else()
|
|
set(timeout_args "")
|
|
set(timeout_msg "none")
|
|
endif()
|
|
|
|
string(REGEX MATCH "[^/\\?]*$" fname "${URL}")
|
|
if(NOT "${fname}" MATCHES "(\\.|=)(bz2|tar|tgz|tar\\.gz|zip)$")
|
|
string(REGEX MATCH "([^/\\?]+(\\.|=)(bz2|tar|tgz|tar\\.gz|zip))/.*$" match_result "${URL}")
|
|
set(fname "${CMAKE_MATCH_1}")
|
|
endif()
|
|
if(NOT "${fname}" MATCHES "(\\.|=)(bz2|tar|tgz|tar\\.gz|zip)$")
|
|
message(FATAL_ERROR "Could not extract tarball filename from url:\n ${url}")
|
|
endif()
|
|
string(REPLACE ";" "-" fname "${fname}")
|
|
|
|
set(file ${DOWNLOAD_DIR}/${fname})
|
|
message(STATUS "file: ${file}")
|
|
|
|
message(STATUS "downloading...
|
|
src='${URL}'
|
|
dst='${file}'
|
|
timeout='${timeout_msg}'")
|
|
|
|
file(DOWNLOAD ${URL} ${file}
|
|
${timeout_args}
|
|
${hash_args}
|
|
STATUS status
|
|
LOG log)
|
|
|
|
list(GET status 0 status_code)
|
|
list(GET status 1 status_string)
|
|
|
|
if(NOT status_code EQUAL 0)
|
|
# Retry on certain errors, e.g. CURLE_COULDNT_RESOLVE_HOST, which is often
|
|
# seen with libtermkey (www.leonerd.org.uk).
|
|
if(status_code EQUAL 6) # "Couldn't resolve host name"
|
|
message(STATUS "warning: retrying '${URL}' (${status_string}, status ${status_code})")
|
|
execute_process(COMMAND ${CMAKE_COMMAND} -E sleep 10)
|
|
file(DOWNLOAD ${URL} ${file}
|
|
${timeout_args}
|
|
${hash_args}
|
|
STATUS status
|
|
LOG log)
|
|
list(GET status 0 status_code)
|
|
list(GET status 1 status_string)
|
|
endif()
|
|
if(NOT status_code EQUAL 0)
|
|
message(FATAL_ERROR "error: downloading '${URL}' failed
|
|
status_code: ${status_code}
|
|
status_string: ${status_string}
|
|
log: ${log}
|
|
")
|
|
endif()
|
|
endif()
|
|
|
|
set(NULL_SHA256 "0000000000000000000000000000000000000000000000000000000000000000")
|
|
|
|
# Allow users to use "SKIP" or "skip" as the sha256 to skip checking the hash.
|
|
# You can still use the all zeros hash too.
|
|
if((EXPECTED_SHA256 STREQUAL "SKIP") OR (EXPECTED_SHA256 STREQUAL "skip"))
|
|
set(EXPECTED_SHA256 ${NULL_SHA256})
|
|
endif()
|
|
|
|
# We could avoid computing the SHA256 entirely if a NULL_SHA256 was given,
|
|
# but we want to warn users of an empty file.
|
|
file(SHA256 ${file} ACTUAL_SHA256)
|
|
if(ACTUAL_SHA256 STREQUAL "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855")
|
|
# File was empty. It's likely due to lack of SSL support.
|
|
message(FATAL_ERROR
|
|
"Failed to download ${URL}. The file is empty and likely means CMake "
|
|
"was built without SSL support. Please use a version of CMake with "
|
|
"proper SSL support. See "
|
|
"https://github.com/neovim/neovim/wiki/Building-Neovim#build-prerequisites "
|
|
"for more information.")
|
|
elseif((NOT EXPECTED_SHA256 STREQUAL NULL_SHA256) AND
|
|
(NOT EXPECTED_SHA256 STREQUAL ACTUAL_SHA256))
|
|
# Wasn't a NULL SHA256 and we didn't match, so we fail.
|
|
message(FATAL_ERROR
|
|
"Failed to download ${URL}. Expected a SHA256 of "
|
|
"${EXPECTED_SHA256} but got ${ACTUAL_SHA256} instead.")
|
|
endif()
|
|
|
|
message(STATUS "downloading... done")
|
|
|
|
# Slurped from a generated extract-TARGET.cmake file.
|
|
message(STATUS "extracting...
|
|
src='${file}'
|
|
dst='${SRC_DIR}'")
|
|
|
|
if(NOT EXISTS "${file}")
|
|
message(FATAL_ERROR "error: file to extract does not exist: '${file}'")
|
|
endif()
|
|
|
|
# Prepare a space for extracting:
|
|
#
|
|
set(i 1234)
|
|
while(EXISTS "${SRC_DIR}/../ex-${TARGET}${i}")
|
|
math(EXPR i "${i} + 1")
|
|
endwhile()
|
|
set(ut_dir "${SRC_DIR}/../ex-${TARGET}${i}")
|
|
file(MAKE_DIRECTORY "${ut_dir}")
|
|
|
|
# Extract it:
|
|
#
|
|
message(STATUS "extracting... [tar xfz]")
|
|
execute_process(COMMAND ${CMAKE_COMMAND} -E tar xfz ${file}
|
|
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 '${file}' 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()
|
|
|
|
# Move "the one" directory to the final directory:
|
|
#
|
|
message(STATUS "extracting... [rename]")
|
|
file(REMOVE_RECURSE ${SRC_DIR})
|
|
get_filename_component(contents ${contents} ABSOLUTE)
|
|
file(RENAME ${contents} ${SRC_DIR})
|
|
|
|
# Remove any existing BINARY_DIR, to force a new build.
|
|
# Without this a necessary output (e.g. libluv.a) might not be updated/installed.
|
|
#
|
|
message(STATUS "extracting... [clean binary dir]")
|
|
file(REMOVE_RECURSE ${BINARY_DIR})
|
|
file(MAKE_DIRECTORY ${BINARY_DIR})
|
|
|
|
# Clean up:
|
|
#
|
|
message(STATUS "extracting... [clean up]")
|
|
file(REMOVE_RECURSE "${ut_dir}")
|
|
|
|
message(STATUS "extracting... done")
|