#ifndef __cxz_xindex_cc_h__ #define __cxz_xindex_cc_h__ #include "xindex.h" namespace CNORXZ { /************** * XIndex * **************/ template XIndex::XIndex(const IndexPtr& i) : mI(i) {} template XIndex::XIndex(const IndexInterface& i) : mI(std::make_shared(i.THIS())) {} template XIndexPtr XIndex::copy() const { return std::make_shared>(mI->THIS()); } template SizeT XIndex::pos() const { return mI->pos(); } template XIndex& XIndex::operator=(SizeT pos) { *mI = pos; return *this; } template XIndex& XIndex::operator++() { ++(*mI); return *this; } template XIndex& XIndex::operator--() { --(*mI); return *this; } template Sptr XIndex::operator+(Int n) const { return std::make_shared>(*mI + n); } template Sptr XIndex::operator-(Int n) const { return std::make_shared>(*mI - n); } template XIndex& XIndex::operator+=(Int n) { (*mI) += n; return *this; } template XIndex& XIndex::operator-=(Int n) { (*mI) -= n; return *this; } template DType XIndex::operator*() const { return DType(*(*mI)); } template DType XIndex::operator->() const { return DType(*(*mI)); } template Int XIndex::pp(PtrId idxPtrNum) { Int out = mI->pp(idxPtrNum); return out; } template Int XIndex::mm(PtrId idxPtrNum) { Int out = mI->mm(idxPtrNum); return out; } template SizeT XIndex::dim() const { return mI->dim(); } template RangePtr XIndex::range() const { return mI->range(); } template SizeT XIndex::getStepSize(PtrId iptr) const { return mI->getStepSize(iptr); } template Int XIndex::getOffset(PtrId iptr) const { return mI->getOffset(iptr); } template String XIndex::stringMeta() const { return mI->stringMeta(); } template DType XIndex::meta() const { return DType(mI->meta()); } template XIndexBase& XIndex::at(const DType& meta) { // check!!! mI->at(std::any_cast(meta.get())); return *this; } /* template DExpr XIndex::ifor(SizeT step, DExpr ex) const { return mI->ifor(step, ex); } template DExpr XIndex::iforh(SizeT step, DExpr ex) const { return mI->iforh(step, ex); } */ } #endif