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