comparison PalanthirServer/ToDcmtkBridge.cpp @ 45:33d67e1ab173

r
author Sebastien Jodogne <s.jodogne@gmail.com>
date Wed, 05 Sep 2012 13:24:59 +0200
parents PalantirServer/ToDcmtkBridge.cpp@3959d33612cc
children a15e90e5d6fc
comparison
equal deleted inserted replaced
43:9be852ad33d2 45:33d67e1ab173
1 /**
2 * Palantir - A Lightweight, RESTful DICOM Store
3 * Copyright (C) 2012 Medical Physics Department, CHU of Liege,
4 * Belgium
5 *
6 * This program is free software: you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License as
8 * published by the Free Software Foundation, either version 3 of the
9 * 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 * General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 **/
19
20
21 #include "ToDcmtkBridge.h"
22
23 #include <memory>
24 #include <dcmtk/dcmdata/dcelem.h>
25 #include <dcmtk/dcmnet/diutil.h>
26
27
28 namespace Palantir
29 {
30 DcmTagKey ToDcmtkBridge::Convert(const DicomTag& tag)
31 {
32 return DcmTagKey(tag.GetGroup(), tag.GetElement());
33 }
34
35
36 DcmDataset* ToDcmtkBridge::Convert(const DicomMap& map)
37 {
38 std::auto_ptr<DcmDataset> result(new DcmDataset);
39
40 for (DicomMap::Map::const_iterator
41 it = map.map_.begin(); it != map.map_.end(); it++)
42 {
43 std::string s = it->second->AsString();
44 DU_putStringDOElement(result.get(), Convert(it->first), s.c_str());
45 }
46
47 return result.release();
48 }
49 }