GDCM 3.0.24
gdcmCSAHeaderDict.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: GDCM (Grassroots DICOM). A DICOM library
4
5 Copyright (c) 2006-2011 Mathieu Malaterre
6 All rights reserved.
7 See Copyright.txt or http://gdcm.sourceforge.net/Copyright.html for details.
8
9 This software is distributed WITHOUT ANY WARRANTY; without even
10 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
11 PURPOSE. See the above copyright notice for more information.
12
13=========================================================================*/
14#ifndef GDCMCSAHEADERDICT_H
15#define GDCMCSAHEADERDICT_H
16
17#include "gdcmTypes.h"
18#include "gdcmTag.h"
20
21#include <iostream>
22#include <iomanip>
23#include <set>
24#include <exception>
25
26namespace gdcm
27{
28
29class GDCM_EXPORT CSAHeaderDictException : public std::exception {};
30
35{
36public:
37 typedef std::set<CSAHeaderDictEntry> MapCSAHeaderDictEntry;
38 typedef MapCSAHeaderDictEntry::iterator Iterator;
39 typedef MapCSAHeaderDictEntry::const_iterator ConstIterator;
40 //static CSAHeaderDictEntry GroupLengthCSAHeaderDictEntry; // = CSAHeaderDictEntry("Group Length",VR::UL,VM::VM1);
41
42 CSAHeaderDict():CSAHeaderDictInternal() {
43 assert( CSAHeaderDictInternal.empty() );
44 }
45 CSAHeaderDict &operator=(const CSAHeaderDict &_val) = delete;
46 CSAHeaderDict(const CSAHeaderDict &_val) = delete;
47
48 friend std::ostream& operator<<(std::ostream& _os, const CSAHeaderDict &_val);
49
50 ConstIterator Begin() const { return CSAHeaderDictInternal.begin(); }
51 ConstIterator End() const { return CSAHeaderDictInternal.end(); }
52
53 bool IsEmpty() const { return CSAHeaderDictInternal.empty(); }
55 {
56#ifndef NDEBUG
57 MapCSAHeaderDictEntry::size_type s = CSAHeaderDictInternal.size();
58#endif
59 CSAHeaderDictInternal.insert( de );
60 assert( s < CSAHeaderDictInternal.size() );
61 }
62
63 const CSAHeaderDictEntry &GetCSAHeaderDictEntry(const char *name) const
64 {
65 MapCSAHeaderDictEntry::const_iterator it = CSAHeaderDictInternal.find( name );
66 if( it != CSAHeaderDictInternal.end() )
67 {
68 return *it;
69 }
71 }
72
73protected:
74 friend class Dicts;
76
77private:
78
79 MapCSAHeaderDictEntry CSAHeaderDictInternal;
80};
81//-----------------------------------------------------------------------------
82inline std::ostream& operator<<(std::ostream& os, const CSAHeaderDict &val)
83{
84 CSAHeaderDict::MapCSAHeaderDictEntry::const_iterator it = val.CSAHeaderDictInternal.begin();
85 for(;it != val.CSAHeaderDictInternal.end(); ++it)
86 {
87 const CSAHeaderDictEntry &de = *it;
88 os << de << '\n';
89 }
90
91
92 return os;
93}
94
95
96} // end namespace gdcm
97
98#endif //GDCMCSAHEADERDICT_H
Class to represent an Entry in the Dict.
Definition gdcmCSAHeaderDictEntry.h:39
Definition gdcmCSAHeaderDict.h:29
Class to represent a map of CSAHeaderDictEntry.
Definition gdcmCSAHeaderDict.h:35
bool IsEmpty() const
Definition gdcmCSAHeaderDict.h:53
ConstIterator End() const
Definition gdcmCSAHeaderDict.h:51
std::set< CSAHeaderDictEntry > MapCSAHeaderDictEntry
Definition gdcmCSAHeaderDict.h:37
MapCSAHeaderDictEntry::const_iterator ConstIterator
Definition gdcmCSAHeaderDict.h:39
CSAHeaderDict()
Definition gdcmCSAHeaderDict.h:42
const CSAHeaderDictEntry & GetCSAHeaderDictEntry(const char *name) const
Definition gdcmCSAHeaderDict.h:63
CSAHeaderDict & operator=(const CSAHeaderDict &_val)=delete
ConstIterator Begin() const
Definition gdcmCSAHeaderDict.h:50
void AddCSAHeaderDictEntry(const CSAHeaderDictEntry &de)
Definition gdcmCSAHeaderDict.h:54
MapCSAHeaderDictEntry::iterator Iterator
Definition gdcmCSAHeaderDict.h:38
CSAHeaderDict(const CSAHeaderDict &_val)=delete
Class to manipulate the sum of knowledge (all the dict user load)
Definition gdcmDicts.h:29
#define GDCM_EXPORT
Definition gdcmWin32.h:34
Definition gdcmASN1.h:21
std::ostream & operator<<(std::ostream &os, const Directory &d)
Definition gdcmDirectory.h:88