/*** Copyright (C) 2021 J Reece Wilson (a/k/a "Reece"). All rights reserved. File: AuroraUtils.hpp Date: 2021-6-9 Author: Reece ***/ #pragma once #if !defined(AURORA_RUNTIME_MAKE_SHARED) #define AURORA_RUNTIME_MAKE_SHARED std::make_shared #endif template static auline AuSPtr AuMakeShared(Args&&... args) { try { return AURORA_RUNTIME_MAKE_SHARED(AuForward(args)...); } catch (...) { return {}; } } #if !defined(AURORA_RUNTIME_MAKE_PAIR) #define AURORA_RUNTIME_MAKE_PAIR std::make_pair #endif template static auline auto AuMakePair(Args&&... args) { return AURORA_RUNTIME_MAKE_PAIR(AuForward(args)...); } #if !defined(AURORA_RUNTIME_MAKE_TUPLE) #define AURORA_RUNTIME_MAKE_TUPLE std::make_tuple #endif template static auline auto AuMakeTuple(Args&&... args) { return AURORA_RUNTIME_MAKE_TUPLE(AuForward(args)...); } #if !defined(AURORA_RUNTIME_TO_STRING) #define AURORA_RUNTIME_TO_STRING std::to_string #endif template AuString AuToString(const T &obj) { return AURORA_RUNTIME_TO_STRING(obj); } #if !defined(AURORA_RUNTIME_EXCHANGE) #define AURORA_RUNTIME_EXCHANGE std::exchange #endif template T AuExchange(T &obj, U &&new_value) { return AURORA_RUNTIME_EXCHANGE(obj, new_value); } #if !defined(AURORA_RUNTIME_MIN) #define AURORA_RUNTIME_MIN std::min #endif template< class T > constexpr const T &AuMin(const T &a, const T &b) { return AURORA_RUNTIME_MIN(a, b); } #if !defined(AURORA_RUNTIME_MAX) #define AURORA_RUNTIME_MAX std::max #endif template< class T > constexpr const T &AuMax(const T &a, const T &b) { return AURORA_RUNTIME_MAX(a, b); } #if !defined(AURORA_RUNTIME_MEMCMP) #define AURORA_RUNTIME_MEMCMP std::memcmp #endif static auline int AuMemcmp(const void *dest, const void *src, size_t n) { return AURORA_RUNTIME_MEMCMP(dest, src, n); } #if !defined(AURORA_RUNTIME_MEMSET) #define AURORA_RUNTIME_MEMSET std::memset #endif static auline void *AuMemset(void *dest, AuUInt8 c, size_t n) { return AURORA_RUNTIME_MEMSET(dest, c, n); } #if !defined(AURORA_RUNTIME_MEMCPY) #define AURORA_RUNTIME_MEMCPY std::memcpy #endif static auline void *AuMemcpy(void *dest, const void *src, size_t n) { return AURORA_RUNTIME_MEMCPY(dest, src, n); } #if !defined(AURORA_RUNTIME_MEMMOVE) #define AURORA_RUNTIME_MEMMOVE std::memmove #endif static auline void *AuMemmove(void *dest, const void *src, size_t n) { return AURORA_RUNTIME_MEMMOVE(dest, src, n); } #if defined(AURORA_IS_MODERNNT_DERIVED) && (defined(_WINDOWS_) || defined(_OTHER_MS_MAIN_HEADER_GUARDS_HERE)) static auline void AuWin32CloseHandle(HANDLE &handle) { HANDLE local; if ((local = AuExchange(handle, INVALID_HANDLE_VALUE)) != INVALID_HANDLE_VALUE) { CloseHandle(local); } } #endif template static AuSPtr AuUnsafeRaiiToShared(T *in) { return AuSPtr(in, [](T *){}); } template static AuSPtr AuUnsafeRaiiToShared(const AuUPtr &in) { return AuSPtr(in.get(), [](T *){}); } template static constexpr int AuArraySize(const T(&array)[Z]) { return Z; } #if defined(DEBUG) || defined(STAGING) template static auline void __declspec(noreturn) SysPanic(T... args); template static void auline SafeDelete(T *in) { static_assert(std::is_base_of::type>::value, "Couldn't not safe delete from type T because it is not derived from Z"); auto cast = dynamic_cast(in); if (cast == nullptr) { Z re; SysPanic("Tried to free: 0x{:x}, type \"{}\" was not inherited from \"{}\"", AuUInt(in), typeid(in).name(), typeid(re).name()); } delete cast; } #else template static void auline SafeDelete(T *in) { static_assert(std::is_base_of::type>::value, "Couldn't not safe delete from type T because it is not derived from Z"); delete static_cast(in); } #endif struct IAuNullDelegate { virtual void OnCall() = 0; }; struct AuNullCallback { const AuVoidFunc voidFunc; const AuSPtr callbackFunc; AU_DEFINE_CTOR_ONE(AuNullCallback, (AuVoidFunc, voidFunc)); AU_DEFINE_CTOR_ONE(AuNullCallback, (AuSPtr, callbackFunc)); auline void operator()() { if (voidFunc) { voidFunc(); } else if (callbackFunc) { callbackFunc->OnCall(); } } }; static constexpr auline AuUInt32 AuConvertMagicTag32(const char buffer[4]) { AuUInt32 magic {}; if (Aurora::Build::kCurrentEndian == Aurora::Build::ECPUEndian::eCPULittle) { magic |= AuUInt32(buffer[0]); magic |= AuUInt32(buffer[1]) << 8; magic |= AuUInt32(buffer[2]) << 16; magic |= AuUInt32(buffer[3]) << 24; // LE will look alright in memory dumps // MSFT uses tags that read back the initial string value when read back hex ints // I prefer binary streams and file headers contain a 4x or 8x ascii char headers (eg. LuaX) } else { // Lazy reinterpret cast reads will always be flipped // Assume byte buffers read/write machine endian // Assume *reinterpret_cast returns machine endian // BE needs to be flipped in memory // BE will look fine in memory dumps // BE will also look fine in stack/variable dumps when printed in hex magic |= AuUInt32(buffer[4]); magic |= AuUInt32(buffer[2]) << 8; magic |= AuUInt32(buffer[1]) << 16; magic |= AuUInt32(buffer[0]) << 24; } // Determinstic across platforms, perhaps unexpected by endian normalized streams // When asserting read(noEndian) against a tag, an endian swap would cause the // assertion to fail, thus providing you with the endian match check // This step is delegated to a de-facto machine endian buffer builder // ByteBuffers that normalize for endianness continue to work with tags // irrespective of reader/writer endianness return magic; } static constexpr auline AuUInt64 AuConvertMagicTag64(const char buffer[8]) { AuUInt64 magic {}; if (Aurora::Build::kCurrentEndian == Aurora::Build::ECPUEndian::eCPULittle) { magic |= AuUInt64(buffer[0]); magic |= AuUInt64(buffer[1]) << 8; magic |= AuUInt64(buffer[2]) << 16; magic |= AuUInt64(buffer[3]) << 24; magic |= AuUInt64(buffer[4]) << 32; magic |= AuUInt64(buffer[5]) << 40; magic |= AuUInt64(buffer[6]) << 48; magic |= AuUInt64(buffer[7]) << 56; } else { magic |= AuUInt64(buffer[7]); magic |= AuUInt64(buffer[6]) << 8; magic |= AuUInt64(buffer[5]) << 16; magic |= AuUInt64(buffer[4]) << 24; magic |= AuUInt64(buffer[3]) << 32; magic |= AuUInt64(buffer[2]) << 40; magic |= AuUInt64(buffer[1]) << 48; magic |= AuUInt64(buffer[0]) << 56; } return magic; } template static auline AuOptional> AuOptionalSharedDynamicCast(AuOptional> &in) { if (!in.has_value()) return {}; return std::dynamic_pointer_cast(in.value()); } template static auline AuOptional> AuOptionalSharedStaticCast(AuOptional> &in) { if (!in.has_value()) return {}; return AuStaticPointerCast(in.value()); } static auline bool AuEndsWith(AuString const &value, AuString const &ending) { if (ending.size() > value.size()) return false; return std::equal(ending.rbegin(), ending.rend(), value.rbegin()); } static auline bool AuStartsWith(AuString const &value, AuString const &starting) { return value.rfind(starting, 0) == 0; } template static auline AuString AuToStringASCIIOp(T op, const AuString &in) { AuString ret; ret.resize(in.size()); std::transform(in.begin(), in.end(), ret.begin(), [=](const char &c) { return op(c); }); return ret; } static auline AuString AuToLower(const AuString &in) { return AuToStringASCIIOp(std::tolower, in); } static auline AuString AuToUpper(const AuString &in) { return AuToStringASCIIOp(std::toupper, in); } template static auline bool AuTryFind(Map &map, const Key &key, Value *&ptr) { auto itr = map.find(key); if (itr != map.end()) { ptr = &itr->second; return true; } else { ptr = nullptr; return false; } } template static auline bool AuTryFind(Map *map, const Key &key, Value *&ptr) { auto itr = map->find(key); if (itr != map->end()) { ptr = &itr->second; return true; } else { ptr = nullptr; return false; } } template static auline bool AuTryFind(Map &map, const Key &key) { auto itr = map.find(key); if (itr != map.end()) { return true; } else { return false; } } template static auline bool AuExists(Range &a, const Key &item) { return std::find(a.begin(), a.end(), item) != a.end(); } template static auline bool AuTryFind(Map *map, const Key &key) { auto itr = map->find(key); if (itr != map->end()) { return true; } else { return false; } } template static auline bool AuTryFindGeneric(Map &map, const Key &key, Value *&ptr) { auto itr = map.find(key); if (itr != map.end()) { ptr = &*itr; return true; } else { ptr = nullptr; return false; } } template static auline bool AuTryFindGeneric(Map &map, const Key &key) { if (map.find(key) != map.end()) { return true; } else { return false; } } template static auline bool AuTryDelete(Map &map, const Key &key) { auto itr = map.find(key); if (itr != map.end()) { map.erase(itr); return true; } else { return false; } } template static auline bool AuTryDeleteList(List &list, const Key &key) { auto itr = std::find(list.begin(), list.end(), key); if (itr != list.end()) { list.erase(itr); return true; } else { return false; } } template static auline bool AuTryInsert(Container &container, const Type &value) { try { container.insert(container.end(), value); return true; } catch (...) { return false; } } template static auline bool AuTryInsert(Container &container, Type &&value) { try { container.insert(container.end(), value); return true; } catch (...) { return false; } } template static auline bool AuTryInsert(Container *container, const Type &value) { try { container->insert(container->end(), value); return true; } catch (...) { return false; } } template static auline bool AuTryInsert(Container *container, Type &&value) { try { container->insert(container->end(), value); return true; } catch (...) { return false; } } template static auline bool AuTryInsertNoEnd(Container &container, Type &&value) // move { try { container.insert(value); return true; } catch (...) { return false; } } template static auline bool AuTryInsertNoEnd(Container &container, const Type &value) // copy { try { container.insert(value); return true; } catch (...) { return false; } } template static auline bool AuTryInsertNoEnd(Container *container, Type &&value) // move { try { container->insert(value); return true; } catch (...) { return false; } } template static auline bool AuTryInsertNoEnd(Container *container, const Type &value) // copy { try { container->insert(value); return true; } catch (...) { return false; } } namespace Aurora::Memory { struct ByteBuffer; } template static auline bool AuTryResize(T &list, AuUInt length) { try { if constexpr (AuIsSame_v) { return list.Resize(length); } else { list.resize(length); return true; } } catch (...) { return false; } } template static auline bool AuTryDownsize(T &list, AuUInt length) { try { if constexpr (AuIsSame_v) { return list.Resize(length); } else { list.resize(length); list.shrink_to_fit(); return true; } } catch (...) { return false; } } static auline AuString AuReplaceAll(AuString &str, const AuString &from, const AuString &to) { size_t start_pos = 0; while ((start_pos = str.find(from, start_pos)) != std::string::npos) { str.replace(start_pos, from.length(), to); start_pos += to.length(); // Handles case where 'to' is a substring of 'from' } return str; // :( } // i told myself not to copy this, required a split function twice, now here we are :D static auline AuList AuSplitString(const AuString& str, const AuString& delim, bool ignoreEmpty = true) { AuList tokens; AuUInt prev = 0, pos = 0; do { pos = str.find(delim, prev); if (pos == AuString::npos) pos = str.length(); auto token = str.substr(prev, pos-prev); if ((!token.empty()) && ignoreEmpty) tokens.push_back(token); prev = pos + delim.length(); } while (pos < str.length() && prev < str.length()); return tokens; } // more copy/pasta. work smart, not hard. // i dont want to waste time working out template kinks between clang and msvc template class base,typename derived> struct is_base_of_template_impl_au { template static constexpr AuTrueType test(const base *); static constexpr AuFalseType test(...); using type = decltype(test(std::declval())); }; template < template class base,typename derived> using AuIsBaseOfTemplate = typename is_base_of_template_impl_au::type; template auto AuTuplePopFrontImpl(const Tuple& tuple, std::index_sequence) { return std::make_tuple(std::get<1 + Is>(tuple)...); } template auto AuTuplePopFront(const Tuple& tuple) { return AuTuplePopFrontImpl(tuple, std::make_index_sequence::value - 1>()); } template static auline bool AuTestBit(T value, AuUInt8 idx) { return value & (T(1) << T(idx)); } template static auline void AuSetBit(T &value, AuUInt8 idx) { value |= T(1) << T(idx); } template static auline void AuClearBit(T &value, AuUInt8 idx) { value &= ~(T(1) << T(idx)); } template static auline bool AuBitScanForward(AuUInt8 &index, T value) { unsigned long ret; bool success; success = false; index = 0; #if defined(AURORA_COMPILER_MSVC) if constexpr (sizeof(T) == sizeof(AuUInt64)) #if defined(AURORA_IS_32BIT) if (!_BitScanForward(&ret, static_cast(value & 0xffffffff))) { if (!_BitScanForward(&ret, static_cast((value >> 32) & 0xffffffff))) { return false; } ret += 32; } #else success = _BitScanForward64(&ret, static_cast(value)); #endif else success = _BitScanForward(&ret, static_cast(value)); #elif defined(AURORA_COMPILER_GCC) || defined(AURORA_COMPILER_CLANG) if (value == 0) { return false; } if constexpr (sizeof(T) == sizeof(AuUInt64)) #if defined(AURORA_IS_32BIT) auto lower = static_cast(value & 0xffffffff)); if (lower == 0) { ret = __builtin_ctzl(static_cast((value >> 32) & 0xffffffff)); ret += 32; } else { ret = __builtin_ctzl(static_cast(lower)); } #else ret = __builtin_ctzll(static_cast(value)); #endif else if constexpr (sizeof(T) == sizeof(unsigned long)) ret = __builtin_ctzl(static_cast(value)); else if constexpr (sizeof(T) == sizeof(unsigned int)) ret = __builtin_ctz(static_cast(value)); success = true; #endif index = ret; return success; } // TODO: AuPopCnt // TODO: AuBitScanReverse #if defined(AURORA_ARCH_X64) || defined(AURORA_ARCH_X86) || defined(AURORA_ARCH_ARM) #define AURORA_PERMIT_ARBITRARY_REF #endif // I'm sorry to anyone reading this. I wanted it to be verbose. I should've just used my old friends, macros :( template static auline T AuReadGenericLE(const void *ptr, int offset) { #if defined(AURORA_PERMIT_ARBITRARY_REF) && defined(AU_CPU_ENDIAN_LITTLE) return *reinterpret_cast(reinterpret_cast(ptr) + offset); #else T temp; AuMemcpy(&temp, reinterpret_cast(ptr) + offset, sizeof(temp)); #if !defined(AU_CPU_ENDIAN_LITTLE) #if defined(AURORA_COMPILER_MSVC) if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_ulong(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_uint64(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_ushort(temp); } #else if constexpr (AuIsSame_v || AuIsSame_v) { temp = __builtin_bswap32(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = __builtin_bswap64(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = (temp << 8) | ((temp >> 8) & 0xFF); } #endif #endif return temp; #endif } template static auline T AuReadGenericBE(const void *ptr, int offset) { #if defined(AURORA_PERMIT_ARBITRARY_REF) && defined(AU_CPU_ENDIAN_BIG) return *reinterpret_cast(reinterpret_cast(ptr) + offset); #else T temp; AuMemcpy(&temp, reinterpret_cast(ptr) + offset, sizeof(temp)); #if defined(AU_CPU_ENDIAN_LITTLE) #if defined(AURORA_COMPILER_MSVC) if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_ulong(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_uint64(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_ushort(temp); } #else if constexpr (AuIsSame_v || AuIsSame_v) { temp = __builtin_bswap32(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = __builtin_bswap64(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = (temp << 8) | ((temp >> 8) & 0xFF); } #endif #endif return temp; #endif } static auline AuUInt64 AuReadU64LE(const void *ptr, int offset) { return AuReadGenericLE(ptr, offset); } static auline AuUInt32 AuReadU32LE(const void *ptr, int offset) { return AuReadGenericLE(ptr, offset); } static auline AuUInt16 AuReadU16LE(const void *ptr, int offset) { return AuReadGenericLE(ptr, offset); } static auline AuUInt8 AuReadU8LE(const void *ptr, int offset) { return AuReadGenericLE(ptr, offset); } static auline AuInt64 AuReadS64LE(const void *ptr, int offset) { return AuReadGenericLE(ptr, offset); } static auline AuInt32 AuReadS32LE(const void *ptr, int offset) { return AuReadGenericLE(ptr, offset); } static auline AuInt16 AuReadS16LE(const void *ptr, int offset) { return AuReadGenericLE(ptr, offset); } static auline AuInt8 AuReadS8LE(const void *ptr, int offset) { return AuReadGenericLE(ptr, offset); } static auline AuUInt64 AuReadU64BE(const void *ptr, int offset) { return AuReadGenericBE(ptr, offset); } static auline AuUInt32 AuReadU32BE(const void *ptr, int offset) { return AuReadGenericBE(ptr, offset); } static auline AuUInt16 AuReadU16BE(const void *ptr, int offset) { return AuReadGenericBE(ptr, offset); } static auline AuUInt8 AuReadU8BE(const void *ptr, int offset) { return AuReadGenericBE(ptr, offset); } static auline AuInt64 AuReadS64BE(const void *ptr, int offset) { return AuReadGenericBE(ptr, offset); } static auline AuInt32 AuReadS32BE(const void *ptr, int offset) { return AuReadGenericBE(ptr, offset); } static auline AuInt16 AuReadS16BE(const void *ptr, int offset) { return AuReadGenericBE(ptr, offset); } static auline AuInt8 AuReadS8BE(const void *ptr, int offset) { return AuReadGenericBE(ptr, offset); } static auline AuUInt64 AuReadU64(const void *ptr, int offset) { #if defined(AU_CPU_ENDIAN_LITTLE) return AuReadU64LE(ptr, offset); #else return AuReadU64BE(ptr, offset); #endif } static auline AuUInt32 AuReadU32(const void *ptr, int offset) { #if defined(AU_CPU_ENDIAN_LITTLE) return AuReadU32LE(ptr, offset); #else return AuReadU32BE(ptr, offset); #endif } static auline AuUInt16 AuReadU16(const void *ptr, int offset) { #if defined(AU_CPU_ENDIAN_LITTLE) return AuReadU16LE(ptr, offset); #else return AuReadU16BE(ptr, offset); #endif } static auline AuUInt8 AuReadU8(const void *ptr, int offset) { #if defined(AU_CPU_ENDIAN_LITTLE) return AuReadU8LE(ptr, offset); #else return AuReadU8BE(ptr, offset); #endif } static auline AuInt64 AuReadS64(const void *ptr, int offset) { #if defined(AU_CPU_ENDIAN_LITTLE) return AuReadS64LE(ptr, offset); #else return AuReadS64BE(ptr, offset); #endif } static auline AuInt32 AuReadS32(const void *ptr, int offset) { #if defined(AU_CPU_ENDIAN_LITTLE) return AuReadS32LE(ptr, offset); #else return AuReadS32BE(ptr, offset); #endif } static auline AuInt16 AuReadS16(const void *ptr, int offset) { #if defined(AU_CPU_ENDIAN_LITTLE) return AuReadS16LE(ptr, offset); #else return AuReadS16BE(ptr, offset); #endif } static auline AuInt8 AuReadS8(const void *ptr, int offset) { #if defined(AU_CPU_ENDIAN_LITTLE) return AuReadS8LE(ptr, offset); #else return AuReadS8BE(ptr, offset); #endif } template static auline void AuWriteGenericLE(void *ptr, int offset, T value) { #if defined(AURORA_PERMIT_ARBITRARY_REF) && defined(AU_CPU_ENDIAN_LITTLE) *reinterpret_cast(reinterpret_cast(ptr) + offset) = value; #else T temp = value; #if !defined(AU_CPU_ENDIAN_LITTLE) #if defined(AURORA_COMPILER_MSVC) if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_ulong(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_uint64(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_ushort(temp); } #else if constexpr (AuIsSame_v || AuIsSame_v) { temp = __builtin_bswap32(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = __builtin_bswap64(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = (temp << 8) | ((temp >> 8) & 0xFF); } #endif #endif AuMemcpy(reinterpret_cast(ptr) + offset, &temp, sizeof(temp)); #endif } template static auline void AuWriteGenericBE(void *ptr, T value, int offset) { #if defined(AURORA_PERMIT_ARBITRARY_REF) && defined(AU_CPU_ENDIAN_BIG) *reinterpret_cast(reinterpret_cast(ptr) + offset) = value; #else T temp = value; #if defined(AU_CPU_ENDIAN_LITTLE) #if defined(AURORA_COMPILER_MSVC) if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_ulong(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_uint64(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = _byteswap_ushort(temp); } #else if constexpr (AuIsSame_v || AuIsSame_v) { temp = __builtin_bswap32(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = __builtin_bswap64(temp); } else if constexpr (AuIsSame_v || AuIsSame_v) { temp = (temp << 8) | ((temp >> 8) & 0xFF); } #endif #endif AuMemcpy(reinterpret_cast(ptr) + offset, &temp, sizeof(temp)); #endif } static auline void AuWriteU64LE(void *ptr, int offset, AuUInt64 value) { AuWriteGenericLE(ptr, offset, value); } static auline void AuWriteU32LE(void *ptr, int offset, AuUInt32 value) { AuWriteGenericLE(ptr, offset, value); } static auline void AuWriteU16LE(void *ptr, int offset, AuUInt16 value) { AuWriteGenericLE(ptr, offset, value); } static auline void AuWriteU8LE(void *ptr, int offset, AuUInt8 value) { AuWriteGenericLE(ptr, offset, value); } static auline void AuWriteS64LE(void *ptr, int offset, AuInt64 value) { AuWriteGenericLE(ptr, offset, value); } static auline void AuWriteS32LE(void *ptr, int offset, AuInt32 value) { AuWriteGenericLE(ptr, offset, value); } static auline void AuWriteS16LE(void *ptr, int offset, AuInt16 value) { AuWriteGenericLE(ptr, offset, value); } static auline void AuWriteS8LE(void *ptr, int offset, AuInt8 value) { AuWriteGenericLE(ptr, offset, value); } static auline void AuWriteU64BE(void *ptr, int offset, AuUInt64 value) { AuWriteGenericBE(ptr, offset, value); } static auline void AuWriteU32BE(void *ptr, int offset, AuUInt32 value) { AuWriteGenericBE(ptr, offset, value); } static auline void AuWriteU16BE(void *ptr, int offset, AuUInt16 value) { AuWriteGenericBE(ptr, offset, value); } static auline void AuWriteU8BE(void *ptr, int offset, AuUInt8 value) { AuWriteGenericBE(ptr, offset, value); } static auline void AuWriteS64BE(void *ptr, int offset, AuInt64 value) { AuWriteGenericBE(ptr, offset, value); } static auline void AuWriteS32BE(void *ptr, int offset, AuInt32 value) { AuWriteGenericBE(ptr, offset, value); } static auline void AuWriteS16BE(void *ptr, int offset, AuInt16 value) { AuWriteGenericBE(ptr, offset, value); } static auline void AuWriteS8BE(void *ptr, int offset, AuInt8 value) { AuWriteGenericBE(ptr, offset, value); } static auline void AuWriteU64(void *ptr, int offset, AuUInt64 value) { #if defined(AU_CPU_ENDIAN_LITTLE) AuWriteU64LE(ptr, offset, value); #else AuWriteU64BE(ptr, offset, value); #endif } static auline void AuWriteU32(void *ptr, int offset, AuUInt32 value) { #if defined(AU_CPU_ENDIAN_LITTLE) AuWriteU32LE(ptr, offset, value); #else AuWriteU32BE(ptr, offset, value); #endif } static auline void AuWriteU16(void *ptr, int offset, AuUInt16 value) { #if defined(AU_CPU_ENDIAN_LITTLE) AuWriteU16LE(ptr, offset, value); #else AuWriteU16BE(ptr, offset, value); #endif } static auline void AuWriteU8(void *ptr, int offset, AuUInt8 value) { #if defined(AU_CPU_ENDIAN_LITTLE) AuWriteU8LE(ptr, offset, value); #else AuWriteU8BE(ptr, offset, value); #endif } static auline void AuWriteS64(void *ptr, int offset, AuInt64 value) { #if defined(AU_CPU_ENDIAN_LITTLE) AuWriteS64LE(ptr, offset, value); #else AuWriteS64BE(ptr, offset, value); #endif } static auline void AuWriteS32(void *ptr, int offset, AuInt32 value) { #if defined(AU_CPU_ENDIAN_LITTLE) AuWriteS32LE(ptr, offset, value); #else AuWriteS32BE(ptr, offset, value); #endif } static auline void AuWriteS16(void *ptr, int offset, AuInt16 value) { #if defined(AU_CPU_ENDIAN_LITTLE) AuWriteS16LE(ptr, offset, value); #else AuWriteS16BE(ptr, offset, value); #endif } static auline void AuWriteS8(void *ptr, int offset, AuInt8 value) { #if defined(AU_CPU_ENDIAN_LITTLE) AuWriteS8LE(ptr, offset, value); #else AuWriteS8BE(ptr, offset, value); #endif }