diff options
author | Nao Pross <naopross@thearcway.org> | 2019-02-22 23:10:07 +0100 |
---|---|---|
committer | Nao Pross <naopross@thearcway.org> | 2019-02-22 23:15:47 +0100 |
commit | 50ab88d5d37e2af635997fce7b103f366594c511 (patch) | |
tree | 123585c0deabc01c96e0aa180353016844f19396 /include/mmvec.hpp | |
parent | Undo directory structure change (diff) | |
parent | Fix typos and other minor errors (diff) | |
download | libmm-50ab88d5d37e2af635997fce7b103f366594c511.tar.gz libmm-50ab88d5d37e2af635997fce7b103f366594c511.zip |
Merge branch 'master' into matrices
Diffstat (limited to 'include/mmvec.hpp')
-rw-r--r-- | include/mmvec.hpp | 34 |
1 files changed, 28 insertions, 6 deletions
diff --git a/include/mmvec.hpp b/include/mmvec.hpp index 4bac658..db3c390 100644 --- a/include/mmvec.hpp +++ b/include/mmvec.hpp @@ -51,13 +51,22 @@ struct mm::basic_vec : public std::array<T, d> { basic_vec(); basic_vec(const std::initializer_list<T> l); + + // copyable to a vector of size n <= d template<std::size_t n> basic_vec(const basic_vec<T, n>& other); + // movable to a vector of size n <= d + template<std::size_t n> basic_vec(basic_vec<T, n>&& other); T length() const; + // copy operator= template<std::size_t n> basic_vec<T, d>& operator=(const mm::basic_vec<T, n>& other); + // move operator= + template<std::size_t n> + basic_vec<T, d>& operator=(mm::basic_vec<T, n>&& other); + template<std::size_t n> basic_vec<T, d>& operator+=(const mm::basic_vec<T, n>& other); @@ -78,9 +87,6 @@ mm::basic_vec<T, d>::basic_vec() : std::array<T, d>() { template<typename T, std::size_t d> mm::basic_vec<T, d>::basic_vec(const std::initializer_list<T> l) { - // construct with empty values - basic_vec(); - // why can't this sh*t be a constexpr with static_assert??? assert(l.size() <= d); std::copy(l.begin(), l.end(), this->begin()); @@ -89,9 +95,12 @@ mm::basic_vec<T, d>::basic_vec(const std::initializer_list<T> l) { template<typename T, std::size_t d> template<std::size_t n> mm::basic_vec<T, d>::basic_vec(const mm::basic_vec<T, n>& other) { - // construct with empty values - basic_vec(); - // uses operator= + *this = other; +} + +template<typename T, std::size_t d> +template<std::size_t n> +mm::basic_vec<T, d>::basic_vec(basic_vec<T, n>&& other) { *this = other; } @@ -122,6 +131,19 @@ mm::basic_vec<T, d>& mm::basic_vec<T, d>::operator=(const mm::basic_vec<T, n>& o template<typename T, std::size_t d> template<std::size_t n> +mm::basic_vec<T, d>& mm::basic_vec<T, d>::operator=(mm::basic_vec<T, n>&& other) { + static_assert( + d >= n, "cannot move a higher dimensional vector into a smaller one" + ); + + std::move(other.begin(), other.end(), this->begin()); + + return *this; +} + + +template<typename T, std::size_t d> +template<std::size_t n> mm::basic_vec<T, d>& mm::basic_vec<T, d>::operator+=(const mm::basic_vec<T, n>& other) { *this = *this + other; return *this; |