Mercurial > hg > orthanc-wsi
annotate Applications/ApplicationToolbox.cpp @ 99:82357198e5e6
fix
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Wed, 04 Jan 2017 17:02:38 +0100 |
parents | ff0ef01c332c |
children | 18e9a5429cc4 |
rev | line source |
---|---|
0 | 1 /** |
2 * Orthanc - A Lightweight, RESTful DICOM Store | |
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics | |
4 * Department, University Hospital of Liege, Belgium | |
98
ff0ef01c332c
shared copyright with osimis
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
93
diff
changeset
|
5 * Copyright (C) 2017 Osimis, Belgium |
0 | 6 * |
7 * This program is free software: you can redistribute it and/or | |
8 * modify it under the terms of the GNU Affero General Public License | |
9 * as published by the Free Software Foundation, either version 3 of | |
10 * the License, or (at your option) any later version. | |
11 * | |
12 * This program is distributed in the hope that it will be useful, but | |
13 * WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
15 * Affero General Public License for more details. | |
16 * | |
17 * You should have received a copy of the GNU Affero General Public License | |
18 * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
19 **/ | |
20 | |
21 | |
22 #include "ApplicationToolbox.h" | |
23 | |
24 #include "../Framework/Inputs/OpenSlideLibrary.h" | |
59
7a3853d51c45
Move "Framework/Orthanc/" as "Resources/Orthanc/"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
25 #include "../Resources/Orthanc/Core/HttpClient.h" |
7a3853d51c45
Move "Framework/Orthanc/" as "Resources/Orthanc/"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
26 #include "../Resources/Orthanc/Core/Logging.h" |
7a3853d51c45
Move "Framework/Orthanc/" as "Resources/Orthanc/"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
27 #include "../Resources/Orthanc/Core/MultiThreading/BagOfTasksProcessor.h" |
93
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
28 #include "../Resources/Orthanc/Core/SystemToolbox.h" |
59
7a3853d51c45
Move "Framework/Orthanc/" as "Resources/Orthanc/"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
51
diff
changeset
|
29 #include "../Resources/Orthanc/OrthancServer/FromDcmtkBridge.h" |
0 | 30 |
93
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
31 #include <boost/filesystem.hpp> |
0 | 32 #include <boost/lexical_cast.hpp> |
33 #include <boost/regex.hpp> | |
93
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
34 #include <boost/date_time/posix_time/posix_time.hpp> |
87 | 35 #include <cassert> |
36 | |
37 | |
38 static bool DisplayPerformanceWarning() | |
39 { | |
40 (void) DisplayPerformanceWarning; // Disable warning about unused function | |
41 LOG(WARNING) << "Performance warning in whole-slide imaging: " | |
42 << "Non-release build, runtime debug assertions are turned on"; | |
43 return true; | |
44 } | |
45 | |
0 | 46 |
47 namespace OrthancWSI | |
48 { | |
49 namespace ApplicationToolbox | |
50 { | |
51 void GlobalInitialize() | |
52 { | |
53 Orthanc::Logging::Initialize(); | |
54 Orthanc::HttpClient::InitializeOpenSsl(); | |
55 Orthanc::HttpClient::GlobalInitialize(); | |
51 | 56 Orthanc::FromDcmtkBridge::InitializeDictionary(false /* don't load private dictionary */); |
87 | 57 assert(DisplayPerformanceWarning()); |
0 | 58 } |
59 | |
60 | |
61 void GlobalFinalize() | |
62 { | |
63 OrthancWSI::OpenSlideLibrary::Finalize(); | |
64 Orthanc::HttpClient::GlobalFinalize(); | |
65 Orthanc::HttpClient::FinalizeOpenSsl(); | |
66 } | |
67 | |
68 | |
69 static void PrintProgress(Orthanc::BagOfTasksProcessor::Handle* handle, | |
70 bool* done) | |
71 { | |
72 unsigned int previous = 0; | |
73 | |
74 while (!*done) | |
75 { | |
76 unsigned int progress = static_cast<unsigned int>(100.0f * handle->GetProgress()); | |
77 if (previous != progress) | |
78 { | |
79 LOG(WARNING) << "Progress: " << progress << "%"; | |
80 previous = progress; | |
81 } | |
82 | |
83 boost::this_thread::sleep(boost::posix_time::milliseconds(100)); | |
84 } | |
85 } | |
86 | |
87 | |
88 void Execute(Orthanc::BagOfTasks& tasks, | |
89 unsigned int threadsCount) | |
90 { | |
91 if (threadsCount > 1) | |
92 { | |
7
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
93 // Submit the tasks to a newly-created processor |
0 | 94 LOG(WARNING) << "Running " << tasks.GetSize() << " tasks"; |
95 LOG(WARNING) << "Using " << threadsCount << " threads for the computation"; | |
96 Orthanc::BagOfTasksProcessor processor(threadsCount); | |
97 std::auto_ptr<Orthanc::BagOfTasksProcessor::Handle> handle(processor.Submit(tasks)); | |
98 | |
7
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
99 // Start a thread to display the progress |
0 | 100 bool done = false; |
101 boost::thread progress(PrintProgress, handle.get(), &done); | |
102 | |
7
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
103 // Wait for the completion of the tasks |
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
104 bool success = handle->Join(); |
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
105 |
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
106 // Stop the progress-printing thread |
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
107 done = true; |
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
108 |
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
109 if (progress.joinable()) |
0 | 110 { |
7
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
111 progress.join(); |
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
112 } |
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
113 |
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
114 if (success) |
bc3ca410b765
Fix freeze if the target Orthanc is not accepting images
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
115 { |
0 | 116 LOG(WARNING) << "All tasks have finished"; |
117 } | |
118 else | |
119 { | |
120 LOG(ERROR) << "Error has occurred, aborting"; | |
121 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); | |
122 } | |
123 } | |
124 else | |
125 { | |
126 LOG(WARNING) << "Running " << tasks.GetSize() << " tasks without multithreading"; | |
127 | |
128 unsigned int previous = 0; | |
129 unsigned int size = tasks.GetSize(); | |
130 | |
131 // No multithreading | |
132 while (!tasks.IsEmpty()) | |
133 { | |
134 std::auto_ptr<Orthanc::ICommand> task(tasks.Pop()); | |
135 if (task->Execute()) | |
136 { | |
137 unsigned int progress = static_cast<unsigned int>(100.0f * | |
138 static_cast<float>((size - tasks.GetSize())) / | |
139 static_cast<float>(size)); | |
140 if (progress != previous) | |
141 { | |
142 LOG(WARNING) << "Progress: " << progress << "%"; | |
143 previous = progress; | |
144 } | |
145 } | |
146 else | |
147 { | |
148 LOG(ERROR) << "Error has occurred, aborting"; | |
149 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); | |
150 } | |
151 } | |
152 } | |
153 } | |
154 | |
155 | |
156 void ParseColor(uint8_t& red, | |
157 uint8_t& green, | |
158 uint8_t& blue, | |
159 const std::string& color) | |
160 { | |
161 boost::regex pattern("([0-9]*),([0-9]*),([0-9]*)"); | |
162 | |
163 bool ok = false; | |
164 boost::cmatch what; | |
165 | |
166 try | |
167 { | |
168 if (regex_match(color.c_str(), what, pattern)) | |
169 { | |
170 int r = boost::lexical_cast<int>(what[1]); | |
171 int g = boost::lexical_cast<int>(what[2]); | |
172 int b = boost::lexical_cast<int>(what[3]); | |
173 | |
174 if (r >= 0 && r <= 255 && | |
175 g >= 0 && g <= 255 && | |
176 b >= 0 && b <= 255) | |
177 { | |
178 red = static_cast<uint8_t>(r); | |
179 green = static_cast<uint8_t>(g); | |
180 blue = static_cast<uint8_t>(b); | |
181 ok = true; | |
182 } | |
183 } | |
184 } | |
185 catch (boost::bad_lexical_cast&) | |
186 { | |
187 } | |
188 | |
189 if (!ok) | |
190 { | |
191 LOG(ERROR) << "Bad color specification: " << color; | |
192 throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); | |
193 } | |
194 } | |
8
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
195 |
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
196 |
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
197 void PrintVersion(const char* path) |
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
198 { |
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
199 std::cout |
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
200 << path << " " << ORTHANC_WSI_VERSION << std::endl |
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
201 << "Copyright (C) 2012-2016 Sebastien Jodogne, " |
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
202 << "Medical Physics Department, University Hospital of Liege (Belgium)" << std::endl |
99 | 203 << "Copyright (C) 2017 Osimis S.A. (Belgium)" << std::endl |
31 | 204 << "Licensing AGPL: GNU AGPL version 3 or later <http://gnu.org/licenses/agpl.html>." << std::endl |
8
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
205 << "This is free software: you are free to change and redistribute it." << std::endl |
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
206 << "There is NO WARRANTY, to the extent permitted by law." << std::endl |
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
207 << std::endl |
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
208 << "Written by Sebastien Jodogne <s.jodogne@gmail.com>" << std::endl; |
62adabb8c122
Provide "--version" in command-line tools
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
209 } |
93
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
210 |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
211 |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
212 void ShowVersionInLog(const char* path) |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
213 { |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
214 std::string version(ORTHANC_WSI_VERSION); |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
215 |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
216 if (version == "mainline") |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
217 { |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
218 try |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
219 { |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
220 boost::filesystem::path exe(Orthanc::SystemToolbox::GetPathToExecutable()); |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
221 std::time_t creation = boost::filesystem::last_write_time(exe); |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
222 boost::posix_time::ptime converted(boost::posix_time::from_time_t(creation)); |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
223 version += " (" + boost::posix_time::to_iso_string(converted) + ")"; |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
224 } |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
225 catch (...) |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
226 { |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
227 } |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
228 } |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
229 |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
230 LOG(WARNING) << "Orthanc WSI version: " << version; |
14146ecd1688
Display version of the framework in the logs
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
231 } |
0 | 232 } |
233 } |