Documentation for SparsePtr
Former-commit-id: f4e51b1a9d7792dbbbd148e028906ba8062787b5
This commit is contained in:
@@ -7,7 +7,7 @@
|
||||
#ifndef NAZARA_SPARSEPTR_HPP
|
||||
#define NAZARA_SPARSEPTR_HPP
|
||||
|
||||
///FIXME: Est-ce que SparsePtr est vraiment le meilleur nom pour cette classe ?
|
||||
///FIXME: Is SparsePtr a really good name for this class ?
|
||||
|
||||
#include <Nazara/Prerequesites.hpp>
|
||||
#include <cstddef>
|
||||
|
||||
@@ -7,24 +7,52 @@
|
||||
|
||||
namespace Nz
|
||||
{
|
||||
/*!
|
||||
* \class Nz::SparsePtr<T>
|
||||
* \brief Core class that represents a pointer and the step between two elements
|
||||
*/
|
||||
|
||||
/*!
|
||||
* \brief Constructs a SparsePtr<T> object by default
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T>::SparsePtr()
|
||||
{
|
||||
Reset();
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Constructs a SparsePtr<T> object with a pointer
|
||||
*
|
||||
* \param ptr Pointer to data
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T>::SparsePtr(T* ptr)
|
||||
{
|
||||
Reset(ptr);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Constructs a SparsePtr<T> object with a pointer and a step
|
||||
*
|
||||
* \param ptr Pointer to data
|
||||
* \param stride Step between two elements
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T>::SparsePtr(VoidPtr ptr, int stride)
|
||||
{
|
||||
Reset(ptr, stride);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Constructs a SparsePtr<T> object from another type of SparsePtr
|
||||
*
|
||||
* \param ptr Pointer to data of type U to convert to type T
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
template<typename U>
|
||||
SparsePtr<T>::SparsePtr(const SparsePtr<U>& ptr)
|
||||
@@ -32,18 +60,32 @@ namespace Nz
|
||||
Reset(ptr);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the original pointer
|
||||
* \return Pointer to the first data
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
typename SparsePtr<T>::VoidPtr SparsePtr<T>::GetPtr() const
|
||||
{
|
||||
return m_ptr;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the stride
|
||||
* \return Step between two elements
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
int SparsePtr<T>::GetStride() const
|
||||
{
|
||||
return m_stride;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Resets the SparsePtr
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
void SparsePtr<T>::Reset()
|
||||
{
|
||||
@@ -51,6 +93,14 @@ namespace Nz
|
||||
SetStride(0);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Resets the SparsePtr with a pointer
|
||||
*
|
||||
* \param ptr Pointer to data
|
||||
*
|
||||
* \remark stride is set to sizeof(T)
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
void SparsePtr<T>::Reset(T* ptr)
|
||||
{
|
||||
@@ -58,6 +108,13 @@ namespace Nz
|
||||
SetStride(sizeof(T));
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Resets the SparsePtr with a pointer and its stride
|
||||
*
|
||||
* \param ptr Pointer to data
|
||||
* \param stride Step between two elements
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
void SparsePtr<T>::Reset(VoidPtr ptr, int stride)
|
||||
{
|
||||
@@ -65,6 +122,12 @@ namespace Nz
|
||||
SetStride(stride);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Resets the SparsePtr with another SparsePtr
|
||||
*
|
||||
* \param ptr Another sparsePtr
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
void SparsePtr<T>::Reset(const SparsePtr& ptr)
|
||||
{
|
||||
@@ -72,6 +135,12 @@ namespace Nz
|
||||
SetStride(ptr.GetStride());
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Resets the SparsePtr with another type of SparsePtr
|
||||
*
|
||||
* \param ptr Another sparsePtr
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
template<typename U>
|
||||
void SparsePtr<T>::Reset(const SparsePtr<U>& ptr)
|
||||
@@ -82,94 +151,187 @@ namespace Nz
|
||||
SetStride(ptr.GetStride());
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Sets the pointer
|
||||
*
|
||||
* \param ptr Pointer to data
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
void SparsePtr<T>::SetPtr(VoidPtr ptr)
|
||||
{
|
||||
m_ptr = reinterpret_cast<BytePtr>(ptr);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Sets the stride
|
||||
*
|
||||
* \param stride Step between two elements
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
void SparsePtr<T>::SetStride(int stride)
|
||||
{
|
||||
m_stride = stride;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Converts the pointer to bool
|
||||
* \return true if pointer is not nullptr
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T>::operator bool() const
|
||||
{
|
||||
return m_ptr != nullptr;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Converts the pointer to a pointer to the value
|
||||
* \return The value of the pointer
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T>::operator T*() const
|
||||
{
|
||||
return reinterpret_cast<T*>(m_ptr);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Dereferences the pointer
|
||||
* \return The dereferencing of the pointer
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
T& SparsePtr<T>::operator*() const
|
||||
{
|
||||
return *reinterpret_cast<T*>(m_ptr);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Dereferences the pointer
|
||||
* \return The dereferencing of the pointer
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
T* SparsePtr<T>::operator->() const
|
||||
{
|
||||
return reinterpret_cast<T*>(m_ptr);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the ith element of the stride pointer
|
||||
* \return A reference to the ith value
|
||||
*
|
||||
* \param index Number of stride to do
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
T& SparsePtr<T>::operator[](int index) const
|
||||
{
|
||||
return *reinterpret_cast<T*>(m_ptr + index*m_stride);
|
||||
return *reinterpret_cast<T*>(m_ptr + index * m_stride);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the SparsePtr with an offset
|
||||
* \return A SparsePtr with the new stride
|
||||
*
|
||||
* \param count Number of stride to do
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T> SparsePtr<T>::operator+(int count) const
|
||||
{
|
||||
return SparsePtr(m_ptr + count*m_stride, m_stride);
|
||||
return SparsePtr(m_ptr + count * m_stride, m_stride);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the SparsePtr with an offset
|
||||
* \return A SparsePtr with the new stride
|
||||
*
|
||||
* \param count Number of stride to do
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T> SparsePtr<T>::operator+(unsigned int count) const
|
||||
{
|
||||
return SparsePtr(m_ptr + count*m_stride, m_stride);
|
||||
return SparsePtr(m_ptr + count * m_stride, m_stride);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the SparsePtr with an offset
|
||||
* \return A SparsePtr with the new stride
|
||||
*
|
||||
* \param count Number of stride to do
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T> SparsePtr<T>::operator-(int count) const
|
||||
{
|
||||
return SparsePtr(m_ptr - count*m_stride, m_stride);
|
||||
return SparsePtr(m_ptr - count * m_stride, m_stride);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the SparsePtr with an offset
|
||||
* \return A SparsePtr with the new stride
|
||||
*
|
||||
* \param count Number of stride to do
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T> SparsePtr<T>::operator-(unsigned int count) const
|
||||
{
|
||||
return SparsePtr(m_ptr - count*m_stride, m_stride);
|
||||
return SparsePtr(m_ptr - count * m_stride, m_stride);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the difference between the two SparsePtr
|
||||
* \return The difference of elements: ptr - this->ptr
|
||||
*
|
||||
* \param ptr Other ptr
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
std::ptrdiff_t SparsePtr<T>::operator-(const SparsePtr& ptr) const
|
||||
{
|
||||
return (m_ptr - ptr.m_ptr)/m_stride;
|
||||
return (m_ptr - ptr.m_ptr) / m_stride;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the SparsePtr with an offset
|
||||
* \return A reference to this pointer with the new stride
|
||||
*
|
||||
* \param count Number of stride to do
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T>& SparsePtr<T>::operator+=(int count)
|
||||
{
|
||||
m_ptr += count*m_stride;
|
||||
m_ptr += count * m_stride;
|
||||
|
||||
return *this;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the SparsePtr with an offset
|
||||
* \return A reference to this pointer with the new stride
|
||||
*
|
||||
* \param count Number of stride to do
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T>& SparsePtr<T>::operator-=(int count)
|
||||
{
|
||||
m_ptr -= count*m_stride;
|
||||
m_ptr -= count * m_stride;
|
||||
|
||||
return *this;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the SparsePtr with the next element
|
||||
* \return A reference to this pointer updated
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T>& SparsePtr<T>::operator++()
|
||||
{
|
||||
@@ -178,19 +340,29 @@ namespace Nz
|
||||
return *this;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the SparsePtr with the next element
|
||||
* \return A SparsePtr not updated
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T> SparsePtr<T>::operator++(int)
|
||||
{
|
||||
// On fait une copie de l'objet
|
||||
// We copy the object
|
||||
SparsePtr tmp(*this);
|
||||
|
||||
// On modifie l'objet
|
||||
// We modify it
|
||||
operator++();
|
||||
|
||||
// On retourne la copie
|
||||
// We return the copy
|
||||
return tmp;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the SparsePtr with the previous element
|
||||
* \return A reference to this pointer updated
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T>& SparsePtr<T>::operator--()
|
||||
{
|
||||
@@ -198,49 +370,96 @@ namespace Nz
|
||||
return *this;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Gets the SparsePtr with the previous element
|
||||
* \return A SparsePtr not updated
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
SparsePtr<T> SparsePtr<T>::operator--(int)
|
||||
{
|
||||
// On fait une copie de l'objet
|
||||
// We copy the object
|
||||
SparsePtr tmp(*this);
|
||||
|
||||
// On modifie l'objet
|
||||
// We modify it
|
||||
operator--();
|
||||
|
||||
// On retourne la copie
|
||||
// We return the copy
|
||||
return tmp;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Compares the SparsePtr to another one
|
||||
* \return true if the two SparsePtr are pointing to the same memory
|
||||
*
|
||||
* \param ptr Other SparsePtr to compare with
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
bool SparsePtr<T>::operator==(const SparsePtr& ptr) const
|
||||
{
|
||||
return m_ptr == ptr.m_ptr;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Compares the SparsePtr to another one
|
||||
* \return false if the two SparsePtr are pointing to the same memory
|
||||
*
|
||||
* \param ptr Other SparsePtr to compare with
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
bool SparsePtr<T>::operator!=(const SparsePtr& ptr) const
|
||||
{
|
||||
return m_ptr != ptr.m_ptr;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Compares the SparsePtr to another one
|
||||
* \return true if the first SparsePtr is pointing to memory inferior to the second one
|
||||
*
|
||||
* \param ptr Other SparsePtr to compare with
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
bool SparsePtr<T>::operator<(const SparsePtr& ptr) const
|
||||
{
|
||||
return m_ptr < ptr.m_ptr;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Compares the SparsePtr to another one
|
||||
* \return true if the first SparsePtr is pointing to memory superior to the second one
|
||||
*
|
||||
* \param ptr Other SparsePtr to compare with
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
bool SparsePtr<T>::operator>(const SparsePtr& ptr) const
|
||||
{
|
||||
return m_ptr > ptr.m_ptr;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Compares the SparsePtr to another one
|
||||
* \return true if the first SparsePtr is pointing to memory inferior or equal to the second one
|
||||
*
|
||||
* \param ptr Other SparsePtr to compare with
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
bool SparsePtr<T>::operator<=(const SparsePtr& ptr) const
|
||||
{
|
||||
return m_ptr <= ptr.m_ptr;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Compares the SparsePtr to another one
|
||||
* \return true if the first SparsePtr is pointing to memory superior or equal to the second one
|
||||
*
|
||||
* \param ptr Other SparsePtr to compare with
|
||||
*/
|
||||
|
||||
template<typename T>
|
||||
bool SparsePtr<T>::operator>=(const SparsePtr& ptr) const
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user