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 );