include/boost/capy/detail/slice_impl.hpp

100.0% Lines (105/105) 96.8% List of functions (92/95)
slice_impl.hpp
f(x) Functions (95)
Function Calls Lines Blocks
boost::capy::detail::slice_impl<boost::capy::const_buffer>::adjust_buffer(boost::capy::const_buffer const&, unsigned long, unsigned long) :66 154x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::adjust_buffer(boost::capy::mutable_buffer const&, unsigned long, unsigned long) :66 144x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::adjust_buffer(boost::capy::const_buffer const&, unsigned long, unsigned long) :66 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::adjust_buffer(boost::capy::const_buffer const&, unsigned long, unsigned long) :66 90x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::adjust_buffer(boost::capy::mutable_buffer const&, unsigned long, unsigned long) :66 0 0.0% 0.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::adjust_buffer(boost::capy::mutable_buffer const&, unsigned long, unsigned long) :66 1x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::adjust_buffer(boost::capy::mutable_buffer const&, unsigned long, unsigned long) :66 90x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::adjust_buffer(boost::capy::mutable_buffer const&, unsigned long, unsigned long) :66 12x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view::const_iterator::const_iterator(boost::capy::const_buffer const*, boost::capy::const_buffer const*, boost::capy::const_buffer const*, unsigned long, unsigned long) :112 308x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view::const_iterator::const_iterator(boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, unsigned long, unsigned long) :112 291x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::data_view::const_iterator::const_iterator(boost::capy::const_buffer const*, boost::capy::const_buffer const*, boost::capy::const_buffer const*, unsigned long, unsigned long) :112 4x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data_view::const_iterator::const_iterator(boost::capy::const_buffer const*, boost::capy::const_buffer const*, boost::capy::const_buffer const*, unsigned long, unsigned long) :112 140x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::data_view::const_iterator::const_iterator(boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, unsigned long, unsigned long) :112 4x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::data_view::const_iterator::const_iterator(boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, unsigned long, unsigned long) :112 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data_view::const_iterator::const_iterator(boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, unsigned long, unsigned long) :112 173x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::data_view::const_iterator::const_iterator(boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, unsigned long, unsigned long) :112 20x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view::const_iterator::operator==(boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view::const_iterator const&) const :126 192x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view::const_iterator::operator==(boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view::const_iterator const&) const :126 156x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::data_view::const_iterator::operator==(boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::data_view::const_iterator const&) const :126 4x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data_view::const_iterator::operator==(boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data_view::const_iterator const&) const :126 104x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::data_view::const_iterator::operator==(boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::data_view::const_iterator const&) const :126 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::data_view::const_iterator::operator==(boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::data_view::const_iterator const&) const :126 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data_view::const_iterator::operator==(boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data_view::const_iterator const&) const :126 119x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::data_view::const_iterator::operator==(boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::data_view::const_iterator const&) const :126 19x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view::const_iterator::operator!=(boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view::const_iterator const&) const :131 192x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view::const_iterator::operator!=(boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view::const_iterator const&) const :131 156x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::data_view::const_iterator::operator!=(boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::data_view::const_iterator const&) const :131 4x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data_view::const_iterator::operator!=(boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data_view::const_iterator const&) const :131 104x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::data_view::const_iterator::operator!=(boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::data_view::const_iterator const&) const :131 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::data_view::const_iterator::operator!=(boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::data_view::const_iterator const&) const :131 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data_view::const_iterator::operator!=(boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data_view::const_iterator const&) const :131 119x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::data_view::const_iterator::operator!=(boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::data_view::const_iterator const&) const :131 19x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view::const_iterator::operator*() const :136 154x 100.0% 78.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view::const_iterator::operator*() const :136 144x 100.0% 78.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::data_view::const_iterator::operator*() const :136 2x 100.0% 78.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data_view::const_iterator::operator*() const :136 90x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::data_view::const_iterator::operator*() const :136 0 0.0% 0.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::data_view::const_iterator::operator*() const :136 1x 100.0% 78.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data_view::const_iterator::operator*() const :136 90x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::data_view::const_iterator::operator*() const :136 12x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view::const_iterator::operator++() :146 136x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view::const_iterator::operator++() :146 140x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::data_view::const_iterator::operator++() :146 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data_view::const_iterator::operator++() :146 90x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::data_view::const_iterator::operator++() :146 0 0.0% 0.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::data_view::const_iterator::operator++() :146 1x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data_view::const_iterator::operator++() :146 82x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::data_view::const_iterator::operator++() :146 12x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view::const_iterator::operator++(int) :152 78x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view::const_iterator::operator++(int) :152 106x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data_view::const_iterator::operator++(int) :152 42x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data_view::const_iterator::operator++(int) :152 36x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view::data_view(boost::capy::const_buffer const*, boost::capy::const_buffer const*, unsigned long, unsigned long) :175 78x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view::data_view(boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, unsigned long, unsigned long) :175 74x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::data_view::data_view(boost::capy::const_buffer const*, boost::capy::const_buffer const*, unsigned long, unsigned long) :175 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data_view::data_view(boost::capy::const_buffer const*, boost::capy::const_buffer const*, unsigned long, unsigned long) :175 42x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::data_view::data_view(boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, unsigned long, unsigned long) :175 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::data_view::data_view(boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, unsigned long, unsigned long) :175 1x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data_view::data_view(boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, unsigned long, unsigned long) :175 65x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::data_view::data_view(boost::capy::mutable_buffer const*, boost::capy::mutable_buffer const*, unsigned long, unsigned long) :175 7x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view::begin() const :187 154x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view::begin() const :187 144x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::data_view::begin() const :187 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data_view::begin() const :187 70x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::data_view::begin() const :187 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::data_view::begin() const :187 1x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data_view::begin() const :187 77x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::data_view::begin() const :187 7x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view::end() const :193 154x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view::end() const :193 147x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::data_view::end() const :193 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data_view::end() const :193 70x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::data_view::end() const :193 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::data_view::end() const :193 1x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data_view::end() const :193 96x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::data_view::end() const :193 13x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::slice_impl(boost::capy::mutable_buffer const&) :202 1x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::slice_impl(std::array<boost::capy::const_buffer, 1ul> const&) :202 1x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::slice_impl(std::array<boost::capy::mutable_buffer, 1ul> const&) :202 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::slice_impl(std::array<boost::capy::mutable_buffer, 2ul> const&) :202 6x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::const_buffer>::slice_impl(boost::capy::const_buffer const&, unsigned long, unsigned long) :208 64x 89.2% 92.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::slice_impl(boost::capy::mutable_buffer const&, unsigned long, unsigned long) :208 67x 89.2% 92.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::slice_impl(std::array<boost::capy::const_buffer, 1ul> const&, unsigned long, unsigned long) :208 1x 81.1% 84.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::slice_impl(std::array<boost::capy::const_buffer, 2ul> const&, unsigned long, unsigned long) :208 42x 94.6% 92.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::slice_impl(std::array<boost::capy::mutable_buffer, 2ul> const&, unsigned long, unsigned long) :208 38x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::slice_impl(std::array<boost::capy::mutable_buffer, 3ul> const&, unsigned long, unsigned long) :208 1x 86.5% 84.0% boost::capy::detail::slice_impl<boost::capy::const_buffer>::data() const :264 78x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data() const :264 74x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 1ul> >::data() const :264 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::const_buffer, 2ul> >::data() const :264 42x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 0ul> >::data() const :264 2x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 1ul> >::data() const :264 1x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 2ul> >::data() const :264 65x 100.0% 100.0% boost::capy::detail::slice_impl<std::array<boost::capy::mutable_buffer, 3ul> >::data() const :264 7x 100.0% 100.0% boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::remove_prefix(unsigned long) :269 29x 80.0% 83.0%
Line TLA Hits Source Code
1 //
2 // Copyright (c) 2026 Michael Vandeberg
3 //
4 // Distributed under the Boost Software License, Version 1.0. (See accompanying
5 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
6 //
7 // Official repository: https://github.com/cppalliance/capy
8 //
9
10 /*
11 Implementation type for the public buffer_slice() free function.
12 Users see this only via auto + the Slice concept; the type is
13 documented as unspecified. Maintained alongside Slice in
14 include/boost/capy/concept/slice.hpp.
15 */
16
17 #ifndef BOOST_CAPY_DETAIL_SLICE_IMPL_HPP
18 #define BOOST_CAPY_DETAIL_SLICE_IMPL_HPP
19
20 #include <boost/capy/detail/config.hpp>
21 #include <boost/capy/buffers.hpp>
22
23 #include <cstddef>
24 #include <iterator>
25 #include <type_traits>
26
27 namespace boost {
28 namespace capy {
29 namespace detail {
30
31 template<class T>
32 struct slice_buffer_type_for;
33
34 template<MutableBufferSequence T>
35 struct slice_buffer_type_for<T>
36 {
37 using type = mutable_buffer;
38 };
39
40 template<ConstBufferSequence T>
41 requires (!MutableBufferSequence<T>)
42 struct slice_buffer_type_for<T>
43 {
44 using type = const_buffer;
45 };
46
47 template<class BufferSequence>
48 requires MutableBufferSequence<BufferSequence>
49 || ConstBufferSequence<BufferSequence>
50 class slice_impl
51 {
52 public:
53 using iterator_type =
54 decltype(capy::begin(std::declval<BufferSequence const&>()));
55 using end_iterator_type =
56 decltype(capy::end(std::declval<BufferSequence const&>()));
57 using buffer_type =
58 typename slice_buffer_type_for<BufferSequence>::type;
59
60 private:
61 iterator_type first_{};
62 end_iterator_type last_{};
63 std::size_t front_skip_ = 0;
64 std::size_t back_skip_ = 0;
65
66 493x static buffer_type adjust_buffer(
67 buffer_type const& buf,
68 std::size_t front,
69 std::size_t back) noexcept
70 {
71 if constexpr (std::is_same_v<buffer_type, mutable_buffer>)
72 {
73 247x return mutable_buffer(
74 247x static_cast<char*>(buf.data()) + front,
75 494x buf.size() - front - back);
76 }
77 else
78 {
79 246x return const_buffer(
80 246x static_cast<char const*>(buf.data()) + front,
81 492x buf.size() - front - back);
82 }
83 }
84
85 public:
86 /// View returned by `slice_impl::data()`.
87 class data_view
88 {
89 iterator_type first_{};
90 end_iterator_type last_{};
91 std::size_t front_skip_ = 0;
92 std::size_t back_skip_ = 0;
93
94 public:
95 class const_iterator
96 {
97 iterator_type cur_{};
98 iterator_type anchor_first_{};
99 end_iterator_type anchor_last_{};
100 std::size_t front_skip_ = 0;
101 std::size_t back_skip_ = 0;
102
103 public:
104 using iterator_category = std::bidirectional_iterator_tag;
105 using value_type = buffer_type;
106 using difference_type = std::ptrdiff_t;
107 using pointer = value_type*;
108 using reference = value_type;
109
110 const_iterator() noexcept = default;
111
112 942x const_iterator(
113 iterator_type cur,
114 iterator_type anchor_first,
115 end_iterator_type anchor_last,
116 std::size_t front_skip,
117 std::size_t back_skip) noexcept
118 942x : cur_(cur)
119 942x , anchor_first_(anchor_first)
120 942x , anchor_last_(anchor_last)
121 942x , front_skip_(front_skip)
122 942x , back_skip_(back_skip)
123 {
124 942x }
125
126 598x bool operator==(const_iterator const& other) const noexcept
127 {
128 598x return cur_ == other.cur_;
129 }
130
131 598x bool operator!=(const_iterator const& other) const noexcept
132 {
133 598x return !(*this == other);
134 }
135
136 493x value_type operator*() const noexcept
137 {
138 493x buffer_type buf = *cur_;
139 493x auto front = (cur_ == anchor_first_) ? front_skip_ : 0;
140 493x auto next = cur_;
141 493x ++next;
142 493x auto back = (next == anchor_last_) ? back_skip_ : 0;
143 493x return adjust_buffer(buf, front, back);
144 }
145
146 463x const_iterator& operator++() noexcept
147 {
148 463x ++cur_;
149 463x return *this;
150 }
151
152 262x const_iterator operator++(int) noexcept
153 {
154 262x const_iterator tmp = *this;
155 262x ++*this;
156 262x return tmp;
157 }
158
159 const_iterator& operator--() noexcept
160 {
161 --cur_;
162 return *this;
163 }
164
165 const_iterator operator--(int) noexcept
166 {
167 const_iterator tmp = *this;
168 --*this;
169 return tmp;
170 }
171 };
172
173 data_view() noexcept = default;
174
175 271x data_view(
176 iterator_type first,
177 end_iterator_type last,
178 std::size_t front_skip,
179 std::size_t back_skip) noexcept
180 271x : first_(first)
181 271x , last_(last)
182 271x , front_skip_(front_skip)
183 271x , back_skip_(back_skip)
184 {
185 271x }
186
187 457x const_iterator begin() const noexcept
188 {
189 return const_iterator(
190 457x first_, first_, last_, front_skip_, back_skip_);
191 }
192
193 485x const_iterator end() const noexcept
194 {
195 return const_iterator(
196 485x last_, first_, last_, front_skip_, back_skip_);
197 }
198 };
199
200 slice_impl() noexcept = default;
201
202 10x explicit slice_impl(BufferSequence const& bs) noexcept
203 10x : first_(capy::begin(bs))
204 10x , last_(capy::end(bs))
205 {
206 10x }
207
208 213x slice_impl(
209 BufferSequence const& bs,
210 std::size_t offset,
211 std::size_t length) noexcept
212 213x {
213 213x auto it_begin = capy::begin(bs);
214 213x auto it_end = capy::end(bs);
215
216 213x std::size_t total = 0;
217 508x for (auto it = it_begin; it != it_end; ++it)
218 295x total += (*it).size();
219
220 213x if (offset > total)
221 1x offset = total;
222 213x std::size_t const remaining = total - offset;
223 213x if (length > remaining)
224 205x length = remaining;
225
226 213x first_ = it_begin;
227 213x last_ = it_end;
228
229 213x std::size_t skip = offset;
230 235x while (first_ != last_)
231 {
232 228x std::size_t const buf_size = (*first_).size();
233 228x if (skip < buf_size)
234 {
235 206x front_skip_ = skip;
236 206x break;
237 }
238 22x skip -= buf_size;
239 22x ++first_;
240 }
241
242 213x std::size_t left = length;
243 213x auto cursor = first_;
244 213x std::size_t cursor_front = front_skip_;
245 278x while (cursor != last_ && left > 0)
246 {
247 270x std::size_t const buf_size = (*cursor).size();
248 270x std::size_t const avail = buf_size - cursor_front;
249 270x if (left <= avail)
250 {
251 205x back_skip_ = avail - left;
252 205x ++cursor;
253 205x last_ = cursor;
254 205x return;
255 }
256 65x left -= avail;
257 65x ++cursor;
258 65x cursor_front = 0;
259 }
260
261 8x last_ = cursor;
262 }
263
264 271x data_view data() const noexcept
265 {
266 271x return data_view(first_, last_, front_skip_, back_skip_);
267 }
268
269 172x void remove_prefix(std::size_t n) noexcept
270 {
271 192x while (n > 0 && first_ != last_)
272 {
273 122x std::size_t const buf_total = (*first_).size();
274 122x std::size_t live = buf_total - front_skip_;
275 122x auto next = first_;
276 122x ++next;
277 122x bool const is_last = (next == last_);
278 122x if (is_last)
279 92x live -= back_skip_;
280
281 122x if (n < live)
282 {
283 35x front_skip_ += n;
284 35x return;
285 }
286
287 87x n -= live;
288 87x if (is_last)
289 {
290 67x first_ = last_;
291 67x front_skip_ = 0;
292 67x back_skip_ = 0;
293 67x return;
294 }
295 20x ++first_;
296 20x front_skip_ = 0;
297 }
298 }
299 };
300
301 } // namespace detail
302 } // namespace capy
303 } // namespace boost
304
305 #endif
306