X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmCommon.h;h=c66ad0d5a8ca90bd065ea0f8129ce8e314dfe1a6;hb=cd6b936f711fcbc70918e6b623b4b7b2f65dc69c;hp=15ab2b00fd876540c61887d4ddf1562c15ee4559;hpb=5512cca3f7d6ae0340e3454d3a48081c097e47e4;p=gdcm.git diff --git a/src/gdcmCommon.h b/src/gdcmCommon.h index 15ab2b00..c66ad0d5 100644 --- a/src/gdcmCommon.h +++ b/src/gdcmCommon.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmCommon.h,v $ Language: C++ - Date: $Date: 2005/07/11 16:18:47 $ - Version: $Revision: 1.74 $ + Date: $Date: 2005/08/22 15:38:05 $ + Version: $Revision: 1.85 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -85,7 +85,7 @@ typedef unsigned int uint32_t; #endif #include -#define FASTTAGKEY 1 +#define FASTTAGKEY 0 // FIXME: Should rewrite this: #if FASTTAGKEY @@ -97,6 +97,8 @@ typedef unsigned int uint32_t; #include #endif + +//----------------------------------------------------------------------------- /// \brief namespace for Grass root DiCoM namespace gdcm { @@ -134,18 +136,26 @@ typedef union { /* ostream operator for TagKey */ inline std::ostream& operator<<(std::ostream& _O, TagKey _val) { - return ( _O << std::right << std::setw(4) << std::setfill('0') << std::hex - << _val.tab[0] << "|" << std::right << std::setw(4) << - std::setfill('0') << std::hex << _val.tab[1]); -}; + _O.setf( std::ios::right); + return (_O << std::hex << std::setw( 4 ) << std::setfill( '0' ) + << _val.tab[0] << '|' << std::setw( 4 ) << std::setfill( '0' ) + << _val.tab[1] << std::setfill( ' ' ) << std::dec); +} inline bool operator==(TagKey _self, TagKey _val) { return _self.tagkey == _val.tagkey; -}; +} inline bool operator<(TagKey _self, TagKey _val) { - return _self.tagkey < _val.tagkey; -}; + // This expression is a tad faster but PrintFile output + // is more difficult to read + //return _self.tagkey < _val.tagkey; + + // More usal order of dicom tags: + if( _self.tab[0] == _val.tab[0] ) + return _self.tab[1] < _val.tab[1]; + return _self.tab[0] < _val.tab[0]; +} #else typedef std::string TagKey; #endif @@ -154,7 +164,7 @@ typedef std::string TagKey; inline std::ostream& operator<<(std::ostream& _O, std::string _val) { return _O << _val.c_str(); -}; +} #endif typedef std::string TagName; @@ -173,9 +183,19 @@ enum DicomDirType { DD_PATIENT, DD_STUDY, DD_SERIE, - DD_IMAGE + DD_IMAGE, + DD_VISIT }; +/// \brief comparaison operators +enum CompOperators { + GDCM_EQUAL = 0, + GDCM_DIFFERENT, + GDCM_GREATER, + GDCM_GREATEROREQUAL, + GDCM_LESS, + GDCM_LESSOREQUAL +}; /** * \brief structure, for internal use only */