Mercurial > hg > orthanc
annotate Resources/CMake/DcmtkConfiguration.cmake @ 100:27dc762e3dc8
getting rid of static dcmtk for debian
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Wed, 03 Oct 2012 09:33:25 +0200 |
parents | 10184c6eabc0 |
children | 428784e59dcd |
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}) |
8 | 5 SET(DCMTK_SOURCES_DIR ${CMAKE_BINARY_DIR}/dcmtk-3.6.0) |
6 DownloadPackage("ftp://dicom.offis.de/pub/dicom/offis/software/dcmtk/dcmtk360/dcmtk-3.6.0.zip" "${DCMTK_SOURCES_DIR}" "" "") | |
7 | |
8 IF(CMAKE_CROSSCOMPILING) | |
9 SET(C_CHAR_UNSIGNED 1 CACHE INTERNAL "Whether char is unsigned.") | |
10 ENDIF() | |
11 SET(DCMTK_SOURCE_DIR ${CMAKE_BINARY_DIR}/dcmtk-3.6.0) | |
12 include(${DCMTK_SOURCES_DIR}/CMake/CheckFunctionWithHeaderExists.cmake) | |
13 include(${DCMTK_SOURCES_DIR}/CMake/GenerateDCMTKConfigure.cmake) | |
14 CONFIGURE_FILE(${DCMTK_SOURCES_DIR}/CMake/osconfig.h.in | |
15 ${DCMTK_SOURCES_DIR}/config/include/dcmtk/config/osconfig.h) | |
16 | |
17 AUX_SOURCE_DIRECTORY(${DCMTK_SOURCES_DIR}/dcmnet/libsrc THIRD_PARTY_SOURCES) | |
18 AUX_SOURCE_DIRECTORY(${DCMTK_SOURCES_DIR}/dcmdata/libsrc THIRD_PARTY_SOURCES) | |
19 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
|
20 |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
21 # Source for the logging facility of DCMTK |
8 | 22 AUX_SOURCE_DIRECTORY(${DCMTK_SOURCES_DIR}/oflog/libsrc THIRD_PARTY_SOURCES) |
23 if (${CMAKE_SYSTEM_NAME} STREQUAL "Linux") | |
24 list(REMOVE_ITEM THIRD_PARTY_SOURCES | |
25 ${DCMTK_SOURCES_DIR}/oflog/libsrc/windebap.cc | |
26 ${DCMTK_SOURCES_DIR}/oflog/libsrc/winsock.cc | |
27 ) | |
28 elseif (${CMAKE_SYSTEM_NAME} STREQUAL "Windows") | |
29 list(REMOVE_ITEM THIRD_PARTY_SOURCES | |
30 ${DCMTK_SOURCES_DIR}/oflog/libsrc/unixsock.cc | |
31 ) | |
32 endif() | |
33 | |
34 list(REMOVE_ITEM THIRD_PARTY_SOURCES | |
35 ${DCMTK_SOURCES_DIR}/dcmdata/libsrc/mkdictbi.cc | |
36 ${DCMTK_SOURCES_DIR}/dcmdata/libsrc/mkdeftag.cc | |
37 ${DCMTK_SOURCES_DIR}/dcmdata/libsrc/dcdictbi.cc | |
38 ) | |
39 | |
40 # This fixes crashes related to the destruction of the DCMTK OFLogger | |
41 # http://support.dcmtk.org/docs-snapshot/file_macros.html | |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
42 #add_definitions(-DLOG4CPLUS_DISABLE_FATAL=1) |
8 | 43 |
44 include_directories( | |
45 #${DCMTK_SOURCES_DIR} | |
46 ${DCMTK_SOURCES_DIR}/config/include | |
47 ${DCMTK_SOURCES_DIR}/dcmnet/include | |
48 ${DCMTK_SOURCES_DIR}/ofstd/include | |
49 ${DCMTK_SOURCES_DIR}/oflog/include | |
50 ${DCMTK_SOURCES_DIR}/dcmdata/include | |
51 ) | |
52 | |
53 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
|
54 |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
55 set(DCMTK_BUNDLES_LOG4CPLUS 1) |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
56 |
8 | 57 else() |
58 include(FindDCMTK) | |
59 | |
60 include_directories(${DCMTK_INCLUDE_DIR}) | |
61 link_libraries(${DCMTK_LIBRARIES} oflog ofstd wrap) | |
62 | |
63 add_definitions( | |
64 -DHAVE_CONFIG_H=1 | |
65 ) | |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
66 |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
67 message("${DCMTK_DIR}/oflog") |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
68 |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
69 IF (EXISTS "${DCMTK_DIR}/oflog") |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
70 set(DCMTK_BUNDLES_LOG4CPLUS 1) |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
71 else() |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
72 set(DCMTK_BUNDLES_LOG4CPLUS 0) |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
73 endif() |
8 | 74 endif() |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
75 |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
90
diff
changeset
|
76 message("DCMTK includes its own copy of Log4Cplus: ${DCMTK_BUNDLES_LOG4CPLUS}") |