Mercurial > hg > orthanc
annotate CMakeLists.txt @ 3996:c2b9a7a1c74a
ORTHANC_FRAMEWORK_BUILDING_PLUGIN
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Fri, 05 Jun 2020 18:26:01 +0200 |
parents | e12c8ac6dc82 |
children | 44e2a8e0b6ae |
rev | line source |
---|---|
2691 | 1 cmake_minimum_required(VERSION 2.8) |
2 | |
3 project(Orthanc) | |
4 | |
5 | |
6 ##################################################################### | |
7 ## Generic parameters of the Orthanc framework | |
8 ##################################################################### | |
9 | |
10 include(${CMAKE_SOURCE_DIR}/Resources/CMake/OrthancFrameworkParameters.cmake) | |
11 | |
12 # Enable all the optional components of the Orthanc framework | |
13 set(ENABLE_CRYPTO_OPTIONS ON) | |
14 set(ENABLE_DCMTK ON) | |
15 set(ENABLE_DCMTK_NETWORKING ON) | |
3893 | 16 set(ENABLE_DCMTK_TRANSCODING ON) |
2691 | 17 set(ENABLE_GOOGLE_TEST ON) |
18 set(ENABLE_JPEG ON) | |
19 set(ENABLE_LOCALE ON) | |
20 set(ENABLE_LUA ON) | |
3723
cc6d4edfe8fe
fix pkcs11 compilation
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3633
diff
changeset
|
21 set(ENABLE_OPENSSL_ENGINES ON) # OpenSSL engines are necessary for PKCS11 |
2691 | 22 set(ENABLE_PNG ON) |
23 set(ENABLE_PUGIXML ON) | |
24 set(ENABLE_SQLITE ON) | |
25 set(ENABLE_WEB_CLIENT ON) | |
26 set(ENABLE_WEB_SERVER ON) | |
27 set(ENABLE_ZLIB ON) | |
28 | |
29 set(HAS_EMBEDDED_RESOURCES ON) | |
30 | |
31 | |
32 ##################################################################### | |
33 ## CMake parameters tunable at the command line to configure the | |
34 ## plugins, the companion tools, and the unit tests | |
35 ##################################################################### | |
36 | |
37 # Parameters of the build | |
38 SET(BUILD_MODALITY_WORKLISTS ON CACHE BOOL "Whether to build the sample plugin to serve modality worklists") | |
39 SET(BUILD_RECOVER_COMPRESSED_FILE ON CACHE BOOL "Whether to build the companion tool to recover files compressed using Orthanc") | |
40 SET(BUILD_SERVE_FOLDERS ON CACHE BOOL "Whether to build the ServeFolders plugin") | |
3622
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
41 SET(BUILD_CONNECTIVITY_CHECKS ON CACHE BOOL "Whether to build the ConnectivityChecks plugin") |
2691 | 42 SET(ENABLE_PLUGINS ON CACHE BOOL "Enable plugins") |
43 SET(UNIT_TESTS_WITH_HTTP_CONNEXIONS ON CACHE BOOL "Allow unit tests to make HTTP requests") | |
44 | |
45 | |
46 ##################################################################### | |
47 ## Configuration of the Orthanc framework | |
48 ##################################################################### | |
49 | |
50 include(${CMAKE_SOURCE_DIR}/Resources/CMake/VisualStudioPrecompiledHeaders.cmake) | |
51 include(${CMAKE_SOURCE_DIR}/Resources/CMake/OrthancFrameworkConfiguration.cmake) | |
52 | |
53 | |
54 ##################################################################### | |
55 ## List of source files | |
56 ##################################################################### | |
57 | |
58 set(ORTHANC_SERVER_SOURCES | |
3093
2e1808b6146a
reorganization of folders
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3091
diff
changeset
|
59 OrthancServer/Database/Compatibility/DatabaseLookup.cpp |
2e1808b6146a
reorganization of folders
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3091
diff
changeset
|
60 OrthancServer/Database/Compatibility/ICreateInstance.cpp |
2e1808b6146a
reorganization of folders
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3091
diff
changeset
|
61 OrthancServer/Database/Compatibility/IGetChildrenMetadata.cpp |
3187
4bbadcd03966
refactoring retrieval of metadata from database
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3095
diff
changeset
|
62 OrthancServer/Database/Compatibility/ILookupResourceAndParent.cpp |
3093
2e1808b6146a
reorganization of folders
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3091
diff
changeset
|
63 OrthancServer/Database/Compatibility/ILookupResources.cpp |
2e1808b6146a
reorganization of folders
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3091
diff
changeset
|
64 OrthancServer/Database/Compatibility/SetOfResources.cpp |
3094
61da3c9b4121
cont reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3093
diff
changeset
|
65 OrthancServer/Database/ResourcesContent.cpp |
3093
2e1808b6146a
reorganization of folders
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3091
diff
changeset
|
66 OrthancServer/Database/SQLiteDatabaseWrapper.cpp |
2691 | 67 OrthancServer/DicomInstanceOrigin.cpp |
68 OrthancServer/DicomInstanceToStore.cpp | |
69 OrthancServer/ExportedResource.cpp | |
70 OrthancServer/LuaScripting.cpp | |
2933
4a38d7d4f0e0
new class: OrthancConfiguration
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2893
diff
changeset
|
71 OrthancServer/OrthancConfiguration.cpp |
2691 | 72 OrthancServer/OrthancFindRequestHandler.cpp |
73 OrthancServer/OrthancHttpHandler.cpp | |
74 OrthancServer/OrthancInitialization.cpp | |
75 OrthancServer/OrthancMoveRequestHandler.cpp | |
3818
4f78da5613a1
Add C-GET SCP support
Stacy Loesch <stacy.loesch@varian.com>
parents:
3746
diff
changeset
|
76 OrthancServer/OrthancGetRequestHandler.cpp |
2691 | 77 OrthancServer/OrthancRestApi/OrthancRestAnonymizeModify.cpp |
78 OrthancServer/OrthancRestApi/OrthancRestApi.cpp | |
79 OrthancServer/OrthancRestApi/OrthancRestArchive.cpp | |
80 OrthancServer/OrthancRestApi/OrthancRestChanges.cpp | |
81 OrthancServer/OrthancRestApi/OrthancRestModalities.cpp | |
82 OrthancServer/OrthancRestApi/OrthancRestResources.cpp | |
83 OrthancServer/OrthancRestApi/OrthancRestSystem.cpp | |
84 OrthancServer/QueryRetrieveHandler.cpp | |
3029
ea653ec47f31
new class: DatabaseConstraint
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3018
diff
changeset
|
85 OrthancServer/Search/DatabaseConstraint.cpp |
2892
ce310baccda6
DicomTagConstraint and DatabaseLookup
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2867
diff
changeset
|
86 OrthancServer/Search/DatabaseLookup.cpp |
ce310baccda6
DicomTagConstraint and DatabaseLookup
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2867
diff
changeset
|
87 OrthancServer/Search/DicomTagConstraint.cpp |
2691 | 88 OrthancServer/Search/HierarchicalMatcher.cpp |
3058
6faf575ba9cc
refactoring: class ISqlLookupFormatter to be used in orthanc-databases
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3057
diff
changeset
|
89 OrthancServer/Search/ISqlLookupFormatter.cpp |
2691 | 90 OrthancServer/ServerContext.cpp |
91 OrthancServer/ServerEnumerations.cpp | |
92 OrthancServer/ServerIndex.cpp | |
93 OrthancServer/ServerJobs/ArchiveJob.cpp | |
3941
771dbd9eb3bd
class CleaningInstancesJob to share cleaning code by merge/split jobs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3893
diff
changeset
|
94 OrthancServer/ServerJobs/CleaningInstancesJob.cpp |
2691 | 95 OrthancServer/ServerJobs/DicomModalityStoreJob.cpp |
2867 | 96 OrthancServer/ServerJobs/DicomMoveScuJob.cpp |
2691 | 97 OrthancServer/ServerJobs/LuaJobManager.cpp |
2853
52b017d22a4f
New URI: "/studies/.../merge" to merge a study
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2844
diff
changeset
|
98 OrthancServer/ServerJobs/MergeStudyJob.cpp |
2691 | 99 OrthancServer/ServerJobs/Operations/DeleteResourceOperation.cpp |
3095
beeeb6096f27
removing dependencies upon ServerContext
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3094
diff
changeset
|
100 OrthancServer/ServerJobs/Operations/DicomInstanceOperationValue.cpp |
2691 | 101 OrthancServer/ServerJobs/Operations/ModifyInstanceOperation.cpp |
102 OrthancServer/ServerJobs/Operations/StorePeerOperation.cpp | |
103 OrthancServer/ServerJobs/Operations/StoreScuOperation.cpp | |
104 OrthancServer/ServerJobs/Operations/SystemCallOperation.cpp | |
105 OrthancServer/ServerJobs/OrthancJobUnserializer.cpp | |
106 OrthancServer/ServerJobs/OrthancPeerStoreJob.cpp | |
107 OrthancServer/ServerJobs/ResourceModificationJob.cpp | |
2844
99863d6245b2
New URI: "/studies/.../split" to split a study
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2808
diff
changeset
|
108 OrthancServer/ServerJobs/SplitStudyJob.cpp |
3636 | 109 OrthancServer/ServerJobs/StorageCommitmentScpJob.cpp |
2691 | 110 OrthancServer/ServerToolbox.cpp |
111 OrthancServer/SliceOrdering.cpp | |
3736
0540b54324f1
StorageCommitmentReports
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3731
diff
changeset
|
112 OrthancServer/StorageCommitmentReports.cpp |
2691 | 113 ) |
114 | |
115 | |
116 set(ORTHANC_UNIT_TESTS_SOURCES | |
2893
1723cbba55c7
testing DicomTagConstraint
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2892
diff
changeset
|
117 UnitTestsSources/DatabaseLookupTests.cpp |
2691 | 118 UnitTestsSources/DicomMapTests.cpp |
119 UnitTestsSources/FileStorageTests.cpp | |
3987 | 120 UnitTestsSources/FrameworkTests.cpp |
2691 | 121 UnitTestsSources/FromDcmtkTests.cpp |
2893
1723cbba55c7
testing DicomTagConstraint
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2892
diff
changeset
|
122 UnitTestsSources/ImageProcessingTests.cpp |
1723cbba55c7
testing DicomTagConstraint
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2892
diff
changeset
|
123 UnitTestsSources/ImageTests.cpp |
1723cbba55c7
testing DicomTagConstraint
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2892
diff
changeset
|
124 UnitTestsSources/JpegLosslessTests.cpp |
3353
54cdad5a7228
Added a public function that will use emscripten-specific logging functions when using its SDK + scaffolding work. Build and UT OK on msvc15 x64. Not actually tested under *nix or emscripten yet
Benjamin Golinvaux <bgo@osimis.io>
parents:
3333
diff
changeset
|
125 UnitTestsSources/LoggingTests.cpp |
2893
1723cbba55c7
testing DicomTagConstraint
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2892
diff
changeset
|
126 UnitTestsSources/LuaTests.cpp |
2691 | 127 UnitTestsSources/MemoryCacheTests.cpp |
2893
1723cbba55c7
testing DicomTagConstraint
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2892
diff
changeset
|
128 UnitTestsSources/MultiThreadingTests.cpp |
2691 | 129 UnitTestsSources/RestApiTests.cpp |
2893
1723cbba55c7
testing DicomTagConstraint
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2892
diff
changeset
|
130 UnitTestsSources/SQLiteChromiumTests.cpp |
2691 | 131 UnitTestsSources/SQLiteTests.cpp |
132 UnitTestsSources/ServerIndexTests.cpp | |
2893
1723cbba55c7
testing DicomTagConstraint
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2892
diff
changeset
|
133 UnitTestsSources/StreamTests.cpp |
3326
b21d4cc8e5d1
speed up base64 decoding + added tests
Alain Mazy <alain@mazy.be>
parents:
3295
diff
changeset
|
134 UnitTestsSources/ToolboxTests.cpp |
2893
1723cbba55c7
testing DicomTagConstraint
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2892
diff
changeset
|
135 UnitTestsSources/UnitTestsMain.cpp |
2691 | 136 UnitTestsSources/VersionsTests.cpp |
137 UnitTestsSources/ZipTests.cpp | |
138 ) | |
139 | |
140 | |
141 if (ENABLE_PLUGINS) | |
3074
495c5edce708
new extension for database plugin SDK: lookupResources
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3071
diff
changeset
|
142 include_directories(${CMAKE_SOURCE_DIR}/Plugins/Include) |
495c5edce708
new extension for database plugin SDK: lookupResources
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3071
diff
changeset
|
143 |
2691 | 144 list(APPEND ORTHANC_SERVER_SOURCES |
145 Plugins/Engine/OrthancPluginDatabase.cpp | |
146 Plugins/Engine/OrthancPlugins.cpp | |
147 Plugins/Engine/PluginsEnumerations.cpp | |
148 Plugins/Engine/PluginsErrorDictionary.cpp | |
2808
37583cd183ed
primitives to create jobs from plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2773
diff
changeset
|
149 Plugins/Engine/PluginsJob.cpp |
2691 | 150 Plugins/Engine/PluginsManager.cpp |
151 ) | |
152 | |
153 list(APPEND ORTHANC_UNIT_TESTS_SOURCES | |
154 UnitTestsSources/PluginsTests.cpp | |
155 ) | |
156 endif() | |
157 | |
158 | |
159 if (CMAKE_COMPILER_IS_GNUCXX | |
160 AND NOT CMAKE_CROSSCOMPILING | |
3275 | 161 AND DCMTK_STATIC_VERSION STREQUAL "3.6.0") |
2691 | 162 # Add the "-pedantic" flag only on the Orthanc sources, and only if |
163 # cross-compiling DCMTK 3.6.0 | |
164 set(ORTHANC_ALL_SOURCES | |
165 ${ORTHANC_CORE_SOURCES_INTERNAL} | |
166 ${ORTHANC_DICOM_SOURCES_INTERNAL} | |
167 ${ORTHANC_SERVER_SOURCES} | |
168 ${ORTHANC_UNIT_TESTS_SOURCES} | |
169 Plugins/Samples/ServeFolders/Plugin.cpp | |
170 Plugins/Samples/ModalityWorklists/Plugin.cpp | |
171 OrthancServer/main.cpp | |
172 ) | |
173 | |
174 set_source_files_properties(${ORTHANC_ALL_SOURCES} | |
175 PROPERTIES COMPILE_FLAGS -pedantic | |
176 ) | |
177 endif() | |
178 | |
179 | |
180 ##################################################################### | |
181 ## Autogeneration of files | |
182 ##################################################################### | |
183 | |
184 set(ORTHANC_EMBEDDED_FILES | |
3094
61da3c9b4121
cont reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3093
diff
changeset
|
185 CONFIGURATION_SAMPLE ${CMAKE_CURRENT_SOURCE_DIR}/Resources/Configuration.json |
61da3c9b4121
cont reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3093
diff
changeset
|
186 DICOM_CONFORMANCE_STATEMENT ${CMAKE_CURRENT_SOURCE_DIR}/Resources/DicomConformanceStatement.txt |
61da3c9b4121
cont reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3093
diff
changeset
|
187 FONT_UBUNTU_MONO_BOLD_16 ${CMAKE_CURRENT_SOURCE_DIR}/Resources/Fonts/UbuntuMonoBold-16.json |
61da3c9b4121
cont reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3093
diff
changeset
|
188 LUA_TOOLBOX ${CMAKE_CURRENT_SOURCE_DIR}/Resources/Toolbox.lua |
61da3c9b4121
cont reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3093
diff
changeset
|
189 PREPARE_DATABASE ${CMAKE_CURRENT_SOURCE_DIR}/OrthancServer/Database/PrepareDatabase.sql |
61da3c9b4121
cont reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3093
diff
changeset
|
190 UPGRADE_DATABASE_3_TO_4 ${CMAKE_CURRENT_SOURCE_DIR}/OrthancServer/Database/Upgrade3To4.sql |
61da3c9b4121
cont reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3093
diff
changeset
|
191 UPGRADE_DATABASE_4_TO_5 ${CMAKE_CURRENT_SOURCE_DIR}/OrthancServer/Database/Upgrade4To5.sql |
61da3c9b4121
cont reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3093
diff
changeset
|
192 |
61da3c9b4121
cont reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3093
diff
changeset
|
193 INSTALL_TRACK_ATTACHMENTS_SIZE |
61da3c9b4121
cont reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3093
diff
changeset
|
194 ${CMAKE_CURRENT_SOURCE_DIR}/OrthancServer/Database/InstallTrackAttachmentsSize.sql |
2691 | 195 ) |
196 | |
197 if (STANDALONE_BUILD) | |
198 # We embed all the resources in the binaries for standalone builds | |
199 add_definitions(-DORTHANC_STANDALONE=1) | |
200 EmbedResources( | |
201 ${ORTHANC_EMBEDDED_FILES} | |
202 ORTHANC_EXPLORER ${CMAKE_CURRENT_SOURCE_DIR}/OrthancExplorer | |
203 ${DCMTK_DICTIONARIES} | |
3333
2a38e00a0638
Size of the Orthanc static binaries are reduced by compressing ICU data
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3326
diff
changeset
|
204 ${LIBICU_RESOURCES} |
2691 | 205 ) |
206 else() | |
207 add_definitions( | |
208 -DORTHANC_STANDALONE=0 | |
209 -DORTHANC_PATH=\"${CMAKE_SOURCE_DIR}\" | |
210 ) | |
211 EmbedResources( | |
212 ${ORTHANC_EMBEDDED_FILES} | |
3333
2a38e00a0638
Size of the Orthanc static binaries are reduced by compressing ICU data
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3326
diff
changeset
|
213 ${LIBICU_RESOURCES} |
2691 | 214 ) |
215 endif() | |
216 | |
217 if (${CMAKE_SYSTEM_NAME} STREQUAL "Windows") | |
218 execute_process( | |
219 COMMAND | |
220 ${PYTHON_EXECUTABLE} ${ORTHANC_ROOT}/Resources/WindowsResources.py | |
221 ${ORTHANC_VERSION} Orthanc Orthanc.exe "Lightweight, RESTful DICOM server for medical imaging" | |
222 ERROR_VARIABLE Failure | |
223 OUTPUT_FILE ${AUTOGENERATED_DIR}/Orthanc.rc | |
224 ) | |
225 | |
226 if (Failure) | |
227 message(FATAL_ERROR "Error while computing the version information: ${Failure}") | |
228 endif() | |
229 | |
230 list(APPEND ORTHANC_RESOURCES ${AUTOGENERATED_DIR}/Orthanc.rc) | |
231 endif() | |
232 | |
233 | |
234 | |
235 ##################################################################### | |
236 ## Configuration of the C/C++ macros | |
237 ##################################################################### | |
238 | |
239 if (ENABLE_PLUGINS) | |
240 add_definitions(-DORTHANC_ENABLE_PLUGINS=1) | |
241 else() | |
242 add_definitions(-DORTHANC_ENABLE_PLUGINS=0) | |
243 endif() | |
244 | |
245 | |
246 if (UNIT_TESTS_WITH_HTTP_CONNEXIONS) | |
247 add_definitions(-DUNIT_TESTS_WITH_HTTP_CONNEXIONS=1) | |
248 else() | |
249 add_definitions(-DUNIT_TESTS_WITH_HTTP_CONNEXIONS=0) | |
250 endif() | |
251 | |
252 | |
253 add_definitions( | |
3996
c2b9a7a1c74a
ORTHANC_FRAMEWORK_BUILDING_PLUGIN
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3987
diff
changeset
|
254 -DORTHANC_FRAMEWORK_BUILDING_PLUGIN=0 |
2691 | 255 -DORTHANC_BUILD_UNIT_TESTS=1 |
256 -DORTHANC_ENABLE_LOGGING_PLUGIN=0 | |
257 | |
258 # Macros for the plugins | |
259 -DHAS_ORTHANC_EXCEPTION=0 | |
260 -DMODALITY_WORKLISTS_VERSION="${ORTHANC_VERSION}" | |
261 -DSERVE_FOLDERS_VERSION="${ORTHANC_VERSION}" | |
262 ) | |
263 | |
264 | |
265 # Setup precompiled headers for Microsoft Visual Studio | |
266 | |
267 # WARNING: There must be NO MORE "add_definitions()", "include()" or | |
268 # "include_directories()" below, otherwise the generated precompiled | |
269 # headers might get broken! | |
270 | |
271 if (MSVC) | |
272 add_definitions(-DORTHANC_USE_PRECOMPILED_HEADERS=1) | |
273 | |
274 set(TMP | |
275 ${ORTHANC_CORE_SOURCES_INTERNAL} | |
276 ${ORTHANC_DICOM_SOURCES_INTERNAL} | |
277 ) | |
278 | |
279 ADD_VISUAL_STUDIO_PRECOMPILED_HEADERS( | |
280 "PrecompiledHeaders.h" "Core/PrecompiledHeaders.cpp" | |
281 TMP ORTHANC_CORE_PCH) | |
282 | |
283 ADD_VISUAL_STUDIO_PRECOMPILED_HEADERS( | |
284 "PrecompiledHeadersServer.h" "OrthancServer/PrecompiledHeadersServer.cpp" | |
285 ORTHANC_SERVER_SOURCES ORTHANC_SERVER_PCH) | |
286 | |
287 ADD_VISUAL_STUDIO_PRECOMPILED_HEADERS( | |
288 "PrecompiledHeadersUnitTests.h" "UnitTestsSources/PrecompiledHeadersUnitTests.cpp" | |
289 ORTHANC_UNIT_TESTS_SOURCES ORTHANC_UNIT_TESTS_PCH) | |
290 endif() | |
291 | |
292 | |
293 | |
294 ##################################################################### | |
295 ## Build the core of Orthanc | |
296 ##################################################################### | |
297 | |
298 # "CoreLibrary" contains all the third-party dependencies and the | |
299 # content of the "Core" folder | |
300 add_library(CoreLibrary | |
301 STATIC | |
302 ${ORTHANC_CORE_PCH} | |
303 ${ORTHANC_CORE_SOURCES} | |
304 ${ORTHANC_DICOM_SOURCES} | |
305 ${AUTOGENERATED_SOURCES} | |
3270 | 306 ) |
307 | |
308 if (LIBICU_LIBRARIES) | |
309 target_link_libraries(CoreLibrary ${LIBICU_LIBRARIES}) | |
310 endif() | |
2691 | 311 |
312 | |
313 ##################################################################### | |
314 ## Build the Orthanc server | |
315 ##################################################################### | |
316 | |
317 add_library(ServerLibrary | |
318 STATIC | |
319 ${ORTHANC_SERVER_PCH} | |
320 ${ORTHANC_SERVER_SOURCES} | |
321 ) | |
322 | |
323 # Ensure autogenerated code is built before building ServerLibrary | |
324 add_dependencies(ServerLibrary CoreLibrary) | |
325 | |
326 add_executable(Orthanc | |
327 OrthancServer/main.cpp | |
328 ${ORTHANC_RESOURCES} | |
329 ) | |
330 | |
331 target_link_libraries(Orthanc ServerLibrary CoreLibrary ${DCMTK_LIBRARIES}) | |
332 | |
333 install( | |
334 TARGETS Orthanc | |
335 RUNTIME DESTINATION sbin | |
336 ) | |
337 | |
338 | |
339 ##################################################################### | |
340 ## Build the unit tests | |
341 ##################################################################### | |
342 | |
343 add_executable(UnitTests | |
344 ${GOOGLE_TEST_SOURCES} | |
345 ${ORTHANC_UNIT_TESTS_PCH} | |
346 ${ORTHANC_UNIT_TESTS_SOURCES} | |
3326
b21d4cc8e5d1
speed up base64 decoding + added tests
Alain Mazy <alain@mazy.be>
parents:
3295
diff
changeset
|
347 ${BOOST_EXTENDED_SOURCES} |
2691 | 348 ) |
349 | |
350 target_link_libraries(UnitTests | |
351 ServerLibrary | |
352 CoreLibrary | |
353 ${DCMTK_LIBRARIES} | |
354 ${GOOGLE_TEST_LIBRARIES} | |
355 ) | |
356 | |
357 | |
358 ##################################################################### | |
3233
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
359 ## Build a static library to share code between the plugins |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
360 ##################################################################### |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
361 |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
362 if (ENABLE_PLUGINS AND |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
363 (BUILD_SERVE_FOLDERS OR BUILD_MODALITY_WORKLISTS)) |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
364 add_library(ThirdPartyPlugins STATIC |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
365 ${BOOST_SOURCES} |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
366 ${JSONCPP_SOURCES} |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
367 ${LIBICONV_SOURCES} |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
368 ${LIBICU_SOURCES} |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
369 Plugins/Samples/Common/OrthancPluginCppWrapper.cpp |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
370 ) |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
371 |
3271 | 372 if (LIBICU_LIBRARIES) |
373 target_link_libraries(ThirdPartyPlugins ${LIBICU_LIBRARIES}) | |
374 endif() | |
375 | |
3233
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
376 # Add the "-fPIC" option as this static library must be embedded |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
377 # inside shared libraries (important on UNIX) |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
378 set_property( |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
379 TARGET ThirdPartyPlugins |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
380 PROPERTY POSITION_INDEPENDENT_CODE ON |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
381 ) |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
382 endif() |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
383 |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
384 |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
385 ##################################################################### |
2691 | 386 ## Build the "ServeFolders" plugin |
387 ##################################################################### | |
388 | |
389 if (ENABLE_PLUGINS AND BUILD_SERVE_FOLDERS) | |
390 if (${CMAKE_SYSTEM_NAME} STREQUAL "Windows") | |
391 execute_process( | |
392 COMMAND | |
393 ${PYTHON_EXECUTABLE} ${ORTHANC_ROOT}/Resources/WindowsResources.py | |
394 ${ORTHANC_VERSION} ServeFolders ServeFolders.dll "Orthanc plugin to serve additional folders" | |
395 ERROR_VARIABLE Failure | |
396 OUTPUT_FILE ${AUTOGENERATED_DIR}/ServeFolders.rc | |
397 ) | |
398 | |
399 if (Failure) | |
400 message(FATAL_ERROR "Error while computing the version information: ${Failure}") | |
401 endif() | |
402 | |
403 list(APPEND SERVE_FOLDERS_RESOURCES ${AUTOGENERATED_DIR}/ServeFolders.rc) | |
404 endif() | |
405 | |
406 add_library(ServeFolders SHARED | |
407 Plugins/Samples/ServeFolders/Plugin.cpp | |
408 ${SERVE_FOLDERS_RESOURCES} | |
409 ) | |
410 | |
3233
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
411 target_link_libraries(ServeFolders ThirdPartyPlugins) |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
412 |
2691 | 413 set_target_properties( |
414 ServeFolders PROPERTIES | |
415 VERSION ${ORTHANC_VERSION} | |
416 SOVERSION ${ORTHANC_VERSION} | |
417 ) | |
418 | |
419 install( | |
420 TARGETS ServeFolders | |
421 RUNTIME DESTINATION lib # Destination for Windows | |
422 LIBRARY DESTINATION share/orthanc/plugins # Destination for Linux | |
423 ) | |
424 endif() | |
425 | |
426 | |
427 | |
428 ##################################################################### | |
429 ## Build the "ModalityWorklists" plugin | |
430 ##################################################################### | |
431 | |
432 if (ENABLE_PLUGINS AND BUILD_MODALITY_WORKLISTS) | |
433 if (${CMAKE_SYSTEM_NAME} STREQUAL "Windows") | |
434 execute_process( | |
435 COMMAND | |
436 ${PYTHON_EXECUTABLE} ${ORTHANC_ROOT}/Resources/WindowsResources.py | |
437 ${ORTHANC_VERSION} ModalityWorklists ModalityWorklists.dll "Sample Orthanc plugin to serve modality worklists" | |
438 ERROR_VARIABLE Failure | |
439 OUTPUT_FILE ${AUTOGENERATED_DIR}/ModalityWorklists.rc | |
440 ) | |
441 | |
442 if (Failure) | |
443 message(FATAL_ERROR "Error while computing the version information: ${Failure}") | |
444 endif() | |
445 | |
446 list(APPEND MODALITY_WORKLISTS_RESOURCES ${AUTOGENERATED_DIR}/ModalityWorklists.rc) | |
447 endif() | |
448 | |
449 add_library(ModalityWorklists SHARED | |
450 Plugins/Samples/ModalityWorklists/Plugin.cpp | |
451 ${MODALITY_WORKLISTS_RESOURCES} | |
452 ) | |
453 | |
3233
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
454 target_link_libraries(ModalityWorklists ThirdPartyPlugins) |
47fbb0467a62
Build a static library to share code between the plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3187
diff
changeset
|
455 |
2691 | 456 set_target_properties( |
457 ModalityWorklists PROPERTIES | |
458 VERSION ${ORTHANC_VERSION} | |
459 SOVERSION ${ORTHANC_VERSION} | |
460 ) | |
461 | |
462 install( | |
463 TARGETS ModalityWorklists | |
464 RUNTIME DESTINATION lib # Destination for Windows | |
465 LIBRARY DESTINATION share/orthanc/plugins # Destination for Linux | |
466 ) | |
467 endif() | |
468 | |
469 | |
470 | |
471 ##################################################################### | |
3622
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
472 ## Build the "ConnectivityChecks" plugin |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
473 ##################################################################### |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
474 |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
475 if (ENABLE_PLUGINS AND BUILD_CONNECTIVITY_CHECKS) |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
476 include(ExternalProject) |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
477 |
3625 | 478 set(Flags) |
3627
b03854e0f796
trying to fix output folders for OS X and windows
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3626
diff
changeset
|
479 |
3622
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
480 if (CMAKE_TOOLCHAIN_FILE) |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
481 # Take absolute path to the toolchain |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
482 get_filename_component(TMP ${CMAKE_TOOLCHAIN_FILE} REALPATH BASE ${CMAKE_SOURCE_DIR}) |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
483 list(APPEND Flags -DCMAKE_TOOLCHAIN_FILE=${TMP}) |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
484 endif() |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
485 |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
486 if ("${CMAKE_SYSTEM_VERSION}" STREQUAL "LinuxStandardBase") |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
487 list(APPEND Flags |
3625 | 488 -DLSB_CC=${CMAKE_LSB_CC} |
489 -DLSB_CXX=${CMAKE_LSB_CXX} | |
3622
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
490 ) |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
491 endif() |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
492 |
3637
06eb59faf4da
use a shorter path for VS2008
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3636
diff
changeset
|
493 externalproject_add(ConnectivityChecks |
3622
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
494 SOURCE_DIR "${ORTHANC_ROOT}/Plugins/Samples/ConnectivityChecks" |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
495 |
3637
06eb59faf4da
use a shorter path for VS2008
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3636
diff
changeset
|
496 # We explicitly provide a build directory, in order to avoid paths |
06eb59faf4da
use a shorter path for VS2008
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3636
diff
changeset
|
497 # that are too long on our Visual Studio 2008 CIS |
06eb59faf4da
use a shorter path for VS2008
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3636
diff
changeset
|
498 BINARY_DIR "${CMAKE_CURRENT_BINARY_DIR}/ConnectivityChecks-build" |
06eb59faf4da
use a shorter path for VS2008
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3636
diff
changeset
|
499 |
3622
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
500 CMAKE_ARGS |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
501 -DCMAKE_BUILD_TYPE:STRING=${CMAKE_BUILD_TYPE} |
3623 | 502 -DCMAKE_INSTALL_PREFIX=${CMAKE_CURRENT_BINARY_DIR} |
3622
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
503 -DPLUGIN_VERSION=${ORTHANC_VERSION} |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
504 -DSTATIC_BUILD=${STATIC_BUILD} |
3625 | 505 -DALLOW_DOWNLOADS=${ALLOW_DOWNLOADS} |
3622
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
506 -DUSE_LEGACY_JSONCPP=${USE_LEGACY_JSONCPP} |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
507 ${Flags} |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
508 ) |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
509 |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
510 if (${CMAKE_SYSTEM_NAME} STREQUAL "Windows") |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
511 if (MSVC) |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
512 set(Prefix "") |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
513 else() |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
514 set(Prefix "lib") # MinGW |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
515 endif() |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
516 |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
517 install(FILES |
3633
5295a49dd78a
removing not working tricks for ConnectivityChecks plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3628
diff
changeset
|
518 ${CMAKE_CURRENT_BINARY_DIR}/${Prefix}ConnectivityChecks.dll |
3622
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
519 DESTINATION "lib") |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
520 else() |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
521 list(GET CMAKE_FIND_LIBRARY_PREFIXES 0 Prefix) |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
522 list(GET CMAKE_FIND_LIBRARY_SUFFIXES 0 Suffix) |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
523 install(FILES |
3633
5295a49dd78a
removing not working tricks for ConnectivityChecks plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3628
diff
changeset
|
524 ${CMAKE_CURRENT_BINARY_DIR}/${Prefix}ConnectivityChecks${Suffix} |
5295a49dd78a
removing not working tricks for ConnectivityChecks plugin
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3628
diff
changeset
|
525 ${CMAKE_CURRENT_BINARY_DIR}/${Prefix}ConnectivityChecks${Suffix}.${ORTHANC_VERSION} |
3622
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
526 DESTINATION "share/orthanc/plugins") |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
527 endif() |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
528 endif() |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
529 |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
530 |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
531 |
8afc14fab01f
New sample plugin: ConnectivityChecks
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3353
diff
changeset
|
532 ##################################################################### |
2691 | 533 ## Build the companion tool to recover files compressed using Orthanc |
534 ##################################################################### | |
535 | |
536 if (BUILD_RECOVER_COMPRESSED_FILE) | |
537 set(RECOVER_COMPRESSED_SOURCES | |
538 Resources/Samples/Tools/RecoverCompressedFile.cpp | |
539 ) | |
540 | |
541 if (${CMAKE_SYSTEM_NAME} STREQUAL "Windows") | |
542 execute_process( | |
543 COMMAND | |
544 ${PYTHON_EXECUTABLE} ${ORTHANC_ROOT}/Resources/WindowsResources.py | |
545 ${ORTHANC_VERSION} OrthancRecoverCompressedFile OrthancRecoverCompressedFile.exe | |
546 "Lightweight, RESTful DICOM server for medical imaging" | |
547 ERROR_VARIABLE Failure | |
548 OUTPUT_FILE ${AUTOGENERATED_DIR}/OrthancRecoverCompressedFile.rc | |
549 ) | |
550 | |
551 if (Failure) | |
552 message(FATAL_ERROR "Error while computing the version information: ${Failure}") | |
553 endif() | |
554 | |
555 list(APPEND RECOVER_COMPRESSED_SOURCES | |
556 ${AUTOGENERATED_DIR}/OrthancRecoverCompressedFile.rc | |
557 ) | |
558 endif() | |
559 | |
560 add_executable(OrthancRecoverCompressedFile ${RECOVER_COMPRESSED_SOURCES}) | |
561 | |
562 target_link_libraries(OrthancRecoverCompressedFile CoreLibrary) | |
563 | |
564 install( | |
565 TARGETS OrthancRecoverCompressedFile | |
566 RUNTIME DESTINATION bin | |
567 ) | |
568 endif() | |
569 | |
570 | |
571 | |
572 ##################################################################### | |
573 ## Generate the documentation if Doxygen is present | |
574 ##################################################################### | |
575 | |
576 find_package(Doxygen) | |
577 if (DOXYGEN_FOUND) | |
578 configure_file( | |
579 ${CMAKE_SOURCE_DIR}/Resources/Orthanc.doxygen | |
580 ${CMAKE_CURRENT_BINARY_DIR}/Orthanc.doxygen | |
581 @ONLY) | |
582 | |
583 configure_file( | |
584 ${CMAKE_SOURCE_DIR}/Resources/OrthancPlugin.doxygen | |
585 ${CMAKE_CURRENT_BINARY_DIR}/OrthancPlugin.doxygen | |
586 @ONLY) | |
587 | |
588 add_custom_target(doc | |
589 ${DOXYGEN_EXECUTABLE} ${CMAKE_CURRENT_BINARY_DIR}/Orthanc.doxygen | |
590 COMMENT "Generating internal documentation with Doxygen" VERBATIM | |
591 ) | |
592 | |
593 add_custom_command(TARGET Orthanc | |
594 POST_BUILD | |
595 COMMAND ${DOXYGEN_EXECUTABLE} ${CMAKE_CURRENT_BINARY_DIR}/OrthancPlugin.doxygen | |
596 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR} | |
597 COMMENT "Generating plugin documentation with Doxygen" VERBATIM | |
598 ) | |
599 | |
600 install( | |
601 DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/OrthancPluginDocumentation/doc/ | |
602 DESTINATION share/doc/orthanc/OrthancPlugin | |
603 ) | |
604 else() | |
605 message("Doxygen not found. The documentation will not be built.") | |
606 endif() | |
607 | |
608 | |
609 | |
610 ##################################################################### | |
611 ## Install the plugin SDK | |
612 ##################################################################### | |
613 | |
614 if (ENABLE_PLUGINS) | |
615 install( | |
616 FILES | |
617 Plugins/Include/orthanc/OrthancCPlugin.h | |
618 Plugins/Include/orthanc/OrthancCDatabasePlugin.h | |
619 DESTINATION include/orthanc | |
620 ) | |
621 endif() | |
622 | |
623 | |
624 | |
625 ##################################################################### | |
626 ## Prepare the "uninstall" target | |
627 ## http://www.cmake.org/Wiki/CMake_FAQ#Can_I_do_.22make_uninstall.22_with_CMake.3F | |
628 ##################################################################### | |
629 | |
630 configure_file( | |
631 "${CMAKE_CURRENT_SOURCE_DIR}/Resources/CMake/Uninstall.cmake.in" | |
632 "${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake" | |
633 IMMEDIATE @ONLY) | |
634 | |
635 add_custom_target(uninstall | |
636 COMMAND ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake) |