comparison OrthancStone/Sources/Toolbox/OsiriX/StringValue.cpp @ 1584:bd180f97c734

parsing osirix annotations
author Sebastien Jodogne <s.jodogne@gmail.com>
date Wed, 21 Oct 2020 17:33:17 +0200
parents
children 4fb8fdf03314
comparison
equal deleted inserted replaced
1583:c8644706e78b 1584:bd180f97c734
1 /**
2 * Stone of Orthanc
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
4 * Department, University Hospital of Liege, Belgium
5 * Copyright (C) 2017-2020 Osimis S.A., Belgium
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 "StringValue.h"
23
24 #include <OrthancException.h>
25 #include <Toolbox.h>
26
27 #include <boost/lexical_cast.hpp>
28
29
30 namespace OrthancStone
31 {
32 namespace OsiriX
33 {
34 void StringValue::ParseVector(Vector& v) const
35 {
36 size_t a = value_.find('(');
37 size_t b = value_.rfind(')');
38 if (a == std::string::npos ||
39 b == std::string::npos ||
40 a >= b)
41 {
42 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat,
43 "Cannot parse vector: " + value_);
44 }
45 else
46 {
47 std::vector<std::string> tokens;
48 Orthanc::Toolbox::TokenizeString(tokens, value_.substr(a + 1, b - (a + 1)), ',');
49
50 v.resize(tokens.size());
51 for (size_t i = 0; i < tokens.size(); i++)
52 {
53 try
54 {
55 v[i] = boost::lexical_cast<double>(Orthanc::Toolbox::StripSpaces(tokens[i]));
56 }
57 catch (boost::bad_lexical_cast&)
58 {
59 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadFileFormat,
60 "Not a real number: " + tokens[i]);
61 }
62 }
63 }
64 }
65 }
66 }