X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmTagKey.h;h=2d32f44359ac69c41166b06d91415d1c45372d70;hb=96775cd7d34ec152fbf1430634bb338f524ee212;hp=a498b72a763805b1899b2ba34107f2c0124d1672;hpb=5d5da90b3d23814b13cfd60f77c4447cf3666556;p=gdcm.git diff --git a/src/gdcmTagKey.h b/src/gdcmTagKey.h index a498b72a..2d32f443 100644 --- a/src/gdcmTagKey.h +++ b/src/gdcmTagKey.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmTagKey.h,v $ Language: C++ - Date: $Date: 2005/10/20 09:23:24 $ - Version: $Revision: 1.2 $ + Date: $Date: 2005/11/08 09:35:44 $ + Version: $Revision: 1.10 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -24,6 +24,7 @@ #include #include #include // for std::ios::left, ... +#include // for ugly sprintf namespace gdcm { @@ -31,55 +32,62 @@ namespace gdcm class TagKey { public : - inline TagKey(const uint16_t &gr, const uint16_t &elt) { tag[0] = gr;tag[1] = elt;} - inline TagKey() { tag[0] = tag[1] = 0x0000;} + TagKey(uint16_t gr, uint16_t elt) { tag[0] = gr;tag[1] = elt;} + TagKey() { tag[0] = tag[1] = 0x0000;} friend std::ostream& operator<<(std::ostream& _os, const TagKey &_val); - inline std::string str() const + std::string str() const { char res[10]; sprintf(res,"%04x|%04x",tag[0],tag[1]); return std::string(res); } - inline void SetGroup(const uint16_t &val) { tag[0] = val; } - inline const uint16_t &GetGroup(void) { return tag[0]; } + void SetGroup(uint16_t group) { tag[0] = group; } + uint16_t GetGroup() const { return tag[0]; } - inline void SetElement(const uint16_t &val) { tag[1] = val; } - inline const uint16_t &GetElement(void) { return tag[1]; } + void SetElement(uint16_t elem) { tag[1] = elem; } + uint16_t GetElement() const { return tag[1]; } - inline TagKey &operator=(const TagKey &_val) + TagKey &operator=(const TagKey &_val) { tag[0] = _val.tag[0]; tag[1] = _val.tag[1]; return *this; } - inline const uint16_t &operator[](const unsigned int &_id) const + TagKey(const TagKey &_val) + { + tag[0] = _val[0]; + tag[1] = _val[1]; + } + + const uint16_t &operator[](const unsigned int &_id) const { assert(_id<2); return tag[_id]; } - inline const uint16_t &operator[](const unsigned int &_id) + const uint16_t &operator[](const unsigned int &_id) { assert(_id<2); return tag[_id]; } - inline bool operator==(const TagKey &_val) const + bool operator==(const TagKey &_val) const { return tag[0] == _val.tag[0] && tag[1] == _val.tag[1]; } - inline bool operator!=(const TagKey &_val) const + bool operator!=(const TagKey &_val) const { return tag[0] != _val.tag[0] || tag[1] != _val.tag[1]; } - inline bool operator<(const TagKey &_val) const + bool operator<(const TagKey &_val) const { - return tag[0] < _val.tag[0] || (tag[0] == _val.tag[0] && tag[1] < _val.tag[1]); + return tag[0] < _val.tag[0] + || (tag[0] == _val.tag[0] && tag[1] < _val.tag[1]); } private :