123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- #ifndef BOOST_MULTI_ARRAY_ALGORITHM_HPP
- #define BOOST_MULTI_ARRAY_ALGORITHM_HPP
- #include <iterator>
- namespace boost {
- namespace detail {
- namespace multi_array {
- #if 1
- template <class InputIter, class Size, class OutputIter>
- OutputIter copy_n(InputIter first, Size count,
- OutputIter result) {
- for ( ; count > 0; --count) {
- *result = *first;
- ++first;
- ++result;
- }
- return result;
- }
- #else
- template <class InputIter, class Size, class OutputIter>
- OutputIter copy_n__(InputIter first, Size count,
- OutputIter result,
- std::input_iterator_tag) {
- for ( ; count > 0; --count) {
- *result = *first;
- ++first;
- ++result;
- }
- return result;
- }
- template <class RAIter, class Size, class OutputIter>
- inline OutputIter
- copy_n__(RAIter first, Size count,
- OutputIter result,
- std::random_access_iterator_tag) {
- RAIter last = first + count;
- return std::copy(first, last, result);
- }
- template <class InputIter, class Size, class OutputIter>
- inline OutputIter
- copy_n__(InputIter first, Size count, OutputIter result) {
- typedef typename std::iterator_traits<InputIter>::iterator_category cat;
- return copy_n__(first, count, result, cat());
- }
- template <class InputIter, class Size, class OutputIter>
- inline OutputIter
- copy_n(InputIter first, Size count, OutputIter result) {
- return copy_n__(first, count, result);
- }
- #endif
- }
- }
- }
- #endif
|