aboutsummaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorPhil Christensen <philc@microsoft.com>2019-07-01 22:39:51 -0700
committerGitHub <noreply@github.com>2019-07-01 22:39:51 -0700
commitd2b3ef9e88fcb51b7273a76abe6e78d49d73a329 (patch)
tree7caa67f5cd823dff6d4edf750e871e3ce2c526e8 /scripts
parent012e9931ebf5ccb6ba51a3f0f98431c278154efa (diff)
downloadvcpkg-d2b3ef9e88fcb51b7273a76abe6e78d49d73a329.tar.gz
vcpkg-d2b3ef9e88fcb51b7273a76abe6e78d49d73a329.zip
Fix vcpkg_from_git (#7082)
* [vcpkg_from_git/fdlibm] Fix flaky sha256 issues * [doc] regenerate docs
Diffstat (limited to 'scripts')
-rw-r--r--scripts/cmake/vcpkg_from_git.cmake61
1 files changed, 29 insertions, 32 deletions
diff --git a/scripts/cmake/vcpkg_from_git.cmake b/scripts/cmake/vcpkg_from_git.cmake
index 2fc66b279..0db818f80 100644
--- a/scripts/cmake/vcpkg_from_git.cmake
+++ b/scripts/cmake/vcpkg_from_git.cmake
@@ -8,7 +8,6 @@
## OUT_SOURCE_PATH <SOURCE_PATH>
## URL <https://android.googlesource.com/platform/external/fdlibm>
## REF <59f7335e4d...>
-## SHA512 <abcdef123...>
## [PATCHES <patch1.patch> <patch2.patch>...]
## )
## ```
@@ -20,17 +19,10 @@
## This should be set to `SOURCE_PATH` by convention.
##
## ### URL
-## The url of the git repository.
-##
-## ### SHA512
-## The SHA512 hash that should match the archive form of the commit.
-##
-## This is most easily determined by first setting it to `0`, then trying to build the port. The error message will contain the full hash, which can be copied back into the portfile.
+## The url of the git repository. Must start with `https`.
##
## ### REF
-## A stable git commit-ish (ideally a tag or commit) that will not change contents. **This should not be a branch.**
-##
-## For repositories without official releases, this can be set to the full commit id of the current latest master.
+## The git sha of the commit to download.
##
## ### PATCHES
## A list of patches to be applied to the extracted sources.
@@ -38,14 +30,14 @@
## Relative paths are based on the port directory.
##
## ## Notes:
-## `OUT_SOURCE_PATH`, `REF`, `SHA512`, and `URL` must be specified.
+## `OUT_SOURCE_PATH`, `REF`, and `URL` must be specified.
##
## ## Examples:
##
## * [fdlibm](https://github.com/Microsoft/vcpkg/blob/master/ports/fdlibm/portfile.cmake)
function(vcpkg_from_git)
- set(oneValueArgs OUT_SOURCE_PATH URL REF SHA512)
+ set(oneValueArgs OUT_SOURCE_PATH URL REF)
set(multipleValuesArgs PATCHES)
cmake_parse_arguments(_vdud "" "${oneValueArgs}" "${multipleValuesArgs}" ${ARGN})
@@ -57,12 +49,15 @@ function(vcpkg_from_git)
message(FATAL_ERROR "The git url must be specified")
endif()
- if(NOT DEFINED _vdud_REF)
- message(FATAL_ERROR "The git ref must be specified.")
+ if( NOT _vdud_URL MATCHES "^https:")
+ # vcpkg_from_git does not support a SHA256 parameter because hashing the git archive is
+ # not stable across all supported platforms. The tradeoff is to require https to download
+ # and the ref to be the git sha (i.e. not things that can change like a label)
+ message(FATAL_ERROR "The git url must be https")
endif()
- if(NOT DEFINED _vdud_SHA512)
- message(FATAL_ERROR "vcpkg_from_git requires a SHA512 argument. If you do not know the SHA512, add it as 'SHA512 0' and re-run this command.")
+ if(NOT DEFINED _vdud_REF)
+ message(FATAL_ERROR "The git ref must be specified.")
endif()
# using .tar.gz instead of .zip because the hash of the latter is affected by timezone.
@@ -71,18 +66,6 @@ function(vcpkg_from_git)
set(ARCHIVE "${DOWNLOADS}/${PORT}-${SANITIZED_REF}.tar.gz")
set(TEMP_SOURCE_PATH "${CURRENT_BUILDTREES_DIR}/src/${SANITIZED_REF}")
- function(test_hash FILE_PATH FILE_KIND CUSTOM_ERROR_ADVICE)
- file(SHA512 ${FILE_PATH} FILE_HASH)
- if(NOT FILE_HASH STREQUAL _vdud_SHA512)
- message(FATAL_ERROR
- "\nFile does not have expected hash:\n"
- " File path: [ ${FILE_PATH} ]\n"
- " Expected hash: [ ${_vdud_SHA512} ]\n"
- " Actual hash: [ ${FILE_HASH} ]\n"
- "${CUSTOM_ERROR_ADVICE}\n")
- endif()
- endfunction()
-
if(NOT EXISTS "${ARCHIVE}")
if(_VCPKG_NO_DOWNLOADS)
message(FATAL_ERROR "Downloads are disabled, but '${ARCHIVE}' does not exist.")
@@ -93,26 +76,40 @@ function(vcpkg_from_git)
vcpkg_execute_required_process(
COMMAND ${GIT} init git-tmp
WORKING_DIRECTORY ${DOWNLOADS}
- LOGNAME git-init
+ LOGNAME git-init-${TARGET_TRIPLET}
)
vcpkg_execute_required_process(
COMMAND ${GIT} fetch ${_vdud_URL} ${_vdud_REF} --depth 1 -n
WORKING_DIRECTORY ${DOWNLOADS}/git-tmp
- LOGNAME git-fetch
+ LOGNAME git-fetch-${TARGET_TRIPLET}
+ )
+ execute_process(
+ COMMAND ${GIT} rev-parse FETCH_HEAD
+ OUTPUT_VARIABLE REV_PARSE_HEAD
+ ERROR_VARIABLE REV_PARSE_HEAD
+ RESULT_VARIABLE error_code
+ WORKING_DIRECTORY ${DOWNLOADS}/git-tmp
)
+ if(error_code)
+ message(FATAL_ERROR "unable to determine FETCH_HEAD after fetching git repository")
+ endif()
+ string(REGEX REPLACE "\n$" "" REV_PARSE_HEAD "${REV_PARSE_HEAD}")
+ if(NOT REV_PARSE_HEAD STREQUAL _vdud_REF)
+ message(FATAL_ERROR "REF (${_vdud_REF}) does not match FETCH_HEAD (${REV_PARSE_HEAD})")
+ endif()
+
file(MAKE_DIRECTORY "${DOWNLOADS}/temp")
vcpkg_execute_required_process(
COMMAND ${GIT} archive FETCH_HEAD -o "${TEMP_ARCHIVE}"
WORKING_DIRECTORY ${DOWNLOADS}/git-tmp
LOGNAME git-archive
)
- test_hash("${TEMP_ARCHIVE}" "downloaded repo" "")
+
get_filename_component(downloaded_file_dir "${ARCHIVE}" DIRECTORY)
file(MAKE_DIRECTORY "${downloaded_file_dir}")
file(RENAME "${TEMP_ARCHIVE}" "${ARCHIVE}")
else()
message(STATUS "Using cached ${ARCHIVE}")
- test_hash("${ARCHIVE}" "cached file" "Please delete the file and retry if this file should be downloaded again.")
endif()
vcpkg_extract_source_archive_ex(