aboutsummaryrefslogtreecommitdiffhomepage
path: root/Eigen
diff options
context:
space:
mode:
authorGravatar Rasmus Munk Larsen <rmlarsen@google.com>2018-10-09 23:42:01 +0000
committerGravatar Rasmus Munk Larsen <rmlarsen@google.com>2018-10-09 23:42:01 +0000
commite8918743c1d036da1662050054c706ffcc689233 (patch)
tree56087c9a2849994c8b6a19f7b8b5040e537aca78 /Eigen
parent1dd1f8e454512a01bcab1ebe9bd77bf9de09ae22 (diff)
parentbefcac883de5ba98ca2322c87e56f278c140588d (diff)
Merged in ezhulenev/eigen-01 (pull request PR-523)
Compile time detection for unimplemented stl-style iterators
Diffstat (limited to 'Eigen')
-rw-r--r--Eigen/src/Core/DenseBase.h14
-rw-r--r--Eigen/src/Core/StlIterators.h13
-rw-r--r--Eigen/src/Core/util/ForwardDeclarations.h1
3 files changed, 27 insertions, 1 deletions
diff --git a/Eigen/src/Core/DenseBase.h b/Eigen/src/Core/DenseBase.h
index 0c34bce40..eedeacc94 100644
--- a/Eigen/src/Core/DenseBase.h
+++ b/Eigen/src/Core/DenseBase.h
@@ -583,11 +583,23 @@ template<typename Derived> class DenseBase
typedef typename internal::conditional< (Flags&DirectAccessBit)==DirectAccessBit,
internal::pointer_based_stl_iterator<Derived>,
internal::generic_randaccess_stl_iterator<Derived>
- >::type iterator;
+ >::type iterator_type;
typedef typename internal::conditional< (Flags&DirectAccessBit)==DirectAccessBit,
internal::pointer_based_stl_iterator<const Derived>,
internal::generic_randaccess_stl_iterator<const Derived>
+ >::type const_iterator_type;
+
+ // Stl-style iterators are supported only for vectors.
+
+ typedef typename internal::conditional< IsVectorAtCompileTime,
+ iterator_type,
+ internal::not_an_iterator<const Derived>
+ >::type iterator;
+
+ typedef typename internal::conditional< IsVectorAtCompileTime,
+ const_iterator_type,
+ internal::not_an_iterator<const Derived>
>::type const_iterator;
#endif
diff --git a/Eigen/src/Core/StlIterators.h b/Eigen/src/Core/StlIterators.h
index 24eef1269..5f2edc4e6 100644
--- a/Eigen/src/Core/StlIterators.h
+++ b/Eigen/src/Core/StlIterators.h
@@ -11,6 +11,19 @@ namespace Eigen {
namespace internal {
+// Iterator type for XprType that do not support stl-style iterators. Allows to
+// detect that expression does not support stl iterators at compile time.
+template<typename XprType>
+class not_an_iterator
+{
+ not_an_iterator() : mp_xpr(0), m_index(0) {}
+ not_an_iterator(XprType& xpr, Index index) : mp_xpr(&xpr), m_index(index) {}
+
+ protected:
+ XprType *mp_xpr;
+ Index m_index;
+};
+
template<typename XprType,typename Derived>
class indexed_based_stl_iterator_base
{
diff --git a/Eigen/src/Core/util/ForwardDeclarations.h b/Eigen/src/Core/util/ForwardDeclarations.h
index 3ab3a5f50..49c4e0c31 100644
--- a/Eigen/src/Core/util/ForwardDeclarations.h
+++ b/Eigen/src/Core/util/ForwardDeclarations.h
@@ -135,6 +135,7 @@ template<typename Derived> class SolverBase;
template<typename XprType> class InnerIterator;
namespace internal {
+template<typename XprType> class not_an_iterator;
template<typename XprType> class generic_randaccess_stl_iterator;
template<typename XprType> class pointer_based_stl_iterator;
template<typename XprType, DirectionType Direction> class subvector_stl_iterator;