-// $Header: /cvs/public/gdcm/src/Attic/gdcmElValSet.h,v 1.8 2003/04/08 15:03:35 frog Exp $
+// $Header: /cvs/public/gdcm/src/Attic/gdcmElValSet.h,v 1.10 2003/04/09 14:04:53 jpr Exp $
#ifndef GDCMELVALSET_H
#define GDCMELVALSET_H
typedef map<string, gdcmElValue*> TagElValueNameHT;
class GDCM_EXPORT gdcmElValSet {
- TagElValueHT tagHt; // Both accesses with a TagKey or with a
- TagElValueNameHT NameHt; // the DictEntry.Name are required.
-//FIXME This is redundant with gdcmHeader::FileType enum. That sux !
+ TagElValueHT tagHt; // Both accesses with a TagKey or with a
+ TagElValueNameHT NameHt; // the DictEntry.Name are required.
+
+ typedef string GroupKey;
+ typedef map<GroupKey, int> GroupHT;
+
public:
- void Add(gdcmElValue*);
- // TODO
- //void ReplaceOrCreate(gdcmElValue*);
- void Print(ostream &);
- void PrintByName(ostream &);
- int Write(FILE *fp, FileType type);
-
- gdcmElValue* GetElementByNumber(guint16 group, guint16 element);
- gdcmElValue* GetElementByName (string);
- string GetElValueByNumber(guint16 group, guint16 element);
- string GetElValueByName (string);
+ void Add(gdcmElValue*);
+
+ void Print(ostream &);
+ void PrintByName(ostream &);
+ int Write(FILE *fp, FileType type);
+
+ gdcmElValue* GetElementByNumber(guint16 group, guint16 element);
+ gdcmElValue* GetElementByName (string);
+ string GetElValueByNumber(guint16 group, guint16 element);
+ string GetElValueByName (string);
- TagElValueHT & GetTagHt(void);
+ TagElValueHT & GetTagHt(void);
- int SetElValueByNumber(string content, guint16 group, guint16 element);
- int SetElValueByName (string content, string TagName);
+ int SetElValueByNumber(string content, guint16 group, guint16 element);
+ int SetElValueByName (string content, string TagName);
- int SetElValueLengthByNumber(guint32 l, guint16 group, guint16 element);
- int SetElValueLengthByName (guint32 l, string TagName);
+ int SetElValueLengthByNumber(guint32 l, guint16 group, guint16 element);
+ int SetElValueLengthByName (guint32 l, string TagName);
guint32 GenerateFreeTagKeyInGroup(guint16 group);
private:
- void UpdateGroupLength(bool SkipSequence = false);
+ void UpdateGroupLength(bool SkipSequence = false, FileType type = ImplicitVR);
void WriteElements(FileType type, FILE *);
-
};
#endif