summaryrefslogtreecommitdiff
path: root/cmake
diff options
context:
space:
mode:
authorJacques Germishuys <jacquesg@striata.com>2014-04-19 23:07:50 +0200
committerJacques Germishuys <jacquesg@striata.com>2014-04-19 23:07:50 +0200
commit5c8d5eac35794391c935e273612744a0684beb29 (patch)
tree0e7156abc56bc666331ed9d575926e1a6cdd8cb6 /cmake
parent364ef52881f98293a5e454aab447bc7c2a3d3725 (diff)
downloadlibgit2-5c8d5eac35794391c935e273612744a0684beb29.tar.gz
Introduce AddCFlagIfSupported CMake macro
Diffstat (limited to 'cmake')
-rw-r--r--cmake/Modules/AddCFlagIfSupported.cmake16
1 files changed, 16 insertions, 0 deletions
diff --git a/cmake/Modules/AddCFlagIfSupported.cmake b/cmake/Modules/AddCFlagIfSupported.cmake
new file mode 100644
index 000000000..67fc89510
--- /dev/null
+++ b/cmake/Modules/AddCFlagIfSupported.cmake
@@ -0,0 +1,16 @@
+# - Append compiler flag to CMAKE_C_FLAGS if compiler supports it
+# ADD_C_FLAG_IF_SUPPORTED(<flag>)
+# <flag> - the compiler flag to test
+# This internally calls the CHECK_C_COMPILER_FLAG macro.
+
+INCLUDE(CheckCCompilerFlag)
+
+MACRO(ADD_C_FLAG_IF_SUPPORTED _FLAG)
+ STRING(TOUPPER ${_FLAG} UPCASE)
+ STRING(REGEX REPLACE "^-" "" UPCASE_PRETTY ${UPCASE})
+ CHECK_C_COMPILER_FLAG(${_FLAG} IS_${UPCASE_PRETTY}_SUPPORTED)
+
+ IF(IS_${UPCASE_PRETTY}_SUPPORTED)
+ SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${_FLAG}")
+ ENDIF()
+ENDMACRO()