2016-09-19 11:50:08 +08:00
|
|
|
function(vcpkg_execute_required_process)
|
2021-07-15 03:45:18 +08:00
|
|
|
cmake_parse_arguments(PARSE_ARGV 0 arg
|
2024-06-29 13:21:10 +08:00
|
|
|
"ALLOW_IN_DOWNLOAD_MODE;OUTPUT_STRIP_TRAILING_WHITESPACE;ERROR_STRIP_TRAILING_WHITESPACE"
|
2021-07-15 03:45:18 +08:00
|
|
|
"WORKING_DIRECTORY;LOGNAME;TIMEOUT;OUTPUT_VARIABLE;ERROR_VARIABLE"
|
2022-07-08 05:58:03 +08:00
|
|
|
"COMMAND;SAVE_LOG_FILES"
|
2021-07-15 03:45:18 +08:00
|
|
|
)
|
2019-08-29 04:49:29 +08:00
|
|
|
|
2021-07-15 03:45:18 +08:00
|
|
|
if(DEFINED arg_UNPARSED_ARGUMENTS)
|
|
|
|
message(WARNING "${CMAKE_CURRENT_FUNCTION} was passed extra arguments: ${arg_UNPARSED_ARGUMENTS}")
|
2020-10-27 10:30:27 +08:00
|
|
|
endif()
|
2021-07-15 03:45:18 +08:00
|
|
|
foreach(required_arg IN ITEMS WORKING_DIRECTORY COMMAND)
|
|
|
|
if(NOT DEFINED arg_${required_arg})
|
|
|
|
message(FATAL_ERROR "${required_arg} must be specified.")
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
if(NOT DEFINED arg_LOGNAME)
|
|
|
|
message(WARNING "LOGNAME should be specified.")
|
|
|
|
set(arg_LOGNAME "required")
|
2020-08-28 10:28:20 +08:00
|
|
|
endif()
|
|
|
|
|
2021-07-15 03:45:18 +08:00
|
|
|
if (VCPKG_DOWNLOAD_MODE AND NOT arg_ALLOW_IN_DOWNLOAD_MODE)
|
2021-02-10 07:53:36 +08:00
|
|
|
message(FATAL_ERROR
|
2019-08-29 04:49:29 +08:00
|
|
|
[[
|
|
|
|
This command cannot be executed in Download Mode.
|
|
|
|
Halting portfile execution.
|
|
|
|
]])
|
|
|
|
endif()
|
|
|
|
|
2021-07-15 03:45:18 +08:00
|
|
|
set(timeout_param "")
|
|
|
|
if(DEFINED arg_TIMEOUT)
|
|
|
|
set(timeout_param TIMEOUT "${arg_TIMEOUT}")
|
|
|
|
endif()
|
2024-06-29 13:21:10 +08:00
|
|
|
|
|
|
|
set(log_out "${CURRENT_BUILDTREES_DIR}/${arg_LOGNAME}-out.log")
|
|
|
|
set(log_err "${CURRENT_BUILDTREES_DIR}/${arg_LOGNAME}-err.log")
|
|
|
|
set(output_param OUTPUT_FILE "${log_out}")
|
|
|
|
set(error_param ERROR_FILE "${log_err}")
|
|
|
|
set(output_and_error_same OFF)
|
2021-07-15 03:45:18 +08:00
|
|
|
if(DEFINED arg_OUTPUT_VARIABLE AND DEFINED arg_ERROR_VARIABLE AND arg_OUTPUT_VARIABLE STREQUAL arg_ERROR_VARIABLE)
|
2024-06-29 13:21:10 +08:00
|
|
|
set(output_param OUTPUT_VARIABLE out_err_var)
|
|
|
|
set(error_param ERROR_VARIABLE out_err_var)
|
2021-07-15 03:45:18 +08:00
|
|
|
set(output_and_error_same ON)
|
|
|
|
else()
|
|
|
|
if(DEFINED arg_OUTPUT_VARIABLE)
|
2024-06-29 13:21:10 +08:00
|
|
|
set(output_param OUTPUT_VARIABLE out_var)
|
2017-10-20 08:19:11 +08:00
|
|
|
endif()
|
2021-07-15 03:45:18 +08:00
|
|
|
if(DEFINED arg_ERROR_VARIABLE)
|
2024-06-29 13:21:10 +08:00
|
|
|
set(error_param ERROR_VARIABLE err_var)
|
2017-10-20 08:19:11 +08:00
|
|
|
endif()
|
2021-07-15 03:45:18 +08:00
|
|
|
endif()
|
2024-06-29 13:21:10 +08:00
|
|
|
if(arg_OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
|
list(APPEND output_param OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
|
endif()
|
|
|
|
if(arg_ERROR_STRIP_TRAILING_WHITESPACE)
|
|
|
|
list(APPEND error_param ERROR_STRIP_TRAILING_WHITESPACE)
|
|
|
|
endif()
|
2021-07-15 03:45:18 +08:00
|
|
|
|
2022-06-11 01:56:44 +08:00
|
|
|
if(X_PORT_PROFILE AND NOT arg_ALLOW_IN_DOWNLOAD_MODE)
|
|
|
|
vcpkg_list(PREPEND arg_COMMAND "${CMAKE_COMMAND}" "-E" "time")
|
|
|
|
endif()
|
|
|
|
|
2021-07-15 03:45:18 +08:00
|
|
|
vcpkg_execute_in_download_mode(
|
|
|
|
COMMAND ${arg_COMMAND}
|
|
|
|
RESULT_VARIABLE error_code
|
|
|
|
WORKING_DIRECTORY "${arg_WORKING_DIRECTORY}"
|
|
|
|
${timeout_param}
|
2024-06-29 13:21:10 +08:00
|
|
|
${output_param}
|
|
|
|
${error_param}
|
2021-07-15 03:45:18 +08:00
|
|
|
)
|
2024-06-29 13:21:10 +08:00
|
|
|
|
|
|
|
if(output_and_error_same)
|
|
|
|
file(WRITE "${log_out}" "${out_err_var}")
|
|
|
|
file(WRITE "${log_err}" "")
|
|
|
|
else()
|
|
|
|
if(DEFINED arg_OUTPUT_VARIABLE)
|
|
|
|
file(WRITE "${log_out}" "${out_var}")
|
|
|
|
endif()
|
|
|
|
if(DEFINED arg_ERROR_VARIABLE)
|
|
|
|
file(WRITE "${log_err}" "${err_var}")
|
|
|
|
endif()
|
|
|
|
endif()
|
2023-01-10 03:13:59 +08:00
|
|
|
vcpkg_list(SET logfiles)
|
|
|
|
vcpkg_list(SET logfile_copies)
|
|
|
|
set(expect_alias FALSE)
|
|
|
|
foreach(item IN LISTS arg_SAVE_LOG_FILES)
|
|
|
|
if(expect_alias)
|
|
|
|
vcpkg_list(POP_BACK logfile_copies)
|
|
|
|
vcpkg_list(APPEND logfile_copies "${CURRENT_BUILDTREES_DIR}/${arg_LOGNAME}-${item}")
|
|
|
|
set(expect_alias FALSE)
|
|
|
|
elseif(item STREQUAL "ALIAS")
|
|
|
|
if(NOT logfiles)
|
|
|
|
message(FATAL_ERROR "ALIAS used without source file")
|
|
|
|
endif()
|
|
|
|
set(expect_alias TRUE)
|
|
|
|
else()
|
|
|
|
vcpkg_list(APPEND logfiles "${arg_WORKING_DIRECTORY}/${item}")
|
|
|
|
cmake_path(GET item FILENAME filename)
|
|
|
|
if(NOT filename MATCHES "[.]log\$")
|
|
|
|
string(APPEND filename ".log")
|
|
|
|
endif()
|
|
|
|
vcpkg_list(APPEND logfile_copies "${CURRENT_BUILDTREES_DIR}/${arg_LOGNAME}-${filename}")
|
2022-07-08 05:58:03 +08:00
|
|
|
endif()
|
2023-01-10 03:13:59 +08:00
|
|
|
endforeach()
|
|
|
|
vcpkg_list(SET saved_logs)
|
|
|
|
foreach(logfile logfile_copy IN ZIP_LISTS logfiles logfile_copies)
|
|
|
|
if(EXISTS "${logfile}")
|
|
|
|
configure_file("${logfile}" "${logfile_copy}" COPYONLY)
|
|
|
|
vcpkg_list(APPEND saved_logs "${logfile_copy}")
|
2022-07-08 05:58:03 +08:00
|
|
|
endif()
|
|
|
|
endforeach()
|
2021-07-15 03:45:18 +08:00
|
|
|
if(NOT error_code EQUAL 0)
|
|
|
|
set(stringified_logs "")
|
2022-07-08 05:58:03 +08:00
|
|
|
foreach(log IN LISTS saved_logs ITEMS "${log_out}" "${log_err}")
|
2021-07-15 03:45:18 +08:00
|
|
|
if(NOT EXISTS "${log}")
|
|
|
|
continue()
|
|
|
|
endif()
|
|
|
|
file(SIZE "${log}" log_size)
|
|
|
|
if(NOT log_size EQUAL "0")
|
|
|
|
file(TO_NATIVE_PATH "${log}" native_log)
|
|
|
|
string(APPEND stringified_logs " ${native_log}\n")
|
2022-01-29 03:30:49 +08:00
|
|
|
file(APPEND "${Z_VCPKG_ERROR_LOG_COLLECTION_FILE}" "${native_log}\n")
|
2021-07-15 03:45:18 +08:00
|
|
|
endif()
|
2017-10-20 08:19:11 +08:00
|
|
|
endforeach()
|
2021-07-15 03:45:18 +08:00
|
|
|
|
|
|
|
z_vcpkg_prettify_command_line(pretty_command ${arg_COMMAND})
|
2016-09-19 11:50:08 +08:00
|
|
|
message(FATAL_ERROR
|
2021-07-15 03:45:18 +08:00
|
|
|
" Command failed: ${pretty_command}\n"
|
|
|
|
" Working Directory: ${arg_WORKING_DIRECTORY}\n"
|
2019-03-07 15:37:24 +08:00
|
|
|
" Error code: ${error_code}\n"
|
2016-10-21 06:46:32 +08:00
|
|
|
" See logs for more information:\n"
|
2021-07-15 03:45:18 +08:00
|
|
|
"${stringified_logs}"
|
2017-10-20 08:19:11 +08:00
|
|
|
)
|
2016-09-19 11:50:08 +08:00
|
|
|
endif()
|
2021-07-15 03:45:18 +08:00
|
|
|
|
2020-10-27 10:30:27 +08:00
|
|
|
# pass output parameters back to caller's scope
|
2021-07-15 03:45:18 +08:00
|
|
|
if(output_and_error_same)
|
|
|
|
z_vcpkg_forward_output_variable(arg_OUTPUT_VARIABLE out_err_var)
|
|
|
|
# arg_ERROR_VARIABLE = arg_OUTPUT_VARIABLE, so no need to set it again
|
|
|
|
else()
|
|
|
|
z_vcpkg_forward_output_variable(arg_OUTPUT_VARIABLE out_var)
|
|
|
|
z_vcpkg_forward_output_variable(arg_ERROR_VARIABLE err_var)
|
|
|
|
endif()
|
2016-09-19 11:50:08 +08:00
|
|
|
endfunction()
|