remove range difference type (unused)

master
Daniel Kolesa 2017-04-16 17:23:09 +02:00
parent 71aa6ff70b
commit 1619dac782
6 changed files with 87 additions and 126 deletions

View File

@ -1210,10 +1210,9 @@ namespace detail {
using range_category = std::common_type_t<
range_category_t<T>, finite_random_access_range_tag
>;
using value_type = std::remove_reference_t<R>;
using reference = R;
using size_type = range_size_t<T>;
using difference_type = range_difference_t<T>;
using value_type = std::remove_reference_t<R>;
using reference = R;
using size_type = range_size_t<T>;
private:
T p_range;
@ -1260,7 +1259,7 @@ namespace detail {
*
* The `reference` member type of the range is `R` where `R` is the return
* value of `func`. The `value_type` is `std::remove_reference_t<R>`. The
* size and difference types are preserved.
* size type is preserved.
*
* On each access of a range item (front, back, indexing), the `func` is
* called with the actual wrapped range's item and the result is returned.
@ -1304,10 +1303,9 @@ namespace detail {
using range_category = std::common_type_t<
range_category_t<T>, forward_range_tag
>;
using value_type = range_value_t<T>;
using reference = range_reference_t<T>;
using size_type = range_size_t<T>;
using difference_type = range_difference_t<T>;
using value_type = range_value_t<T>;
using reference = range_reference_t<T>;
using size_type = range_size_t<T>;
private:
T p_range;
@ -1373,7 +1371,7 @@ namespace detail {
* }
* ~~~
*
* The value, reference, size and difference types are preserved, as are
* The value, reference and size types are preserved, as are
* calls to `front()` and `empty()`.
*
* @see ostd::map()

View File

@ -1188,11 +1188,10 @@ using yield_type = typename detail::yield_type_base<T>::type;
namespace detail {
template<typename T>
struct generator_range: input_range<generator_range<T>> {
using range_category = input_range_tag;
using value_type = T;
using reference = T &;
using size_type = std::size_t;
using difference_type = std::ptrdiff_t;
using range_category = input_range_tag;
using value_type = T;
using reference = T &;
using size_type = std::size_t;
generator_range() = delete;

View File

@ -277,10 +277,9 @@ OSTD_EXPORT extern file_stream cerr;
namespace detail {
/* lightweight output range for direct stdout */
struct stdout_range: output_range<stdout_range> {
using value_type = char;
using reference = char &;
using size_type = std::size_t;
using difference_type = std::ptrdiff_t;
using value_type = char;
using reference = char &;
using size_type = std::size_t;
stdout_range() {}
void put(char c) {

View File

@ -188,11 +188,10 @@ namespace detail {
template<typename R>
struct range_traits_base<R, true> {
using range_category = typename R::range_category;
using size_type = typename R::size_type;
using value_type = typename R::value_type;
using reference = typename R::reference;
using difference_type = typename R::difference_type;
using range_category = typename R::range_category;
using size_type = typename R::size_type;
using value_type = typename R::value_type;
using reference = typename R::reference;
template<typename R2>
static constexpr bool is_element_swappable_with =
@ -239,7 +238,6 @@ namespace detail {
* * `size_type` - can contain the range's length (typically `size_t`)
* * `value_type` - the type of the range's elements
* * `reference` - the type returned from value accessors
* * `difference_type` - the type used for distances (typically `ptrdiff_t`)
*
* It will always contain the following members as well:
*
@ -277,7 +275,7 @@ namespace detail {
* You can read about more details [here](@ref ranges).
*
* @see ostd::range_category_t, ostd::range_size_t, ostd::range_value_t,
* ostd::range_reference_t, ostd::range_difference_t
* ostd::range_reference_t
*/
template<typename R>
struct range_traits: detail::range_traits_impl<R, detail::test_range_category<R>> {};
@ -290,8 +288,7 @@ struct range_traits: detail::range_traits_impl<R, detail::test_range_category<R>
* typename ostd::range_traits<R>::range_category
* ~~~
*
* @see ostd::range_size_t, ostd::range_value_t, ostd::range_reference_t,
* ostd::range_difference_t
* @see ostd::range_size_t, ostd::range_value_t, ostd::range_reference_t
*/
template<typename R>
using range_category_t = typename range_traits<R>::range_category;
@ -304,8 +301,7 @@ using range_category_t = typename range_traits<R>::range_category;
* typename ostd::range_traits<R>::size_type
* ~~~
*
* @see ostd::range_category_t, ostd::range_value_t, ostd::range_reference_t,
* ostd::range_difference_t
* @see ostd::range_category_t, ostd::range_value_t, ostd::range_reference_t
*/
template<typename R>
using range_size_t = typename range_traits<R>::size_type;
@ -318,8 +314,7 @@ using range_size_t = typename range_traits<R>::size_type;
* typename ostd::range_traits<R>::value_type
* ~~~
*
* @see ostd::range_category_t, ostd::range_size_t, ostd::range_reference_t,
* ostd::range_difference_t
* @see ostd::range_category_t, ostd::range_size_t, ostd::range_reference_t
*/
template<typename R>
using range_value_t = typename range_traits<R>::value_type;
@ -332,26 +327,11 @@ using range_value_t = typename range_traits<R>::value_type;
* typename ostd::range_traits<R>::reference
* ~~~
*
* @see ostd::range_category_t, ostd::range_size_t, ostd::range_value_t,
* ostd::range_difference_t
* @see ostd::range_category_t, ostd::range_size_t, ostd::range_value_t
*/
template<typename R>
using range_reference_t = typename range_traits<R>::reference;
/** @brief The difference type of a range type.
*
* It's the same as doing
*
* ~~~{.cc}
* typename ostd::range_traits<R>::difference_type
* ~~~
*
* @see ostd::range_category_t, ostd::range_size_t, ostd::range_value_t,
* ostd::range_reference_t
*/
template<typename R>
using range_difference_t = typename range_traits<R>::difference_type;
/** @brief Checks whether two ranges can swap elements with each other.
*
* It's the same as doing
@ -753,7 +733,7 @@ struct input_range {
* wrapped range will be always ostd::finite_random_access_range_tag.
* Otherwise, it will be ostd::bidirectional_range_tag.
*
* The value, reference, size and difference types are the same.
* The value, reference and size types are the same.
*/
auto reverse() const {
static_assert(
@ -777,7 +757,7 @@ struct input_range {
* > == true
* ~~~
*
* The value, size and difference types remain the same. The new reference
* The value and size types remain the same. The new reference
* type becomes `ostd::range_value_t<R> &&`.
*
* Accesses to the front member result in the element being moved.
@ -792,8 +772,8 @@ struct input_range {
* remain mostly the same, but an index counter is kept and incremented on
* each pop.
*
* It's always at most ostd::forward_range_tag. The value, size and
* difference types stay the same, the new reference type is like this:
* It's always at most ostd::forward_range_tag. The value and size types
* stay the same, the new reference type is like this:
*
* ~~~{.cc}
* struct enumerated_value_t {
@ -869,8 +849,8 @@ struct input_range {
*
* The value type can be a pair (for two ranges) or a tuple (for more) of
* the value types. The reference type is also a pair or a tuple, but of
* the reference types. The size and difference types are common types
* between the zipped ranges.
* the reference types. The size type is the common type between the
* zipped ranges.
*/
template<typename R1, typename ...RR>
auto zip(R1 r1, RR ...rr) const {
@ -948,10 +928,9 @@ inline void range_put_all(OR &orange, IR range) {
namespace detail {
template<typename T>
struct noop_output_range: output_range<noop_output_range<T>> {
using value_type = T;
using reference = T &;
using size_type = std::size_t;
using difference_type = std::ptrdiff_t;
using value_type = T;
using reference = T &;
using size_type = std::size_t;
/** @brief Has no effect. */
void put(T const &) {}
@ -972,10 +951,9 @@ inline auto noop_sink() {
namespace detail {
template<typename R>
struct counting_output_range: output_range<counting_output_range<R>> {
using value_type = range_value_t<R>;
using reference = range_reference_t<R>;
using size_type = range_size_t<R>;
using difference_type = range_difference_t<R>;
using value_type = range_value_t<R>;
using reference = range_reference_t<R>;
using size_type = range_size_t<R>;
private:
R p_range;
@ -1194,11 +1172,10 @@ namespace detail {
namespace detail {
template<typename T>
struct number_range: input_range<number_range<T>> {
using range_category = forward_range_tag;
using value_type = T;
using reference = T;
using size_type = std::size_t;
using difference_type = std::ptrdiff_t;
using range_category = forward_range_tag;
using value_type = T;
using reference = T;
using size_type = std::size_t;
number_range() = delete;
@ -1263,15 +1240,14 @@ inline auto range(T v) {
namespace detail {
template<typename T>
struct reverse_range: input_range<reverse_range<T>> {
using range_category = std::conditional_t<
using range_category = std::conditional_t<
is_finite_random_access_range<T>,
finite_random_access_range_tag,
bidirectional_range_tag
>;
using value_type = range_value_t <T>;
using reference = range_reference_t <T>;
using size_type = range_size_t <T>;
using difference_type = range_difference_t<T>;
using value_type = range_value_t <T>;
using reference = range_reference_t<T>;
using size_type = range_size_t <T>;
private:
T p_range;
@ -1318,11 +1294,10 @@ namespace detail {
"Wrapped range references must be proper references to the value type"
);
using range_category = input_range_tag;
using value_type = range_value_t <T>;
using reference = range_value_t <T> &&;
using size_type = range_size_t <T>;
using difference_type = range_difference_t<T>;
using range_category = input_range_tag;
using value_type = range_value_t<T>;
using reference = range_value_t<T> &&;
using size_type = range_size_t<T>;
private:
T p_range;
@ -1348,13 +1323,12 @@ namespace detail {
};
public:
using range_category = std::common_type_t<
using range_category = std::common_type_t<
range_category_t<T>, forward_range_tag
>;
using value_type = range_value_t<T>;
using reference = enumerated_value_t;
using size_type = range_size_t <T>;
using difference_type = range_difference_t<T>;
using value_type = range_value_t<T>;
using reference = enumerated_value_t;
using size_type = range_size_t<T>;
private:
T p_range;
@ -1378,13 +1352,12 @@ namespace detail {
template<typename T>
struct take_range: input_range<take_range<T>> {
using range_category = std::common_type_t<
using range_category = std::common_type_t<
range_category_t<T>, forward_range_tag
>;
using value_type = range_value_t <T>;
using reference = range_reference_t <T>;
using size_type = range_size_t <T>;
using difference_type = range_difference_t<T>;
using value_type = range_value_t<T>;
using reference = range_reference_t<T>;
using size_type = range_size_t<T>;
private:
T p_range;
@ -1411,13 +1384,12 @@ namespace detail {
template<typename T>
struct chunks_range: input_range<chunks_range<T>> {
using range_category = std::common_type_t<
using range_category = std::common_type_t<
range_category_t<T>, forward_range_tag
>;
using value_type = take_range <T>;
using reference = take_range <T>;
using size_type = range_size_t <T>;
using difference_type = range_difference_t<T>;
using value_type = take_range<T>;
using reference = take_range<T>;
using size_type = range_size_t<T>;
private:
T p_range;
@ -1464,13 +1436,12 @@ namespace detail {
template<typename ...R>
struct join_range: input_range<join_range<R...>> {
using range_category = std::common_type_t<
using range_category = std::common_type_t<
forward_range_tag, range_category_t<R>...
>;
using value_type = std::common_type_t<range_value_t<R>...>;
using reference = std::common_type_t<range_reference_t<R>...>;
using size_type = std::common_type_t<range_size_t<R>...>;
using difference_type = std::common_type_t<range_difference_t<R>...>;
using value_type = std::common_type_t<range_value_t<R>...>;
using reference = std::common_type_t<range_reference_t<R>...>;
using size_type = std::common_type_t<range_size_t<R>...>;
private:
std::tuple<R...> p_ranges;
@ -1510,13 +1481,12 @@ namespace detail {
template<typename ...R>
struct zip_range: input_range<zip_range<R...>> {
using range_category = std::common_type_t<
using range_category = std::common_type_t<
forward_range_tag, range_category_t<R>...
>;
using value_type = zip_value_t<range_value_t<R>...>;
using reference = zip_value_t<range_reference_t<R>...>;
using size_type = std::common_type_t<range_size_t<R>...>;
using difference_type = std::common_type_t<range_difference_t<R>...>;
using value_type = zip_value_t<range_value_t<R>...>;
using reference = zip_value_t<range_reference_t<R>...>;
using size_type = std::common_type_t<range_size_t<R>...>;
private:
std::tuple<R...> p_ranges;
@ -1558,10 +1528,9 @@ namespace detail {
*/
template<typename T>
struct appender_range: output_range<appender_range<T>> {
using value_type = typename T::value_type;
using reference = typename T::reference;
using size_type = typename T::size_type;
using difference_type = typename T::difference_type;
using value_type = typename T::value_type;
using reference = typename T::reference;
using size_type = typename T::size_type;
/** @brief Default constructs the container inside. */
appender_range(): p_data() {}
@ -1682,17 +1651,16 @@ using iterator_range_tag = typename detail::iterator_range_tag_base<T>::type;
*/
template<typename T>
struct iterator_range: input_range<iterator_range<T>> {
using range_category = std::conditional_t<
using range_category = std::conditional_t<
std::is_pointer_v<T>,
contiguous_range_tag,
iterator_range_tag<typename std::iterator_traits<T>::iterator_category>
>;
using value_type = typename std::iterator_traits<T>::value_type;
using reference = typename std::iterator_traits<T>::reference;
using size_type = std::make_unsigned_t<
using value_type = typename std::iterator_traits<T>::value_type;
using reference = typename std::iterator_traits<T>::reference;
using size_type = std::make_unsigned_t<
typename std::iterator_traits<T>::difference_type
>;
using difference_type = typename std::iterator_traits<T>::difference_type;
/** @brief Creates an iterator range.
*

View File

@ -554,11 +554,10 @@ private:
*/
template<typename T>
struct stream_range<T, true>: input_range<stream_range<T>> {
using range_category = input_range_tag;
using value_type = T;
using reference = T;
using size_type = std::size_t;
using difference_type = stream_off_t;
using range_category = input_range_tag;
using value_type = T;
using reference = T;
using size_type = std::size_t;
stream_range() = delete;
@ -667,11 +666,10 @@ inline stream_range<T> stream::iter() {
*/
template<typename T, typename TC>
struct stream_line_range: input_range<stream_line_range<T, TC>> {
using range_category = input_range_tag;
using value_type = TC;
using reference = TC &;
using size_type = std::size_t;
using difference_type = stream_off_t;
using range_category = input_range_tag;
using value_type = TC;
using reference = TC &;
using size_type = std::size_t;
stream_line_range() = delete;

View File

@ -76,11 +76,10 @@ namespace ostd {
*/
template<typename T, typename TR = std::char_traits<std::remove_const_t<T>>>
struct basic_char_range: input_range<basic_char_range<T>> {
using range_category = contiguous_range_tag;
using value_type = T;
using reference = T &;
using size_type = std::size_t;
using difference_type = std::ptrdiff_t;
using range_category = contiguous_range_tag;
using value_type = T;
using reference = T &;
using size_type = std::size_t;
using traits_type = TR;