Mercurial > hg > orthanc
annotate Resources/CMake/DcmtkConfiguration.cmake @ 119:b0734fbcdd97 Orthanc-0.2.2
Orthanc-0.2.2
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Thu, 04 Oct 2012 15:09:56 +0200 |
parents | 0c5902cfe9db |
children | 1058c115aed1 |
rev | line source |
---|---|
90 | 1 # We always statically link against DCMTK 3.6.0, as there are many |
2 # differences wrt. DCMTK 3.5.x. | |
3 | |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
4 if (${STATIC_BUILD}) |
103
f2ecbe7d50b8
detection of dcmtk version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
5 SET(DCMTK_VERSION_NUMBER 360) |
8 | 6 SET(DCMTK_SOURCES_DIR ${CMAKE_BINARY_DIR}/dcmtk-3.6.0) |
7 DownloadPackage("ftp://dicom.offis.de/pub/dicom/offis/software/dcmtk/dcmtk360/dcmtk-3.6.0.zip" "${DCMTK_SOURCES_DIR}" "" "") | |
8 | |
9 IF(CMAKE_CROSSCOMPILING) | |
10 SET(C_CHAR_UNSIGNED 1 CACHE INTERNAL "Whether char is unsigned.") | |
11 ENDIF() | |
12 SET(DCMTK_SOURCE_DIR ${CMAKE_BINARY_DIR}/dcmtk-3.6.0) | |
13 include(${DCMTK_SOURCES_DIR}/CMake/CheckFunctionWithHeaderExists.cmake) | |
14 include(${DCMTK_SOURCES_DIR}/CMake/GenerateDCMTKConfigure.cmake) | |
15 CONFIGURE_FILE(${DCMTK_SOURCES_DIR}/CMake/osconfig.h.in | |
16 ${DCMTK_SOURCES_DIR}/config/include/dcmtk/config/osconfig.h) | |
17 | |
18 AUX_SOURCE_DIRECTORY(${DCMTK_SOURCES_DIR}/dcmnet/libsrc THIRD_PARTY_SOURCES) | |
19 AUX_SOURCE_DIRECTORY(${DCMTK_SOURCES_DIR}/dcmdata/libsrc THIRD_PARTY_SOURCES) | |
20 AUX_SOURCE_DIRECTORY(${DCMTK_SOURCES_DIR}/ofstd/libsrc THIRD_PARTY_SOURCES) | |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
21 |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
22 # Source for the logging facility of DCMTK |
8 | 23 AUX_SOURCE_DIRECTORY(${DCMTK_SOURCES_DIR}/oflog/libsrc THIRD_PARTY_SOURCES) |
24 if (${CMAKE_SYSTEM_NAME} STREQUAL "Linux") | |
25 list(REMOVE_ITEM THIRD_PARTY_SOURCES | |
26 ${DCMTK_SOURCES_DIR}/oflog/libsrc/windebap.cc | |
27 ${DCMTK_SOURCES_DIR}/oflog/libsrc/winsock.cc | |
28 ) | |
29 elseif (${CMAKE_SYSTEM_NAME} STREQUAL "Windows") | |
30 list(REMOVE_ITEM THIRD_PARTY_SOURCES | |
31 ${DCMTK_SOURCES_DIR}/oflog/libsrc/unixsock.cc | |
32 ) | |
33 endif() | |
34 | |
35 list(REMOVE_ITEM THIRD_PARTY_SOURCES | |
36 ${DCMTK_SOURCES_DIR}/dcmdata/libsrc/mkdictbi.cc | |
37 ${DCMTK_SOURCES_DIR}/dcmdata/libsrc/mkdeftag.cc | |
38 ${DCMTK_SOURCES_DIR}/dcmdata/libsrc/dcdictbi.cc | |
39 ) | |
40 | |
41 # This fixes crashes related to the destruction of the DCMTK OFLogger | |
42 # http://support.dcmtk.org/docs-snapshot/file_macros.html | |
103
f2ecbe7d50b8
detection of dcmtk version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
43 add_definitions( |
f2ecbe7d50b8
detection of dcmtk version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
44 -DLOG4CPLUS_DISABLE_FATAL=1 |
f2ecbe7d50b8
detection of dcmtk version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
45 -DDCMTK_VERSION_NUMBER=360 |
f2ecbe7d50b8
detection of dcmtk version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
46 ) |
8 | 47 |
48 include_directories( | |
49 #${DCMTK_SOURCES_DIR} | |
50 ${DCMTK_SOURCES_DIR}/config/include | |
51 ${DCMTK_SOURCES_DIR}/dcmnet/include | |
52 ${DCMTK_SOURCES_DIR}/ofstd/include | |
53 ${DCMTK_SOURCES_DIR}/oflog/include | |
54 ${DCMTK_SOURCES_DIR}/dcmdata/include | |
55 ) | |
56 | |
57 source_group(ThirdParty\\Dcmtk REGULAR_EXPRESSION ${DCMTK_SOURCES_DIR}/.*) | |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
58 |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
59 set(DCMTK_BUNDLES_LOG4CPLUS 1) |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
60 |
8 | 61 else() |
116
5dce26a8d045
skip autodetection of dcmtk by cmake
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
115
diff
changeset
|
62 #include(FindDCMTK) |
5dce26a8d045
skip autodetection of dcmtk by cmake
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
115
diff
changeset
|
63 set(DCMTK_DIR /usr/include/dcmtk) |
5dce26a8d045
skip autodetection of dcmtk by cmake
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
115
diff
changeset
|
64 set(DCMTK_INCLUDE_DIR ${DCMTK_DIR}) |
8 | 65 |
115 | 66 #message(${DCMTK_LIBRARIES}) |
67 | |
8 | 68 include_directories(${DCMTK_INCLUDE_DIR}) |
117 | 69 link_libraries(dcmdata dcmnet wrap ofstd) |
8 | 70 |
71 add_definitions( | |
72 -DHAVE_CONFIG_H=1 | |
73 ) | |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
74 |
109 | 75 if (NOT EXISTS "${DCMTK_DIR}/config/cfunix.h") |
76 message(FATAL_ERROR "Please install libdcmtk1-dev") | |
77 endif() | |
103
f2ecbe7d50b8
detection of dcmtk version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
78 |
f2ecbe7d50b8
detection of dcmtk version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
79 # Autodetection of the version of DCMTK |
104 | 80 file(STRINGS "${DCMTK_DIR}/config/cfunix.h" DCMTK_VERSION_NUMBER1 |
81 REGEX ".*PACKAGE_VERSION .*") | |
82 string(REGEX REPLACE ".*PACKAGE_VERSION.*\"([0-9]*)\\.([0-9]*)\\.([0-9]*)\"$" "\\1\\2\\3" DCMTK_VERSION_NUMBER ${DCMTK_VERSION_NUMBER1}) | |
103
f2ecbe7d50b8
detection of dcmtk version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
83 |
f2ecbe7d50b8
detection of dcmtk version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
84 |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
85 IF (EXISTS "${DCMTK_DIR}/oflog") |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
86 set(DCMTK_BUNDLES_LOG4CPLUS 1) |
117 | 87 link_libraries(oflog) |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
88 else() |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
89 set(DCMTK_BUNDLES_LOG4CPLUS 0) |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
90 endif() |
8 | 91 endif() |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
92 |
103
f2ecbe7d50b8
detection of dcmtk version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
93 add_definitions(-DDCMTK_VERSION_NUMBER=${DCMTK_VERSION_NUMBER}) |
f2ecbe7d50b8
detection of dcmtk version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
94 message("DCMTK version: ${DCMTK_VERSION_NUMBER}") |
101 | 95 message("Does DCMTK includes its own copy of Log4Cplus: ${DCMTK_BUNDLES_LOG4CPLUS}") |