mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2025-10-24 09:30:26 -04:00
201 lines
5.7 KiB
Plaintext
201 lines
5.7 KiB
Plaintext
[/
|
|
Copyright 2010 Neil Groves
|
|
Distributed under 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)
|
|
/]
|
|
[section:semantics Semantics]
|
|
|
|
[heading notation]
|
|
|
|
[table
|
|
[[Type ] [Object] [Describes ]]
|
|
[[`X` ] [`x` ] [any type ]]
|
|
[[`T` ] [`t` ] [denotes behavior of the primary templates]]
|
|
[[`P` ] [`p` ] [denotes `std::pair<iterator,iterator>` ]]
|
|
[[`A[sz]`] [`a` ] [denotes an array of type `A` of size `sz`]]
|
|
[[`Char*`] [`s` ] [denotes either `char*` or `wchar_t*` ]]
|
|
]
|
|
|
|
[section Metafunctions]
|
|
|
|
[table
|
|
[[Expression] [Return type] [Complexity]]
|
|
[
|
|
[`range_iterator<X>::type`]
|
|
[``
|
|
T::iterator
|
|
P::first_type
|
|
A*
|
|
``]
|
|
[compile time]
|
|
]
|
|
[
|
|
[`range_iterator<const X>::type`]
|
|
[``
|
|
T::const_iterator
|
|
P::first_type
|
|
const A*
|
|
``]
|
|
[compile time]
|
|
]
|
|
[
|
|
[`range_value<X>::type`]
|
|
[`boost::iterator_value<range_iterator<X>::type>::type`]
|
|
[compile time]
|
|
]
|
|
[
|
|
[`range_reference<X>::type`]
|
|
[`boost::iterator_reference<range_iterator<X>::type>::type`]
|
|
[compile time]
|
|
]
|
|
[
|
|
[`range_pointer<X>::type`]
|
|
[`boost::iterator_pointer<range_iterator<X>::type>::type`]
|
|
[compile time]
|
|
]
|
|
[
|
|
[`range_category<X>::type`]
|
|
[`boost::iterator_category<range_iterator<X>::type>::type`]
|
|
[compile time]
|
|
]
|
|
[
|
|
[`range_difference<X>::type`]
|
|
[`boost::iterator_difference<range_iterator<X>::type>::type`]
|
|
[compile time]
|
|
]
|
|
[
|
|
[`range_reverse_iterator<X>::type`]
|
|
[`boost::reverse_iterator<range_iterator<X>::type>`]
|
|
[compile time]
|
|
]
|
|
[
|
|
[`range_reverse_iterator<const X>::type`]
|
|
[`boost::reverse_iterator<range_iterator<const X>::type`]
|
|
[compile time]
|
|
]
|
|
[
|
|
[`has_range_iterator<X>::type`]
|
|
[`mpl::true_` if `range_mutable_iterator<X>::type` is a valid expression, `mpl::false_` otherwise]
|
|
[compile time]
|
|
]
|
|
[
|
|
[`has_range_const_iterator<X>::type`]
|
|
[`mpl::true_` if `range_const_iterator<X>::type` is a valid expression, `mpl::false_` otherwise]
|
|
[compile time]
|
|
]
|
|
]
|
|
|
|
[endsect]
|
|
|
|
[section Functions]
|
|
|
|
[table
|
|
[[Expression] [Return type] [Returns] [Complexity]]
|
|
|
|
[
|
|
[`begin(x)`]
|
|
[`range_iterator<X>::type`]
|
|
[
|
|
`p.first` if `p` is of type `std::pair<T>`
|
|
`a` if `a` is an array
|
|
`range_begin(x)` if that expression would invoke a function found by ADL
|
|
`t.begin()` otherwise
|
|
]
|
|
[constant time]
|
|
]
|
|
[
|
|
[`end(x)`]
|
|
[`range_iterator<X>::type`]
|
|
[
|
|
`p.second` if `p` is of type `std::pair<T>`
|
|
`a + sz` if `a` is an array of size `sz`
|
|
`range_end(x)` if that expression would invoke a function found by ADL
|
|
`t.end()` otherwise
|
|
]
|
|
[constant time]
|
|
]
|
|
[
|
|
[`empty(x)`]
|
|
[`bool`]
|
|
[`boost::begin(x) == boost::end(x)`]
|
|
[constant time]
|
|
]
|
|
[
|
|
[`distance(x)`]
|
|
[`range_difference<X>::type`]
|
|
[`std::distance(boost::begin(x),boost::end(x))`]
|
|
[-]
|
|
]
|
|
[
|
|
[`size(x)`]
|
|
[`range_size<X>::type`]
|
|
[`range_calculate_size(x)` which by default is `boost::end(x) - boost::begin(x)`. Users may supply alternative implementations by implementing `range_calculate_size(x)` so that it will be found via ADL]
|
|
[constant time]
|
|
]
|
|
[
|
|
[`rbegin(x)`]
|
|
[`range_reverse_iterator<X>::type`]
|
|
[`range_reverse_iterator<X>::type(boost::end(x))`]
|
|
[constant time]
|
|
]
|
|
[
|
|
[`rend(x)`]
|
|
[`range_reverse_iterator<X>::type`]
|
|
[`range_reverse_iterator<X>::type(boost::begin(x))`]
|
|
[constant time]
|
|
]
|
|
[
|
|
[`const_begin(x)`]
|
|
[`range_iterator<const X>::type`]
|
|
[`range_iterator<const X>::type(boost::begin(x))`]
|
|
[constant time]
|
|
]
|
|
[
|
|
[`const_end(x)`]
|
|
[`range_iterator<const X>::type`]
|
|
[`range_iterator<const X>::type(boost::end(x))`]
|
|
[constant time]
|
|
]
|
|
[
|
|
[`const_rbegin(x)`]
|
|
[`range_reverse_iterator<const X>::type`]
|
|
[`range_reverse_iterator<const X>::type(boost::rbegin(x))`]
|
|
[constant time]
|
|
]
|
|
[
|
|
[`const_rend(x)`]
|
|
[`range_reverse_iterator<const X>::type`]
|
|
[`range_reverse_iterator<const X>::type(boost::rend(x))`]
|
|
[constant time]
|
|
]
|
|
[
|
|
[`as_literal(x)`]
|
|
[`iterator_range<U>` where `U` is `Char*` if `x` is a pointer to a string and `U` is `range_iterator<X>::type` otherwise]
|
|
[
|
|
`[s,s + std::char_traits<X>::length(s))` if `s` is a `Char*` or an array of `Char` `[boost::begin(x),boost::end(x))` otherwise
|
|
]
|
|
[
|
|
linear time for pointers to a string or arrays of `Char`, constant time otherwise
|
|
]
|
|
]
|
|
[
|
|
[`as_array(x)`]
|
|
[`iterator_range<X>`]
|
|
[`[boost::begin(x),boost::end(x))`]
|
|
]
|
|
]
|
|
|
|
The special `const_`-named functions are useful when you want to document clearly that your code is read-only.
|
|
|
|
`as_literal()` can be used ['*internally*] in string algorithm libraries such that arrays of characters are handled correctly.
|
|
|
|
`as_array()` can be used with string algorithm libraries to make it clear that arrays of characters are handled like an array and not like a string.
|
|
|
|
Notice that the above functions should always be called with qualification (`boost::`) to prevent ['*unintended*] Argument Dependent Lookup (ADL).
|
|
|
|
[endsect]
|
|
|
|
[endsect]
|
|
|
|
|