Viewing file: gdcmCSAHeaderDict.h (2.8 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/*=========================================================================
Program: GDCM (Grassroots DICOM). A DICOM library
Copyright (c) 2006-2011 Mathieu Malaterre All rights reserved. See Copyright.txt or http://gdcm.sourceforge.net/Copyright.html for details.
This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the above copyright notice for more information.
=========================================================================*/ #ifndef GDCMCSAHEADERDICT_H #define GDCMCSAHEADERDICT_H
#include "gdcmTypes.h" #include "gdcmTag.h" #include "gdcmCSAHeaderDictEntry.h"
#include <iostream> #include <iomanip> #include <set> #include <exception>
namespace gdcm {
class GDCM_EXPORT CSAHeaderDictException : public std::exception {};
/** * \brief Class to represent a map of CSAHeaderDictEntry */ class GDCM_EXPORT CSAHeaderDict { public: typedef std::set<CSAHeaderDictEntry> MapCSAHeaderDictEntry; typedef MapCSAHeaderDictEntry::iterator Iterator; typedef MapCSAHeaderDictEntry::const_iterator ConstIterator; //static CSAHeaderDictEntry GroupLengthCSAHeaderDictEntry; // = CSAHeaderDictEntry("Group Length",VR::UL,VM::VM1);
CSAHeaderDict():CSAHeaderDictInternal() { assert( CSAHeaderDictInternal.empty() ); } CSAHeaderDict &operator=(const CSAHeaderDict &_val) = delete; CSAHeaderDict(const CSAHeaderDict &_val) = delete;
friend std::ostream& operator<<(std::ostream& _os, const CSAHeaderDict &_val);
ConstIterator Begin() const { return CSAHeaderDictInternal.begin(); } ConstIterator End() const { return CSAHeaderDictInternal.end(); }
bool IsEmpty() const { return CSAHeaderDictInternal.empty(); } void AddCSAHeaderDictEntry(const CSAHeaderDictEntry &de) { #ifndef NDEBUG MapCSAHeaderDictEntry::size_type s = CSAHeaderDictInternal.size(); #endif CSAHeaderDictInternal.insert( de ); assert( s < CSAHeaderDictInternal.size() ); }
const CSAHeaderDictEntry &GetCSAHeaderDictEntry(const char *name) const { MapCSAHeaderDictEntry::const_iterator it = CSAHeaderDictInternal.find( name ); if( it != CSAHeaderDictInternal.end() ) { return *it; } throw CSAHeaderDictException(); }
protected: friend class Dicts; void LoadDefault();
private:
MapCSAHeaderDictEntry CSAHeaderDictInternal; }; //----------------------------------------------------------------------------- inline std::ostream& operator<<(std::ostream& os, const CSAHeaderDict &val) { CSAHeaderDict::MapCSAHeaderDictEntry::const_iterator it = val.CSAHeaderDictInternal.begin(); for(;it != val.CSAHeaderDictInternal.end(); ++it) { const CSAHeaderDictEntry &de = *it; os << de << '\n'; }
return os; }
} // end namespace gdcm
#endif //GDCMCSAHEADERDICT_H
|