From a6913c2174cba9569898057c3180a113df8448e5 Mon Sep 17 00:00:00 2001 From: Philip de Nier Date: Thu, 28 Mar 2024 16:08:48 +0000 Subject: [PATCH] MXFDump: add dump of generic stream partition packs --- deps/libMXF/tools/MXFDump/MXFDump.cpp | 15 +++++++++++++++ deps/libMXF/tools/MXFDump/MXFMetaDictionary.h | 7 +++++++ 2 files changed, 22 insertions(+) diff --git a/deps/libMXF/tools/MXFDump/MXFDump.cpp b/deps/libMXF/tools/MXFDump/MXFDump.cpp index 71d97c9c..ed4a71ed 100644 --- a/deps/libMXF/tools/MXFDump/MXFDump.cpp +++ b/deps/libMXF/tools/MXFDump/MXFDump.cpp @@ -5294,6 +5294,8 @@ void destroyPartitions(PartitionList& partitions) // OpenBody 06 0e 2b 34 02 05 01 01 0d 01 02 01 01 03 03 00 // Body 06 0e 2b 34 02 05 01 01 0d 01 02 01 01 03 04 00 // +// GenericStream 06 0e 2b 34 02 05 01 01 0d 01 02 01 01 03 11 00 +// // IncompleteFooter 06 0e 2b 34 02 05 01 01 0d 01 02 01 01 04 02 00 // Footer 06 0e 2b 34 02 05 01 01 0d 01 02 01 01 04 04 00 // @@ -5326,6 +5328,8 @@ bool isPartition(mxfKey& key) result = true; } else if (memcmp(&Body, &key, sizeof(mxfKey)) == 0) { result = true; + } else if (memcmp(&GenericStream, &key, sizeof(mxfKey)) == 0) { + result = true; } else if (memcmp(&IncompleteFooter, &key, sizeof(mxfKey)) == 0) { result = true; } else if (memcmp(&Footer, &key, sizeof(mxfKey)) == 0) { @@ -5377,6 +5381,8 @@ bool isClosed(const mxfKey& key) result = true; } else if (memcmp(&Body, &key, sizeof(mxfKey)) == 0) { result = true; + } else if (memcmp(&GenericStream, &key, sizeof(mxfKey)) == 0) { + result = true; } else if (memcmp(&IncompleteFooter, &key, sizeof(mxfKey)) == 0) { result = true; } else if (memcmp(&Footer, &key, sizeof(mxfKey)) == 0) { @@ -5728,6 +5734,13 @@ void printBodyPartition(mxfKey& k, mxfLength& len, mxfFile infile) printPartition(k, len, infile); } +void printGenericStreamPartition(mxfKey& k, mxfLength& len, mxfFile infile); + +void printGenericStreamPartition(mxfKey& k, mxfLength& len, mxfFile infile) +{ + printPartition(k, len, infile); +} + void printFooterPartition(mxfKey& k, mxfLength& len, mxfFile infile); void printFooterPartition(mxfKey& k, mxfLength& len, mxfFile infile) @@ -6640,6 +6653,8 @@ void mxfDumpKLV(mxfKey& k, mxfLength& len, mxfFile infile) printBodyPartition(k, len, infile); } else if (memcmp(&Body, &k, sizeof(mxfKey)) == 0) { printBodyPartition(k, len, infile); + } else if (memcmp(&GenericStream, &k, sizeof(mxfKey)) == 0) { + printGenericStreamPartition(k, len, infile); } else if (memcmp(&IncompleteFooter, &k, sizeof(mxfKey)) == 0) { printFooterPartition(k, len, infile); } else if (memcmp(&Footer, &k, sizeof(mxfKey)) == 0) { diff --git a/deps/libMXF/tools/MXFDump/MXFMetaDictionary.h b/deps/libMXF/tools/MXFDump/MXFMetaDictionary.h index 5dcfe3cd..e3df7505 100644 --- a/deps/libMXF/tools/MXFDump/MXFMetaDictionary.h +++ b/deps/libMXF/tools/MXFDump/MXFMetaDictionary.h @@ -229,6 +229,13 @@ MXF_DEFINE_PACK_KEY(Body, MXF_LABEL(0x06, 0x0e, 0x2b, 0x34, 0x02, 0x05, 0x01, 0x01, 0x0d, 0x01, 0x02, 0x01, 0x01, 0x03, 0x04, 0x00)) +// Generic Stream Partition Pack +// +// 06.0e.2b.34.02.05.01.01.0d.01.02.01.01.03.11.00 +MXF_DEFINE_PACK_KEY(GenericStream, + MXF_LABEL(0x06, 0x0e, 0x2b, 0x34, 0x02, 0x05, 0x01, 0x01, + 0x0d, 0x01, 0x02, 0x01, 0x01, 0x03, 0x11, 0x00)) + // Footer Partition Pack // // 06.0e.2b.34.02.05.01.01.0d.01.02.01.01.04.02.00