aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/CMakeLists.txt
diff options
context:
space:
mode:
authorEgor Tensin <Egor.Tensin@gmail.com>2016-10-16 08:44:24 +0300
committerEgor Tensin <Egor.Tensin@gmail.com>2016-10-16 08:44:24 +0300
commit323f9f9e6434e262839c7845416039c159166f39 (patch)
tree30b33a4a166855294bd28b18bd35a82dff3ca3b0 /CMakeLists.txt
parentREADME update (diff)
downloadprivilege-check-323f9f9e6434e262839c7845416039c159166f39.tar.gz
privilege-check-323f9f9e6434e262839c7845416039c159166f39.zip
CMakeLists.txt update
* Nicer static runtime linking macro. * Other minor-ish improvements.
Diffstat (limited to '')
-rw-r--r--CMakeLists.txt52
1 files changed, 35 insertions, 17 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index b064826..9a859f3 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -11,9 +11,39 @@ project(privilege_check CXX)
if(MSVC)
add_compile_options(/MP /W4)
elseif(CMAKE_COMPILER_IS_GNUCXX)
- add_compile_options(-Wall -Wextra -std=c++14)
+ add_compile_options(-Wall -Wextra)
endif()
+get_directory_property(PRIVILEGE_CHECK_PARENT_DIRECTORY PARENT_DIRECTORY)
+set(PRIVILEGE_CHECK_IS_ROOT $<NOT:PRIVILEGE_CHECK_PARENT_DIRECTORY>)
+
+function(privilege_check_use_static_runtime target)
+ if(TARGET ${target} AND PRIVILEGE_CHECK_IS_ROOT)
+ if(MSVC)
+ target_compile_options(${target} PRIVATE
+ $<$<CONFIG:Release>:/MT>
+ $<$<CONFIG:Debug>:/MTd>)
+ elseif(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_GNUCXX)
+ get_target_property(type ${target} TYPE)
+ if(type STREQUAL EXECUTABLE)
+ target_link_libraries(${target} PRIVATE
+ -static-libgcc
+ -static-libstdc++)
+ endif()
+ endif()
+ endif()
+endfunction()
+
+macro(add_executable target)
+ _add_executable(${ARGV})
+ if(TARGET ${target})
+ privilege_check_use_static_runtime(${target})
+ if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_GNUCXX)
+ target_link_libraries(${target} PRIVATE $<$<CONFIG:Release>:-s>)
+ endif()
+ endif()
+endmacro()
+
file(GLOB ${PROJECT_NAME}_source_files "src/*.cpp")
file(GLOB ${PROJECT_NAME}_header_files "src/*.h" "src/*.hpp")
file(GLOB ${PROJECT_NAME}_resource_files "src/*.rc")
@@ -22,6 +52,10 @@ add_executable(${PROJECT_NAME} WIN32
${${PROJECT_NAME}_header_files}
${${PROJECT_NAME}_resource_files})
+if(CMAKE_COMPILER_IS_GNUCXX)
+ target_compile_options(${PROJECT_NAME} PRIVATE -std=c++11)
+endif()
+
if(MSVC)
target_compile_definitions(${PROJECT_NAME} PRIVATE _UNICODE UNICODE)
elseif(MINGW)
@@ -34,19 +68,3 @@ elseif(MINGW)
NTDDI_VERSION=NTDDI_VISTA
_WIN32_WINNT=_WIN32_WINNT_VISTA)
endif()
-
-if(CMAKE_COMPILER_IS_GNUCXX)
- target_link_libraries(${PROJECT_NAME} PRIVATE $<$<CONFIG:Release>:-s>)
-endif()
-
-# I prefer the CRT library to be linked statically, so that the binary can
-# easily be used on other computers.
-if(MSVC)
- target_compile_options(${PROJECT_NAME} PRIVATE
- $<$<CONFIG:Release>:/MT>
- $<$<CONFIG:Debug>:/MTd>)
-elseif(MINGW)
- target_link_libraries(${PROJECT_NAME} PRIVATE
- -static-libgcc
- -static-libstdc++)
-endif()