From a4621e8b7ed3152f80979b9d4f8b5b18818bb72a Mon Sep 17 00:00:00 2001 From: Nat! Date: Wed, 20 Nov 2024 15:44:41 +0100 Subject: [PATCH] * change MULLE_C_COMPILER_ID, which is now simplified and all uppercase --- RELEASENOTES.md | 5 +++ .../all/cmake/share/CompilerDetectionC.cmake | 36 +++++++++++++++---- 2 files changed, 35 insertions(+), 6 deletions(-) diff --git a/RELEASENOTES.md b/RELEASENOTES.md index cb7a875..ed21161 100644 --- a/RELEASENOTES.md +++ b/RELEASENOTES.md @@ -1,3 +1,8 @@ +## 0.18.0 + +* minor bugfix and updates such as version increments + + ### 0.17.1 * Various small improvements diff --git a/src/mulle-c/c-cmake/project/all/cmake/share/CompilerDetectionC.cmake b/src/mulle-c/c-cmake/project/all/cmake/share/CompilerDetectionC.cmake index 33b88b4..5d90a07 100644 --- a/src/mulle-c/c-cmake/project/all/cmake/share/CompilerDetectionC.cmake +++ b/src/mulle-c/c-cmake/project/all/cmake/share/CompilerDetectionC.cmake @@ -9,19 +9,43 @@ if( NOT __COMPILER_DETECTION_C_CMAKE__) message( STATUS "# Include \"${CMAKE_CURRENT_LIST_FILE}\"" ) endif() + # + # for windows want a MSVC prefix + # + # CMAKE_C_COMPILER_ID, doesn't detect mulle-clang necessarily, so fallback + # on -DCMAKE_C_COMPILER + # if( NOT MULLE_C_COMPILER_ID) - if( ("${CMAKE_SYSTEM_NAME}" STREQUAL "Windows") AND ( "${CMAKE_C_COMPILER_ID}" MATCHES "^(Clang|MulleClang)$") ) - set( MULLE_C_COMPILER_ID "MSVC-${CMAKE_C_COMPILER_ID}") + string( TOUPPER "${CMAKE_C_COMPILER_ID}" TMP_NAME) + string( REGEX REPLACE "[^A-Za-z0-9]" "" TMP_NAME "${TMP_NAME}") + if( ("${CMAKE_SYSTEM_NAME}" STREQUAL "Windows") AND ( "${TMP_NAME}" MATCHES "CLANG") ) + set( MULLE_C_COMPILER_ID "MSVC-${TMP_NAME}") else() - set( MULLE_C_COMPILER_ID "${CMAKE_C_COMPILER_ID}") + get_filename_component( TMP_NAME2 "${CMAKE_C_COMPILER}" NAME_WE) + string( TOUPPER "${TMP_NAME2}" TMP_NAME2) + string( REGEX REPLACE "[^A-Za-z0-9]" "" TMP_NAME2 "${TMP_NAME2}") + if( "${TMP_NAME2}" MATCHES "MULLECLANG") + set( MULLE_C_COMPILER_ID "${TMP_NAME2}") + else() + set( MULLE_C_COMPILER_ID "${TMP_NAME}") + endif() endif() endif() if( NOT MULLE_CXX_COMPILER_ID) - if( ("${CMAKE_SYSTEM_NAME}" STREQUAL "Windows") AND ( "${CMAKE_CXX_COMPILER_ID}" MATCHES "^(Clang|MulleClang)$") ) - set( MULLE_CXX_COMPILER_ID "MSVC-${CMAKE_CXX_COMPILER_ID}") + string( TOUPPER "${CMAKE_CXX_COMPILER_ID}" TMP_NAME) + string( REGEX REPLACE "[^A-Za-z0-9]" "" TMP_NAME "${TMP_NAME}") + if( ("${CMAKE_SYSTEM_NAME}" STREQUAL "Windows") AND ( "${TMP_NAME}" MATCHES "CLANG") ) + set( MULLE_CXX_COMPILER_ID "MSVC-${TMP_NAME}") else() - set( MULLE_CXX_COMPILER_ID "${CMAKE_CXX_COMPILER_ID}") + get_filename_component( TMP_NAME2 "${CMAKE_CXX_COMPILER}" NAME_WE) + string( TOUPPER "${TMP_NAME2}" TMP_NAME2) + string( REGEX REPLACE "[^A-Za-z0-9]" "" TMP_NAME2 "${TMP_NAME2}") + if( "${TMP_NAME2}" MATCHES "MULLECLANG") + set( MULLE_CXX_COMPILER_ID "${TMP_NAME2}") + else() + set( MULLE_CXX_COMPILER_ID "${TMP_NAME}") + endif() endif() endif()