summaryrefslogtreecommitdiffstats
path: root/src/civetweb/cmake/DetermineTargetArchitecture.cmake
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 18:24:20 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 18:24:20 +0000
commit483eb2f56657e8e7f419ab1a4fab8dce9ade8609 (patch)
treee5d88d25d870d5dedacb6bbdbe2a966086a0a5cf /src/civetweb/cmake/DetermineTargetArchitecture.cmake
parentInitial commit. (diff)
downloadceph-483eb2f56657e8e7f419ab1a4fab8dce9ade8609.tar.xz
ceph-483eb2f56657e8e7f419ab1a4fab8dce9ade8609.zip
Adding upstream version 14.2.21.upstream/14.2.21upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--src/civetweb/cmake/DetermineTargetArchitecture.cmake47
1 files changed, 47 insertions, 0 deletions
diff --git a/src/civetweb/cmake/DetermineTargetArchitecture.cmake b/src/civetweb/cmake/DetermineTargetArchitecture.cmake
new file mode 100644
index 00000000..7d18213f
--- /dev/null
+++ b/src/civetweb/cmake/DetermineTargetArchitecture.cmake
@@ -0,0 +1,47 @@
+# - Determines the target architecture of the compilation
+#
+# This function checks the architecture that will be built by the compiler
+# and sets a variable to the architecture
+#
+# determine_target_architecture(<OUTPUT_VAR>)
+#
+# - Example
+#
+# include(DetermineTargetArchitecture)
+# determine_target_architecture(PROJECT_NAME_ARCHITECTURE)
+
+if(__determine_target_architecture)
+ return()
+endif()
+set(__determine_target_architecture INCLUDED)
+
+function(determine_target_architecture FLAG)
+ if (MSVC)
+ if("${MSVC_C_ARCHITECTURE_ID}" STREQUAL "X86")
+ set(ARCH "i686")
+ elseif("${MSVC_C_ARCHITECTURE_ID}" STREQUAL "x64")
+ set(ARCH "x86_64")
+ elseif("${MSVC_C_ARCHITECTURE_ID}" STREQUAL "ARM")
+ set(ARCH "arm")
+ else()
+ message(FATAL_ERROR "Failed to determine the MSVC target architecture: ${MSVC_C_ARCHITECTURE_ID}")
+ endif()
+ else()
+ execute_process(
+ COMMAND ${CMAKE_C_COMPILER} -dumpmachine
+ RESULT_VARIABLE RESULT
+ OUTPUT_VARIABLE ARCH
+ ERROR_QUIET
+ )
+ if (RESULT)
+ message(FATAL_ERROR "Failed to determine target architecture triplet: ${RESULT}")
+ endif()
+ string(REGEX MATCH "([^-]+).*" ARCH_MATCH ${ARCH})
+ if (NOT CMAKE_MATCH_1 OR NOT ARCH_MATCH)
+ message(FATAL_ERROR "Failed to match the target architecture triplet: ${ARCH}")
+ endif()
+ set(ARCH ${CMAKE_MATCH_1})
+ endif()
+ message(STATUS "Target architecture - ${ARCH}")
+ set(FLAG ${ARCH} PARENT_SCOPE)
+endfunction()