squtils.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. /* see copyright notice in squirrel.h */
  2. #ifndef _SQUTILS_H_
  3. #define _SQUTILS_H_
  4. void *sq_vm_malloc(SQUnsignedInteger size);
  5. void *sq_vm_realloc(void *p,SQUnsignedInteger oldsize,SQUnsignedInteger size);
  6. void sq_vm_free(void *p,SQUnsignedInteger size);
  7. #define sq_new(__ptr,__type) {__ptr=(__type *)sq_vm_malloc(sizeof(__type));new (__ptr) __type;}
  8. #define sq_delete(__ptr,__type) {__ptr->~__type();sq_vm_free(__ptr,sizeof(__type));}
  9. #define SQ_MALLOC(__size) sq_vm_malloc((__size));
  10. #define SQ_FREE(__ptr,__size) sq_vm_free((__ptr),(__size));
  11. #define SQ_REALLOC(__ptr,__oldsize,__size) sq_vm_realloc((__ptr),(__oldsize),(__size));
  12. #define sq_aligning(v) (((size_t)(v) + (SQ_ALIGNMENT-1)) & (~(SQ_ALIGNMENT-1)))
  13. //sqvector mini vector class, supports objects by value
  14. template<typename T> class sqvector
  15. {
  16. public:
  17. sqvector():_vals(NULL),_size(0),_allocated(0)
  18. {
  19. }
  20. sqvector(const sqvector<T>& v)
  21. {
  22. copy(v);
  23. }
  24. void copy(const sqvector<T>& v)
  25. {
  26. if(_size) {
  27. resize(0); //destroys all previous stuff
  28. }
  29. //resize(v._size);
  30. if(v._size > _allocated) {
  31. _realloc(v._size);
  32. }
  33. for(SQUnsignedInteger i = 0; i < v._size; i++) {
  34. new ((void *)&_vals[i]) T(v._vals[i]);
  35. }
  36. _size = v._size;
  37. }
  38. ~sqvector()
  39. {
  40. if(_allocated) {
  41. for(SQUnsignedInteger i = 0; i < _size; i++)
  42. _vals[i].~T();
  43. SQ_FREE(_vals, (_allocated * sizeof(T)));
  44. }
  45. }
  46. void reserve(SQUnsignedInteger newsize) { _realloc(newsize); }
  47. void resize(SQUnsignedInteger newsize, const T& fill = T())
  48. {
  49. if(newsize > _allocated)
  50. _realloc(newsize);
  51. if(newsize > _size) {
  52. while(_size < newsize) {
  53. new ((void *)&_vals[_size]) T(fill);
  54. _size++;
  55. }
  56. }
  57. else{
  58. for(SQUnsignedInteger i = newsize; i < _size; i++) {
  59. _vals[i].~T();
  60. }
  61. _size = newsize;
  62. }
  63. }
  64. void shrinktofit() { if(_size > 4) { _realloc(_size); } }
  65. T& top() const { return _vals[_size - 1]; }
  66. inline SQUnsignedInteger size() const { return _size; }
  67. bool empty() const { return (_size <= 0); }
  68. inline T &push_back(const T& val = T())
  69. {
  70. if(_allocated <= _size)
  71. _realloc(_size * 2);
  72. return *(new ((void *)&_vals[_size++]) T(val));
  73. }
  74. inline void pop_back()
  75. {
  76. _size--; _vals[_size].~T();
  77. }
  78. void insert(SQUnsignedInteger idx, const T& val)
  79. {
  80. resize(_size + 1);
  81. for(SQUnsignedInteger i = _size - 1; i > idx; i--) {
  82. _vals[i] = _vals[i - 1];
  83. }
  84. _vals[idx] = val;
  85. }
  86. void remove(SQUnsignedInteger idx)
  87. {
  88. _vals[idx].~T();
  89. if(idx < (_size - 1)) {
  90. memmove(&_vals[idx], &_vals[idx+1], sizeof(T) * (_size - idx - 1));
  91. }
  92. _size--;
  93. }
  94. void removeFromBegining(SQUnsignedInteger count)
  95. {
  96. if(count <= _size){
  97. for(SQUnsignedInteger i=0; i < count; ++i) _vals[i].~T();
  98. if(count < (_size - 1)) {
  99. memmove(&_vals[0], &_vals[count], sizeof(T) * (_size - count));
  100. }
  101. _size -= count;
  102. }
  103. }
  104. SQUnsignedInteger capacity() { return _allocated; }
  105. inline T &back() const { return _vals[_size - 1]; }
  106. inline T& operator[](SQUnsignedInteger pos) const{ return _vals[pos]; }
  107. T* _vals;
  108. private:
  109. void _realloc(SQUnsignedInteger newsize)
  110. {
  111. newsize = (newsize > 0)?newsize:4;
  112. _vals = (T*)SQ_REALLOC(_vals, _allocated * sizeof(T), newsize * sizeof(T));
  113. _allocated = newsize;
  114. }
  115. SQUnsignedInteger _size;
  116. SQUnsignedInteger _allocated;
  117. };
  118. class SQCharBuf : public sqvector<char>
  119. {
  120. public:
  121. void append(const char *p, size_t count)
  122. {
  123. size_t old_size = size();
  124. resize(old_size + count);
  125. memcpy(_vals+old_size, p, count);
  126. }
  127. const char *data(){return _vals;}
  128. };
  129. #endif //_SQUTILS_H_