diff --git a/libsrc/core/array.hpp b/libsrc/core/array.hpp index dedd974e..4e460f66 100644 --- a/libsrc/core/array.hpp +++ b/libsrc/core/array.hpp @@ -303,14 +303,24 @@ namespace ngcore return T_Range (0, n); } - template - NETGEN_INLINE auto Range_impl (const T & ao, std::false_type) - -> T_Range> + template + NETGEN_INLINE auto Range_impl (const TA & ao, std::false_type) + -> T_Range> { - return T_Range> (IndexBASE>(), - IndexBASE>() + index_type(ao.Size())); + return T_Range> (IndexBASE>(), + IndexBASE>() + index_type(ao.Size())); } + /* + Range(obj) will create a range in using the following steps: + + * if obj is an integral type it will create T_Range(0, obj) + * if obj has a function Range() it will return obj.Range() + * if obj has a typedef index_type it will return + T_Range(IndexBASE(), IndexBASE() + index_type(obj.Size())) + * else it will return T_Range (0, obj.Size()) + + */ template auto Range(const T & x) -> typename std::enable_if || !has_range, @@ -630,6 +640,7 @@ namespace ngcore using FlatArray::BASE; public: + using index_type = typename FlatArray::index_type; /// Generate array of logical and physical size asize NETGEN_INLINE explicit Array() : FlatArray (0, nullptr) @@ -795,42 +806,42 @@ namespace ngcore } /// Add element at end of array. reallocation if necessary. - NETGEN_INLINE size_t Append (const T & el) + /// Returns index of new element. + NETGEN_INLINE index_type Append (const T & el) { if (size == allocsize) ReSize (size+1); data[size] = el; - size++; - return size; + return BASE + size++; } /// Add element at end of array. reallocation not necessary. - NETGEN_INLINE size_t AppendHaveMem (const T & el) + /// Returns index of new element. + NETGEN_INLINE index_type AppendHaveMem (const T & el) { + NETGEN_CHECK_RANGE(size, 0, allocsize); data[size] = el; - size++; - return size; + return BASE + size++; } /// Add element at end of array. reallocation if necessary. - NETGEN_INLINE size_t Append (T && el) + /// Returns index of new element. + NETGEN_INLINE index_type Append (T && el) { if (size == allocsize) ReSize (size+1); data[size] = std::move(el); - size++; - return size; + return BASE + size++; } // Add elements of initializer list to end of array. Reallocation if necessary. - NETGEN_INLINE size_t Append(std::initializer_list lst) + NETGEN_INLINE void Append(std::initializer_list lst) { if(allocsize < size + lst.size()) ReSize(size+lst.size()); for(auto val : lst) data[size++] = val; - return size; } /// Add element at end of array. reallocation if necessary. @@ -852,8 +863,7 @@ namespace ngcore /// Append array at end of array. reallocation if necessary. - // int Append (const Array & source) - NETGEN_INLINE size_t Append (FlatArray source) + NETGEN_INLINE void Append (FlatArray source) { if(size + source.Size() >= allocsize) ReSize (size + source.Size() + 1); @@ -862,7 +872,6 @@ namespace ngcore data[i] = source[j]; size += source.Size(); - return size; } @@ -879,6 +888,7 @@ namespace ngcore /// Delete element i. Move all remaining elements forward NETGEN_INLINE void RemoveElement (size_t i) { + NETGEN_CHECK_RANGE(i, BASE, BASE+size); for(size_t j = i; j < this->size-1; j++) this->data[j] = this->data[j+1]; this->size--;