cmake/Modules/ExternalProject/gitclone.cmake.in

88 lines
2.6 KiB
CMake
Raw Normal View History

2022-03-29 21:10:50 +02:00
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
# file Copyright.txt or https://cmake.org/licensing for details.
cmake_minimum_required(VERSION 3.5)
if(EXISTS "@gitclone_stampfile@" AND EXISTS "@gitclone_infofile@" AND
"@gitclone_stampfile@" IS_NEWER_THAN "@gitclone_infofile@")
2024-07-09 14:46:46 +02:00
message(VERBOSE
2022-03-29 21:10:50 +02:00
"Avoiding repeated git clone, stamp file is up to date: "
"'@gitclone_stampfile@'"
)
return()
endif()
2024-07-09 14:46:46 +02:00
# Even at VERBOSE level, we don't want to see the commands executed, but
# enabling them to be shown for DEBUG may be useful to help diagnose problems.
cmake_language(GET_MESSAGE_LOG_LEVEL active_log_level)
if(active_log_level MATCHES "DEBUG|TRACE")
2024-07-22 20:56:20 +02:00
set(maybe_show_command COMMAND_ECHO STDOUT)
2024-07-09 14:46:46 +02:00
else()
set(maybe_show_command "")
endif()
2022-03-29 21:10:50 +02:00
execute_process(
COMMAND ${CMAKE_COMMAND} -E rm -rf "@source_dir@"
RESULT_VARIABLE error_code
2024-07-09 14:46:46 +02:00
${maybe_show_command}
2022-03-29 21:10:50 +02:00
)
if(error_code)
message(FATAL_ERROR "Failed to remove directory: '@source_dir@'")
endif()
# try the clone 3 times in case there is an odd git clone issue
set(error_code 1)
set(number_of_tries 0)
while(error_code AND number_of_tries LESS 3)
execute_process(
2023-07-02 19:51:09 +02:00
COMMAND "@git_EXECUTABLE@"
2022-03-29 21:10:50 +02:00
clone @git_clone_options@ "@git_repository@" "@src_name@"
WORKING_DIRECTORY "@work_dir@"
RESULT_VARIABLE error_code
2024-07-09 14:46:46 +02:00
${maybe_show_command}
2022-03-29 21:10:50 +02:00
)
math(EXPR number_of_tries "${number_of_tries} + 1")
endwhile()
if(number_of_tries GREATER 1)
2024-07-09 14:46:46 +02:00
message(NOTICE "Had to git clone more than once: ${number_of_tries} times.")
2022-03-29 21:10:50 +02:00
endif()
if(error_code)
message(FATAL_ERROR "Failed to clone repository: '@git_repository@'")
endif()
execute_process(
2023-07-02 19:51:09 +02:00
COMMAND "@git_EXECUTABLE@"
2022-03-29 21:10:50 +02:00
checkout "@git_tag@" @git_checkout_explicit--@
WORKING_DIRECTORY "@work_dir@/@src_name@"
RESULT_VARIABLE error_code
2024-07-09 14:46:46 +02:00
${maybe_show_command}
2022-03-29 21:10:50 +02:00
)
if(error_code)
message(FATAL_ERROR "Failed to checkout tag: '@git_tag@'")
endif()
set(init_submodules @init_submodules@)
if(init_submodules)
execute_process(
2023-07-02 19:51:09 +02:00
COMMAND "@git_EXECUTABLE@" @git_submodules_config_options@
2022-03-29 21:10:50 +02:00
submodule update @git_submodules_recurse@ --init @git_submodules@
WORKING_DIRECTORY "@work_dir@/@src_name@"
RESULT_VARIABLE error_code
2024-07-09 14:46:46 +02:00
${maybe_show_command}
2022-03-29 21:10:50 +02:00
)
endif()
if(error_code)
message(FATAL_ERROR "Failed to update submodules in: '@work_dir@/@src_name@'")
endif()
# Complete success, update the script-last-run stamp file:
#
execute_process(
COMMAND ${CMAKE_COMMAND} -E copy "@gitclone_infofile@" "@gitclone_stampfile@"
RESULT_VARIABLE error_code
2024-07-09 14:46:46 +02:00
${maybe_show_command}
2022-03-29 21:10:50 +02:00
)
if(error_code)
message(FATAL_ERROR "Failed to copy script-last-run stamp file: '@gitclone_stampfile@'")
endif()