update dependencies (#52)
This commit is contained in:
parent
082aa0c7df
commit
4e87a9410a
2 changed files with 47 additions and 17 deletions
|
@ -3,7 +3,7 @@
|
||||||
# See https://github.com/TheLartians/CPM.cmake for usage and update instructions.
|
# See https://github.com/TheLartians/CPM.cmake for usage and update instructions.
|
||||||
#
|
#
|
||||||
# MIT License
|
# MIT License
|
||||||
# -----------
|
# -----------
|
||||||
#[[
|
#[[
|
||||||
Copyright (c) 2019 Lars Melchior
|
Copyright (c) 2019 Lars Melchior
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 3.14 FATAL_ERROR)
|
cmake_minimum_required(VERSION 3.14 FATAL_ERROR)
|
||||||
|
|
||||||
set(CURRENT_CPM_VERSION 0.26.2)
|
set(CURRENT_CPM_VERSION 0.27.2)
|
||||||
|
|
||||||
if(CPM_DIRECTORY)
|
if(CPM_DIRECTORY)
|
||||||
if(NOT CPM_DIRECTORY STREQUAL CMAKE_CURRENT_LIST_DIR)
|
if(NOT CPM_DIRECTORY STREQUAL CMAKE_CURRENT_LIST_DIR)
|
||||||
|
@ -42,13 +42,13 @@ See https://github.com/TheLartians/CPM.cmake for more information."
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
get_property(CPM_INITIALIZED GLOBAL "" PROPERTY CPM_INITIALIZED SET)
|
get_property(CPM_INITIALIZED GLOBAL "" PROPERTY CPM_INITIALIZED SET)
|
||||||
if (CPM_INITIALIZED)
|
if (CPM_INITIALIZED)
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set_property(GLOBAL PROPERTY CPM_INITIALIZED true)
|
set_property(GLOBAL PROPERTY CPM_INITIALIZED true)
|
||||||
|
|
||||||
option(CPM_USE_LOCAL_PACKAGES "Always try to use `find_package` to get dependencies" $ENV{CPM_USE_LOCAL_PACKAGES})
|
option(CPM_USE_LOCAL_PACKAGES "Always try to use `find_package` to get dependencies" $ENV{CPM_USE_LOCAL_PACKAGES})
|
||||||
option(CPM_LOCAL_PACKAGES_ONLY "Only use `find_package` to get dependencies" $ENV{CPM_LOCAL_PACKAGES_ONLY})
|
option(CPM_LOCAL_PACKAGES_ONLY "Only use `find_package` to get dependencies" $ENV{CPM_LOCAL_PACKAGES_ONLY})
|
||||||
|
@ -125,7 +125,7 @@ function(CPMFindPackage)
|
||||||
cmake_parse_arguments(CPM_ARGS "" "${oneValueArgs}" "" ${ARGN})
|
cmake_parse_arguments(CPM_ARGS "" "${oneValueArgs}" "" ${ARGN})
|
||||||
|
|
||||||
if (NOT DEFINED CPM_ARGS_VERSION)
|
if (NOT DEFINED CPM_ARGS_VERSION)
|
||||||
if (DEFINED CPM_ARGS_GIT_TAG)
|
if (DEFINED CPM_ARGS_GIT_TAG)
|
||||||
cpm_get_version_from_git_tag("${CPM_ARGS_GIT_TAG}" CPM_ARGS_VERSION)
|
cpm_get_version_from_git_tag("${CPM_ARGS_GIT_TAG}" CPM_ARGS_VERSION)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
@ -190,6 +190,8 @@ function(CPMAddPackage)
|
||||||
SOURCE_DIR
|
SOURCE_DIR
|
||||||
DOWNLOAD_COMMAND
|
DOWNLOAD_COMMAND
|
||||||
FIND_PACKAGE_ARGUMENTS
|
FIND_PACKAGE_ARGUMENTS
|
||||||
|
NO_CACHE
|
||||||
|
GIT_SHALLOW
|
||||||
)
|
)
|
||||||
|
|
||||||
set(multiValueArgs
|
set(multiValueArgs
|
||||||
|
@ -201,7 +203,7 @@ function(CPMAddPackage)
|
||||||
# Set default values for arguments
|
# Set default values for arguments
|
||||||
|
|
||||||
if (NOT DEFINED CPM_ARGS_VERSION)
|
if (NOT DEFINED CPM_ARGS_VERSION)
|
||||||
if (DEFINED CPM_ARGS_GIT_TAG)
|
if (DEFINED CPM_ARGS_GIT_TAG)
|
||||||
cpm_get_version_from_git_tag("${CPM_ARGS_GIT_TAG}" CPM_ARGS_VERSION)
|
cpm_get_version_from_git_tag("${CPM_ARGS_GIT_TAG}" CPM_ARGS_VERSION)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
@ -217,7 +219,7 @@ function(CPMAddPackage)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (DEFINED CPM_ARGS_GITLAB_REPOSITORY)
|
if (DEFINED CPM_ARGS_GITLAB_REPOSITORY)
|
||||||
list(CPM_ARGS_GIT_REPOSITORY "https://gitlab.com/${CPM_ARGS_GITLAB_REPOSITORY}.git")
|
set(CPM_ARGS_GIT_REPOSITORY "https://gitlab.com/${CPM_ARGS_GITLAB_REPOSITORY}.git")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (DEFINED CPM_ARGS_GIT_REPOSITORY)
|
if (DEFINED CPM_ARGS_GIT_REPOSITORY)
|
||||||
|
@ -229,6 +231,10 @@ function(CPMAddPackage)
|
||||||
|
|
||||||
if (DEFINED CPM_ARGS_GIT_TAG)
|
if (DEFINED CPM_ARGS_GIT_TAG)
|
||||||
list(APPEND CPM_ARGS_UNPARSED_ARGUMENTS GIT_TAG ${CPM_ARGS_GIT_TAG})
|
list(APPEND CPM_ARGS_UNPARSED_ARGUMENTS GIT_TAG ${CPM_ARGS_GIT_TAG})
|
||||||
|
# If GIT_SHALLOW is explicitly specified, honor the value.
|
||||||
|
if (DEFINED CPM_ARGS_GIT_SHALLOW)
|
||||||
|
list(APPEND CPM_ARGS_UNPARSED_ARGUMENTS GIT_SHALLOW ${CPM_ARGS_GIT_SHALLOW})
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Check if package has been added before
|
# Check if package has been added before
|
||||||
|
@ -270,7 +276,7 @@ function(CPMAddPackage)
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(CPM_LOCAL_PACKAGES_ONLY)
|
if(CPM_LOCAL_PACKAGES_ONLY)
|
||||||
message(SEND_ERROR "CPM: ${CPM_ARGS_NAME} not found via find_package(${CPM_ARGS_NAME} ${CPM_ARGS_VERSION})")
|
message(SEND_ERROR "CPM: ${CPM_ARGS_NAME} not found via find_package(${CPM_ARGS_NAME} ${CPM_ARGS_VERSION})")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
@ -296,7 +302,7 @@ function(CPMAddPackage)
|
||||||
list(APPEND CPM_ARGS_UNPARSED_ARGUMENTS DOWNLOAD_COMMAND ${CPM_ARGS_DOWNLOAD_COMMAND})
|
list(APPEND CPM_ARGS_UNPARSED_ARGUMENTS DOWNLOAD_COMMAND ${CPM_ARGS_DOWNLOAD_COMMAND})
|
||||||
elseif (DEFINED CPM_ARGS_SOURCE_DIR)
|
elseif (DEFINED CPM_ARGS_SOURCE_DIR)
|
||||||
list(APPEND CPM_ARGS_UNPARSED_ARGUMENTS SOURCE_DIR ${CPM_ARGS_SOURCE_DIR})
|
list(APPEND CPM_ARGS_UNPARSED_ARGUMENTS SOURCE_DIR ${CPM_ARGS_SOURCE_DIR})
|
||||||
elseif (CPM_SOURCE_CACHE)
|
elseif (CPM_SOURCE_CACHE AND NOT CPM_ARGS_NO_CACHE)
|
||||||
string(TOLOWER ${CPM_ARGS_NAME} lower_case_name)
|
string(TOLOWER ${CPM_ARGS_NAME} lower_case_name)
|
||||||
set(origin_parameters ${CPM_ARGS_UNPARSED_ARGUMENTS})
|
set(origin_parameters ${CPM_ARGS_UNPARSED_ARGUMENTS})
|
||||||
list(SORT origin_parameters)
|
list(SORT origin_parameters)
|
||||||
|
@ -308,6 +314,15 @@ function(CPMAddPackage)
|
||||||
list(APPEND CPM_ARGS_UNPARSED_ARGUMENTS DOWNLOAD_COMMAND "${CMAKE_COMMAND}")
|
list(APPEND CPM_ARGS_UNPARSED_ARGUMENTS DOWNLOAD_COMMAND "${CMAKE_COMMAND}")
|
||||||
set(PACKAGE_INFO "${download_directory}")
|
set(PACKAGE_INFO "${download_directory}")
|
||||||
else()
|
else()
|
||||||
|
# Enable shallow clone when GIT_TAG is not a commit hash.
|
||||||
|
# Our guess may not be accurate, but it should guarantee no commit hash get mis-detected.
|
||||||
|
if (NOT DEFINED CPM_ARGS_GIT_SHALLOW)
|
||||||
|
cpm_is_git_tag_commit_hash("${CPM_ARGS_GIT_TAG}" IS_HASH)
|
||||||
|
if (NOT ${IS_HASH})
|
||||||
|
list(APPEND CPM_ARGS_UNPARSED_ARGUMENTS GIT_SHALLOW TRUE)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
# remove timestamps so CMake will re-download the dependency
|
# remove timestamps so CMake will re-download the dependency
|
||||||
file(REMOVE_RECURSE ${CMAKE_BINARY_DIR}/_deps/${lower_case_name}-subbuild)
|
file(REMOVE_RECURSE ${CMAKE_BINARY_DIR}/_deps/${lower_case_name}-subbuild)
|
||||||
set(PACKAGE_INFO "${PACKAGE_INFO} -> ${download_directory}")
|
set(PACKAGE_INFO "${PACKAGE_INFO} -> ${download_directory}")
|
||||||
|
@ -353,7 +368,7 @@ macro(cpm_export_variables name)
|
||||||
SET(${name}_ADDED "${${name}_ADDED}" PARENT_SCOPE)
|
SET(${name}_ADDED "${${name}_ADDED}" PARENT_SCOPE)
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
# declares a package, so that any call to CPMAddPackage for the
|
# declares a package, so that any call to CPMAddPackage for the
|
||||||
# package name will use these arguments instead.
|
# package name will use these arguments instead.
|
||||||
# Previous declarations will not be overriden.
|
# Previous declarations will not be overriden.
|
||||||
macro(CPMDeclarePackage Name)
|
macro(CPMDeclarePackage Name)
|
||||||
|
@ -401,11 +416,11 @@ function(CPMGetPackageVersion PACKAGE OUTPUT)
|
||||||
set(${OUTPUT} "${CPM_PACKAGE_${PACKAGE}_VERSION}" PARENT_SCOPE)
|
set(${OUTPUT} "${CPM_PACKAGE_${PACKAGE}_VERSION}" PARENT_SCOPE)
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
# declares a package in FetchContent_Declare
|
# declares a package in FetchContent_Declare
|
||||||
function (cpm_declare_fetch PACKAGE VERSION INFO)
|
function (cpm_declare_fetch PACKAGE VERSION INFO)
|
||||||
message(STATUS "${CPM_INDENT} adding package ${PACKAGE}@${VERSION} (${INFO})")
|
message(STATUS "${CPM_INDENT} adding package ${PACKAGE}@${VERSION} (${INFO})")
|
||||||
|
|
||||||
if (${CPM_DRY_RUN})
|
if (${CPM_DRY_RUN})
|
||||||
message(STATUS "${CPM_INDENT} package not declared (dry run)")
|
message(STATUS "${CPM_INDENT} package not declared (dry run)")
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
@ -417,7 +432,7 @@ endfunction()
|
||||||
|
|
||||||
# returns properties for a package previously defined by cpm_declare_fetch
|
# returns properties for a package previously defined by cpm_declare_fetch
|
||||||
function (cpm_get_fetch_properties PACKAGE)
|
function (cpm_get_fetch_properties PACKAGE)
|
||||||
if (${CPM_DRY_RUN})
|
if (${CPM_DRY_RUN})
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
FetchContent_GetProperties(${PACKAGE})
|
FetchContent_GetProperties(${PACKAGE})
|
||||||
|
@ -427,8 +442,8 @@ function (cpm_get_fetch_properties PACKAGE)
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
# downloads a previously declared package via FetchContent
|
# downloads a previously declared package via FetchContent
|
||||||
function (cpm_fetch_package PACKAGE DOWNLOAD_ONLY)
|
function (cpm_fetch_package PACKAGE DOWNLOAD_ONLY)
|
||||||
if (${CPM_DRY_RUN})
|
if (${CPM_DRY_RUN})
|
||||||
message(STATUS "${CPM_INDENT} package ${PACKAGE} not fetched (dry run)")
|
message(STATUS "${CPM_INDENT} package ${PACKAGE} not fetched (dry run)")
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
@ -465,7 +480,7 @@ endfunction()
|
||||||
# guesses the package version from a git tag
|
# guesses the package version from a git tag
|
||||||
function(cpm_get_version_from_git_tag GIT_TAG RESULT)
|
function(cpm_get_version_from_git_tag GIT_TAG RESULT)
|
||||||
string(LENGTH ${GIT_TAG} length)
|
string(LENGTH ${GIT_TAG} length)
|
||||||
if (length EQUAL 40)
|
if (length EQUAL 40)
|
||||||
# GIT_TAG is probably a git hash
|
# GIT_TAG is probably a git hash
|
||||||
SET(${RESULT} 0 PARENT_SCOPE)
|
SET(${RESULT} 0 PARENT_SCOPE)
|
||||||
else()
|
else()
|
||||||
|
@ -473,3 +488,18 @@ function(cpm_get_version_from_git_tag GIT_TAG RESULT)
|
||||||
SET(${RESULT} ${CMAKE_MATCH_1} PARENT_SCOPE)
|
SET(${RESULT} ${CMAKE_MATCH_1} PARENT_SCOPE)
|
||||||
endif()
|
endif()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
|
# guesses if the git tag is a commit hash or an actual tag or a branch nane.
|
||||||
|
function(cpm_is_git_tag_commit_hash GIT_TAG RESULT)
|
||||||
|
string(LENGTH "${GIT_TAG}" length)
|
||||||
|
# full hash has 40 characters, and short hash has at least 7 characters.
|
||||||
|
if (length LESS 7 OR length GREATER 40)
|
||||||
|
SET(${RESULT} 0 PARENT_SCOPE)
|
||||||
|
else()
|
||||||
|
if (${GIT_TAG} MATCHES "^[a-fA-F0-9]+$")
|
||||||
|
SET(${RESULT} 1 PARENT_SCOPE)
|
||||||
|
else()
|
||||||
|
SET(${RESULT} 0 PARENT_SCOPE)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
endfunction()
|
||||||
|
|
|
@ -35,7 +35,7 @@ endif()
|
||||||
CPMAddPackage(
|
CPMAddPackage(
|
||||||
NAME Format.cmake
|
NAME Format.cmake
|
||||||
GITHUB_REPOSITORY TheLartians/Format.cmake
|
GITHUB_REPOSITORY TheLartians/Format.cmake
|
||||||
VERSION 1.3
|
VERSION 1.5.2
|
||||||
)
|
)
|
||||||
|
|
||||||
# ---- Create binary ----
|
# ---- Create binary ----
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue