From 69062ba3ab6b2ac2d291c3e4b6931c1c0dd2b6ac Mon Sep 17 00:00:00 2001 From: gingerBill Date: Sun, 25 Feb 2018 20:24:38 +0000 Subject: More code tidying with `Array` --- src/array.cpp | 46 +++++++++++++++++++++++++++++++--------------- 1 file changed, 31 insertions(+), 15 deletions(-) (limited to 'src/array.cpp') diff --git a/src/array.cpp b/src/array.cpp index ff3aefd9b..6809574df 100644 --- a/src/array.cpp +++ b/src/array.cpp @@ -24,20 +24,21 @@ struct Array { } }; -template void array_init (Array *array, gbAllocator const &a); -template void array_init (Array *array, gbAllocator const &a, isize count); -template void array_init (Array *array, gbAllocator const &a, isize count, isize capacity); -template Array array_make (gbAllocator const &a); -template Array array_make (gbAllocator const &a, isize count); -template Array array_make (gbAllocator const &a, isize count, isize capacity); +template void array_init (Array *array, gbAllocator const &a); +template void array_init (Array *array, gbAllocator const &a, isize count); +template void array_init (Array *array, gbAllocator const &a, isize count, isize capacity); +template Array array_make (gbAllocator const &a); +template Array array_make (gbAllocator const &a, isize count); +template Array array_make (gbAllocator const &a, isize count, isize capacity); template Array array_make_from_ptr(T *data, isize count, isize capacity); -template void array_free (Array *array); -template void array_add (Array *array, T const &t); -template T array_pop (Array *array); -template void array_clear (Array *array); -template void array_reserve (Array *array, isize capacity); -template void array_resize (Array *array, isize count); -template void array_set_capacity(Array *array, isize capacity); +template void array_free (Array *array); +template void array_add (Array *array, T const &t); +template T array_pop (Array *array); +template void array_clear (Array *array); +template void array_reserve (Array *array, isize capacity); +template void array_resize (Array *array, isize count); +template void array_set_capacity (Array *array, isize capacity); +template Array array_slice (Array const &array, isize lo, isize hi); template gb_inline void array_init(Array *array, gbAllocator const &a) { @@ -102,7 +103,7 @@ gb_inline Array array_make(gbAllocator const &a, isize count, isize capacity) template -void array_free(Array *array) { +gb_inline void array_free(Array *array) { if (array->allocator.proc != nullptr) { gb_free(array->allocator, array->data); } @@ -129,7 +130,7 @@ void array_add(Array *array, T const &t) { } template -T array_pop(Array *array) { +gb_inline T array_pop(Array *array) { GB_ASSERT(array->count > 0); array->count--; return array->data[array->count]; @@ -175,6 +176,21 @@ void array_set_capacity(Array *array, isize capacity) { array->capacity = capacity; } + +template +gb_inline Array array_slice(Array const &array, isize lo, isize hi) { + GB_ASSERT(0 <= lo && lo <= hi && hi <= array.count); + Array out = {}; + isize len = hi-lo; + if (len > 0) { + out.data = array.data+lo; + out.count = len; + out.capacity = len; + } + return out; +} + + #endif #if 0 -- cgit v1.2.3