Mercurial > hg > orthanc
annotate Resources/CMake/Compiler.cmake @ 1308:f7966e9950e4 db-changes
integration mainline->db-changes
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Wed, 11 Feb 2015 10:32:14 +0100 |
parents | 303eb5e09a4b |
children | 4bed63189508 |
rev | line source |
---|---|
134 | 1 # This file sets all the compiler-related flags |
2 | |
3 if (${CMAKE_COMPILER_IS_GNUCXX}) | |
4 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -Wno-long-long -Wno-implicit-function-declaration") | |
5 # --std=c99 makes libcurl not to compile | |
6 # -pedantic gives a lot of warnings on OpenSSL | |
7 set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -pedantic -Wno-long-long -Wno-variadic-macros") | |
571 | 8 |
9 if (CMAKE_CROSSCOMPILING) | |
10 # http://stackoverflow.com/a/3543845/881731 | |
11 set(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> -O coff -I<CMAKE_CURRENT_SOURCE_DIR> <SOURCE> <OBJECT>") | |
12 endif() | |
13 | |
134 | 14 elseif (${MSVC}) |
569 | 15 # Use static runtime under Visual Studio |
16 # http://www.cmake.org/Wiki/CMake_FAQ#Dynamic_Replace | |
134 | 17 # http://stackoverflow.com/a/6510446 |
18 foreach(flag_var | |
19 CMAKE_C_FLAGS_DEBUG | |
20 CMAKE_CXX_FLAGS_DEBUG | |
21 CMAKE_C_FLAGS_RELEASE | |
22 CMAKE_CXX_FLAGS_RELEASE | |
23 CMAKE_C_FLAGS_MINSIZEREL | |
24 CMAKE_CXX_FLAGS_MINSIZEREL | |
25 CMAKE_C_FLAGS_RELWITHDEBINFO | |
26 CMAKE_CXX_FLAGS_RELWITHDEBINFO) | |
27 string(REGEX REPLACE "/MD" "/MT" ${flag_var} "${${flag_var}}") | |
28 string(REGEX REPLACE "/MDd" "/MTd" ${flag_var} "${${flag_var}}") | |
29 endforeach(flag_var) | |
569 | 30 |
1060 | 31 # Add /Zm256 compiler option to Visual Studio to fix PCH errors |
32 set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /Zm256") | |
33 | |
134 | 34 add_definitions( |
35 -D_CRT_SECURE_NO_WARNINGS=1 | |
36 -D_CRT_SECURE_NO_DEPRECATE=1 | |
37 ) | |
1057
3a26bc6e4867
more generic paths in CMake
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1031
diff
changeset
|
38 include_directories(${ORTHANC_ROOT}/Resources/ThirdParty/VisualStudio) |
134 | 39 link_libraries(netapi32) |
40 endif() | |
41 | |
42 | |
890 | 43 if (${CMAKE_SYSTEM_NAME} STREQUAL "Linux" OR |
44 ${CMAKE_SYSTEM_NAME} STREQUAL "kFreeBSD") | |
193
a1b9d1e1497b
failed attempt to compile with linux standard base
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
134
diff
changeset
|
45 if ("${CMAKE_SYSTEM_VERSION}" STREQUAL "LinuxStandardBase") |
566
6a3e2ca7a7a0
the client library compiles with LSB 4.0
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
564
diff
changeset
|
46 SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} --lsb-target-version=${LSB_TARGET_VERSION} -I${LSB_PATH}/include") |
6a3e2ca7a7a0
the client library compiles with LSB 4.0
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
564
diff
changeset
|
47 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") |
6a3e2ca7a7a0
the client library compiles with LSB 4.0
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
564
diff
changeset
|
48 SET(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} --lsb-target-version=${LSB_TARGET_VERSION} -L${LSB_LIBPATH}") |
193
a1b9d1e1497b
failed attempt to compile with linux standard base
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
134
diff
changeset
|
49 endif() |
a1b9d1e1497b
failed attempt to compile with linux standard base
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
134
diff
changeset
|
50 |
134 | 51 add_definitions( |
52 -D_LARGEFILE64_SOURCE=1 | |
53 -D_FILE_OFFSET_BITS=64 | |
54 ) | |
517
b2b56b4e33b0
simplifications to cmake
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
495
diff
changeset
|
55 set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--as-needed") |
b2b56b4e33b0
simplifications to cmake
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
495
diff
changeset
|
56 set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,--no-undefined") |
b2b56b4e33b0
simplifications to cmake
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
495
diff
changeset
|
57 set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--no-undefined") |
134 | 58 |
59 # Remove the "-rdynamic" option | |
60 # http://www.mail-archive.com/cmake@cmake.org/msg08837.html | |
61 set(CMAKE_SHARED_LIBRARY_LINK_CXX_FLAGS "") | |
1031 | 62 link_libraries(uuid pthread rt dl) |
134 | 63 |
64 elseif(${CMAKE_SYSTEM_NAME} STREQUAL "Windows") | |
65 add_definitions( | |
66 -DWINVER=0x0501 | |
67 -D_CRT_SECURE_NO_WARNINGS=1 | |
68 ) | |
69 link_libraries(rpcrt4 ws2_32) | |
495 | 70 |
71 if (${CMAKE_COMPILER_IS_GNUCXX}) | |
72 # This is a patch for MinGW64 | |
73 SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--allow-multiple-definition -static-libgcc -static-libstdc++") | |
74 endif() | |
75 | |
918 | 76 elseif (${CMAKE_SYSTEM_NAME} STREQUAL "Darwin") |
77 add_definitions( | |
78 -D_XOPEN_SOURCE=1 | |
79 ) | |
921
37aec47f49f0
successful compilation under Mac OS X Mavericks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
918
diff
changeset
|
80 link_libraries(iconv) |
918 | 81 |
134 | 82 endif() |
83 | |
84 | |
85 if (${CMAKE_SYSTEM_NAME} STREQUAL "Windows") | |
86 CHECK_INCLUDE_FILES(rpc.h HAVE_UUID_H) | |
87 else() | |
88 CHECK_INCLUDE_FILES(uuid/uuid.h HAVE_UUID_H) | |
89 endif() | |
90 | |
91 if (NOT HAVE_UUID_H) | |
92 message(FATAL_ERROR "Please install the uuid-dev package") | |
93 endif() | |
94 | |
95 if (${STATIC_BUILD}) | |
96 add_definitions(-DORTHANC_STATIC=1) | |
97 else() | |
98 add_definitions(-DORTHANC_STATIC=0) | |
99 endif() |