mirror of
				https://github.com/TheLartians/ModernCppStarter.git
				synced 2025-10-31 02:01:33 +01:00 
			
		
		
		
	update dependencies
This commit is contained in:
		
							parent
							
								
									082aa0c7df
								
							
						
					
					
						commit
						fb1d578ab4
					
				
					 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