| // This file is part of Eigen, a lightweight C++ template library |
| // for linear algebra. |
| // |
| // Copyright (C) 2009 Gael Guennebaud <gael.guennebaud@inria.fr> |
| // Copyright (C) 2009 Hauke Heibel <hauke.heibel@googlemail.com> |
| // |
| // This Source Code Form is subject to the terms of the Mozilla |
| // Public License v. 2.0. If a copy of the MPL was not distributed |
| // with this file, You can obtain one at http://mozilla.org/MPL/2.0/. |
| |
| #ifndef EIGEN_STL_DETAILS_H |
| #define EIGEN_STL_DETAILS_H |
| |
| #ifndef EIGEN_ALIGNED_ALLOCATOR |
| #define EIGEN_ALIGNED_ALLOCATOR Eigen::aligned_allocator |
| #endif |
| |
| namespace Eigen { |
| |
| // This one is needed to prevent reimplementing the whole std::vector. |
| template <class T> |
| class aligned_allocator_indirection : public EIGEN_ALIGNED_ALLOCATOR<T> { |
| public: |
| typedef std::size_t size_type; |
| typedef std::ptrdiff_t difference_type; |
| typedef T* pointer; |
| typedef const T* const_pointer; |
| typedef T& reference; |
| typedef const T& const_reference; |
| typedef T value_type; |
| |
| template <class U> |
| struct rebind { |
| typedef aligned_allocator_indirection<U> other; |
| }; |
| |
| aligned_allocator_indirection() {} |
| aligned_allocator_indirection(const aligned_allocator_indirection&) : EIGEN_ALIGNED_ALLOCATOR<T>() {} |
| aligned_allocator_indirection(const EIGEN_ALIGNED_ALLOCATOR<T>&) {} |
| template <class U> |
| aligned_allocator_indirection(const aligned_allocator_indirection<U>&) {} |
| template <class U> |
| aligned_allocator_indirection(const EIGEN_ALIGNED_ALLOCATOR<U>&) {} |
| ~aligned_allocator_indirection() {} |
| }; |
| |
| #if EIGEN_COMP_MSVC |
| |
| // sometimes, MSVC detects, at compile time, that the argument x |
| // in std::vector::resize(size_t s,T x) won't be aligned and generate an error |
| // even if this function is never called. Whence this little wrapper. |
| #define EIGEN_WORKAROUND_MSVC_STL_SUPPORT(T) \ |
| std::conditional_t<Eigen::internal::is_arithmetic<T>::value, T, Eigen::internal::workaround_msvc_stl_support<T> > |
| |
| namespace internal { |
| template <typename T> |
| struct workaround_msvc_stl_support : public T { |
| inline workaround_msvc_stl_support() : T() {} |
| inline workaround_msvc_stl_support(const T& other) : T(other) {} |
| inline operator T&() { return *static_cast<T*>(this); } |
| inline operator const T&() const { return *static_cast<const T*>(this); } |
| template <typename OtherT> |
| inline T& operator=(const OtherT& other) { |
| T::operator=(other); |
| return *this; |
| } |
| inline workaround_msvc_stl_support& operator=(const workaround_msvc_stl_support& other) { |
| T::operator=(other); |
| return *this; |
| } |
| }; |
| } // namespace internal |
| |
| #else |
| |
| #define EIGEN_WORKAROUND_MSVC_STL_SUPPORT(T) T |
| |
| #endif |
| |
| } // namespace Eigen |
| |
| #endif // EIGEN_STL_DETAILS_H |