aboutsummaryrefslogtreecommitdiff
path: root/Src/replicant/nsid3v2/extendedheader.h
diff options
context:
space:
mode:
authorJean-Francois Mauguit <jfmauguit@mac.com>2024-09-24 09:03:25 -0400
committerGitHub <noreply@github.com>2024-09-24 09:03:25 -0400
commitbab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/replicant/nsid3v2/extendedheader.h
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/replicant/nsid3v2/extendedheader.h')
-rw-r--r--Src/replicant/nsid3v2/extendedheader.h52
1 files changed, 52 insertions, 0 deletions
diff --git a/Src/replicant/nsid3v2/extendedheader.h b/Src/replicant/nsid3v2/extendedheader.h
new file mode 100644
index 00000000..fe85b614
--- /dev/null
+++ b/Src/replicant/nsid3v2/extendedheader.h
@@ -0,0 +1,52 @@
+#pragma once
+#include "header.h"
+
+namespace ID3v2_21
+{
+#pragma pack(push, 1)
+ struct ExtendedHeaderData
+ {
+ uint32_t size;
+ };
+#pragma pack(pop)
+
+ class ExtendedHeaderBase
+ {
+ public:
+ ExtendedHeaderBase(const ID3v2::Header &_tagHeader);
+ int Parse(const void *_data, size_t len, size_t *bytes_read);
+ enum
+ {
+ SIZE=4,
+ };
+ protected:
+ uint32_t Size() const;
+ void *data;
+ size_t data_size;
+ ExtendedHeaderData headerData;
+ const ID3v2::Header &tagHeader;
+ };
+}
+
+namespace ID3v2_3
+{
+ class ExtendedHeader : public ID3v2_21::ExtendedHeaderBase
+ {
+ public:
+ ExtendedHeader(const ID3v2::Header &_tagHeader);
+ };
+}
+
+namespace ID3v2_4
+{
+ class ExtendedHeader : public ID3v2_21::ExtendedHeaderBase
+ {
+ public:
+ ExtendedHeader(const ID3v2::Header &_tagHeader);
+ int Parse(const void *_data, size_t len, size_t *bytes_read);
+
+ protected:
+ uint32_t Size() const;
+
+ };
+}