From 2ed598b4e2626e30299b21fdaebd4ec460ab62bf Mon Sep 17 00:00:00 2001 From: GAMMACASE <31375974+GAMMACASE@users.noreply.github.com> Date: Thu, 5 Jun 2025 16:43:30 +0300 Subject: [PATCH] Update AlignedByteArray_t --- public/tier0/platform.h | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/public/tier0/platform.h b/public/tier0/platform.h index 6f6f97ca..1809714a 100644 --- a/public/tier0/platform.h +++ b/public/tier0/platform.h @@ -1117,6 +1117,8 @@ PLATFORM_INTERFACE void Plat_ExitProcess( int nCode ); PLATFORM_INTERFACE bool Plat_ShouldCollectMiniDumpsForFatalErrors(); +PLATFORM_INTERFACE void Plat_NonFatalErrorFunc( const tchar *pMsg, ... ) FMTFUNCTION( 1, 2 ); + #define Plat_FatalError( ... ) do { Log_Error( LOG_GENERAL, ##__VA_ARGS__ ); Plat_ExitProcess( EXIT_FAILURE ); } while( 0 ) #define Plat_FatalErrorFunc @@ -1786,9 +1788,12 @@ template < size_t NUM, class T > struct AlignedByteArray_t : public AlignedByteA struct ALIGN_N( ALIGN ) AlignedByteArrayExplicit_t< NUM, T, ALIGN > \ { \ /* NOTE: verify alignment in the constructor (which may be wrong if this is heap-allocated, for ALIGN > MEMALLOC_MAX_AUTO_ALIGN) */ \ - AlignedByteArrayExplicit_t() { if ( (ALIGN-1) & (size_t)this ) { DebuggerBreakIfDebugging(); } } \ + AlignedByteArrayExplicit_t() { if ( (ALIGN-1) & (size_t)this ) { Plat_NonFatalErrorFunc( "AlignedByteArray not properly aligned\n" ); } } \ T * Base( void ) { ValidateAlignmentExplicit(); return (T *)&m_Data; } \ const T * Base( void ) const { ValidateAlignmentExplicit(); return (const T *)&m_Data; } \ + size_t Count() const { return NUM; } \ + T &operator[]( int i ) { return Base()[i]; } \ + const T &operator[]( int i ) const { return Base()[i]; } \ private: \ byte m_Data[ NUM*sizeof( T ) ]; \ } ALIGN_N_POST( ALIGN );