Files
clang-r547379/lib/cmake/llvm/GetErrcMessages.cmake
Ryan Prichard 6024e5c395 Update prebuilt Clang to r547379 (20.0.0).
clang 20.0.0 (based on r547379) from build 12806354.

Bug: http://b/379133546
Test: N/A
Change-Id: I2eb8938af55d809de674be63cb30cf27e801862b

Upstream-Commit: ad834e67b1105d15ef907f6255d4c96e8e733f57
2025-11-26 14:59:46 -05:00

46 lines
1.8 KiB
CMake

# This function returns the messages of various POSIX error codes as they are returned by std::error_code.
# The purpose of this function is to supply those error messages to llvm-lit using the errc_messages config.
# Currently supplied and needed error codes: ENOENT, EISDIR, EINVAL and EACCES.
# Messages are semi colon separated.
# Keep amount, order and tested error codes in sync with llvm/utils/lit/lit/llvm/config.py.
function(get_errc_messages outvar)
if(CMAKE_CROSSCOMPILING AND NOT CMAKE_CROSSCOMPILING_EMULATOR AND NOT DEFINED errc_exit_code)
set(${outvar} "" PARENT_SCOPE)
message(STATUS "Can't get errc messages in cross-compilation mode")
return()
endif()
set(errc_test_code ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/getErrc.cpp)
file(WRITE ${errc_test_code} "
#include <cerrno>
#include <iostream>
#include <string>
#include <system_error>
std::string getMessageFor(int err) {
return std::make_error_code(static_cast<std::errc>(err)).message();
}
int main() {
std::cout << getMessageFor(ENOENT) << ';' << getMessageFor(EISDIR);
std::cout << ';' << getMessageFor(EINVAL) << ';' << getMessageFor(EACCES);
return 0;
}
")
try_run(errc_exit_code
errc_compiled
${CMAKE_BINARY_DIR}
${errc_test_code}
RUN_OUTPUT_VARIABLE errc_result
COMPILE_OUTPUT_VARIABLE errc_compile_errors)
if (errc_compiled AND "${errc_exit_code}" STREQUAL "0")
set(${outvar} ${errc_result} PARENT_SCOPE)
else()
set(${outvar} "" PARENT_SCOPE)
message(NOTICE "${errc_compile_errors}")
message(STATUS "Failed to get errc messages")
endif ()
endfunction()