#ifndef __TRACYVARARRAY_HPP__ #define __TRACYVARARRAY_HPP__ #include #include "../common/TracyForceInline.hpp" #include "tracy_flat_hash_map.hpp" #include "TracyCharUtil.hpp" #include "TracyMemory.hpp" namespace tracy { #pragma pack( 1 ) template class VarArray { public: VarArray( uint8_t size, const T* data ) : m_size( size ) , m_ptr( data ) { T hash = 0; for( uint8_t i=0; i 0 ); return m_ptr[0]; } tracy_force_inline const T& back() const { assert( m_size > 0 ); return m_ptr[m_size - 1]; } tracy_force_inline const T& operator[]( size_t idx ) const { return m_ptr[idx]; } private: uint8_t m_size; uint32_t m_hash; const T* m_ptr; }; #pragma pack() template bool Compare( const VarArray& lhs, const VarArray& rhs ) { if( lhs.size() != rhs.size() || lhs.get_hash() != rhs.get_hash() ) return false; const auto sz = lhs.size(); for( uint8_t i=0; i struct VarArrayHasher { size_t operator()( const VarArray* arr ) const { return arr->get_hash(); } }; template struct VarArrayHasherPOT : public VarArrayHasher { typedef tracy::power_of_two_hash_policy hash_policy; }; template struct VarArrayComparator { bool operator()( const VarArray* lhs, const VarArray* rhs ) const { return Compare( *lhs, *rhs ); } }; } #endif