TracyFastVector.hpp 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. #ifndef __TRACYFASTVECTOR_HPP__
  2. #define __TRACYFASTVECTOR_HPP__
  3. #include <assert.h>
  4. #include <stddef.h>
  5. #include "../common/TracyAlloc.hpp"
  6. #include "../common/TracyForceInline.hpp"
  7. namespace tracy
  8. {
  9. template<typename T>
  10. class FastVector
  11. {
  12. public:
  13. using iterator = T*;
  14. using const_iterator = const T*;
  15. FastVector( size_t capacity )
  16. : m_ptr( (T*)tracy_malloc( sizeof( T ) * capacity ) )
  17. , m_write( m_ptr )
  18. , m_end( m_ptr + capacity )
  19. {
  20. assert( capacity != 0 );
  21. }
  22. FastVector( const FastVector& ) = delete;
  23. FastVector( FastVector&& ) = delete;
  24. ~FastVector()
  25. {
  26. tracy_free( m_ptr );
  27. }
  28. FastVector& operator=( const FastVector& ) = delete;
  29. FastVector& operator=( FastVector&& ) = delete;
  30. bool empty() const { return m_ptr == m_write; }
  31. size_t size() const { return m_write - m_ptr; }
  32. T* data() { return m_ptr; }
  33. const T* data() const { return m_ptr; };
  34. T* begin() { return m_ptr; }
  35. const T* begin() const { return m_ptr; }
  36. T* end() { return m_write; }
  37. const T* end() const { return m_write; }
  38. T& front() { assert( !empty() ); return m_ptr[0]; }
  39. const T& front() const { assert( !empty() ); return m_ptr[0]; }
  40. T& back() { assert( !empty() ); return m_write[-1]; }
  41. const T& back() const { assert( !empty() ); return m_write[-1]; }
  42. T& operator[]( size_t idx ) { return m_ptr[idx]; }
  43. const T& operator[]( size_t idx ) const { return m_ptr[idx]; }
  44. T* push_next()
  45. {
  46. if( m_write == m_end ) AllocMore();
  47. return m_write++;
  48. }
  49. T* prepare_next()
  50. {
  51. if( m_write == m_end ) AllocMore();
  52. return m_write;
  53. }
  54. void commit_next()
  55. {
  56. m_write++;
  57. }
  58. void clear()
  59. {
  60. m_write = m_ptr;
  61. }
  62. void swap( FastVector& vec )
  63. {
  64. const auto ptr1 = m_ptr;
  65. const auto ptr2 = vec.m_ptr;
  66. const auto write1 = m_write;
  67. const auto write2 = vec.m_write;
  68. const auto end1 = m_end;
  69. const auto end2 = vec.m_end;
  70. m_ptr = ptr2;
  71. vec.m_ptr = ptr1;
  72. m_write = write2;
  73. vec.m_write = write1;
  74. m_end = end2;
  75. vec.m_end = end1;
  76. }
  77. private:
  78. tracy_no_inline void AllocMore()
  79. {
  80. const auto cap = size_t( m_end - m_ptr ) * 2;
  81. const auto size = size_t( m_write - m_ptr );
  82. T* ptr = (T*)tracy_malloc( sizeof( T ) * cap );
  83. memcpy( ptr, m_ptr, size * sizeof( T ) );
  84. tracy_free( m_ptr );
  85. m_ptr = ptr;
  86. m_write = m_ptr + size;
  87. m_end = m_ptr + cap;
  88. }
  89. T* m_ptr;
  90. T* m_write;
  91. T* m_end;
  92. };
  93. }
  94. #endif