1 /*=========================================================================
4 Module: $RCSfile: gdcmContentEntry.h,v $
6 Date: $Date: 2005/01/30 17:30:57 $
7 Version: $Revision: 1.4 $
9 Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
10 l'Image). All rights reserved. See Doc/License.txt or
11 http://www.creatis.insa-lyon.fr/Public/Gdcm/License.html for details.
13 This software is distributed WITHOUT ANY WARRANTY; without even
14 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 PURPOSE. See the above copyright notices for more information.
17 =========================================================================*/
19 #ifndef GDCMCONTENTENTRY_H
20 #define GDCMCONTENTENTRY_H
22 #include "gdcmDocEntry.h"
28 //-----------------------------------------------------------------------------
30 * \brief Any Dicom Document (File or DicomDir) contains
31 * a set of DocEntry - Dicom entries -
32 * (when successfuly parsed against a given Dicom dictionary)
33 * ContentEntry is an elementary DocEntry (as opposed to SeqEntry).
34 * Depending on the type of its content,
35 * ContentEntry is specialized as a ValEntry or a BinEntry
37 class GDCM_EXPORT ContentEntry : public DocEntry
40 virtual void WriteContent(std::ofstream *fp, FileType filetype) = 0;
42 // Accessors are protected, not to be invoked by end user
44 /// Sets the value (string) of the current Dicom entry
45 virtual void SetValue(std::string const &val) { Value = val; };
47 /// \brief Returns the 'Value' (e.g. "Dupond Marcel") converted
48 /// into a 'string', event if it's physically stored on disk as an integer
49 std::string const &GetValue() const { return Value; };
51 void Copy(DocEntry *doc);
54 // Contructors are protected, not to be invoked by end user.
55 ContentEntry(DictEntry *e);
56 ContentEntry(DocEntry *d);
57 // Destructor is protected, not to be invoked by end user.
62 /// \brief Dicom entry value, internaly represented as a std::string.
63 /// The Value Representation (\ref VR) is independently used
64 /// in order to interpret (decode) this field.
68 } // end namespace gdcm
70 //-----------------------------------------------------------------------------