/* REFARRAYIMPL.hpp - some implementations of the ref-array interface Copyright (C) Lumiera.org 2008, Hermann Vosseler This program 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. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #ifndef LIB_REFARRAYIMPL_H #define LIB_REFARRAYIMPL_H #include "lib/refarray.hpp" #include "proc/nobugcfg.hpp" #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[] (uint 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 fix sized 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