mirror of
https://github.com/bolero-MURAKAMI/Sprout.git
synced 2025-02-11 10:03:59 +00:00
add constexpr algorithm C++14 version: move, move_backward, swap_ranges, iter_swap
This commit is contained in:
parent
d5c84b07c9
commit
a3427d375f
23 changed files with 430 additions and 47 deletions
|
@ -9,6 +9,43 @@
|
||||||
#define SPROUT_ALGORITHM_COPY_HPP
|
#define SPROUT_ALGORITHM_COPY_HPP
|
||||||
|
|
||||||
#include <sprout/config.hpp>
|
#include <sprout/config.hpp>
|
||||||
|
#include <sprout/type_traits/enabler_if.hpp>
|
||||||
|
#include <sprout/iterator/type_traits/is_iterator_of.hpp>
|
||||||
|
#include <sprout/algorithm/fixed/result_of.hpp>
|
||||||
|
#include <sprout/algorithm/fixed/copy.hpp>
|
||||||
|
|
||||||
|
namespace sprout {
|
||||||
|
//
|
||||||
|
// 25.3.1 Copy
|
||||||
|
//
|
||||||
|
template<
|
||||||
|
typename InputIterator, typename OutputIterator,
|
||||||
|
typename sprout::enabler_if<sprout::is_output_iterator<OutputIterator>::value>::type = sprout::enabler
|
||||||
|
>
|
||||||
|
inline SPROUT_CXX14_CONSTEXPR OutputIterator
|
||||||
|
copy(InputIterator first, InputIterator last, OutputIterator result) {
|
||||||
|
while (first != last) {
|
||||||
|
*result++ = *first++;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<
|
||||||
|
typename InputIterator, typename Result,
|
||||||
|
typename sprout::enabler_if<!sprout::is_output_iterator<Result>::value>::type = sprout::enabler
|
||||||
|
>
|
||||||
|
inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::algorithm<Result>::type
|
||||||
|
copy(InputIterator first, InputIterator last, Result const& result) {
|
||||||
|
return sprout::fixed::copy(first, last, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename Result, typename InputIterator>
|
||||||
|
inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::algorithm<Result>::type
|
||||||
|
copy(InputIterator first, InputIterator last) {
|
||||||
|
return sprout::fixed::copy<Result>(first, last);
|
||||||
|
}
|
||||||
|
} // namespace sprout
|
||||||
|
|
||||||
#include <sprout/algorithm/fixed/copy.hpp>
|
#include <sprout/algorithm/fixed/copy.hpp>
|
||||||
#include <sprout/algorithm/fit/copy.hpp>
|
#include <sprout/algorithm/fit/copy.hpp>
|
||||||
|
|
||||||
|
|
|
@ -9,6 +9,43 @@
|
||||||
#define SPROUT_ALGORITHM_COPY_BACKWARD_HPP
|
#define SPROUT_ALGORITHM_COPY_BACKWARD_HPP
|
||||||
|
|
||||||
#include <sprout/config.hpp>
|
#include <sprout/config.hpp>
|
||||||
|
#include <sprout/type_traits/enabler_if.hpp>
|
||||||
|
#include <sprout/iterator/type_traits/is_iterator_of.hpp>
|
||||||
|
#include <sprout/algorithm/fixed/result_of.hpp>
|
||||||
|
#include <sprout/algorithm/fixed/copy_backward.hpp>
|
||||||
|
|
||||||
|
namespace sprout {
|
||||||
|
//
|
||||||
|
// 25.3.1 Copy
|
||||||
|
//
|
||||||
|
template<
|
||||||
|
typename BidirectionalIterator1, typename BidirectionalIterator2,
|
||||||
|
typename sprout::enabler_if<sprout::is_output_iterator<BidirectionalIterator2>::value>::type = sprout::enabler
|
||||||
|
>
|
||||||
|
inline SPROUT_CXX14_CONSTEXPR BidirectionalIterator2
|
||||||
|
copy_backward(BidirectionalIterator1 first, BidirectionalIterator1 last, BidirectionalIterator2 result) {
|
||||||
|
while (first != last) {
|
||||||
|
*--result = *--first;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<
|
||||||
|
typename BidirectionalIterator, typename Result,
|
||||||
|
typename sprout::enabler_if<!sprout::is_output_iterator<Result>::value>::type = sprout::enabler
|
||||||
|
>
|
||||||
|
inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::algorithm<Result>::type
|
||||||
|
copy_backward(BidirectionalIterator first, BidirectionalIterator last, Result const& result) {
|
||||||
|
return sprout::fixed::copy_backward(first, last, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename Result, typename BidirectionalIterator>
|
||||||
|
inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::algorithm<Result>::type
|
||||||
|
copy_backward(BidirectionalIterator first, BidirectionalIterator last) {
|
||||||
|
return sprout::fixed::copy_backward<Result>(first, last);
|
||||||
|
}
|
||||||
|
} // namespace sprout
|
||||||
|
|
||||||
#include <sprout/algorithm/fixed/copy_backward.hpp>
|
#include <sprout/algorithm/fixed/copy_backward.hpp>
|
||||||
#include <sprout/algorithm/fit/copy_backward.hpp>
|
#include <sprout/algorithm/fit/copy_backward.hpp>
|
||||||
|
|
||||||
|
|
|
@ -9,6 +9,45 @@
|
||||||
#define SPROUT_ALGORITHM_COPY_IF_HPP
|
#define SPROUT_ALGORITHM_COPY_IF_HPP
|
||||||
|
|
||||||
#include <sprout/config.hpp>
|
#include <sprout/config.hpp>
|
||||||
|
#include <sprout/type_traits/enabler_if.hpp>
|
||||||
|
#include <sprout/iterator/type_traits/is_iterator_of.hpp>
|
||||||
|
#include <sprout/algorithm/fixed/result_of.hpp>
|
||||||
|
#include <sprout/algorithm/fixed/copy_if.hpp>
|
||||||
|
|
||||||
|
namespace sprout {
|
||||||
|
//
|
||||||
|
// 25.3.1 Copy
|
||||||
|
//
|
||||||
|
template<
|
||||||
|
typename InputIterator, typename OutputIterator, typename Predicate,
|
||||||
|
typename sprout::enabler_if<sprout::is_output_iterator<OutputIterator>::value>::type = sprout::enabler
|
||||||
|
>
|
||||||
|
inline SPROUT_CXX14_CONSTEXPR OutputIterator
|
||||||
|
copy_if(InputIterator first, InputIterator last, OutputIterator result, Predicate pred) {
|
||||||
|
for (; first != last; ++first) {
|
||||||
|
if (pred(*first)) {
|
||||||
|
*result++ = *first;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<
|
||||||
|
typename InputIterator, typename Result, typename Predicate,
|
||||||
|
typename sprout::enabler_if<!sprout::is_output_iterator<Result>::value>::type = sprout::enabler
|
||||||
|
>
|
||||||
|
inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::algorithm<Result>::type
|
||||||
|
copy_if(InputIterator first, InputIterator last, Result const& result, Predicate pred) {
|
||||||
|
return sprout::fixed::copy_if(first, last, result, pred);
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename Result, typename InputIterator, typename Predicate>
|
||||||
|
inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::algorithm<Result>::type
|
||||||
|
copy_if(InputIterator first, InputIterator last, Predicate pred) {
|
||||||
|
return sprout::fixed::copy_if<Result>(first, last, pred);
|
||||||
|
}
|
||||||
|
} // namespace sprout
|
||||||
|
|
||||||
#include <sprout/algorithm/fixed/copy_if.hpp>
|
#include <sprout/algorithm/fixed/copy_if.hpp>
|
||||||
#include <sprout/algorithm/fit/copy_if.hpp>
|
#include <sprout/algorithm/fit/copy_if.hpp>
|
||||||
|
|
||||||
|
|
|
@ -9,6 +9,43 @@
|
||||||
#define SPROUT_ALGORITHM_COPY_N_HPP
|
#define SPROUT_ALGORITHM_COPY_N_HPP
|
||||||
|
|
||||||
#include <sprout/config.hpp>
|
#include <sprout/config.hpp>
|
||||||
|
#include <sprout/type_traits/enabler_if.hpp>
|
||||||
|
#include <sprout/iterator/type_traits/is_iterator_of.hpp>
|
||||||
|
#include <sprout/algorithm/fixed/result_of.hpp>
|
||||||
|
#include <sprout/algorithm/fixed/copy_n.hpp>
|
||||||
|
|
||||||
|
namespace sprout {
|
||||||
|
//
|
||||||
|
// 25.3.1 Copy
|
||||||
|
//
|
||||||
|
template<
|
||||||
|
typename InputIterator, typename Size, typename OutputIterator,
|
||||||
|
typename sprout::enabler_if<sprout::is_output_iterator<OutputIterator>::value>::type = sprout::enabler
|
||||||
|
>
|
||||||
|
inline SPROUT_CXX14_CONSTEXPR OutputIterator
|
||||||
|
copy_n(InputIterator first, Size n, OutputIterator result) {
|
||||||
|
for (Size i = 0; i < n; ++i) {
|
||||||
|
*result++ = *first++;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<
|
||||||
|
typename InputIterator, typename Size, typename Result,
|
||||||
|
typename sprout::enabler_if<!sprout::is_output_iterator<Result>::value>::type = sprout::enabler
|
||||||
|
>
|
||||||
|
inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::algorithm<Result>::type
|
||||||
|
copy_n(InputIterator first, Size n, Result const& result) {
|
||||||
|
return sprout::fixed::copy_n(first, n, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename Result, typename Size, typename InputIterator>
|
||||||
|
inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::algorithm<Result>::type
|
||||||
|
copy_n(InputIterator first, Size n) {
|
||||||
|
return sprout::fixed::copy_n<Result>(first, n);
|
||||||
|
}
|
||||||
|
} // namespace sprout
|
||||||
|
|
||||||
#include <sprout/algorithm/fixed/copy_n.hpp>
|
#include <sprout/algorithm/fixed/copy_n.hpp>
|
||||||
#include <sprout/algorithm/fit/copy_n.hpp>
|
#include <sprout/algorithm/fit/copy_n.hpp>
|
||||||
|
|
||||||
|
|
|
@ -134,8 +134,6 @@ namespace sprout {
|
||||||
return sprout::fixed::copy(first, last, sprout::pit<Result>());
|
return sprout::fixed::copy(first, last, sprout::pit<Result>());
|
||||||
}
|
}
|
||||||
} // namespace fixed
|
} // namespace fixed
|
||||||
|
|
||||||
using sprout::fixed::copy;
|
|
||||||
} // namespace sprout
|
} // namespace sprout
|
||||||
|
|
||||||
#endif // #ifndef SPROUT_ALGORITHM_FIXED_COPY_HPP
|
#endif // #ifndef SPROUT_ALGORITHM_FIXED_COPY_HPP
|
||||||
|
|
|
@ -124,8 +124,6 @@ namespace sprout {
|
||||||
return sprout::fixed::copy_backward(first, last, sprout::pit<Result>());
|
return sprout::fixed::copy_backward(first, last, sprout::pit<Result>());
|
||||||
}
|
}
|
||||||
} // namespace fixed
|
} // namespace fixed
|
||||||
|
|
||||||
using sprout::fixed::copy_backward;
|
|
||||||
} // namespace sprout
|
} // namespace sprout
|
||||||
|
|
||||||
#endif // #ifndef SPROUT_ALGORITHM_FIXED_COPY_BACKWARD_HPP
|
#endif // #ifndef SPROUT_ALGORITHM_FIXED_COPY_BACKWARD_HPP
|
||||||
|
|
|
@ -89,8 +89,6 @@ namespace sprout {
|
||||||
return sprout::fixed::copy_if(first, last, sprout::pit<Result>(), pred);
|
return sprout::fixed::copy_if(first, last, sprout::pit<Result>(), pred);
|
||||||
}
|
}
|
||||||
} // namespace fixed
|
} // namespace fixed
|
||||||
|
|
||||||
using sprout::fixed::copy_if;
|
|
||||||
} // namespace sprout
|
} // namespace sprout
|
||||||
|
|
||||||
#endif // #ifndef SPROUT_ALGORITHM_FIXED_COPY_IF_HPP
|
#endif // #ifndef SPROUT_ALGORITHM_FIXED_COPY_IF_HPP
|
||||||
|
|
|
@ -107,8 +107,6 @@ namespace sprout {
|
||||||
return sprout::fixed::copy_n(first, n, sprout::pit<Result>());
|
return sprout::fixed::copy_n(first, n, sprout::pit<Result>());
|
||||||
}
|
}
|
||||||
} // namespace fixed
|
} // namespace fixed
|
||||||
|
|
||||||
using sprout::fixed::copy_n;
|
|
||||||
} // namespace sprout
|
} // namespace sprout
|
||||||
|
|
||||||
#endif // #ifndef SPROUT_ALGORITHM_FIXED_COPY_N_HPP
|
#endif // #ifndef SPROUT_ALGORITHM_FIXED_COPY_N_HPP
|
||||||
|
|
25
sprout/algorithm/iter_swap.hpp
Normal file
25
sprout/algorithm/iter_swap.hpp
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
/*=============================================================================
|
||||||
|
Copyright (c) 2011-2013 Bolero MURAKAMI
|
||||||
|
https://github.com/bolero-MURAKAMI/Sprout
|
||||||
|
|
||||||
|
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)
|
||||||
|
=============================================================================*/
|
||||||
|
#ifndef SPROUT_ALGORITHM_ITER_SWAP_HPP
|
||||||
|
#define SPROUT_ALGORITHM_ITER_SWAP_HPP
|
||||||
|
|
||||||
|
#include <sprout/config.hpp>
|
||||||
|
#include <sprout/utility/swap.hpp>
|
||||||
|
|
||||||
|
namespace sprout {
|
||||||
|
//
|
||||||
|
// 25.3.3 swap
|
||||||
|
//
|
||||||
|
template<typename ForwardIterator1, typename ForwardIterator2>
|
||||||
|
inline SPROUT_CXX14_CONSTEXPR void
|
||||||
|
iter_swap(ForwardIterator1 a, ForwardIterator2 b) {
|
||||||
|
sprout::swap(*a, *b);
|
||||||
|
}
|
||||||
|
} // namespace sprout
|
||||||
|
|
||||||
|
#endif // #ifndef SPROUT_ALGORITHM_ITER_SWAP_HPP
|
|
@ -9,7 +9,71 @@
|
||||||
#define SPROUT_ALGORITHM_MODIFYIING_HPP
|
#define SPROUT_ALGORITHM_MODIFYIING_HPP
|
||||||
|
|
||||||
#include <sprout/config.hpp>
|
#include <sprout/config.hpp>
|
||||||
#include <sprout/algorithm/fixed.hpp>
|
#include <sprout/algorithm/copy.hpp>
|
||||||
#include <sprout/algorithm/fit.hpp>
|
#include <sprout/algorithm/copy_n.hpp>
|
||||||
|
#include <sprout/algorithm/copy_if.hpp>
|
||||||
|
#include <sprout/algorithm/copy_backward.hpp>
|
||||||
|
#include <sprout/algorithm/move.hpp>
|
||||||
|
#include <sprout/algorithm/move_backward.hpp>
|
||||||
|
#include <sprout/algorithm/swap_ranges.hpp>
|
||||||
|
#include <sprout/algorithm/iter_swap.hpp>
|
||||||
|
#include <sprout/algorithm/transform.hpp>
|
||||||
|
#include <sprout/algorithm/replace.hpp>
|
||||||
|
#include <sprout/algorithm/replace_if.hpp>
|
||||||
|
#include <sprout/algorithm/replace_copy.hpp>
|
||||||
|
#include <sprout/algorithm/replace_copy_if.hpp>
|
||||||
|
#include <sprout/algorithm/fill.hpp>
|
||||||
|
#include <sprout/algorithm/fill_n.hpp>
|
||||||
|
#include <sprout/algorithm/generate.hpp>
|
||||||
|
#include <sprout/algorithm/generate_n.hpp>
|
||||||
|
#include <sprout/algorithm/unfold.hpp>
|
||||||
|
#include <sprout/algorithm/unfold_n.hpp>
|
||||||
|
#include <sprout/algorithm/recurrence.hpp>
|
||||||
|
#include <sprout/algorithm/recurrence_n.hpp>
|
||||||
|
#include <sprout/algorithm/remove.hpp>
|
||||||
|
#include <sprout/algorithm/remove_if.hpp>
|
||||||
|
#include <sprout/algorithm/remove_copy.hpp>
|
||||||
|
#include <sprout/algorithm/remove_copy_if.hpp>
|
||||||
|
#include <sprout/algorithm/unique.hpp>
|
||||||
|
#include <sprout/algorithm/unique_copy.hpp>
|
||||||
|
#include <sprout/algorithm/reverse.hpp>
|
||||||
|
#include <sprout/algorithm/reverse_copy.hpp>
|
||||||
|
#include <sprout/algorithm/rotate.hpp>
|
||||||
|
#include <sprout/algorithm/rotate_copy.hpp>
|
||||||
|
#include <sprout/algorithm/shuffle.hpp>
|
||||||
|
#include <sprout/algorithm/shuffle_result.hpp>
|
||||||
|
#include <sprout/algorithm/partition.hpp>
|
||||||
|
#include <sprout/algorithm/partition_copy.hpp>
|
||||||
|
#include <sprout/algorithm/stable_partition.hpp>
|
||||||
|
#include <sprout/algorithm/stable_partition_copy.hpp>
|
||||||
|
#include <sprout/algorithm/sort.hpp>
|
||||||
|
#include <sprout/algorithm/stable_sort.hpp>
|
||||||
|
#include <sprout/algorithm/partial_sort.hpp>
|
||||||
|
#include <sprout/algorithm/nth_element.hpp>
|
||||||
|
#include <sprout/algorithm/merge.hpp>
|
||||||
|
#include <sprout/algorithm/inplace_merge.hpp>
|
||||||
|
#include <sprout/algorithm/set_union.hpp>
|
||||||
|
#include <sprout/algorithm/set_intersection.hpp>
|
||||||
|
#include <sprout/algorithm/set_difference.hpp>
|
||||||
|
#include <sprout/algorithm/set_symmetric_difference.hpp>
|
||||||
|
#include <sprout/algorithm/push_heap.hpp>
|
||||||
|
#include <sprout/algorithm/pop_heap.hpp>
|
||||||
|
#include <sprout/algorithm/make_heap.hpp>
|
||||||
|
#include <sprout/algorithm/make_partial_heap.hpp>
|
||||||
|
#include <sprout/algorithm/sort_heap.hpp>
|
||||||
|
#include <sprout/algorithm/next_permutation.hpp>
|
||||||
|
#include <sprout/algorithm/prev_permutation.hpp>
|
||||||
|
#include <sprout/algorithm/copy_while.hpp>
|
||||||
|
#include <sprout/algorithm/copy_until.hpp>
|
||||||
|
#include <sprout/algorithm/clamp_range.hpp>
|
||||||
|
#include <sprout/algorithm/clamp_range_copy.hpp>
|
||||||
|
#include <sprout/algorithm/swap_element.hpp>
|
||||||
|
#include <sprout/algorithm/swap_element_copy.hpp>
|
||||||
|
#include <sprout/algorithm/random_swap.hpp>
|
||||||
|
#include <sprout/algorithm/random_swap_result.hpp>
|
||||||
|
#include <sprout/algorithm/bogo_sort.hpp>
|
||||||
|
#include <sprout/algorithm/bogo_sort_result.hpp>
|
||||||
|
#include <sprout/algorithm/bozo_sort.hpp>
|
||||||
|
#include <sprout/algorithm/bozo_sort_result.hpp>
|
||||||
|
|
||||||
#endif // #ifndef SPROUT_ALGORITHM_MODIFYIING_HPP
|
#endif // #ifndef SPROUT_ALGORITHM_MODIFYIING_HPP
|
||||||
|
|
33
sprout/algorithm/move.hpp
Normal file
33
sprout/algorithm/move.hpp
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
/*=============================================================================
|
||||||
|
Copyright (c) 2011-2013 Bolero MURAKAMI
|
||||||
|
https://github.com/bolero-MURAKAMI/Sprout
|
||||||
|
|
||||||
|
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)
|
||||||
|
=============================================================================*/
|
||||||
|
#ifndef SPROUT_ALGORITHM_MOVE_HPP
|
||||||
|
#define SPROUT_ALGORITHM_MOVE_HPP
|
||||||
|
|
||||||
|
#include <sprout/config.hpp>
|
||||||
|
#include <sprout/type_traits/enabler_if.hpp>
|
||||||
|
#include <sprout/iterator/type_traits/is_iterator_of.hpp>
|
||||||
|
#include <sprout/utility/move.hpp>
|
||||||
|
|
||||||
|
namespace sprout {
|
||||||
|
//
|
||||||
|
// 25.3.2 Move
|
||||||
|
//
|
||||||
|
template<
|
||||||
|
typename InputIterator, typename OutputIterator,
|
||||||
|
typename sprout::enabler_if<sprout::is_output_iterator<OutputIterator>::value>::type = sprout::enabler
|
||||||
|
>
|
||||||
|
inline SPROUT_CXX14_CONSTEXPR OutputIterator
|
||||||
|
move(InputIterator first, InputIterator last, OutputIterator result) {
|
||||||
|
while (first != last) {
|
||||||
|
*result++ = sprout::move(*first++);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
} // namespace sprout
|
||||||
|
|
||||||
|
#endif // #ifndef SPROUT_ALGORITHM_MOVE_HPP
|
33
sprout/algorithm/move_backward.hpp
Normal file
33
sprout/algorithm/move_backward.hpp
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
/*=============================================================================
|
||||||
|
Copyright (c) 2011-2013 Bolero MURAKAMI
|
||||||
|
https://github.com/bolero-MURAKAMI/Sprout
|
||||||
|
|
||||||
|
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)
|
||||||
|
=============================================================================*/
|
||||||
|
#ifndef SPROUT_ALGORITHM_MOVE_BACKWARD_HPP
|
||||||
|
#define SPROUT_ALGORITHM_MOVE_BACKWARD_HPP
|
||||||
|
|
||||||
|
#include <sprout/config.hpp>
|
||||||
|
#include <sprout/type_traits/enabler_if.hpp>
|
||||||
|
#include <sprout/iterator/type_traits/is_iterator_of.hpp>
|
||||||
|
#include <sprout/utility/move.hpp>
|
||||||
|
|
||||||
|
namespace sprout {
|
||||||
|
//
|
||||||
|
// 25.3.2 Move
|
||||||
|
//
|
||||||
|
template<
|
||||||
|
typename InputIterator, typename OutputIterator,
|
||||||
|
typename sprout::enabler_if<sprout::is_output_iterator<OutputIterator>::value>::type = sprout::enabler
|
||||||
|
>
|
||||||
|
inline SPROUT_CXX14_CONSTEXPR OutputIterator
|
||||||
|
move_backward(InputIterator first, InputIterator last, OutputIterator result) {
|
||||||
|
while (first != last) {
|
||||||
|
*--result = sprout::move(*--first);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
} // namespace sprout
|
||||||
|
|
||||||
|
#endif // #ifndef SPROUT_ALGORITHM_MOVE_BACKWARD_HPP
|
28
sprout/algorithm/swap_ranges.hpp
Normal file
28
sprout/algorithm/swap_ranges.hpp
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
/*=============================================================================
|
||||||
|
Copyright (c) 2011-2013 Bolero MURAKAMI
|
||||||
|
https://github.com/bolero-MURAKAMI/Sprout
|
||||||
|
|
||||||
|
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)
|
||||||
|
=============================================================================*/
|
||||||
|
#ifndef SPROUT_ALGORITHM_SWAP_RANGES_HPP
|
||||||
|
#define SPROUT_ALGORITHM_SWAP_RANGES_HPP
|
||||||
|
|
||||||
|
#include <sprout/config.hpp>
|
||||||
|
#include <sprout/algorithm/iter_swap.hpp>
|
||||||
|
|
||||||
|
namespace sprout {
|
||||||
|
//
|
||||||
|
// 25.3.3 swap
|
||||||
|
//
|
||||||
|
template<typename ForwardIterator1, typename ForwardIterator2>
|
||||||
|
inline SPROUT_CXX14_CONSTEXPR ForwardIterator2
|
||||||
|
swap_ranges(ForwardIterator1 first1, ForwardIterator1 last1, ForwardIterator2 first2) {
|
||||||
|
while (first1 != last1) {
|
||||||
|
sprout::iter_swap(*first1++, *first2++);
|
||||||
|
}
|
||||||
|
return first2;
|
||||||
|
}
|
||||||
|
} // namespace sprout
|
||||||
|
|
||||||
|
#endif // #ifndef SPROUT_ALGORITHM_SWAP_RANGES_HPP
|
|
@ -63,6 +63,9 @@ namespace sprout {
|
||||||
container->push_back(sprout::move(value));
|
container->push_back(sprout::move(value));
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
SPROUT_CONSTEXPR back_insert_iterator& operator*() const {
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
SPROUT_CXX14_CONSTEXPR back_insert_iterator& operator*() {
|
SPROUT_CXX14_CONSTEXPR back_insert_iterator& operator*() {
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
|
@ -63,6 +63,9 @@ namespace sprout {
|
||||||
container->push_front(sprout::move(value));
|
container->push_front(sprout::move(value));
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
SPROUT_CONSTEXPR front_insert_iterator& operator*() const {
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
SPROUT_CXX14_CONSTEXPR front_insert_iterator& operator*() {
|
SPROUT_CXX14_CONSTEXPR front_insert_iterator& operator*() {
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,6 +70,9 @@ namespace sprout {
|
||||||
container->insert(iter, sprout::move(value));
|
container->insert(iter, sprout::move(value));
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
SPROUT_CONSTEXPR insert_iterator& operator*() const {
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
SPROUT_CXX14_CONSTEXPR insert_iterator& operator*() {
|
SPROUT_CXX14_CONSTEXPR insert_iterator& operator*() {
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
28
sprout/utility/exchange.hpp
Normal file
28
sprout/utility/exchange.hpp
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
/*=============================================================================
|
||||||
|
Copyright (c) 2011-2013 Bolero MURAKAMI
|
||||||
|
https://github.com/bolero-MURAKAMI/Sprout
|
||||||
|
|
||||||
|
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)
|
||||||
|
=============================================================================*/
|
||||||
|
#ifndef SPROUT_UTILITY_EXCAHNGE_HPP
|
||||||
|
#define SPROUT_UTILITY_EXCAHNGE_HPP
|
||||||
|
|
||||||
|
#include <sprout/config.hpp>
|
||||||
|
#include <sprout/utility/forward.hpp>
|
||||||
|
#include <sprout/utility/move.hpp>
|
||||||
|
|
||||||
|
namespace sprout {
|
||||||
|
//
|
||||||
|
// 20.2.3 exchange
|
||||||
|
//
|
||||||
|
template<typename T, typename U = T>
|
||||||
|
inline SPROUT_CXX14_CONSTEXPR T
|
||||||
|
exchange(T& obj, U&& new_val) {
|
||||||
|
T old_val = sprout::move(obj);
|
||||||
|
obj = sprout::forward<U>(new_val);
|
||||||
|
return old_val;
|
||||||
|
}
|
||||||
|
} // namespace sprout
|
||||||
|
|
||||||
|
#endif // #ifndef SPROUT_UTILITY_EXCAHNGE_HPP
|
|
@ -13,5 +13,6 @@
|
||||||
#include <sprout/utility/forward.hpp>
|
#include <sprout/utility/forward.hpp>
|
||||||
#include <sprout/utility/move.hpp>
|
#include <sprout/utility/move.hpp>
|
||||||
#include <sprout/utility/swap.hpp>
|
#include <sprout/utility/swap.hpp>
|
||||||
|
#include <sprout/utility/exchange.hpp>
|
||||||
|
|
||||||
#endif // #ifndef SPROUT_UTILITY_OPERATION_HPP
|
#endif // #ifndef SPROUT_UTILITY_OPERATION_HPP
|
||||||
|
|
|
@ -73,7 +73,7 @@ namespace sprout {
|
||||||
typename U, typename V,
|
typename U, typename V,
|
||||||
typename
|
typename
|
||||||
>
|
>
|
||||||
inline sprout::pair<T1, T2>& sprout::pair<T1, T2>::operator=(sprout::tuples::tuple<U, V> const& rhs) {
|
inline SPROUT_CXX14_CONSTEXPR sprout::pair<T1, T2>& sprout::pair<T1, T2>::operator=(sprout::tuples::tuple<U, V> const& rhs) {
|
||||||
first = sprout::tuples::get<0>(rhs);
|
first = sprout::tuples::get<0>(rhs);
|
||||||
second = sprout::tuples::get<0>(rhs);
|
second = sprout::tuples::get<0>(rhs);
|
||||||
return *this;
|
return *this;
|
||||||
|
@ -83,7 +83,7 @@ namespace sprout {
|
||||||
typename U, typename V,
|
typename U, typename V,
|
||||||
typename
|
typename
|
||||||
>
|
>
|
||||||
inline sprout::pair<T1, T2>& sprout::pair<T1, T2>::operator=(sprout::tuples::tuple<U, V>&& rhs) {
|
inline SPROUT_CXX14_CONSTEXPR sprout::pair<T1, T2>& sprout::pair<T1, T2>::operator=(sprout::tuples::tuple<U, V>&& rhs) {
|
||||||
first = sprout::forward<U>(sprout::tuples::get<0>(rhs));
|
first = sprout::forward<U>(sprout::tuples::get<0>(rhs));
|
||||||
second = sprout::forward<V>(sprout::tuples::get<1>(rhs));
|
second = sprout::forward<V>(sprout::tuples::get<1>(rhs));
|
||||||
return *this;
|
return *this;
|
||||||
|
|
|
@ -103,7 +103,7 @@ namespace sprout {
|
||||||
SPROUT_CONSTEXPR pair(sprout::tuples::tuple<U, V>&& other);
|
SPROUT_CONSTEXPR pair(sprout::tuples::tuple<U, V>&& other);
|
||||||
|
|
||||||
pair& operator=(pair const& rhs) = default;
|
pair& operator=(pair const& rhs) = default;
|
||||||
pair& operator=(pair&& rhs)
|
SPROUT_CXX14_CONSTEXPR pair& operator=(pair&& rhs)
|
||||||
SPROUT_NOEXCEPT_EXPR(std::is_nothrow_move_assignable<T1>::value && std::is_nothrow_move_assignable<T2>::value)
|
SPROUT_NOEXCEPT_EXPR(std::is_nothrow_move_assignable<T1>::value && std::is_nothrow_move_assignable<T2>::value)
|
||||||
{
|
{
|
||||||
first = sprout::forward<T1>(rhs.first);
|
first = sprout::forward<T1>(rhs.first);
|
||||||
|
@ -116,7 +116,7 @@ namespace sprout {
|
||||||
std::is_assignable<first_type&, U const&>::value && std::is_assignable<second_type&, V const&>::value
|
std::is_assignable<first_type&, U const&>::value && std::is_assignable<second_type&, V const&>::value
|
||||||
>::type
|
>::type
|
||||||
>
|
>
|
||||||
pair& operator=(sprout::pair<U, V> const& rhs) {
|
SPROUT_CXX14_CONSTEXPR pair& operator=(sprout::pair<U, V> const& rhs) {
|
||||||
first = rhs.first;
|
first = rhs.first;
|
||||||
second = rhs.second;
|
second = rhs.second;
|
||||||
return *this;
|
return *this;
|
||||||
|
@ -127,7 +127,7 @@ namespace sprout {
|
||||||
std::is_assignable<first_type&, U&&>::value && std::is_assignable<second_type&, V&&>::value
|
std::is_assignable<first_type&, U&&>::value && std::is_assignable<second_type&, V&&>::value
|
||||||
>::type
|
>::type
|
||||||
>
|
>
|
||||||
pair& operator=(sprout::pair<U, V>&& rhs) {
|
SPROUT_CXX14_CONSTEXPR pair& operator=(sprout::pair<U, V>&& rhs) {
|
||||||
first = sprout::forward<U>(rhs.first);
|
first = sprout::forward<U>(rhs.first);
|
||||||
second = sprout::forward<V>(rhs.second);
|
second = sprout::forward<V>(rhs.second);
|
||||||
return *this;
|
return *this;
|
||||||
|
@ -138,16 +138,16 @@ namespace sprout {
|
||||||
std::is_assignable<first_type&, U const&>::value && std::is_assignable<second_type&, V const&>::value
|
std::is_assignable<first_type&, U const&>::value && std::is_assignable<second_type&, V const&>::value
|
||||||
>::type
|
>::type
|
||||||
>
|
>
|
||||||
pair& operator=(sprout::tuples::tuple<U, V> const& rhs);
|
SPROUT_CXX14_CONSTEXPR pair& operator=(sprout::tuples::tuple<U, V> const& rhs);
|
||||||
template<
|
template<
|
||||||
typename U, typename V,
|
typename U, typename V,
|
||||||
typename = typename std::enable_if<
|
typename = typename std::enable_if<
|
||||||
std::is_assignable<first_type&, U&&>::value && std::is_assignable<second_type&, V&&>::value
|
std::is_assignable<first_type&, U&&>::value && std::is_assignable<second_type&, V&&>::value
|
||||||
>::type
|
>::type
|
||||||
>
|
>
|
||||||
pair& operator=(sprout::tuples::tuple<U, V>&& rhs);
|
SPROUT_CXX14_CONSTEXPR pair& operator=(sprout::tuples::tuple<U, V>&& rhs);
|
||||||
|
|
||||||
void swap(pair& other)
|
SPROUT_CXX14_CONSTEXPR void swap(pair& other)
|
||||||
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(sprout::swap(first, other.first)) && SPROUT_NOEXCEPT_EXPR(sprout::swap(second, other.second))) {
|
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(sprout::swap(first, other.first)) && SPROUT_NOEXCEPT_EXPR(sprout::swap(second, other.second))) {
|
||||||
sprout::swap(first, other.first);
|
sprout::swap(first, other.first);
|
||||||
sprout::swap(second, other.second);
|
sprout::swap(second, other.second);
|
||||||
|
@ -158,7 +158,7 @@ namespace sprout {
|
||||||
// swap
|
// swap
|
||||||
//
|
//
|
||||||
template<typename T1, typename T2>
|
template<typename T1, typename T2>
|
||||||
inline void
|
inline SPROUT_CXX14_CONSTEXPR void
|
||||||
swap(sprout::pair<T1, T2>& lhs, sprout::pair<T1, T2>& rhs)
|
swap(sprout::pair<T1, T2>& lhs, sprout::pair<T1, T2>& rhs)
|
||||||
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(lhs.swap(rhs)))
|
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(lhs.swap(rhs)))
|
||||||
{
|
{
|
||||||
|
|
|
@ -77,6 +77,7 @@ namespace sprout {
|
||||||
private:
|
private:
|
||||||
const_pointer ptr_;
|
const_pointer ptr_;
|
||||||
size_type len_;
|
size_type len_;
|
||||||
|
private:
|
||||||
public:
|
public:
|
||||||
// construct/copy/destroy:
|
// construct/copy/destroy:
|
||||||
SPROUT_CONSTEXPR basic_string_ref()
|
SPROUT_CONSTEXPR basic_string_ref()
|
||||||
|
@ -100,7 +101,7 @@ namespace sprout {
|
||||||
{}
|
{}
|
||||||
// iterators:
|
// iterators:
|
||||||
#if SPROUT_USE_INDEX_ITERATOR_IMPLEMENTATION
|
#if SPROUT_USE_INDEX_ITERATOR_IMPLEMENTATION
|
||||||
iterator
|
SPROUT_CXX14_CONSTEXPR iterator
|
||||||
begin() SPROUT_NOEXCEPT {
|
begin() SPROUT_NOEXCEPT {
|
||||||
return iterator(*this, 0);
|
return iterator(*this, 0);
|
||||||
}
|
}
|
||||||
|
@ -108,7 +109,7 @@ namespace sprout {
|
||||||
begin() const SPROUT_NOEXCEPT {
|
begin() const SPROUT_NOEXCEPT {
|
||||||
return const_iterator(*this, 0);
|
return const_iterator(*this, 0);
|
||||||
}
|
}
|
||||||
iterator
|
SPROUT_CXX14_CONSTEXPR iterator
|
||||||
end() SPROUT_NOEXCEPT {
|
end() SPROUT_NOEXCEPT {
|
||||||
return iterator(*this, size());
|
return iterator(*this, size());
|
||||||
}
|
}
|
||||||
|
@ -117,10 +118,18 @@ namespace sprout {
|
||||||
return const_iterator(*this, size());
|
return const_iterator(*this, size());
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
SPROUT_CXX14_CONSTEXPR iterator
|
||||||
|
begin() SPROUT_NOEXCEPT {
|
||||||
|
return data();
|
||||||
|
}
|
||||||
SPROUT_CONSTEXPR const_iterator
|
SPROUT_CONSTEXPR const_iterator
|
||||||
begin() const SPROUT_NOEXCEPT {
|
begin() const SPROUT_NOEXCEPT {
|
||||||
return data();
|
return data();
|
||||||
}
|
}
|
||||||
|
SPROUT_CXX14_CONSTEXPR iterator
|
||||||
|
end() SPROUT_NOEXCEPT {
|
||||||
|
return data() + size();
|
||||||
|
}
|
||||||
SPROUT_CONSTEXPR const_iterator
|
SPROUT_CONSTEXPR const_iterator
|
||||||
end() const SPROUT_NOEXCEPT {
|
end() const SPROUT_NOEXCEPT {
|
||||||
return data() + size();
|
return data() + size();
|
||||||
|
@ -174,7 +183,7 @@ namespace sprout {
|
||||||
max_size() const SPROUT_NOEXCEPT {
|
max_size() const SPROUT_NOEXCEPT {
|
||||||
return size();
|
return size();
|
||||||
}
|
}
|
||||||
void
|
SPROUT_CXX14_CONSTEXPR void
|
||||||
clear() {
|
clear() {
|
||||||
len_ = 0;
|
len_ = 0;
|
||||||
}
|
}
|
||||||
|
@ -202,14 +211,14 @@ namespace sprout {
|
||||||
return ptr_[size() - 1];
|
return ptr_[size() - 1];
|
||||||
}
|
}
|
||||||
// modifiers:
|
// modifiers:
|
||||||
void
|
SPROUT_CXX14_CONSTEXPR void
|
||||||
swap(basic_string_ref& other)
|
swap(basic_string_ref& other)
|
||||||
SPROUT_NOEXCEPT
|
SPROUT_NOEXCEPT
|
||||||
{
|
{
|
||||||
sprout::swap(ptr_, other.ptr_);
|
sprout::swap(ptr_, other.ptr_);
|
||||||
sprout::swap(len_, other.len_);
|
sprout::swap(len_, other.len_);
|
||||||
}
|
}
|
||||||
void
|
SPROUT_CXX14_CONSTEXPR void
|
||||||
remove_prefix(size_type n) {
|
remove_prefix(size_type n) {
|
||||||
if (n > size()) {
|
if (n > size()) {
|
||||||
n = size();
|
n = size();
|
||||||
|
@ -223,7 +232,7 @@ namespace sprout {
|
||||||
: basic_string_ref(data() + n, size() - n)
|
: basic_string_ref(data() + n, size() - n)
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
void
|
SPROUT_CXX14_CONSTEXPR void
|
||||||
remove_suffix(size_type n) {
|
remove_suffix(size_type n) {
|
||||||
if (n > size()) {
|
if (n > size()) {
|
||||||
n = size();
|
n = size();
|
||||||
|
@ -401,20 +410,21 @@ namespace sprout {
|
||||||
SPROUT_EXPLICIT_CONVERSION operator std::basic_string<T, Traits, Allocator>() const {
|
SPROUT_EXPLICIT_CONVERSION operator std::basic_string<T, Traits, Allocator>() const {
|
||||||
return std::basic_string<T, Traits, Allocator>(data(), size());
|
return std::basic_string<T, Traits, Allocator>(data(), size());
|
||||||
}
|
}
|
||||||
pointer
|
SPROUT_CONSTEXPR const_pointer
|
||||||
|
c_array() const SPROUT_NOEXCEPT {
|
||||||
|
return data();
|
||||||
|
}
|
||||||
|
SPROUT_CXX14_CONSTEXPR pointer
|
||||||
c_array() SPROUT_NOEXCEPT {
|
c_array() SPROUT_NOEXCEPT {
|
||||||
return data();
|
return data();
|
||||||
}
|
}
|
||||||
void
|
// others:
|
||||||
|
SPROUT_CXX14_CONSTEXPR void
|
||||||
rangecheck(size_type i) const {
|
rangecheck(size_type i) const {
|
||||||
if (i >= size()) {
|
if (i >= size()) {
|
||||||
throw std::out_of_range("basic_string_ref<>: index out of range");
|
throw std::out_of_range("basic_string_ref<>: index out of range");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void
|
|
||||||
maxcheck(size_type n) const {
|
|
||||||
rangecheck(n);
|
|
||||||
}
|
|
||||||
|
|
||||||
#if SPROUT_USE_INDEX_ITERATOR_IMPLEMENTATION
|
#if SPROUT_USE_INDEX_ITERATOR_IMPLEMENTATION
|
||||||
template<typename ConstIterator>
|
template<typename ConstIterator>
|
||||||
|
@ -549,7 +559,7 @@ namespace sprout {
|
||||||
// swap
|
// swap
|
||||||
//
|
//
|
||||||
template<typename T, typename Traits>
|
template<typename T, typename Traits>
|
||||||
inline void
|
inline SPROUT_CXX14_CONSTEXPR void
|
||||||
swap(sprout::basic_string_ref<T, Traits>& lhs, sprout::basic_string_ref<T, Traits>& rhs)
|
swap(sprout::basic_string_ref<T, Traits>& lhs, sprout::basic_string_ref<T, Traits>& rhs)
|
||||||
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(lhs.swap(rhs)))
|
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(lhs.swap(rhs)))
|
||||||
{
|
{
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
#ifndef SPROUT_UTILITY_SWAP_HPP
|
#ifndef SPROUT_UTILITY_SWAP_HPP
|
||||||
#define SPROUT_UTILITY_SWAP_HPP
|
#define SPROUT_UTILITY_SWAP_HPP
|
||||||
|
|
||||||
|
#include <cstddef>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
#include <sprout/config.hpp>
|
#include <sprout/config.hpp>
|
||||||
|
|
||||||
|
@ -15,20 +16,29 @@ namespace sprout_swap_detail {
|
||||||
using std::swap;
|
using std::swap;
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
inline void
|
inline SPROUT_CXX14_CONSTEXPR void
|
||||||
swap_impl(T& a, T& b)
|
swap_impl(T& a, T& b)
|
||||||
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(swap(a, b)))
|
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(swap(a, b)))
|
||||||
{
|
{
|
||||||
return swap(a, b);
|
swap(a, b);
|
||||||
|
}
|
||||||
|
template<typename T, std::size_t N>
|
||||||
|
inline SPROUT_CXX14_CONSTEXPR void
|
||||||
|
swap_impl(T (& a)[N], T (& b)[N])
|
||||||
|
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(swap(*a, *b)))
|
||||||
|
{
|
||||||
|
for (std::size_t i = 0; i < N; ++i) {
|
||||||
|
swap(a[i], b[i]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} // namespace sprout_swap_detail
|
} // namespace sprout_swap_detail
|
||||||
|
|
||||||
namespace sprout {
|
namespace sprout {
|
||||||
//
|
//
|
||||||
// swap
|
// 20.2.2 swap
|
||||||
//
|
//
|
||||||
template<typename T1, typename T2>
|
template<typename T1, typename T2>
|
||||||
inline void
|
inline SPROUT_CXX14_CONSTEXPR void
|
||||||
swap(T1& lhs, T2& rhs)
|
swap(T1& lhs, T2& rhs)
|
||||||
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(sprout_swap_detail::swap_impl(lhs, rhs)))
|
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(sprout_swap_detail::swap_impl(lhs, rhs)))
|
||||||
{
|
{
|
||||||
|
|
|
@ -236,61 +236,61 @@ namespace sprout {
|
||||||
|
|
||||||
value_holder& operator=(value_holder const&) = default;
|
value_holder& operator=(value_holder const&) = default;
|
||||||
value_holder& operator=(value_holder&&) = default;
|
value_holder& operator=(value_holder&&) = default;
|
||||||
value_holder& operator=(argument_type p) {
|
SPROUT_CXX14_CONSTEXPR value_holder& operator=(argument_type p) {
|
||||||
value_holder temp(p);
|
value_holder temp(p);
|
||||||
temp.swap(*this);
|
temp.swap(*this);
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
value_holder& operator=(movable_argument_type p) {
|
SPROUT_CXX14_CONSTEXPR value_holder& operator=(movable_argument_type p) {
|
||||||
value_holder temp(sprout::move(p));
|
value_holder temp(sprout::move(p));
|
||||||
temp.swap(*this);
|
temp.swap(*this);
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void swap(value_holder& other)
|
SPROUT_CXX14_CONSTEXPR void swap(value_holder& other)
|
||||||
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(sprout::swap(holder_, other.holder_)))
|
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(sprout::swap(holder_, other.holder_)))
|
||||||
{
|
{
|
||||||
sprout::swap(holder_, other.holder_);
|
sprout::swap(holder_, other.holder_);
|
||||||
}
|
}
|
||||||
|
|
||||||
operator reference() {
|
SPROUT_CXX14_CONSTEXPR operator reference() {
|
||||||
return helper_type::ref(holder_);
|
return helper_type::ref(holder_);
|
||||||
}
|
}
|
||||||
SPROUT_CONSTEXPR operator mutable_or_const_reference() const {
|
SPROUT_CONSTEXPR operator mutable_or_const_reference() const {
|
||||||
return helper_type::ref(holder_);
|
return helper_type::ref(holder_);
|
||||||
}
|
}
|
||||||
reference operator*() {
|
SPROUT_CXX14_CONSTEXPR reference operator*() {
|
||||||
return helper_type::ref(holder_);
|
return helper_type::ref(holder_);
|
||||||
}
|
}
|
||||||
SPROUT_CONSTEXPR mutable_or_const_reference operator*() const {
|
SPROUT_CONSTEXPR mutable_or_const_reference operator*() const {
|
||||||
return helper_type::ref(holder_);
|
return helper_type::ref(holder_);
|
||||||
}
|
}
|
||||||
reference get() {
|
SPROUT_CXX14_CONSTEXPR reference get() {
|
||||||
return helper_type::ref(holder_);
|
return helper_type::ref(holder_);
|
||||||
}
|
}
|
||||||
SPROUT_CONSTEXPR mutable_or_const_reference get() const {
|
SPROUT_CONSTEXPR mutable_or_const_reference get() const {
|
||||||
return helper_type::ref(holder_);
|
return helper_type::ref(holder_);
|
||||||
}
|
}
|
||||||
reference value() {
|
SPROUT_CXX14_CONSTEXPR reference value() {
|
||||||
return get();
|
return get();
|
||||||
}
|
}
|
||||||
SPROUT_CONSTEXPR mutable_or_const_reference value() const {
|
SPROUT_CONSTEXPR mutable_or_const_reference value() const {
|
||||||
return get();
|
return get();
|
||||||
}
|
}
|
||||||
|
|
||||||
pointer operator->() SPROUT_NOEXCEPT {
|
SPROUT_CXX14_CONSTEXPR pointer operator->() SPROUT_NOEXCEPT {
|
||||||
return helper_type::ptr(holder_);
|
return helper_type::ptr(holder_);
|
||||||
}
|
}
|
||||||
SPROUT_CONSTEXPR mutable_or_const_pointer operator->() const SPROUT_NOEXCEPT {
|
SPROUT_CONSTEXPR mutable_or_const_pointer operator->() const SPROUT_NOEXCEPT {
|
||||||
return helper_type::ptr(holder_);
|
return helper_type::ptr(holder_);
|
||||||
}
|
}
|
||||||
pointer get_pointer() SPROUT_NOEXCEPT {
|
SPROUT_CXX14_CONSTEXPR pointer get_pointer() SPROUT_NOEXCEPT {
|
||||||
return helper_type::ptr(holder_);
|
return helper_type::ptr(holder_);
|
||||||
}
|
}
|
||||||
SPROUT_CONSTEXPR mutable_or_const_pointer get_pointer() const SPROUT_NOEXCEPT {
|
SPROUT_CONSTEXPR mutable_or_const_pointer get_pointer() const SPROUT_NOEXCEPT {
|
||||||
return helper_type::ptr(holder_);
|
return helper_type::ptr(holder_);
|
||||||
}
|
}
|
||||||
pointer get_ptr() SPROUT_NOEXCEPT {
|
SPROUT_CXX14_CONSTEXPR pointer get_ptr() SPROUT_NOEXCEPT {
|
||||||
return get_pointer();
|
return get_pointer();
|
||||||
}
|
}
|
||||||
SPROUT_CONSTEXPR mutable_or_const_pointer get_ptr() const SPROUT_NOEXCEPT {
|
SPROUT_CONSTEXPR mutable_or_const_pointer get_ptr() const SPROUT_NOEXCEPT {
|
||||||
|
@ -305,7 +305,7 @@ namespace sprout {
|
||||||
// swap
|
// swap
|
||||||
//
|
//
|
||||||
template<typename T>
|
template<typename T>
|
||||||
inline void
|
inline SPROUT_CXX14_CONSTEXPR void
|
||||||
swap(sprout::value_holder<T>& lhs, sprout::value_holder<T>& rhs)
|
swap(sprout::value_holder<T>& lhs, sprout::value_holder<T>& rhs)
|
||||||
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(lhs.swap(rhs)))
|
SPROUT_NOEXCEPT_EXPR(SPROUT_NOEXCEPT_EXPR(lhs.swap(rhs)))
|
||||||
{
|
{
|
||||||
|
|
Loading…
Add table
Reference in a new issue