Buildfix and reorder of files
This commit is contained in:
parent
eecb16afcd
commit
f9e249a972
10 changed files with 573 additions and 75 deletions
25
include/components/tyler.hpp
Normal file
25
include/components/tyler.hpp
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
#ifndef id6FB3FC97331449038D42AAAB4C01ABA1
|
||||||
|
#define id6FB3FC97331449038D42AAAB4C01ABA1
|
||||||
|
|
||||||
|
#include "implem/coords.hpp"
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
namespace dk {
|
||||||
|
class Viewport;
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
class Tyler {
|
||||||
|
public:
|
||||||
|
Tyler ( const coords& parCoords );
|
||||||
|
virtual ~Tyler ( void ) noexcept = default;
|
||||||
|
|
||||||
|
virtual bool batch_load ( const coords& parFrom, const coords& parTo );
|
||||||
|
virtual bool single_load ( const coords& parCoords );
|
||||||
|
|
||||||
|
private:
|
||||||
|
const coords m_size;
|
||||||
|
std::vector<T> m_tiles;
|
||||||
|
};
|
||||||
|
} //namespace dk
|
||||||
|
|
||||||
|
#endif
|
|
@ -1,20 +1,20 @@
|
||||||
#ifndef id0ADBCC15BA574485BF3267254090D99B
|
#ifndef id0ADBCC15BA574485BF3267254090D99B
|
||||||
#define id0ADBCC15BA574485BF3267254090D99B
|
#define id0ADBCC15BA574485BF3267254090D99B
|
||||||
|
|
||||||
#include "coords.hpp"
|
#include "implem/coords.hpp"
|
||||||
|
|
||||||
namespace dk {
|
namespace dk {
|
||||||
class Viewport {
|
class Viewport {
|
||||||
public:
|
public:
|
||||||
explicit Viewport ( const Coords& parSize );
|
explicit Viewport ( const coords& parSize );
|
||||||
Viewport ( const Coords& parSize, const Coord; parPos );
|
Viewport ( const coords& parSize, const coords& parPos );
|
||||||
~Viewport ( void ) noexcept = default;
|
~Viewport ( void ) noexcept = default;
|
||||||
|
|
||||||
Viewport& operator= ( const Viewport& ) = default;
|
Viewport& operator= ( const Viewport& ) = default;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Coords size_;
|
coords m_size;
|
||||||
Coords position_;
|
coords m_position;
|
||||||
};
|
};
|
||||||
} //namespace dk
|
} //namespace dk
|
||||||
|
|
|
@ -1,15 +0,0 @@
|
||||||
#ifndef id305A77366E3B4D3C84CC345C93A7C38B
|
|
||||||
#define id305A77366E3B4D3C84CC345C93A7C38B
|
|
||||||
|
|
||||||
#include <cstddef>
|
|
||||||
|
|
||||||
namespace dk {
|
|
||||||
typedef std::size_t CoordType;
|
|
||||||
|
|
||||||
struct Coords {
|
|
||||||
CoordType width;
|
|
||||||
CoordType height;
|
|
||||||
};
|
|
||||||
} //namespace dk
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -1,23 +1,7 @@
|
||||||
#ifndef id5A4C05FA7D264B65B7B7D14A0792E3A2
|
#ifndef id5A4C05FA7D264B65B7B7D14A0792E3A2
|
||||||
#define id5A4C05FA7D264B65B7B7D14A0792E3A2
|
#define id5A4C05FA7D264B65B7B7D14A0792E3A2
|
||||||
|
|
||||||
#include "coords.hpp"
|
#include "components/tyler.hpp"
|
||||||
|
#include "components/viewport.hpp"
|
||||||
namespace dk {
|
|
||||||
class Viewport;
|
|
||||||
|
|
||||||
class Tyler {
|
|
||||||
public:
|
|
||||||
Tyler ( const Coords& parCoords );
|
|
||||||
virtual ~Tyler ( void ) noexcept = default;
|
|
||||||
|
|
||||||
virtual bool batch_load ( const Coords& parFrom, const Coords& parTo );
|
|
||||||
virtual bool single_load ( const Coords& parCoords );
|
|
||||||
|
|
||||||
private:
|
|
||||||
const Coords size_;
|
|
||||||
|
|
||||||
};
|
|
||||||
} //namespace dk
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
58
include/implem/compatibility.h
Normal file
58
include/implem/compatibility.h
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
/*
|
||||||
|
Copyright 2014 Michele "King_DuckZ" Santullo
|
||||||
|
|
||||||
|
This file is part of CloonelJump.
|
||||||
|
|
||||||
|
CloonelJump 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 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
CloonelJump 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 CloonelJump. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef id45CDD1DAEF4F42968E3C89F68FDDA9BC
|
||||||
|
#define id45CDD1DAEF4F42968E3C89F68FDDA9BC
|
||||||
|
|
||||||
|
#if defined(__GNUC__)
|
||||||
|
# if defined(__clang__)
|
||||||
|
# if !defined(__has_attribute)
|
||||||
|
//Fall back to version number comparing
|
||||||
|
# else
|
||||||
|
# if __has_attribute(flatten)
|
||||||
|
# define a_flatten __attribute__((flatten))
|
||||||
|
# else
|
||||||
|
# define a_flatten
|
||||||
|
# endif
|
||||||
|
# if __has_attribute(always_inline)
|
||||||
|
# define a_always_inline __attribute__((always_inline))
|
||||||
|
# else
|
||||||
|
# define a_always_inline
|
||||||
|
# endif
|
||||||
|
# if __has_attribute(pure)
|
||||||
|
# define a_pure __attribute__((pure))
|
||||||
|
# else
|
||||||
|
# define a_pure
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
# else
|
||||||
|
//Fix here if you get warnings about unsupported attributes on your compiler
|
||||||
|
# define a_flatten __attribute__((flatten))
|
||||||
|
# define a_always_inline __attribute__((always_inline))
|
||||||
|
# define a_pure __attribute__((pure))
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
# warning "Unsupported compiler, please fill this section or file a bug"
|
||||||
|
# define a_flatten
|
||||||
|
# define a_always_inline
|
||||||
|
# define a_pure
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
12
include/implem/coords.hpp
Normal file
12
include/implem/coords.hpp
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
#ifndef id305A77366E3B4D3C84CC345C93A7C38B
|
||||||
|
#define id305A77366E3B4D3C84CC345C93A7C38B
|
||||||
|
|
||||||
|
#include "implem/vector.hpp"
|
||||||
|
|
||||||
|
namespace dk {
|
||||||
|
typedef int coord_type;
|
||||||
|
typedef cloonel::Vector<coord_type, 2> coords;
|
||||||
|
typedef cloonel::Vector<int, 2> int2;
|
||||||
|
} //namespace dk
|
||||||
|
|
||||||
|
#endif
|
219
include/implem/vector.hpp
Normal file
219
include/implem/vector.hpp
Normal file
|
@ -0,0 +1,219 @@
|
||||||
|
/*
|
||||||
|
Copyright 2014 Michele "King_DuckZ" Santullo
|
||||||
|
|
||||||
|
This file is part of CloonelJump.
|
||||||
|
|
||||||
|
CloonelJump 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 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
CloonelJump 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 CloonelJump. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef idid0528646832E04CF08E9785B66CFE0BD1
|
||||||
|
#define idid0528646832E04CF08E9785B66CFE0BD1
|
||||||
|
|
||||||
|
#include "compatibility.h"
|
||||||
|
#include <cstdint>
|
||||||
|
#include <ciso646>
|
||||||
|
#include <type_traits>
|
||||||
|
#include <algorithm>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
#if !defined(NDEBUG)
|
||||||
|
#include <iostream>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__INTEL_COMPILER)
|
||||||
|
# define DONT_GUESS_NOEXCEPT
|
||||||
|
#endif
|
||||||
|
|
||||||
|
namespace cloonel {
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
class Vector {
|
||||||
|
template <typename U, uint32_t R> friend class Vector;
|
||||||
|
public:
|
||||||
|
#if defined(DONT_GUESS_NOEXCEPT)
|
||||||
|
Vector ( void ) = default;
|
||||||
|
explicit Vector ( T parValue );
|
||||||
|
template <typename U> explicit Vector ( const Vector<U, S>& parOther );
|
||||||
|
#else
|
||||||
|
Vector ( void ) noexcept(noexcept(T())) = default;
|
||||||
|
explicit Vector ( T parValue ) noexcept(noexcept(T()) && noexcept(parValue=parValue));
|
||||||
|
template <typename U> explicit Vector ( const Vector<U, S>& parOther ) noexcept(noexcept(T()) && noexcept(const_cast<U&>(parOther.m_mem[0])=T()));
|
||||||
|
#endif
|
||||||
|
template <typename = std::enable_if<S == 2> > Vector ( T parX, T parY ) noexcept : m_mem {parX, parY} {}
|
||||||
|
template <typename = std::enable_if<S == 3> > Vector ( T parX, T parY, T parZ ) noexcept : m_mem {parX, parY, parZ} {}
|
||||||
|
template <typename = std::enable_if<S == 4> > Vector ( T parX, T parY, T parZ, T parW ) noexcept : m_mem {parX, parY, parZ, parW} {}
|
||||||
|
|
||||||
|
~Vector ( void ) noexcept = default;
|
||||||
|
|
||||||
|
enum {
|
||||||
|
Dimension = S
|
||||||
|
};
|
||||||
|
|
||||||
|
template <typename = std::enable_if< 4 >= S> > T& x ( void ) { return m_mem[0]; }
|
||||||
|
template <typename = std::enable_if< 4 >= S> > const T& x ( void ) const { return m_mem[0]; }
|
||||||
|
template <typename = std::enable_if<S >= 2 and 4 >= S> > T& y ( void ) { return m_mem[1]; }
|
||||||
|
template <typename = std::enable_if<S >= 2 and 4 >= S> > const T& y ( void ) const { return m_mem[1]; }
|
||||||
|
template <typename = std::enable_if<S >= 3 and 4 >= S> > T& z ( void ) { return m_mem[2]; }
|
||||||
|
template <typename = std::enable_if<S >= 3 and 4 >= S> > const T& z ( void ) const { return m_mem[2]; }
|
||||||
|
template <typename = std::enable_if<S >= 4 and 4 >= S> > T& w ( void ) { return m_mem[3]; }
|
||||||
|
template <typename = std::enable_if<S >= 4 and 4 >= S> > const T& w ( void ) const { return m_mem[3]; }
|
||||||
|
|
||||||
|
template <typename U> const Vector& operator+= ( const Vector<U, S>& parOther );
|
||||||
|
template <typename U> const Vector& operator-= ( const Vector<U, S>& parOther );
|
||||||
|
template <typename U> const Vector& operator*= ( const Vector<U, S>& parOther );
|
||||||
|
template <typename U> const Vector& operator/= ( const Vector<U, S>& parOther );
|
||||||
|
template <typename U> const Vector& operator+= ( U parOther );
|
||||||
|
template <typename U> const Vector& operator-= ( U parOther );
|
||||||
|
template <typename U> const Vector& operator*= ( U parOther );
|
||||||
|
template <typename U> const Vector& operator/= ( U parOther );
|
||||||
|
|
||||||
|
T& operator[] ( uint32_t parIndex ) { assert(parIndex < S); return m_mem[parIndex]; }
|
||||||
|
const T& operator[] ( uint32_t parIndex ) const { assert(parIndex < S); return m_mem[parIndex]; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
T m_mem[S];
|
||||||
|
};
|
||||||
|
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator+ ( const Vector<T, S>& parA, const Vector<U, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator- ( const Vector<T, S>& parA, const Vector<U, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator* ( const Vector<T, S>& parA, const Vector<U, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator/ ( const Vector<T, S>& parA, const Vector<U, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S, typename=typename std::enable_if<std::is_fundamental<U>::value>::type>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator+ ( U parA, const Vector<T, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S, typename=typename std::enable_if<std::is_fundamental<U>::value>::type>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator- ( U parA, const Vector<T, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S, typename=typename std::enable_if<std::is_fundamental<U>::value>::type>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator* ( U parA, const Vector<T, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S, typename=typename std::enable_if<std::is_fundamental<U>::value>::type>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator/ ( U parA, const Vector<T, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S, typename=typename std::enable_if<std::is_fundamental<U>::value>::type>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator+ ( const Vector<T, S>& parA, U parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S, typename=typename std::enable_if<std::is_fundamental<U>::value>::type>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator- ( const Vector<T, S>& parA, U parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S, typename=typename std::enable_if<std::is_fundamental<U>::value>::type>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator* ( const Vector<T, S>& parA, U parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S, typename=typename std::enable_if<std::is_fundamental<U>::value>::type>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator/ ( const Vector<T, S>& parA, U parB ) a_pure;
|
||||||
|
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
bool operator< ( const Vector<T, S>& parA, const Vector<U, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
bool operator> ( const Vector<T, S>& parA, const Vector<U, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
bool operator<= ( const Vector<T, S>& parA, const Vector<U, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
bool operator>= ( const Vector<T, S>& parA, const Vector<U, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
bool operator== ( const Vector<T, S>& parA, const Vector<U, S>& parB ) a_pure;
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
bool operator!= ( const Vector<T, S>& parA, const Vector<U, S>& parB ) a_pure;
|
||||||
|
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
Vector<T, S> operator- ( Vector<T, S> parOperand ) a_pure;
|
||||||
|
|
||||||
|
typedef Vector<float, 2> float2;
|
||||||
|
typedef Vector<uint16_t, 2> ushort2;
|
||||||
|
#if !defined(NDEBUG)
|
||||||
|
typedef Vector<int16_t, 2> short2;
|
||||||
|
#endif
|
||||||
|
typedef Vector<int32_t, 2> int2;
|
||||||
|
|
||||||
|
#if !defined(NDEBUG)
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
std::ostream& operator<< ( std::ostream& parStream, const Vector<T, S>& parVector ) {
|
||||||
|
parStream << "<";
|
||||||
|
for (uint32_t z = 0; z < S - 1; ++z) {
|
||||||
|
parStream << parVector[z] << ",";
|
||||||
|
}
|
||||||
|
parStream << parVector[S - 1] << ">";
|
||||||
|
return parStream;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
namespace implem {
|
||||||
|
template <typename T, typename U>
|
||||||
|
struct CategorizeTypes {
|
||||||
|
typedef typename std::common_type<T, U>::type CommonType;
|
||||||
|
typedef typename std::conditional<std::is_same<CommonType, T>::value, U, T>::type OtherType;
|
||||||
|
};
|
||||||
|
template <typename Cat, uint32_t S, bool Straightforward=std::is_same<typename Cat::CommonType, typename Cat::OtherType>::value>
|
||||||
|
struct DoOperation {
|
||||||
|
static Vector<typename Cat::CommonType, S> do_mul ( Vector<typename Cat::CommonType, S> parLho, const Vector<typename Cat::CommonType, S>& parRho ) {
|
||||||
|
parLho *= parRho;
|
||||||
|
return parLho;
|
||||||
|
}
|
||||||
|
static Vector<typename Cat::CommonType, S> do_div ( Vector<typename Cat::CommonType, S> parLho, const Vector<typename Cat::CommonType, S>& parRho ) {
|
||||||
|
parLho /= parRho;
|
||||||
|
return parLho;
|
||||||
|
}
|
||||||
|
static Vector<typename Cat::CommonType, S> do_sum ( Vector<typename Cat::CommonType, S> parLho, const Vector<typename Cat::CommonType, S>& parRho ) {
|
||||||
|
parLho += parRho;
|
||||||
|
return parLho;
|
||||||
|
}
|
||||||
|
static Vector<typename Cat::CommonType, S> do_sub ( Vector<typename Cat::CommonType, S> parLho, const Vector<typename Cat::CommonType, S>& parRho ) {
|
||||||
|
parLho -= parRho;
|
||||||
|
return parLho;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
template <typename Cat, uint32_t S>
|
||||||
|
struct DoOperation<Cat, S, false> {
|
||||||
|
static Vector<typename Cat::CommonType, S> do_mul ( Vector<typename Cat::CommonType, S> parLho, const Vector<typename Cat::OtherType, S>& parRho ) {
|
||||||
|
parLho *= parRho;
|
||||||
|
return parLho;
|
||||||
|
}
|
||||||
|
static Vector<typename Cat::CommonType, S> do_mul ( const Vector<typename Cat::OtherType, S>& parLho, const Vector<typename Cat::CommonType, S>& parRho ) {
|
||||||
|
Vector<typename Cat::CommonType, S> ret(parLho);
|
||||||
|
ret *= parRho;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
static Vector<typename Cat::CommonType, S> do_div ( Vector<typename Cat::CommonType, S> parLho, const Vector<typename Cat::OtherType, S>& parRho ) {
|
||||||
|
parLho /= parRho;
|
||||||
|
return parLho;
|
||||||
|
}
|
||||||
|
static Vector<typename Cat::CommonType, S> do_div ( const Vector<typename Cat::OtherType, S>& parLho, const Vector<typename Cat::CommonType, S>& parRho ) {
|
||||||
|
Vector<typename Cat::CommonType, S> ret(parLho);
|
||||||
|
ret /= parRho;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
static Vector<typename Cat::CommonType, S> do_sum ( Vector<typename Cat::CommonType, S> parLho, const Vector<typename Cat::OtherType, S>& parRho ) {
|
||||||
|
parLho += parRho;
|
||||||
|
return parLho;
|
||||||
|
}
|
||||||
|
static Vector<typename Cat::CommonType, S> do_sum ( const Vector<typename Cat::OtherType, S>& parLho, const Vector<typename Cat::CommonType, S>& parRho ) {
|
||||||
|
Vector<typename Cat::CommonType, S> ret(parLho);
|
||||||
|
ret += parRho;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
static Vector<typename Cat::CommonType, S> do_sub ( Vector<typename Cat::CommonType, S> parLho, const Vector<typename Cat::OtherType, S>& parRho ) {
|
||||||
|
parLho -= parRho;
|
||||||
|
return parLho;
|
||||||
|
}
|
||||||
|
static Vector<typename Cat::CommonType, S> do_sub ( const Vector<typename Cat::OtherType, S>& parLho, const Vector<typename Cat::CommonType, S>& parRho ) {
|
||||||
|
Vector<typename Cat::CommonType, S> ret(parLho);
|
||||||
|
ret -= parRho;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} //namespace implem
|
||||||
|
} //namespace cloonel
|
||||||
|
#include "vector.inl"
|
||||||
|
|
||||||
|
#if defined(DONT_GUESS_NOEXCEPT)
|
||||||
|
#undef DONT_GUESS_NOEXCEPT
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
252
include/implem/vector.inl
Normal file
252
include/implem/vector.inl
Normal file
|
@ -0,0 +1,252 @@
|
||||||
|
/*
|
||||||
|
Copyright 2014 Michele "King_DuckZ" Santullo
|
||||||
|
|
||||||
|
This file is part of CloonelJump.
|
||||||
|
|
||||||
|
CloonelJump 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 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
CloonelJump 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 CloonelJump. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace cloonel {
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
#if defined(DONT_GUESS_NOEXCEPT)
|
||||||
|
Vector<T, S>::Vector (T parValue) {
|
||||||
|
#else
|
||||||
|
Vector<T, S>::Vector (T parValue) noexcept(noexcept(T()) && noexcept(parValue=parValue)) {
|
||||||
|
#endif
|
||||||
|
std::fill(m_mem, m_mem + S, parValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
template <typename U>
|
||||||
|
#if defined(DONT_GUESS_NOEXCEPT)
|
||||||
|
Vector<T, S>::Vector (const Vector<U, S>& parOther) {
|
||||||
|
#else
|
||||||
|
Vector<T, S>::Vector (const Vector<U, S>& parOther) noexcept(noexcept(T()) && noexcept(const_cast<U&>(parOther.m_mem[0])=T())) {
|
||||||
|
#endif
|
||||||
|
std::copy(parOther.m_mem, parOther.m_mem + S, m_mem);
|
||||||
|
}
|
||||||
|
|
||||||
|
#pragma GCC diagnostic push
|
||||||
|
#pragma GCC diagnostic ignored "-Wconversion"
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
template <typename U>
|
||||||
|
const Vector<T, S>& Vector<T, S>::operator+= (const Vector<U, S>& parOther) {
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
m_mem[z] += parOther.m_mem[z];
|
||||||
|
}
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
template <typename U>
|
||||||
|
const Vector<T, S>& Vector<T, S>::operator-= (const Vector<U, S>& parOther) {
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
m_mem[z] -= parOther.m_mem[z];
|
||||||
|
}
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
template <typename U>
|
||||||
|
const Vector<T, S>& Vector<T, S>::operator*= (const Vector<U, S>& parOther) {
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
m_mem[z] *= parOther.m_mem[z];
|
||||||
|
}
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
template <typename U>
|
||||||
|
const Vector<T, S>& Vector<T, S>::operator/= (const Vector<U, S>& parOther) {
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
m_mem[z] /= parOther.m_mem[z];
|
||||||
|
}
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
#pragma GCC diagnostic pop
|
||||||
|
|
||||||
|
#pragma GCC diagnostic push
|
||||||
|
#pragma GCC diagnostic ignored "-Wconversion"
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
template <typename U>
|
||||||
|
const Vector<T, S>& Vector<T, S>::operator+= (U parOther) {
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
m_mem[z] += parOther;
|
||||||
|
}
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
template <typename U>
|
||||||
|
const Vector<T, S>& Vector<T, S>::operator-= (U parOther) {
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
m_mem[z] -= parOther;
|
||||||
|
}
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
template <typename U>
|
||||||
|
const Vector<T, S>& Vector<T, S>::operator*= (U parOther) {
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
m_mem[z] *= parOther;
|
||||||
|
}
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
template <typename U>
|
||||||
|
const Vector<T, S>& Vector<T, S>::operator/= (U parOther) {
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
m_mem[z] /= parOther;
|
||||||
|
}
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
#pragma GCC diagnostic pop
|
||||||
|
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
inline
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator+ (const Vector<T, S>& parA, const Vector<U, S>& parB) {
|
||||||
|
return implem::DoOperation<implem::CategorizeTypes<T, U>, S>::do_sum(parA, parB);
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
inline
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator- (const Vector<T, S>& parA, const Vector<U, S>& parB) {
|
||||||
|
return implem::DoOperation<implem::CategorizeTypes<T, U>, S>::do_sub(parA, parB);
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
inline
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator* (const Vector<T, S>& parA, const Vector<U, S>& parB) {
|
||||||
|
return implem::DoOperation<implem::CategorizeTypes<T, U>, S>::do_mul(parA, parB);
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
inline
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator/ (const Vector<T, S>& parA, const Vector<U, S>& parB) {
|
||||||
|
return implem::DoOperation<implem::CategorizeTypes<T, U>, S>::do_div(parA, parB);
|
||||||
|
}
|
||||||
|
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
///-------------------------------------------------------------------------
|
||||||
|
template <typename T, typename U, uint32_t S, typename>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator+ (U parA, const Vector<T, S>& parB) {
|
||||||
|
return parB + parA;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S, typename>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator- (U parA, const Vector<T, S>& parB) {
|
||||||
|
return Vector<T, S>(parA) - parB;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S, typename>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator* (U parA, const Vector<T, S>& parB) {
|
||||||
|
return parB * parA;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S, typename>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator/ (U parA, const Vector<T, S>& parB) {
|
||||||
|
return Vector<T, S>(parA) / parB;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S, typename>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator+ (const Vector<T, S>& parA, U parB) {
|
||||||
|
typedef typename std::common_type<T, U>::type RetType;
|
||||||
|
Vector<RetType, S> retVal;
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
retVal[z] = parA[z] + parB;
|
||||||
|
}
|
||||||
|
return retVal;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S, typename>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator- (const Vector<T, S>& parA, U parB) {
|
||||||
|
typedef typename std::common_type<T, U>::type RetType;
|
||||||
|
Vector<RetType, S> retVal;
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
retVal[z] = parA[z] - parB;
|
||||||
|
}
|
||||||
|
return retVal;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S, typename>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator* (const Vector<T, S>& parA, U parB) {
|
||||||
|
typedef typename std::common_type<T, U>::type RetType;
|
||||||
|
Vector<RetType, S> retVal;
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
retVal[z] = parA[z] * parB;
|
||||||
|
}
|
||||||
|
return retVal;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S, typename>
|
||||||
|
Vector<typename std::common_type<T, U>::type, S> operator/ (const Vector<T, S>& parA, U parB) {
|
||||||
|
typedef typename std::common_type<T, U>::type RetType;
|
||||||
|
Vector<RetType, S> retVal;
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
retVal[z] = parA[z] / parB;
|
||||||
|
}
|
||||||
|
return retVal;
|
||||||
|
}
|
||||||
|
|
||||||
|
///--------------------------------------------------------------------------
|
||||||
|
///--------------------------------------------------------------------------
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
inline bool operator< (const Vector<T, S>& parA, const Vector<U, S>& parB) {
|
||||||
|
bool retVal = true;
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
retVal &= static_cast<bool>(parA[z] < parB[z]);
|
||||||
|
}
|
||||||
|
return retVal;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
inline bool operator> (const Vector<T, S>& parA, const Vector<U, S>& parB) {
|
||||||
|
bool retVal = true;
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
retVal &= static_cast<bool>(parA[z] > parB[z]);
|
||||||
|
}
|
||||||
|
return retVal;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
inline bool operator<= (const Vector<T, S>& parA, const Vector<U, S>& parB) {
|
||||||
|
bool retVal = true;
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
retVal &= static_cast<bool>(parA[z] <= parB[z]);
|
||||||
|
}
|
||||||
|
return retVal;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
inline bool operator>= (const Vector<T, S>& parA, const Vector<U, S>& parB) {
|
||||||
|
bool retVal = true;
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
retVal &= static_cast<bool>(parA[z] >= parB[z]);
|
||||||
|
}
|
||||||
|
return retVal;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
inline bool operator== (const Vector<T, S>& parA, const Vector<U, S>& parB) {
|
||||||
|
bool retVal = true;
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
retVal &= static_cast<bool>(parA[z] == parB[z]);
|
||||||
|
}
|
||||||
|
return retVal;
|
||||||
|
}
|
||||||
|
template <typename T, typename U, uint32_t S>
|
||||||
|
inline bool operator!= (const Vector<T, S>& parA, const Vector<U, S>& parB) {
|
||||||
|
return not operator==(parA, parB);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, uint32_t S>
|
||||||
|
Vector<T, S> operator- (Vector<T, S> parOperand) {
|
||||||
|
for (uint32_t z = 0; z < S; ++z) {
|
||||||
|
parOperand[z] = -parOperand[z];
|
||||||
|
}
|
||||||
|
return parOperand;
|
||||||
|
}
|
||||||
|
} //namespace cloonel
|
|
@ -1,33 +0,0 @@
|
||||||
#ifndef id9B2FF4B4CA4244EAB93C619479A8E816
|
|
||||||
#define id9B2FF4B4CA4244EAB93C619479A8E816
|
|
||||||
|
|
||||||
#include <FBVector.h>
|
|
||||||
|
|
||||||
namespace dk {
|
|
||||||
template <typename T, typename C>
|
|
||||||
class ItemsWithID {
|
|
||||||
typedef C container_type;
|
|
||||||
public:
|
|
||||||
typedef T value_type;
|
|
||||||
typedef typename container_type::size_type size_type;
|
|
||||||
typedef typename container_type::size_type id_type;
|
|
||||||
typedef value_type& reference_type;
|
|
||||||
|
|
||||||
ItemsWithID ( void ) = default;
|
|
||||||
~ItemsWithID ( void ) noexcept = default;
|
|
||||||
|
|
||||||
id_type add ( const value_type& parNewVal );
|
|
||||||
void erase ( id_type parID );
|
|
||||||
reference_type operator[] ( id_type parID );
|
|
||||||
const reference_type operator[] ( id_type parID ) const;
|
|
||||||
|
|
||||||
|
|
||||||
private:
|
|
||||||
container_type items_;
|
|
||||||
|
|
||||||
// see:
|
|
||||||
// https://github.com/facebook/folly/blob/master/folly/docs/FBVector.md
|
|
||||||
};
|
|
||||||
} //namespace dk
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -1,5 +1 @@
|
||||||
#include "doorkeeper.hpp"
|
#include "doorkeeper.hpp"
|
||||||
|
|
||||||
|
|
||||||
#include <folly/FBVector.h>
|
|
||||||
#include <jemalloc/jemalloc.h>
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue