EuropaTools/include/europa/structs/Yatf.hpp

66 lines
1.4 KiB
C++
Raw Normal View History

//
// EuropaTools
//
2025-01-07 14:17:50 -05:00
// (C) 2021-2025 modeco80 <lily.modeco80@protonmail.ch>
//
// SPDX-License-Identifier: MIT
//
#ifndef EUROPA_STRUCTS_YATF_H
#define EUROPA_STRUCTS_YATF_H
#include <europa/structs/ImHexAdapter.hpp>
#include <europa/util/FourCC.hpp>
#include <type_traits>
namespace europa::structs {
#ifdef _MSC_VER
#pragma pack(push, 1)
#endif
struct [[gnu::packed]] YatfHeader {
enum class TextureFormat : u8 {
// V1 formats.
kTextureFormatV1_8Bpp = 0,
kTextureFormatV1_24Bpp = 2,
kTextureFormatV1_32Bpp = 3,
// V2/jsf uses these
kTextureFormatV2_8Bpp = 1,
kTextureFormatV2_24Bpp = 3,
kTextureFormatV2_32Bpp = 4,
kTextureFormatV2_4Bpp = 5
};
// For some reason Jedi Starfighter YATFs use a different fourcc. ???
constexpr static auto ValidMagicSF = util::FourCC<"YATF", std::endian::big>();
constexpr static auto ValidMagicJSF = util::FourCC<"YATF", std::endian::little>();
u32 magic;
u16 version; // 0x1 for starfighter, 0x2 for new jsf files
TextureFormat format;
u8 unkThing2; // flags? some palbpp? V2 seems to end up usually matching
// Always zeroed.
u32 zero;
u32 height;
u32 width;
[[nodiscard]] constexpr bool IsValid() const {
return magic == ValidMagicSF || magic == ValidMagicJSF;
}
};
#ifdef _MSC_VER
#pragma pack(pop)
#endif
} // namespace europa::structs
#endif // EUROPA_STRUCTS_YATF_H