#ifndef BINARY_H #define BINARY_H #include "dolphin/types.h" namespace JGadget { namespace binary { struct TEBit { u32 value; }; const void* parseVariableUInt_16_32_following(const void* pu16, u32* pu32First, u32* pu32Second, TEBit* tebit); inline u32 align_roundUp(u32 arg0, u32 uAlign) { return (arg0 + uAlign - 1) & ~(uAlign - 1); } struct TParseData { TParseData(const void* pContent) : raw(pContent) {} const void* getRaw() const { return raw; } void setRaw(const void* p) { raw = p; } /* 0x0 */ const void* raw; }; template struct TParseData_aligned : public TParseData { TParseData_aligned(const void* pContent) : TParseData(pContent) {} void setRaw(const void* p) { /* if ((u32)p % T != 0) { JUTWarn w; w << "misaligned : " << (u32)p; } */ static_cast(this)->setRaw(p); } }; // Base for header and/or block parsing struct TParse_header_block { virtual ~TParse_header_block() = 0; virtual bool parseHeader_next(const void** ppData_inout, u32* puBlock_out, u32 arg2) = 0; virtual bool parseBlock_next(const void** ppData_inout, u32* puData_out, u32 arg2) = 0; bool parse_next(const void** ppData_inout, u32 a2); bool parse(const void* ppData_inout, u32 a2) { return parse_next(&ppData_inout, a2); } bool checkNext(const void** ptrLocation, u32* headerEnd, u32 idx) { bool checkNext = false; if (parseHeader_next(ptrLocation, headerEnd, idx)) { checkNext = true; } return checkNext; } }; template struct TParseValue_raw_ { typedef T ParseType; static T parse(const void* data) { return *(T*)data; } }; template struct TParseValue_endian_big_ : public TParseValue_raw_ { static T parse(const void* data) { return TParseValue_raw_::parse(data); } }; template class Parser> struct TParseValue : public Parser { static T parse(const void* data) { return Parser::parse(data); } static T parse(const void* data, s32 advanceNum) { return Parser::parse(advance(data, advanceNum)); } static const void* advance(const void* data, s32 advanceNum) { return (char*)data + (advanceNum * sizeof(T)); } }; template struct TValueIterator { TValueIterator(const void* begin) { mBegin = begin; } const void* get() const { return mBegin; } typename Parser::ParseType operator*() const { return Parser::parse(get()); } TValueIterator& operator++() { const_cast(mBegin)++; return *this; } const TValueIterator operator++(int) { TValueIterator old(*this); ++(*this); return old; } TValueIterator& operator+=(s32 v) { const_cast(mBegin) += v; return *this; } const void* mBegin; }; template struct TValueIterator_raw : public TValueIterator, 1> { TValueIterator_raw(const void* begin) : TValueIterator, 1>(begin) {} }; template struct TParseValue_misaligned : TParseValue_raw_ { static T parse(const void* data) { return TParseValue_raw_::parse(data); } }; template struct TValueIterator_misaligned : public TValueIterator, sizeof(T)> { TValueIterator_misaligned(const void* begin) : TValueIterator, sizeof(T)>(begin) {} }; inline bool operator==(TValueIterator, 4> a, TValueIterator, 4> b) { return a.mBegin == b.mBegin; } } // namespace binary } // namespace JGadget #endif /* BINARY_H */