Mercurial > hg > orthanc
annotate Resources/CMake/Compiler.cmake @ 1675:131136aeeaa7 db-changes
improved exception handling in the main program
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Fri, 02 Oct 2015 13:57:54 +0200 |
parents | 8040d56cb0b3 |
children | c131566b8252 50234539a0dd |
rev | line source |
---|---|
134 | 1 # This file sets all the compiler-related flags |
2 | |
1414 | 3 if (CMAKE_CROSSCOMPILING) |
4 # Cross-compilation necessarily implies standalone and static build | |
5 SET(STATIC_BUILD ON) | |
6 SET(STANDALONE_BUILD ON) | |
7 endif() | |
8 | |
9 if (CMAKE_COMPILER_IS_GNUCXX) | |
134 | 10 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -Wno-long-long -Wno-implicit-function-declaration") |
11 # --std=c99 makes libcurl not to compile | |
12 # -pedantic gives a lot of warnings on OpenSSL | |
13 set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -pedantic -Wno-long-long -Wno-variadic-macros") | |
571 | 14 |
15 if (CMAKE_CROSSCOMPILING) | |
16 # http://stackoverflow.com/a/3543845/881731 | |
17 set(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> -O coff -I<CMAKE_CURRENT_SOURCE_DIR> <SOURCE> <OBJECT>") | |
18 endif() | |
19 | |
1414 | 20 elseif (MSVC) |
569 | 21 # Use static runtime under Visual Studio |
22 # http://www.cmake.org/Wiki/CMake_FAQ#Dynamic_Replace | |
134 | 23 # http://stackoverflow.com/a/6510446 |
24 foreach(flag_var | |
25 CMAKE_C_FLAGS_DEBUG | |
26 CMAKE_CXX_FLAGS_DEBUG | |
27 CMAKE_C_FLAGS_RELEASE | |
28 CMAKE_CXX_FLAGS_RELEASE | |
29 CMAKE_C_FLAGS_MINSIZEREL | |
30 CMAKE_CXX_FLAGS_MINSIZEREL | |
31 CMAKE_C_FLAGS_RELWITHDEBINFO | |
32 CMAKE_CXX_FLAGS_RELWITHDEBINFO) | |
33 string(REGEX REPLACE "/MD" "/MT" ${flag_var} "${${flag_var}}") | |
34 string(REGEX REPLACE "/MDd" "/MTd" ${flag_var} "${${flag_var}}") | |
35 endforeach(flag_var) | |
569 | 36 |
1060 | 37 # Add /Zm256 compiler option to Visual Studio to fix PCH errors |
38 set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /Zm256") | |
39 | |
134 | 40 add_definitions( |
41 -D_CRT_SECURE_NO_WARNINGS=1 | |
42 -D_CRT_SECURE_NO_DEPRECATE=1 | |
43 ) | |
1057
3a26bc6e4867
more generic paths in CMake
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1031
diff
changeset
|
44 include_directories(${ORTHANC_ROOT}/Resources/ThirdParty/VisualStudio) |
134 | 45 link_libraries(netapi32) |
46 endif() | |
47 | |
48 | |
890 | 49 if (${CMAKE_SYSTEM_NAME} STREQUAL "Linux" OR |
1337 | 50 ${CMAKE_SYSTEM_NAME} STREQUAL "kFreeBSD" OR |
51 ${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD") | |
517
b2b56b4e33b0
simplifications to cmake
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
495
diff
changeset
|
52 set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,--no-undefined") |
1649
8040d56cb0b3
New function "OrthancPluginRegisterErrorCode()" to declare custom error codes
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1647
diff
changeset
|
53 set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--no-undefined -Wl,--version-script=${ORTHANC_ROOT}/Plugins/Samples/Common/VersionScript.map") |
134 | 54 |
55 # Remove the "-rdynamic" option | |
56 # http://www.mail-archive.com/cmake@cmake.org/msg08837.html | |
57 set(CMAKE_SHARED_LIBRARY_LINK_CXX_FLAGS "") | |
1337 | 58 link_libraries(uuid pthread rt) |
59 | |
60 if (NOT ${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD") | |
61 set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--as-needed") | |
1416
037d5ffca74d
as needed for plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1414
diff
changeset
|
62 set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,--as-needed") |
037d5ffca74d
as needed for plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1414
diff
changeset
|
63 set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--as-needed") |
1337 | 64 add_definitions( |
65 -D_LARGEFILE64_SOURCE=1 | |
66 -D_FILE_OFFSET_BITS=64 | |
67 ) | |
68 link_libraries(dl) | |
69 endif() | |
134 | 70 |
71 elseif(${CMAKE_SYSTEM_NAME} STREQUAL "Windows") | |
1560
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
72 if (MSVC) |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
73 message("MSVC compiler version = " ${MSVC_VERSION} "\n") |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
74 # Starting Visual Studio 2013 (version 1800), it is not possible |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
75 # to target Windows XP anymore |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
76 if (MSVC_VERSION LESS 1800) |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
77 add_definitions( |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
78 -DWINVER=0x0501 |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
79 -D_WIN32_WINNT=0x0501 |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
80 ) |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
81 endif() |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
82 else() |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
83 add_definitions( |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
84 -DWINVER=0x0501 |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
85 -D_WIN32_WINNT=0x0501 |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
86 ) |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
87 endif() |
307b9ea6c39b
fixes for Visual Studio 2013 and QtCreator
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1420
diff
changeset
|
88 |
134 | 89 add_definitions( |
90 -D_CRT_SECURE_NO_WARNINGS=1 | |
91 ) | |
92 link_libraries(rpcrt4 ws2_32) | |
495 | 93 |
1414 | 94 if (CMAKE_COMPILER_IS_GNUCXX) |
495 | 95 # This is a patch for MinGW64 |
96 SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--allow-multiple-definition -static-libgcc -static-libstdc++") | |
1420 | 97 SET(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--allow-multiple-definition -static-libgcc -static-libstdc++") |
1377
601d34afdab9
patch for recent versions of MinGW
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1337
diff
changeset
|
98 |
1381 | 99 CHECK_LIBRARY_EXISTS(winpthread pthread_create "" HAVE_WIN_PTHREAD) |
100 if (HAVE_WIN_PTHREAD) | |
101 # This line is necessary to compile with recent versions of MinGW, | |
102 # otherwise "libwinpthread-1.dll" is not statically linked. | |
103 SET(CMAKE_CXX_STANDARD_LIBRARIES "${CMAKE_CXX_STANDARD_LIBRARIES} -Wl,-Bstatic -lstdc++ -lpthread -Wl,-Bdynamic") | |
104 add_definitions(-DHAVE_WIN_PTHREAD=1) | |
105 else() | |
106 add_definitions(-DHAVE_WIN_PTHREAD=0) | |
107 endif() | |
495 | 108 endif() |
109 | |
918 | 110 elseif (${CMAKE_SYSTEM_NAME} STREQUAL "Darwin") |
1649
8040d56cb0b3
New function "OrthancPluginRegisterErrorCode()" to declare custom error codes
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1647
diff
changeset
|
111 SET(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -exported_symbols_list ${ORTHANC_ROOT}/Plugins/Samples/Common/ExportedSymbols.list") |
1647
fe458dde986e
hide symbols in plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1560
diff
changeset
|
112 |
918 | 113 add_definitions( |
114 -D_XOPEN_SOURCE=1 | |
115 ) | |
921
37aec47f49f0
successful compilation under Mac OS X Mavericks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
918
diff
changeset
|
116 link_libraries(iconv) |
918 | 117 |
134 | 118 endif() |
119 | |
120 | |
1337 | 121 if ("${CMAKE_SYSTEM_VERSION}" STREQUAL "LinuxStandardBase") |
122 SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} --lsb-target-version=${LSB_TARGET_VERSION} -I${LSB_PATH}/include") | |
123 SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} --lsb-target-version=${LSB_TARGET_VERSION} -nostdinc++ -I${LSB_PATH}/include -I${LSB_PATH}/include/c++ -I${LSB_PATH}/include/c++/backward -fpermissive") | |
124 SET(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} --lsb-target-version=${LSB_TARGET_VERSION} -L${LSB_LIBPATH}") | |
125 endif() | |
126 | |
127 | |
128 if (${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD") | |
129 # In FreeBSD, the "/usr/local/" folder contains the ports and need to be imported | |
130 SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -I/usr/local/include") | |
1405 | 131 SET(CMAKE_CXX_FLAGS "${CMAKE_C_FLAGS} -I/usr/local/include") |
1337 | 132 SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -L/usr/local/lib") |
133 SET(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -L/usr/local/lib") | |
134 endif() | |
135 | |
136 | |
134 | 137 if (${CMAKE_SYSTEM_NAME} STREQUAL "Windows") |
138 CHECK_INCLUDE_FILES(rpc.h HAVE_UUID_H) | |
139 else() | |
1336
a80e811ec619
fix unneeded complexity
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1335
diff
changeset
|
140 CHECK_INCLUDE_FILES(uuid/uuid.h HAVE_UUID_H) |
134 | 141 endif() |
142 | |
143 if (NOT HAVE_UUID_H) | |
144 message(FATAL_ERROR "Please install the uuid-dev package") | |
145 endif() | |
146 | |
1337 | 147 |
1414 | 148 if (STATIC_BUILD) |
134 | 149 add_definitions(-DORTHANC_STATIC=1) |
150 else() | |
151 add_definitions(-DORTHANC_STATIC=0) | |
152 endif() |