From 6236214be608840b53eff8d7c4301ebc6af82fd1 Mon Sep 17 00:00:00 2001 From: Gary Talent Date: Wed, 2 May 2018 21:11:00 -0500 Subject: [PATCH] [ox/buffer] Add to to Ptr --- deps/ox/src/ox/ptrarith/ptr.hpp | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/deps/ox/src/ox/ptrarith/ptr.hpp b/deps/ox/src/ox/ptrarith/ptr.hpp index 0746d628..d406f8bb 100644 --- a/deps/ox/src/ox/ptrarith/ptr.hpp +++ b/deps/ox/src/ox/ptrarith/ptr.hpp @@ -17,6 +17,7 @@ class Ptr { private: uint8_t *m_dataStart = nullptr; + size_t m_dataSize = 0; size_t m_itemOffset = 0; size_t m_itemSize = 0; // this should be removed later on, but the excessive validation is @@ -72,6 +73,9 @@ class Ptr { template inline Ptr subPtr(size_t offset); + template + inline const Ptr to() const; + }; template @@ -86,6 +90,7 @@ inline Ptr::Ptr(void *dataStart, size_t dataSize, size_t i itemStart >= minOffset and itemStart + itemSize <= dataSize) { m_dataStart = reinterpret_cast(dataStart); + m_dataSize = dataSize; m_itemOffset = itemStart; m_itemSize = itemSize; } @@ -189,8 +194,7 @@ inline bool Ptr::operator!=(const Ptr template inline const Ptr Ptr::subPtr(size_t offset, size_t size) const { - auto out = Ptr(get(), this->size(), offset, size); - return out; + return Ptr(get(), this->size(), offset, size); } template @@ -203,8 +207,7 @@ inline const Ptr Ptr::subPtr(size template template inline Ptr Ptr::subPtr(size_t offset, size_t size) { - auto out = Ptr(get(), this->size(), offset, size); - return out; + return Ptr(get(), this->size(), offset, size); } template @@ -214,4 +217,10 @@ inline Ptr Ptr::subPtr(size_t off return subPtr(offset, m_itemSize - offset); } +template +template +inline const Ptr Ptr::to() const { + return Ptr(m_dataStart, m_dataSize, m_itemOffset, m_itemSize); +} + }