// -*- C++ -*- #ifndef __range_base_h__ #define __range_base_h__ #include #include #include #include "rbase_def.h" namespace MultiArrayTools { class RangeBase; } namespace MultiArrayTools { size_t indexId(); enum class SpaceType { NONE = 0, // meta data is that of a classic range, i.e. 0,1,2,...,N-1 ANY = 1, // meta data is arbitrary, i.e. explicitly stored; range could be multiple #define include_range_type(x,n) x = n, #include "range_types/header.h" #undef include_range_type ANON = -1, // anonymous content DYN = -3 // dynamic content }; struct DataHeader { public: static constexpr size_t VERSION = 1; // fixed by version of this repository ! private: size_t version = VERSION; public: int spaceType = static_cast( SpaceType::NONE ); size_t metaSize = 0; // size of meta data int multiple = 0; // = 1 if multi range int metaType = 0; // type of meta data inline size_t v() const { return version; } }; class RangeFactoryBase { public: RangeFactoryBase() = default; virtual ~RangeFactoryBase() = default; // should return mProd !! virtual std::shared_ptr create() = 0; protected: std::shared_ptr mProd; // call this function before returning product !! void setSelf(); }; std::shared_ptr createRangeFactory(const char** dp); std::shared_ptr createSingleRangeFactory(const vector*& d, int metaType, size_t size); class RangeBase { public: static constexpr bool ISINDEX = false; virtual ~RangeBase() = default; virtual size_t size() const = 0; virtual size_t dim() const = 0; bool operator==(const RangeBase& in) const; bool operator!=(const RangeBase& in) const; std::intptr_t id() const; virtual vector typeNum() const = 0; virtual size_t cmeta(char* target, size_t pos) const = 0; virtual size_t cmetaSize() const = 0; virtual std::string stringMeta(size_t pos) const = 0; virtual vector data() const = 0; // usefull when writing to files, etc... virtual SpaceType spaceType() const = 0; virtual DataHeader dataHeader() const = 0; virtual std::shared_ptr sub(size_t num) const { return std::shared_ptr(); } virtual std::shared_ptr aindex() const = 0; friend RangeFactoryBase; protected: RangeBase() = default; std::weak_ptr mThis; }; template inline std::shared_ptr mkIndexWrapper(const Index& i); template class RangeInterface : public RangeBase { public: //typedef typename Index::MetaType MetaType; typedef Index IndexType; static constexpr SpaceType STYPE = IndexType::STYPE; virtual Index begin() const = 0; virtual Index end() const = 0; virtual std::shared_ptr aindex() const override final { return mkIndexWrapper(this->begin()); } //{ auto i = std::make_shared(this->begin()); return std::make_shared>(i); } //!!! //{ auto i = std::make_shared(this->begin()); return nullptr; } //!!! protected: RangeInterface() = default; }; } #endif