/* Ptr_Iterator class implementation: inline functions. Copyright (C) 2001-2010 Roberto Bagnara Copyright (C) 2010-2011 BUGSENG srl (http://bugseng.com) This file is part of the Parma Polyhedra Library (PPL). The PPL 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. The PPL 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 this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1307, USA. For the most up-to-date information see the Parma Polyhedra Library site: http://www.cs.unipr.it/ppl/ . */ #ifndef PPL_Ptr_Iterator_inlines_hh #define PPL_Ptr_Iterator_inlines_hh 1 #include #include "assert.hh" namespace Parma_Polyhedra_Library { namespace Implementation { template inline const P& Ptr_Iterator

::base() const { return p; } template inline Ptr_Iterator

::Ptr_Iterator() : p(P()) { } template inline Ptr_Iterator

::Ptr_Iterator(const P& q) : p(q) { } template template inline Ptr_Iterator

::Ptr_Iterator(const Ptr_Iterator& y) : p(y.base()) { } template inline typename Ptr_Iterator

::reference Ptr_Iterator

::operator*() const { return *p; } template inline typename Ptr_Iterator

::pointer Ptr_Iterator

::operator->() const { return p; } template inline typename Ptr_Iterator

::reference Ptr_Iterator

::operator[](const difference_type m) const { return p[m]; } template inline Ptr_Iterator

& Ptr_Iterator

::operator++() { ++p; return *this; } template inline Ptr_Iterator

Ptr_Iterator

::operator++(int) { return Ptr_Iterator(p++); } template inline Ptr_Iterator

& Ptr_Iterator

::operator--() { --p; return *this; } template inline Ptr_Iterator

Ptr_Iterator

::operator--(int) { return Ptr_Iterator(p--); } template inline Ptr_Iterator

& Ptr_Iterator

::operator+=(const difference_type m) { p += m; return *this; } template inline Ptr_Iterator

& Ptr_Iterator

::operator-=(const difference_type m) { p -= m; return *this; } template inline typename Ptr_Iterator

::difference_type Ptr_Iterator

::operator-(const Ptr_Iterator& y) const { return p - y.p; } template inline Ptr_Iterator

Ptr_Iterator

::operator+(const difference_type m) const { return Ptr_Iterator(p + m); } template inline Ptr_Iterator

Ptr_Iterator

::operator-(const difference_type m) const { return Ptr_Iterator(p - m); } template inline bool operator==(const Ptr_Iterator

& x, const Ptr_Iterator& y) { return x.base() == y.base(); } template inline bool operator!=(const Ptr_Iterator

& x, const Ptr_Iterator& y) { return x.base() != y.base(); } template inline bool operator<(const Ptr_Iterator

& x, const Ptr_Iterator& y) { return x.base() < y.base(); } template inline bool operator<=(const Ptr_Iterator

& x, const Ptr_Iterator& y) { return x.base() <= y.base(); } template inline bool operator>(const Ptr_Iterator

& x, const Ptr_Iterator& y) { return x.base() > y.base(); } template inline bool operator>=(const Ptr_Iterator

& x, const Ptr_Iterator& y) { return x.base() >= y.base(); } template inline typename Ptr_Iterator

::difference_type operator-(const Ptr_Iterator

& x, const Ptr_Iterator& y) { return x.base() - y.base(); } template inline Ptr_Iterator

operator+(typename Ptr_Iterator

::difference_type m, const Ptr_Iterator

& y) { return Ptr_Iterator

(m + y.base()); } } // namespace Implementation } // namespace Parma_Polyhedra_Library #endif // !defined(PPL_Ptr_Iterator_inlines_hh)