2003-11-04 08:03:29 +00:00
|
|
|
// Copyright David Abrahams 2003. Use, modification and distribution is
|
|
|
|
// subject to the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
|
|
|
|
#include <deque>
|
|
|
|
#include <iterator>
|
2017-12-27 09:20:39 +01:00
|
|
|
#include <cstddef> // std::ptrdiff_t
|
2003-11-04 08:03:29 +00:00
|
|
|
#include <boost/noncopyable.hpp>
|
|
|
|
#include <boost/iterator/is_lvalue_iterator.hpp>
|
|
|
|
|
|
|
|
struct v
|
|
|
|
{
|
|
|
|
v();
|
|
|
|
~v();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-12-27 09:20:39 +01:00
|
|
|
struct value_iterator
|
2003-11-04 08:03:29 +00:00
|
|
|
{
|
2017-12-27 09:20:39 +01:00
|
|
|
typedef std::input_iterator_tag iterator_category;
|
|
|
|
typedef v value_type;
|
|
|
|
typedef std::ptrdiff_t difference_type;
|
|
|
|
typedef v* pointer;
|
|
|
|
typedef v& reference;
|
|
|
|
|
2003-11-04 08:03:29 +00:00
|
|
|
v operator*() const;
|
|
|
|
};
|
|
|
|
|
2017-12-27 09:20:39 +01:00
|
|
|
struct noncopyable_iterator
|
2003-11-04 08:03:29 +00:00
|
|
|
{
|
2017-12-27 09:20:39 +01:00
|
|
|
typedef std::forward_iterator_tag iterator_category;
|
|
|
|
typedef boost::noncopyable value_type;
|
|
|
|
typedef std::ptrdiff_t difference_type;
|
|
|
|
typedef boost::noncopyable* pointer;
|
|
|
|
typedef boost::noncopyable& reference;
|
2020-03-04 01:06:45 +03:00
|
|
|
|
2003-11-04 08:03:29 +00:00
|
|
|
boost::noncopyable const& operator*() const;
|
|
|
|
};
|
|
|
|
|
2003-11-22 01:18:37 +00:00
|
|
|
template <class T>
|
|
|
|
struct proxy_iterator
|
2003-11-04 08:03:29 +00:00
|
|
|
{
|
2003-11-22 01:18:37 +00:00
|
|
|
typedef T value_type;
|
2017-12-27 09:20:39 +01:00
|
|
|
typedef std::output_iterator_tag iterator_category;
|
|
|
|
typedef std::ptrdiff_t difference_type;
|
|
|
|
typedef T* pointer;
|
|
|
|
typedef T& reference;
|
2020-03-04 01:06:45 +03:00
|
|
|
|
2003-11-04 08:03:29 +00:00
|
|
|
struct proxy
|
|
|
|
{
|
2003-11-22 01:18:37 +00:00
|
|
|
operator value_type&() const;
|
|
|
|
proxy& operator=(value_type) const;
|
2003-11-04 08:03:29 +00:00
|
|
|
};
|
2020-03-04 01:06:45 +03:00
|
|
|
|
2003-11-04 08:03:29 +00:00
|
|
|
proxy operator*() const;
|
|
|
|
};
|
|
|
|
|
2003-11-22 01:18:37 +00:00
|
|
|
template <class T>
|
|
|
|
struct lvalue_iterator
|
|
|
|
{
|
|
|
|
typedef T value_type;
|
|
|
|
typedef T& reference;
|
|
|
|
typedef T difference_type;
|
|
|
|
typedef std::input_iterator_tag iterator_category;
|
|
|
|
typedef T* pointer;
|
|
|
|
|
|
|
|
T& operator*() const;
|
|
|
|
lvalue_iterator& operator++();
|
|
|
|
lvalue_iterator operator++(int);
|
|
|
|
};
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
struct constant_lvalue_iterator
|
|
|
|
{
|
|
|
|
typedef T value_type;
|
|
|
|
typedef T const& reference;
|
|
|
|
typedef T difference_type;
|
|
|
|
typedef std::input_iterator_tag iterator_category;
|
|
|
|
typedef T const* pointer;
|
|
|
|
|
|
|
|
T const& operator*() const;
|
|
|
|
constant_lvalue_iterator& operator++();
|
|
|
|
constant_lvalue_iterator operator++(int);
|
|
|
|
};
|
|
|
|
|
2003-11-04 08:03:29 +00:00
|
|
|
int main()
|
|
|
|
{
|
2025-01-26 15:17:36 +03:00
|
|
|
static_assert(boost::is_lvalue_iterator<v*>::value,
|
|
|
|
"boost::is_lvalue_iterator<v*>::value is expected to be true.");
|
|
|
|
static_assert(boost::is_lvalue_iterator<v const*>::value,
|
|
|
|
"boost::is_lvalue_iterator<v const*>::value is expected to be true.");
|
|
|
|
static_assert(boost::is_lvalue_iterator<std::deque<v>::iterator>::value,
|
|
|
|
"boost::is_lvalue_iterator<std::deque<v>::iterator>::value.");
|
|
|
|
static_assert(boost::is_lvalue_iterator<std::deque<v>::const_iterator>::value,
|
|
|
|
"boost::is_lvalue_iterator<std::deque<v>::const_iterator>::value is expected to be true.");
|
|
|
|
static_assert(!boost::is_lvalue_iterator<std::back_insert_iterator<std::deque<v>>>::value,
|
|
|
|
"boost::is_lvalue_iterator<std::back_insert_iterator<std::deque<v>>>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_lvalue_iterator<std::ostream_iterator<v>>::value,
|
|
|
|
"boost::is_lvalue_iterator<std::ostream_iterator<v>>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_lvalue_iterator<proxy_iterator<v>>::value,
|
|
|
|
"boost::is_lvalue_iterator<proxy_iterator<v>>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_lvalue_iterator<proxy_iterator<int>>::value,
|
|
|
|
"boost::is_lvalue_iterator<proxy_iterator<int>>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_lvalue_iterator<value_iterator>::value,
|
|
|
|
"boost::is_lvalue_iterator<value_iterator>::value is expected to be false.");
|
2003-11-04 08:03:29 +00:00
|
|
|
// Make sure inaccessible copy constructor doesn't prevent
|
|
|
|
// reference binding
|
2025-01-26 15:17:36 +03:00
|
|
|
static_assert(boost::is_lvalue_iterator<noncopyable_iterator>::value,
|
|
|
|
"boost::is_lvalue_iterator<noncopyable_iterator>::value is expected to be true.");
|
|
|
|
|
|
|
|
static_assert(boost::is_lvalue_iterator<lvalue_iterator<v>>::value,
|
|
|
|
"boost::is_lvalue_iterator<lvalue_iterator<v>>::value is expected to be true.");
|
|
|
|
static_assert(boost::is_lvalue_iterator<lvalue_iterator<int>>::value,
|
|
|
|
"boost::is_lvalue_iterator<lvalue_iterator<int>>::value is expected to be true.");
|
|
|
|
static_assert(boost::is_lvalue_iterator<lvalue_iterator<char*>>::value,
|
|
|
|
"boost::is_lvalue_iterator<lvalue_iterator<char*>>::value is expected to be true.");
|
|
|
|
static_assert(boost::is_lvalue_iterator<lvalue_iterator<float>>::value,
|
|
|
|
"boost::is_lvalue_iterator<lvalue_iterator<float>>::value is expected to be true.");
|
|
|
|
|
|
|
|
|
|
|
|
static_assert(boost::is_lvalue_iterator<constant_lvalue_iterator<v>>::value,
|
|
|
|
"boost::is_lvalue_iterator<constant_lvalue_iterator<v>>::value is expected to be true.");
|
|
|
|
static_assert(boost::is_lvalue_iterator<constant_lvalue_iterator<int>>::value,
|
|
|
|
"boost::is_lvalue_iterator<constant_lvalue_iterator<int>>::value is expected to be true.");
|
|
|
|
static_assert(boost::is_lvalue_iterator<constant_lvalue_iterator<char*>>::value,
|
|
|
|
"boost::is_lvalue_iterator<constant_lvalue_iterator<char*>>::value is expected to be true.");
|
|
|
|
static_assert(boost::is_lvalue_iterator<constant_lvalue_iterator<float>>::value,
|
|
|
|
"boost::is_lvalue_iterator<constant_lvalue_iterator<float>>::value is expected to be true.");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static_assert(boost::is_non_const_lvalue_iterator<v*>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<v*>::value is expected to be true.");
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<v const*>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<v const*>::value is expected to be false.");
|
|
|
|
static_assert(boost::is_non_const_lvalue_iterator<std::deque<v>::iterator>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<std::deque<v>::iterator>::value is expected to be true.");
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<std::deque<v>::const_iterator>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<std::deque<v>::const_iterator>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<std::back_insert_iterator<std::deque<v>>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<std::back_insert_iterator<std::deque<v>>>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<std::ostream_iterator<v>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<std::ostream_iterator<v>>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<proxy_iterator<v>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<proxy_iterator<v>>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<proxy_iterator<int>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<proxy_iterator<int>>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<value_iterator>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<value_iterator>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<noncopyable_iterator>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<noncopyable_iterator>::value is expected to be false.");
|
|
|
|
|
|
|
|
static_assert(boost::is_non_const_lvalue_iterator<lvalue_iterator<v>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<lvalue_iterator<v>>::value is expected to be true.");
|
|
|
|
static_assert(boost::is_non_const_lvalue_iterator<lvalue_iterator<int>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<lvalue_iterator<int>>::value is expected to be true.");
|
|
|
|
static_assert(boost::is_non_const_lvalue_iterator<lvalue_iterator<char*>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<lvalue_iterator<char*>>::value is expected to be true.");
|
|
|
|
static_assert(boost::is_non_const_lvalue_iterator<lvalue_iterator<float>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<lvalue_iterator<float>>::value is expected to be true.");
|
|
|
|
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<constant_lvalue_iterator<v>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<constant_lvalue_iterator<v>>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<constant_lvalue_iterator<int>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<constant_lvalue_iterator<int>>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<constant_lvalue_iterator<char*>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<constant_lvalue_iterator<char*>>::value is expected to be false.");
|
|
|
|
static_assert(!boost::is_non_const_lvalue_iterator<constant_lvalue_iterator<float>>::value,
|
|
|
|
"boost::is_non_const_lvalue_iterator<constant_lvalue_iterator<float>>::value is expected to be false.");
|
2020-03-04 01:06:45 +03:00
|
|
|
|
2003-11-04 08:03:29 +00:00
|
|
|
return 0;
|
|
|
|
}
|