/* REF-ARRAY-IMPL.hpp - some implementations of the ref-array interface Copyright (C) 2008, Hermann Vosseler   **Lumiera** is free software; you can redistribute it and/or modify it   under the terms of the GNU General Public License as published by the   Free Software Foundation; either version 2 of the License, or (at your   option) any later version. See the file COPYING for further details. */ /** @file ref-array-impl.hpp ** Some (library-) implementations of the RefArray interface. ** ** Being an array-like object exposing just a const ref, it is typically used ** on interfaces, and the type of the array "elements" usually is a ABC or interface. ** The actual implementation typically holds a subclass, and is either based on a vector, ** or a fixed storage contained within the implementation. The only price to pay is ** a virtual call on element access. ** ** For advanced uses it would be possible to have a pointer-array or even an embedded ** storage of variant-records, able to hold a mixture of subclasses. (the latter cases ** will be implemented when needed). ** ** @deprecated 5/2025 to be reworked and obsoleted — do not use further ** @see several-builder.hpp ** @see ref-array-test.cpp ** */ #ifndef LIB_REF_ARRAY_IMPL_H #define LIB_REF_ARRAY_IMPL_H #include "lib/ref-array.hpp" #include "include/logging.h" #include using std::vector; namespace lib { /** * Wrap a vector holding objects of a subtype and * provide array-like access using the interface type. */ template class RefArrayVectorWrapper : public RefArray { typedef vector const& Tab; Tab table_; public: RefArrayVectorWrapper (Tab toWrap) : table_(toWrap) { } virtual size_t size() const { return table_.size(); } virtual B const& operator[] (size_t i) const { REQUIRE (i < size()); return table_[i]; } }; /** * This variation of the wrapper actually * \em is a vector, but can act as a RefArray */ template class RefArrayVector : public vector, public RefArrayVectorWrapper { typedef RefArrayVectorWrapper Wrap; typedef vector Vect; typedef typename Vect::size_type Size_t; typedef typename Vect::value_type Val_t; public: RefArrayVector() : Vect(), Wrap((Vect&)*this) {} RefArrayVector(Size_t n, Val_t const& v = Val_t()) : Vect(n,v), Wrap((Vect&)*this) {} RefArrayVector(Vect const& ref) : Vect(ref), Wrap((Vect&)*this) {} using Vect::size; using Wrap::operator[]; }; /** * RefArray implementation based on a fixed size array, * i.e. the storage is embedded. Embedded subclass obj * either need to be default constructible or be * placed directly by a factory */ template class RefArrayTable : public RefArray { char storage_[n*sizeof(IM)]; IM* array_; public: RefArrayTable() ///< objects created in-place by default ctor : array_ (reinterpret_cast (&storage_)) { size_t i=0; try { while (i RefArrayTable(FAC& factory) ///< objects created in-place by factory : array_ (reinterpret_cast (&storage_)) { size_t i=0; try { while (i