From 834ba2852f69e4dceec1a0a63400fe5171a97c48 Mon Sep 17 00:00:00 2001 From: Amlal El Mahrouss Date: Wed, 20 Mar 2024 03:53:47 +0100 Subject: unstable: Add ODF header, still in WiP, althougth priority is on the AHCI driver and HCFS/NewFS support. Signed-off-by: Amlal El Mahrouss --- Public/Kits/System.Core/Containers/ODF.hxx | 43 +++++++++++++++++++++++++++++ Public/Kits/System.Core/Containers/XIFF.hxx | 24 ++++++++-------- 2 files changed, 55 insertions(+), 12 deletions(-) create mode 100644 Public/Kits/System.Core/Containers/ODF.hxx (limited to 'Public/Kits/System.Core/Containers') diff --git a/Public/Kits/System.Core/Containers/ODF.hxx b/Public/Kits/System.Core/Containers/ODF.hxx new file mode 100644 index 00000000..3c4e81fc --- /dev/null +++ b/Public/Kits/System.Core/Containers/ODF.hxx @@ -0,0 +1,43 @@ +/** =========================================== + (C) Mahrouss Logic + ===========================================*/ + +#ifndef __ODF__ +#define __ODF__ + +#include + +/** + * @brief Open Document Format + * @file ODF.hxx +*/ + +/// @brief four-character code for ODF. +#define kFourCCLength_ODF 4 + +/// @brief Document file header. +typedef struct ODFFileHeader +{ + CHAR f_Ident[kFourCCLength_ODF]; + + INT32 f_DocumentKind; + INT32 f_DocumentSize; + + INT64 f_MetaForkOffset; + INT64 f_DocumentForkOffset; + + CHAR f_Padding[4]; +} PACKED ODFFileHeader; + +/// @brief ODF Fork header +typedef struct ODFForkHeader +{ + CHAR f_MetadataName[255]; + + INT32 f_MetadataKind; + INT32 f_MetadataSize; + + CHAR f_Padding; +} PACKED ODFForkHeader; + +#endif // !__ODF__ \ No newline at end of file diff --git a/Public/Kits/System.Core/Containers/XIFF.hxx b/Public/Kits/System.Core/Containers/XIFF.hxx index b9fa741e..622a5a87 100644 --- a/Public/Kits/System.Core/Containers/XIFF.hxx +++ b/Public/Kits/System.Core/Containers/XIFF.hxx @@ -17,26 +17,26 @@ /// @brief four-character code for XIFF. #define kFourCCLength_XIFF 4 +#define kXIFFContainerVideo "XVFF" +#define kXIFFContainerAudio "XAFF" +#define kXIFFContainerInstaller "XNFF" +#define kXIFFContainerGeneric "XIFF" +#define kXIFFContainerBinary "XBFF" + /*** * @brief Generic XIFF header * Used by XIFF based containers. */ struct PACKED XiffHeader final { - BYTE f_Mag[kFourCCLength_XIFF]; // XIFF string (includes \0) - DWORD f_Size; // overall size of header (XiffHeader) in bytes - DWORD f_FormatType; // format type. generic - BYTE f_SpecificMag[4]; // The sub header magic - DWORD f_SpecificSize; // length of the format data - DWORD f_SpecificFormatType; // format type. generic + BYTE f_Magic[kFourCCLength_XIFF]; // XIFF string (includes \0) + DWORD f_Size; // overall size of header (XiffHeader) in bytes + DWORD f_FormatType; // format type. generic + BYTE f_SpecificMag[kFourCCLength_XIFF]; // The sub header magic + DWORD f_SpecificSize; // length of the format data + DWORD f_SpecificFormatType; // format type. generic }; typedef struct XiffHeader XiffHeader; -#define kXIFFContainerVideo "XVFF" -#define kXIFFContainerAudio "XAFF" -#define kXIFFContainerInstaller "XNFF" -#define kXIFFContainerGeneric "XIFF" -#define kXIFFContainerBinary "XBFF" - #endif // ifndef __XIFF__ -- cgit v1.2.3