const, baby
[asdcplib.git] / src / Metadata.h
index deb1abd7804be042a35dbe3874d9a58a52fbc349..4c83034c1a68275407ce2c95d4c998407c8df90f 100755 (executable)
@@ -1,5 +1,5 @@
 /*
-Copyright (c) 2005-2006, John Hurst
+Copyright (c) 2005-2009, John Hurst
 All rights reserved.
 
 Redistribution and use in source and binary forms, with or without
@@ -29,8 +29,8 @@ THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     \brief   MXF metadata objects
 */
 
-#ifndef _METADATA_H_
-#define _METADATA_H_
+#ifndef _Metadata_H_
+#define _Metadata_H_
 
 #include "MXF.h"
 
@@ -38,377 +38,656 @@ namespace ASDCP
 {
   namespace MXF
     {
+      void Metadata_InitTypes(const Dictionary*& Dict);
+
+      //
+
       //
       class Identification : public InterchangeObject
        {
          ASDCP_NO_COPY_CONSTRUCT(Identification);
+         Identification();
 
        public:
-         UUID         ThisGenerationUID;
-         UTF16String  CompanyName;
-         UTF16String  ProductName;
-         ui16_t       ProductVersion;
-         UTF16String  VersionString;
-         UUID         ProductUID;
-         Timestamp    ModificationDate;
-         ui16_t       ToolkitVersion;
-         UTF16String  Platform;
-
-         Identification() {}
+         const Dictionary*& m_Dict;
+          UUID ThisGenerationUID;
+          UTF16String CompanyName;
+          UTF16String ProductName;
+          VersionType ProductVersion;
+          UTF16String VersionString;
+          UUID ProductUID;
+          Timestamp ModificationDate;
+          VersionType ToolkitVersion;
+          UTF16String Platform;
+
+  Identification(const Dictionary*& d) : InterchangeObject(d), m_Dict(d) {}
          virtual ~Identification() {}
+          virtual const char* HasName() { return "Identification"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
-         virtual void     Dump(FILE* = 0);
        };
 
-
       //
       class ContentStorage : public InterchangeObject
        {
          ASDCP_NO_COPY_CONSTRUCT(ContentStorage);
+         ContentStorage();
 
        public:
-         UUID        GenerationUID;
-         Batch<UUID> Packages;
-         Batch<UUID> EssenceContainerData;
+         const Dictionary*& m_Dict;
+          Batch<UUID> Packages;
+          Batch<UUID> EssenceContainerData;
 
-         ContentStorage() {}
+  ContentStorage(const Dictionary*& d) : InterchangeObject(d), m_Dict(d) {}
          virtual ~ContentStorage() {}
+          virtual const char* HasName() { return "ContentStorage"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
+
+      //
+      class EssenceContainerData : public InterchangeObject
+       {
+         ASDCP_NO_COPY_CONSTRUCT(EssenceContainerData);
+         EssenceContainerData();
+
+       public:
+         const Dictionary*& m_Dict;
+          UMID LinkedPackageUID;
+          ui32_t IndexSID;
+          ui32_t BodySID;
+
+  EssenceContainerData(const Dictionary*& d) : InterchangeObject(d), m_Dict(d), IndexSID(0), BodySID(0) {}
+         virtual ~EssenceContainerData() {}
+          virtual const char* HasName() { return "EssenceContainerData"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
          virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
        };
 
-      // 
+      //
       class GenericPackage : public InterchangeObject
        {
          ASDCP_NO_COPY_CONSTRUCT(GenericPackage);
+         GenericPackage();
 
        public:
-         UMID          PackageUID;
-         UUID          GenerationUID;
-          UTF16String   Name;
-          Timestamp     PackageCreationDate;
-          Timestamp     PackageModifiedDate;
-          Batch<UID>    Tracks;
-
-          GenericPackage() {}
+         const Dictionary*& m_Dict;
+          UMID PackageUID;
+          UTF16String Name;
+          Timestamp PackageCreationDate;
+          Timestamp PackageModifiedDate;
+          Batch<UUID> Tracks;
+
+  GenericPackage(const Dictionary*& d) : InterchangeObject(d), m_Dict(d) {}
          virtual ~GenericPackage() {}
-         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l) = 0;
-         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
-         virtual void     Dump(FILE* = 0) = 0;
-        };
-
+          virtual const char* HasName() { return "GenericPackage"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+       };
 
-      // 
+      //
       class MaterialPackage : public GenericPackage
        {
          ASDCP_NO_COPY_CONSTRUCT(MaterialPackage);
+         MaterialPackage();
 
        public:
-          MaterialPackage() {}
+         const Dictionary*& m_Dict;
+
+  MaterialPackage(const Dictionary*& d) : GenericPackage(d), m_Dict(d) {}
          virtual ~MaterialPackage() {}
+          virtual const char* HasName() { return "MaterialPackage"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
-         virtual void     Dump(FILE* = 0);
-        };
-
+       };
 
-      // 
+      //
       class SourcePackage : public GenericPackage
        {
          ASDCP_NO_COPY_CONSTRUCT(SourcePackage);
+         SourcePackage();
 
        public:
-          SourcePackage() {}
+         const Dictionary*& m_Dict;
+          UUID Descriptor;
+
+  SourcePackage(const Dictionary*& d) : GenericPackage(d), m_Dict(d) {}
          virtual ~SourcePackage() {}
+          virtual const char* HasName() { return "SourcePackage"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
+
+      //
+      class GenericTrack : public InterchangeObject
+       {
+         ASDCP_NO_COPY_CONSTRUCT(GenericTrack);
+         GenericTrack();
+
+       public:
+         const Dictionary*& m_Dict;
+          ui32_t TrackID;
+          ui32_t TrackNumber;
+          UTF16String TrackName;
+          UUID Sequence;
+
+  GenericTrack(const Dictionary*& d) : InterchangeObject(d), m_Dict(d), TrackID(0), TrackNumber(0) {}
+         virtual ~GenericTrack() {}
+          virtual const char* HasName() { return "GenericTrack"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
          virtual void     Dump(FILE* = 0);
-        };
+       };
 
       //
-      class Track : public InterchangeObject
+      class StaticTrack : public GenericTrack
+       {
+         ASDCP_NO_COPY_CONSTRUCT(StaticTrack);
+         StaticTrack();
+
+       public:
+         const Dictionary*& m_Dict;
+
+  StaticTrack(const Dictionary*& d) : GenericTrack(d), m_Dict(d) {}
+         virtual ~StaticTrack() {}
+          virtual const char* HasName() { return "StaticTrack"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
+
+      //
+      class Track : public GenericTrack
        {
          ASDCP_NO_COPY_CONSTRUCT(Track);
+         Track();
 
        public:
-         UUID        GenerationUID;
-         ui32_t      TrackID;
-         ui32_t      TrackNumber;
-         UTF16String TrackName;
-         UUID        Sequence;
-         Rational    EditRate;
-         ui64_t      Origin;
-
-         Track() {}
+         const Dictionary*& m_Dict;
+          Rational EditRate;
+          ui64_t Origin;
+
+  Track(const Dictionary*& d) : GenericTrack(d), m_Dict(d), Origin(0) {}
          virtual ~Track() {}
+          virtual const char* HasName() { return "Track"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
+
+      //
+      class StructuralComponent : public InterchangeObject
+       {
+         ASDCP_NO_COPY_CONSTRUCT(StructuralComponent);
+         StructuralComponent();
+
+       public:
+         const Dictionary*& m_Dict;
+          UL DataDefinition;
+          ui64_t Duration;
+
+  StructuralComponent(const Dictionary*& d) : InterchangeObject(d), m_Dict(d), Duration(0) {}
+         virtual ~StructuralComponent() {}
+          virtual const char* HasName() { return "StructuralComponent"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
          virtual void     Dump(FILE* = 0);
        };
 
-      // 
-      class Sequence : public InterchangeObject
+      //
+      class Sequence : public StructuralComponent
        {
          ASDCP_NO_COPY_CONSTRUCT(Sequence);
+         Sequence();
 
        public:
-         UUID          GenerationUID;
-          UL            DataDefinition;
-          ui64_t        Duration;
-          Batch<UID>    StructuralComponents;
+         const Dictionary*& m_Dict;
+          Batch<UUID> StructuralComponents;
 
-          Sequence() {}
+  Sequence(const Dictionary*& d) : StructuralComponent(d), m_Dict(d) {}
          virtual ~Sequence() {}
+          virtual const char* HasName() { return "Sequence"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
-         virtual void     Dump(FILE* = 0);
-        };
+       };
 
-      // 
-      class SourceClip : public InterchangeObject
+      //
+      class SourceClip : public StructuralComponent
        {
          ASDCP_NO_COPY_CONSTRUCT(SourceClip);
+         SourceClip();
 
        public:
-         UUID          GenerationUID;
-          UL            DataDefinition;
-          ui64_t        StartPosition;
-          ui64_t        Duration;
-          UMID          SourcePackageID;
-          ui32_t        SourceTrackID;
-
-          SourceClip() {}
+         const Dictionary*& m_Dict;
+          ui64_t StartPosition;
+          UMID SourcePackageID;
+          ui32_t SourceTrackID;
+
+  SourceClip(const Dictionary*& d) : StructuralComponent(d), m_Dict(d), StartPosition(0), SourceTrackID(0) {}
          virtual ~SourceClip() {}
+          virtual const char* HasName() { return "SourceClip"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
-         virtual void     Dump(FILE* = 0);
-        };
+       };
 
-       //
-       class TimecodeComponent : public InterchangeObject
+      //
+      class TimecodeComponent : public StructuralComponent
        {
          ASDCP_NO_COPY_CONSTRUCT(TimecodeComponent);
+         TimecodeComponent();
 
        public:
-         UUID          GenerationUID;
-          UL            DataDefinition;
-          ui64_t        Duration;
-          ui16_t        RoundedTimecodeBase;
-          ui64_t        StartTimecode;
-          ui8_t         DropFrame;
-
-          TimecodeComponent() {}
+         const Dictionary*& m_Dict;
+          ui16_t RoundedTimecodeBase;
+          ui64_t StartTimecode;
+          ui8_t DropFrame;
+
+  TimecodeComponent(const Dictionary*& d) : StructuralComponent(d), m_Dict(d), RoundedTimecodeBase(0), StartTimecode(0), DropFrame(0) {}
          virtual ~TimecodeComponent() {}
+          virtual const char* HasName() { return "TimecodeComponent"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
-         virtual void     Dump(FILE* = 0);
-        };
-    
+       };
+
       //
-      class MPEG2VideoDescriptor : public ASDCP::MPEG2::VideoDescriptor, public InterchangeObject
+      class GenericDescriptor : public InterchangeObject
        {
-         ASDCP_NO_COPY_CONSTRUCT(MPEG2VideoDescriptor);
-
-        public:
-         ui32_t LinkedTrackID;
-         UL     EssenceContainer;
+         ASDCP_NO_COPY_CONSTRUCT(GenericDescriptor);
+         GenericDescriptor();
 
-         MPEG2VideoDescriptor() : LinkedTrackID(0) {}
-         ~MPEG2VideoDescriptor() {}
-          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
-         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
-          virtual void     Dump(FILE* = 0);
+       public:
+         const Dictionary*& m_Dict;
+          Batch<UUID> Locators;
+          Batch<UUID> SubDescriptors;
+
+  GenericDescriptor(const Dictionary*& d) : InterchangeObject(d), m_Dict(d) {}
+         virtual ~GenericDescriptor() {}
+          virtual const char* HasName() { return "GenericDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
        };
 
       //
-      class FileDescriptor : public InterchangeObject
+      class FileDescriptor : public GenericDescriptor
        {
          ASDCP_NO_COPY_CONSTRUCT(FileDescriptor);
+         FileDescriptor();
 
-        public:
-         UUID      GenerationUID;
-         Batch<UUID> Locators;
-         Batch<UUID> SubDescriptors;
-         ui32_t    LinkedTrackID;
-         Rational  SampleRate;
-         ui64_t    ContainerDuration;
-         UL        EssenceContainer;
-         UL        Codec;
-
-         FileDescriptor() : LinkedTrackID(0), ContainerDuration(0) {}
-         ~FileDescriptor() {}
+       public:
+         const Dictionary*& m_Dict;
+          ui32_t LinkedTrackID;
+          Rational SampleRate;
+          ui64_t ContainerDuration;
+          UL EssenceContainer;
+          UL Codec;
+
+  FileDescriptor(const Dictionary*& d) : GenericDescriptor(d), m_Dict(d), LinkedTrackID(0), ContainerDuration(0) {}
+         virtual ~FileDescriptor() {}
+          virtual const char* HasName() { return "FileDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
+
+      //
+      class GenericSoundEssenceDescriptor : public FileDescriptor
+       {
+         ASDCP_NO_COPY_CONSTRUCT(GenericSoundEssenceDescriptor);
+         GenericSoundEssenceDescriptor();
+
+       public:
+         const Dictionary*& m_Dict;
+          Rational AudioSamplingRate;
+          ui8_t Locked;
+          ui8_t AudioRefLevel;
+          ui32_t ChannelCount;
+          ui32_t QuantizationBits;
+          ui8_t DialNorm;
+
+  GenericSoundEssenceDescriptor(const Dictionary*& d) : FileDescriptor(d), m_Dict(d), Locked(0), AudioRefLevel(0), ChannelCount(0), QuantizationBits(0), DialNorm(0) {}
+         virtual ~GenericSoundEssenceDescriptor() {}
+          virtual const char* HasName() { return "GenericSoundEssenceDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
          virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
        };
 
       //
-      class WaveAudioDescriptor : public FileDescriptor
+      class WaveAudioDescriptor : public GenericSoundEssenceDescriptor
        {
          ASDCP_NO_COPY_CONSTRUCT(WaveAudioDescriptor);
+         WaveAudioDescriptor();
 
-        public:
-         Rational AudioSamplingRate;
-         ui8_t    Locked;
-         i8_t     AudioRefLevel;
-         ui8_t    ElectroSpatialFormulation;
-         ui32_t   ChannelCount;
-         ui32_t   QuantizationBits;
-         i8_t     DialNorm;
-         UL       SoundEssenceCompression;
-         ui16_t   BlockAlign;
-         ui8_t    SequenceOffset;
-         ui32_t   AvgBps;
-         //      Stream   PeakEnvelope;
-
-         WaveAudioDescriptor() :
-           Locked(false), AudioRefLevel(0), ElectroSpatialFormulation(0),
-           ChannelCount(0), QuantizationBits(0), DialNorm(0), BlockAlign(0), 
-           SequenceOffset(0), AvgBps(0) {}
-
-         ~WaveAudioDescriptor() {}
-          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+       public:
+         const Dictionary*& m_Dict;
+          ui16_t BlockAlign;
+          ui8_t SequenceOffset;
+          ui32_t AvgBps;
+          UL ChannelAssignment;
+
+  WaveAudioDescriptor(const Dictionary*& d) : GenericSoundEssenceDescriptor(d), m_Dict(d), BlockAlign(0), SequenceOffset(0), AvgBps(0) {}
+         virtual ~WaveAudioDescriptor() {}
+          virtual const char* HasName() { return "WaveAudioDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
-          virtual void     Dump(FILE* = 0);
        };
 
       //
       class GenericPictureEssenceDescriptor : public FileDescriptor
        {
          ASDCP_NO_COPY_CONSTRUCT(GenericPictureEssenceDescriptor);
+         GenericPictureEssenceDescriptor();
 
-        public:
-         ui8_t    FrameLayout;
-         ui32_t   StoredWidth;
-         ui32_t   StoredHeight;
-         ui32_t   DisplayWidth;
-         ui32_t   DisplayHeight;
-         Rational AspectRatio;
-         ui32_t   ComponentMaxRef;
-         ui32_t   ComponentMinRef;
-         UL       Gamma;
-         UL       PictureEssenceCoding;
-
-         GenericPictureEssenceDescriptor() :
-           FrameLayout(0), StoredWidth(0), StoredHeight(0), DisplayWidth(0), 
-           DisplayHeight(0), ComponentMaxRef(0), ComponentMinRef(0) {}
-
-         ~GenericPictureEssenceDescriptor() {}
-         //          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+       public:
+         const Dictionary*& m_Dict;
+          ui8_t FrameLayout;
+          ui32_t StoredWidth;
+          ui32_t StoredHeight;
+          Rational AspectRatio;
+          UL PictureEssenceCoding;
+
+  GenericPictureEssenceDescriptor(const Dictionary*& d) : FileDescriptor(d), m_Dict(d), FrameLayout(0), StoredWidth(0), StoredHeight(0) {}
+         virtual ~GenericPictureEssenceDescriptor() {}
+          virtual const char* HasName() { return "GenericPictureEssenceDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
-         //          virtual void     Dump(FILE* = 0);
        };
 
       //
       class RGBAEssenceDescriptor : public GenericPictureEssenceDescriptor
        {
          ASDCP_NO_COPY_CONSTRUCT(RGBAEssenceDescriptor);
+         RGBAEssenceDescriptor();
 
-        public:
-         class RGBLayout
-           {
-           public:
-             struct element {
-               ui8_t Code;
-               ui8_t Depth;
-             } PictureElement[8];
-             RGBLayout() { memset(PictureElement, 0, sizeof(PictureElement)); }
-           };
-
-         RGBLayout PixelLayout;
-
-         RGBAEssenceDescriptor() {}
-         ~RGBAEssenceDescriptor() {}
-         //          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+       public:
+         const Dictionary*& m_Dict;
+          ui32_t ComponentMaxRef;
+          ui32_t ComponentMinRef;
+
+  RGBAEssenceDescriptor(const Dictionary*& d) : GenericPictureEssenceDescriptor(d), m_Dict(d), ComponentMaxRef(0), ComponentMinRef(0) {}
+         virtual ~RGBAEssenceDescriptor() {}
+          virtual const char* HasName() { return "RGBAEssenceDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
-         //          virtual void     Dump(FILE* = 0);
        };
 
-      class Raw
+      //
+      class JPEG2000PictureSubDescriptor : public InterchangeObject
        {
-         ASDCP_NO_COPY_CONSTRUCT(Raw);
+         ASDCP_NO_COPY_CONSTRUCT(JPEG2000PictureSubDescriptor);
+         JPEG2000PictureSubDescriptor();
 
        public:
-         byte_t* data;
-         Raw() {}
-         ~Raw() {}
+         const Dictionary*& m_Dict;
+          ui16_t Rsize;
+          ui32_t Xsize;
+          ui32_t Ysize;
+          ui32_t XOsize;
+          ui32_t YOsize;
+          ui32_t XTsize;
+          ui32_t YTsize;
+          ui32_t XTOsize;
+          ui32_t YTOsize;
+          ui16_t Csize;
+          Raw PictureComponentSizing;
+          Raw CodingStyleDefault;
+          Raw QuantizationDefault;
+
+  JPEG2000PictureSubDescriptor(const Dictionary*& d) : InterchangeObject(d), m_Dict(d), Rsize(0), Xsize(0), Ysize(0), XOsize(0), YOsize(0), XTsize(0), YTsize(0), XTOsize(0), YTOsize(0), Csize(0) {}
+         virtual ~JPEG2000PictureSubDescriptor() {}
+          virtual const char* HasName() { return "JPEG2000PictureSubDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
 
+      //
+      class CDCIEssenceDescriptor : public GenericPictureEssenceDescriptor
+       {
+         ASDCP_NO_COPY_CONSTRUCT(CDCIEssenceDescriptor);
+         CDCIEssenceDescriptor();
+
+       public:
+         const Dictionary*& m_Dict;
+          ui32_t ComponentDepth;
+          ui32_t HorizontalSubsampling;
+          ui32_t VerticalSubsampling;
+          ui8_t ColorSiting;
+
+  CDCIEssenceDescriptor(const Dictionary*& d) : GenericPictureEssenceDescriptor(d), m_Dict(d), ComponentDepth(0), HorizontalSubsampling(0), VerticalSubsampling(0), ColorSiting(0) {}
+         virtual ~CDCIEssenceDescriptor() {}
+          virtual const char* HasName() { return "CDCIEssenceDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
        };
 
       //
-      class JPEG2000PictureSubDescriptor : public InterchangeObject
+      class MPEG2VideoDescriptor : public CDCIEssenceDescriptor
        {
-         ASDCP_NO_COPY_CONSTRUCT(JPEG2000PictureSubDescriptor);
+         ASDCP_NO_COPY_CONSTRUCT(MPEG2VideoDescriptor);
+         MPEG2VideoDescriptor();
 
        public:
-         ui16_t Rsize;
-         ui32_t Xsize;
-         ui32_t Ysize;
-         ui32_t XOsize;
-         ui32_t YOsize;
-         ui32_t XTsize;
-         ui32_t YTsize;
-         ui32_t XTOsize;
-         ui32_t YTOsize;
-         ui16_t Csize;
-         Raw PictureComponentSizing;
-         Raw CodingStyleDefault;
-         Raw QuantizationDefault;
-
-         JPEG2000PictureSubDescriptor() :
-           Rsize(0), Xsize(0), Ysize(0),
-           XOsize(0), YOsize(0), XTsize(0),
-           YTsize(0), XTOsize(0), YTOsize(0),
-           Csize(0) {}
-
-         ~JPEG2000PictureSubDescriptor() {}
-          //          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         const Dictionary*& m_Dict;
+          ui8_t CodedContentType;
+          ui8_t LowDelay;
+          ui32_t BitRate;
+          ui8_t ProfileAndLevel;
+
+  MPEG2VideoDescriptor(const Dictionary*& d) : CDCIEssenceDescriptor(d), m_Dict(d), CodedContentType(0), LowDelay(0), BitRate(0), ProfileAndLevel(0) {}
+         virtual ~MPEG2VideoDescriptor() {}
+          virtual const char* HasName() { return "MPEG2VideoDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
          virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
-          //          virtual void     Dump(FILE* = 0);
-        };
+       };
+
+      //
+      class DMSegment : public InterchangeObject
+       {
+         ASDCP_NO_COPY_CONSTRUCT(DMSegment);
+         DMSegment();
 
+       public:
+         const Dictionary*& m_Dict;
+          UL DataDefinition;
+          ui64_t EventStartPosition;
+          ui64_t Duration;
+          UTF16String EventComment;
+          UUID DMFramework;
+
+  DMSegment(const Dictionary*& d) : InterchangeObject(d), m_Dict(d), EventStartPosition(0), Duration(0) {}
+         virtual ~DMSegment() {}
+          virtual const char* HasName() { return "DMSegment"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
 
       //
       class CryptographicFramework : public InterchangeObject
        {
          ASDCP_NO_COPY_CONSTRUCT(CryptographicFramework);
+         CryptographicFramework();
 
        public:
-         UUID ContextSR;
-
-         CryptographicFramework() {}
-         ~CryptographicFramework() {}
-         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
-         // virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+         const Dictionary*& m_Dict;
+          UUID ContextSR;
+
+  CryptographicFramework(const Dictionary*& d) : InterchangeObject(d), m_Dict(d) {}
+         virtual ~CryptographicFramework() {}
+          virtual const char* HasName() { return "CryptographicFramework"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
          virtual void     Dump(FILE* = 0);
-        };
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
 
       //
       class CryptographicContext : public InterchangeObject
        {
          ASDCP_NO_COPY_CONSTRUCT(CryptographicContext);
+         CryptographicContext();
 
        public:
-         UUID ContextID;
-         UL   SourceEssenceContainer;
-         UL   CipherAlgorithm;
-         UL   MICAlgorithm;
-         UUID CryptographicKeyID;
-
-         CryptographicContext() {}
-         ~CryptographicContext() {}
+         const Dictionary*& m_Dict;
+          UUID ContextID;
+          UL SourceEssenceContainer;
+          UL CipherAlgorithm;
+          UL MICAlgorithm;
+          UUID CryptographicKeyID;
+
+  CryptographicContext(const Dictionary*& d) : InterchangeObject(d), m_Dict(d) {}
+         virtual ~CryptographicContext() {}
+          virtual const char* HasName() { return "CryptographicContext"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
          virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
-         // virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
+
+      //
+      class GenericDataEssenceDescriptor : public FileDescriptor
+       {
+         ASDCP_NO_COPY_CONSTRUCT(GenericDataEssenceDescriptor);
+         GenericDataEssenceDescriptor();
+
+       public:
+         const Dictionary*& m_Dict;
+          UL DataEssenceCoding;
+
+  GenericDataEssenceDescriptor(const Dictionary*& d) : FileDescriptor(d), m_Dict(d) {}
+         virtual ~GenericDataEssenceDescriptor() {}
+          virtual const char* HasName() { return "GenericDataEssenceDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
          virtual void     Dump(FILE* = 0);
-        };
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
+
+      //
+      class TimedTextDescriptor : public GenericDataEssenceDescriptor
+       {
+         ASDCP_NO_COPY_CONSTRUCT(TimedTextDescriptor);
+         TimedTextDescriptor();
+
+       public:
+         const Dictionary*& m_Dict;
+          UUID ResourceID;
+          UTF16String UCSEncoding;
+          UTF16String NamespaceURI;
+
+  TimedTextDescriptor(const Dictionary*& d) : GenericDataEssenceDescriptor(d), m_Dict(d) {}
+         virtual ~TimedTextDescriptor() {}
+          virtual const char* HasName() { return "TimedTextDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
+
+      //
+      class TimedTextResourceSubDescriptor : public InterchangeObject
+       {
+         ASDCP_NO_COPY_CONSTRUCT(TimedTextResourceSubDescriptor);
+         TimedTextResourceSubDescriptor();
+
+       public:
+         const Dictionary*& m_Dict;
+          UUID AncillaryResourceID;
+          UTF16String MIMEMediaType;
+          ui32_t EssenceStreamID;
+
+  TimedTextResourceSubDescriptor(const Dictionary*& d) : InterchangeObject(d), m_Dict(d), EssenceStreamID(0) {}
+         virtual ~TimedTextResourceSubDescriptor() {}
+          virtual const char* HasName() { return "TimedTextResourceSubDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
+
+      //
+      class StereoscopicPictureSubDescriptor : public InterchangeObject
+       {
+         ASDCP_NO_COPY_CONSTRUCT(StereoscopicPictureSubDescriptor);
+         StereoscopicPictureSubDescriptor();
+
+       public:
+         const Dictionary*& m_Dict;
+
+  StereoscopicPictureSubDescriptor(const Dictionary*& d) : InterchangeObject(d), m_Dict(d) {}
+         virtual ~StereoscopicPictureSubDescriptor() {}
+          virtual const char* HasName() { return "StereoscopicPictureSubDescriptor"; }
+          virtual Result_t InitFromTLVSet(TLVReader& TLVSet);
+          virtual Result_t WriteToTLVSet(TLVWriter& TLVSet);
+         virtual void     Dump(FILE* = 0);
+         virtual Result_t InitFromBuffer(const byte_t* p, ui32_t l);
+         virtual Result_t WriteToBuffer(ASDCP::FrameBuffer&);
+       };
 
     } // namespace MXF
 } // namespace ASDCP
 
 
-#endif // _METADATA_H_
+#endif // _Metadata_H_
 
 //
 // end Metadata.h