]> Creatis software - gdcm.git/blobdiff - src/gdcmTagKey.h
Commenting out useless code should avoid pb on Big Endian processors.
[gdcm.git] / src / gdcmTagKey.h
index 01b35d2b0276d9bfb8e3c53a54dcefa0a31085d1..ad325d20f2a6bb679ae7b7a5f288eb37c5d2f36a 100644 (file)
@@ -3,8 +3,8 @@
   Program:   gdcm
   Module:    $RCSfile: gdcmTagKey.h,v $
   Language:  C++
-  Date:      $Date: 2005/10/19 13:17:05 $
-  Version:   $Revision: 1.1 $
+  Date:      $Date: 2005/10/26 15:36:19 $
+  Version:   $Revision: 1.7 $
                                                                                 
   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 <assert.h>
 #include <iostream>
 #include <iomanip> // for std::ios::left, ...
+#include <stdio.h> // for ugly sprintf
 
 namespace gdcm 
 {
@@ -31,48 +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(const uint16_t &gr, const 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 void SetGroup(const uint16_t &val) { tag[0] = val; }
-   inline const uint16_t &GetGroup(void) { return tag[0]; }
+   std::string str() const
+   {
+      char res[10];
+      sprintf(res,"%04x|%04x",tag[0],tag[1]);
+      return std::string(res);
+   }
 
-   inline void SetElement(const uint16_t &val) { tag[1] = val; }
-   inline const uint16_t &GetElement(void) { return tag[1]; }
+   void SetGroup(const uint16_t &group) { tag[0] = group; }
+   uint16_t &GetGroup(void) { return tag[0]; } const
 
-   inline TagKey &operator=(const TagKey &_val)
+   void SetElement(const uint16_t &elem) { tag[1] = elem; }
+   uint16_t GetElement(void) { return tag[1]; } const
+
+   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 :