include/boost/capy/buffers/make_buffer.hpp
100.0% Lines (47/47)
100.0% List of functions (49/49)
Functions (49)
Function
Calls
Lines
Blocks
boost::capy::make_buffer(boost::capy::mutable_buffer const&)
:38
1x
100.0%
100.0%
boost::capy::make_buffer(boost::capy::mutable_buffer const&, unsigned long)
:53
2x
100.0%
100.0%
boost::capy::make_buffer(void*, unsigned long)
:71
4047x
100.0%
100.0%
boost::capy::make_buffer(void*, unsigned long, unsigned long)
:89
2x
100.0%
100.0%
boost::capy::make_buffer(boost::capy::const_buffer const&)
:106
1x
100.0%
100.0%
boost::capy::make_buffer(boost::capy::const_buffer const&, unsigned long)
:121
2x
100.0%
100.0%
boost::capy::make_buffer(void const*, unsigned long)
:139
2x
100.0%
100.0%
boost::capy::make_buffer(void const*, unsigned long, unsigned long)
:157
2x
100.0%
100.0%
boost::capy::const_buffer boost::capy::make_buffer<char, std::char_traits<char> >(std::basic_string_view<char, std::char_traits<char> >)
:179
45x
100.0%
100.0%
boost::capy::const_buffer boost::capy::make_buffer<wchar_t, std::char_traits<wchar_t> >(std::basic_string_view<wchar_t, std::char_traits<wchar_t> >)
:179
1x
100.0%
88.0%
boost::capy::const_buffer boost::capy::make_buffer<char, std::char_traits<char> >(std::basic_string_view<char, std::char_traits<char> >, unsigned long)
:198
2x
100.0%
91.0%
boost::capy::mutable_buffer boost::capy::make_buffer<boost::span<char, 18446744073709551615ul> >(boost::span<char, 18446744073709551615ul>&&)
:246
1x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<boost::span<char, 18446744073709551615ul>&>(boost::span<char, 18446744073709551615ul>&)
:246
1x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [10]>(char (&) [10])
:246
7x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [11]>(char (&) [11])
:246
12x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [1]>(char (&) [1])
:246
12x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [32]>(char (&) [32])
:246
148x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [3]>(char (&) [3])
:246
78x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [4]>(char (&) [4])
:246
38x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [5]>(char (&) [5])
:246
98x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [64]>(char (&) [64])
:246
1x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<int (&) [5]>(int (&) [5])
:246
1x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >&>(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >&)
:246
168x
100.0%
100.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::__cxx11::basic_string<wchar_t, std::char_traits<wchar_t>, std::allocator<wchar_t> >&>(std::__cxx11::basic_string<wchar_t, std::char_traits<wchar_t>, std::allocator<wchar_t> >&)
:246
1x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::array<char, 10ul>&>(std::array<char, 10ul>&)
:246
1x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::array<int, 5ul>&>(std::array<int, 5ul>&)
:246
1x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::span<char, 10ul>&>(std::span<char, 10ul>&)
:246
1x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::span<char, 18446744073709551615ul> >(std::span<char, 18446744073709551615ul>&&)
:246
1x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::span<char, 18446744073709551615ul>&>(std::span<char, 18446744073709551615ul>&)
:246
1x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::vector<char, std::allocator<char> >&>(std::vector<char, std::allocator<char> >&)
:246
2x
100.0%
100.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::vector<int, std::allocator<int> >&>(std::vector<int, std::allocator<int> >&)
:246
1x
100.0%
88.0%
boost::capy::mutable_buffer boost::capy::make_buffer<boost::span<char, 18446744073709551615ul>&>(boost::span<char, 18446744073709551615ul>&, unsigned long)
:267
1x
100.0%
82.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [10]>(char (&) [10], unsigned long)
:267
2x
100.0%
91.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [3]>(char (&) [3], unsigned long)
:267
2x
100.0%
82.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [4]>(char (&) [4], unsigned long)
:267
30x
100.0%
82.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [64]>(char (&) [64], unsigned long)
:267
1x
100.0%
82.0%
boost::capy::mutable_buffer boost::capy::make_buffer<char (&) [8]>(char (&) [8], unsigned long)
:267
2x
100.0%
82.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >&>(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >&, unsigned long)
:267
2x
100.0%
91.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::array<char, 10ul>&>(std::array<char, 10ul>&, unsigned long)
:267
2x
100.0%
91.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::span<char, 18446744073709551615ul>&>(std::span<char, 18446744073709551615ul>&, unsigned long)
:267
2x
100.0%
91.0%
boost::capy::mutable_buffer boost::capy::make_buffer<std::vector<char, std::allocator<char> >&>(std::vector<char, std::allocator<char> >&, unsigned long)
:267
2x
100.0%
91.0%
boost::capy::const_buffer boost::capy::make_buffer<boost::span<char const, 18446744073709551615ul> >(boost::span<char const, 18446744073709551615ul> const&)
:289
1x
100.0%
88.0%
boost::capy::const_buffer boost::capy::make_buffer<char [10]>(char const (&) [10])
:289
1x
100.0%
88.0%
boost::capy::const_buffer boost::capy::make_buffer<char [6]>(char const (&) [6])
:289
1x
100.0%
88.0%
boost::capy::const_buffer boost::capy::make_buffer<std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > >(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&)
:289
165x
100.0%
88.0%
boost::capy::const_buffer boost::capy::make_buffer<std::array<char, 10ul> >(std::array<char, 10ul> const&)
:289
1x
100.0%
88.0%
boost::capy::const_buffer boost::capy::make_buffer<std::span<char const, 18446744073709551615ul> >(std::span<char const, 18446744073709551615ul> const&)
:289
1x
100.0%
88.0%
boost::capy::const_buffer boost::capy::make_buffer<std::vector<char, std::allocator<char> > >(std::vector<char, std::allocator<char> > const&)
:289
1x
100.0%
88.0%
boost::capy::const_buffer boost::capy::make_buffer<char [6]>(char const (&) [6], unsigned long)
:310
6x
100.0%
82.0%
| Line | TLA | Hits | Source Code |
|---|---|---|---|
| 1 | // | ||
| 2 | // Copyright (c) 2023 Vinnie Falco (vinnie.falco@gmail.com) | ||
| 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 | #ifndef BOOST_CAPY_BUFFERS_MAKE_BUFFER_HPP | ||
| 11 | #define BOOST_CAPY_BUFFERS_MAKE_BUFFER_HPP | ||
| 12 | |||
| 13 | #include <boost/capy/detail/config.hpp> | ||
| 14 | #include <boost/capy/buffers.hpp> | ||
| 15 | #include <array> | ||
| 16 | #include <cstdlib> | ||
| 17 | #include <iterator> | ||
| 18 | #include <ranges> | ||
| 19 | #include <span> | ||
| 20 | #include <string> | ||
| 21 | #include <string_view> | ||
| 22 | #include <type_traits> | ||
| 23 | #include <vector> | ||
| 24 | |||
| 25 | BOOST_CAPY_MSVC_WARNING_PUSH | ||
| 26 | BOOST_CAPY_MSVC_WARNING_DISABLE(4459) | ||
| 27 | |||
| 28 | namespace boost { | ||
| 29 | namespace capy { | ||
| 30 | |||
| 31 | /** Return the buffer unchanged. | ||
| 32 | |||
| 33 | @param b The buffer to return. | ||
| 34 | @return A copy of `b`, referring to the same storage. | ||
| 35 | */ | ||
| 36 | [[nodiscard]] inline | ||
| 37 | mutable_buffer | ||
| 38 | 1x | make_buffer( | |
| 39 | mutable_buffer const& b) noexcept | ||
| 40 | { | ||
| 41 | 1x | return b; | |
| 42 | } | ||
| 43 | |||
| 44 | /** Return the buffer, clamped to a maximum size. | ||
| 45 | |||
| 46 | @param b The buffer to return. | ||
| 47 | @param max_size The maximum size, in bytes, of the result. | ||
| 48 | @return A buffer referring to the storage of `b` whose size | ||
| 49 | is the smaller of `b.size()` and `max_size`. | ||
| 50 | */ | ||
| 51 | [[nodiscard]] inline | ||
| 52 | mutable_buffer | ||
| 53 | 2x | make_buffer( | |
| 54 | mutable_buffer const& b, | ||
| 55 | std::size_t max_size) noexcept | ||
| 56 | { | ||
| 57 | 5x | return mutable_buffer( | |
| 58 | b.data(), | ||
| 59 | 5x | b.size() < max_size ? b.size() : max_size); | |
| 60 | } | ||
| 61 | |||
| 62 | /** Return a buffer referring to a region of memory. | ||
| 63 | |||
| 64 | @param data A pointer to the start of the region. The region | ||
| 65 | must outlive the returned buffer. | ||
| 66 | @param size The size of the region, in bytes. | ||
| 67 | @return A buffer referring to `[data, data + size)`. | ||
| 68 | */ | ||
| 69 | [[nodiscard]] inline | ||
| 70 | mutable_buffer | ||
| 71 | 4047x | make_buffer( | |
| 72 | void* data, | ||
| 73 | std::size_t size) noexcept | ||
| 74 | { | ||
| 75 | 4047x | return mutable_buffer(data, size); | |
| 76 | } | ||
| 77 | |||
| 78 | /** Return a buffer referring to a region of memory, clamped to a maximum size. | ||
| 79 | |||
| 80 | @param data A pointer to the start of the region. The region | ||
| 81 | must outlive the returned buffer. | ||
| 82 | @param size The size of the region, in bytes. | ||
| 83 | @param max_size The maximum size, in bytes, of the result. | ||
| 84 | @return A buffer referring to `data` whose size is the smaller | ||
| 85 | of `size` and `max_size`. | ||
| 86 | */ | ||
| 87 | [[nodiscard]] inline | ||
| 88 | mutable_buffer | ||
| 89 | 2x | make_buffer( | |
| 90 | void* data, | ||
| 91 | std::size_t size, | ||
| 92 | std::size_t max_size) noexcept | ||
| 93 | { | ||
| 94 | 2x | return mutable_buffer( | |
| 95 | data, | ||
| 96 | 2x | size < max_size ? size : max_size); | |
| 97 | } | ||
| 98 | |||
| 99 | /** Return the buffer unchanged. | ||
| 100 | |||
| 101 | @param b The buffer to return. | ||
| 102 | @return A copy of `b`, referring to the same storage. | ||
| 103 | */ | ||
| 104 | [[nodiscard]] inline | ||
| 105 | const_buffer | ||
| 106 | 1x | make_buffer( | |
| 107 | const_buffer const& b) noexcept | ||
| 108 | { | ||
| 109 | 1x | return b; | |
| 110 | } | ||
| 111 | |||
| 112 | /** Return the buffer, clamped to a maximum size. | ||
| 113 | |||
| 114 | @param b The buffer to return. | ||
| 115 | @param max_size The maximum size, in bytes, of the result. | ||
| 116 | @return A buffer referring to the storage of `b` whose size | ||
| 117 | is the smaller of `b.size()` and `max_size`. | ||
| 118 | */ | ||
| 119 | [[nodiscard]] inline | ||
| 120 | const_buffer | ||
| 121 | 2x | make_buffer( | |
| 122 | const_buffer const& b, | ||
| 123 | std::size_t max_size) noexcept | ||
| 124 | { | ||
| 125 | 5x | return const_buffer( | |
| 126 | b.data(), | ||
| 127 | 5x | b.size() < max_size ? b.size() : max_size); | |
| 128 | } | ||
| 129 | |||
| 130 | /** Return a buffer referring to a region of memory. | ||
| 131 | |||
| 132 | @param data A pointer to the start of the region. The region | ||
| 133 | must outlive the returned buffer. | ||
| 134 | @param size The size of the region, in bytes. | ||
| 135 | @return A buffer referring to `[data, data + size)`. | ||
| 136 | */ | ||
| 137 | [[nodiscard]] inline | ||
| 138 | const_buffer | ||
| 139 | 2x | make_buffer( | |
| 140 | void const* data, | ||
| 141 | std::size_t size) noexcept | ||
| 142 | { | ||
| 143 | 2x | return const_buffer(data, size); | |
| 144 | } | ||
| 145 | |||
| 146 | /** Return a buffer referring to a region of memory, clamped to a maximum size. | ||
| 147 | |||
| 148 | @param data A pointer to the start of the region. The region | ||
| 149 | must outlive the returned buffer. | ||
| 150 | @param size The size of the region, in bytes. | ||
| 151 | @param max_size The maximum size, in bytes, of the result. | ||
| 152 | @return A buffer referring to `data` whose size is the smaller | ||
| 153 | of `size` and `max_size`. | ||
| 154 | */ | ||
| 155 | [[nodiscard]] inline | ||
| 156 | const_buffer | ||
| 157 | 2x | make_buffer( | |
| 158 | void const* data, | ||
| 159 | std::size_t size, | ||
| 160 | std::size_t max_size) noexcept | ||
| 161 | { | ||
| 162 | 2x | return const_buffer( | |
| 163 | data, | ||
| 164 | 2x | size < max_size ? size : max_size); | |
| 165 | } | ||
| 166 | |||
| 167 | // std::basic_string_view | ||
| 168 | |||
| 169 | /** Return a buffer from a `std::basic_string_view`. | ||
| 170 | |||
| 171 | @param data The view whose characters are referenced. The | ||
| 172 | underlying storage must outlive the returned buffer. | ||
| 173 | @return A buffer referring to the view's storage. The size, | ||
| 174 | in bytes, is `data.size() * sizeof(CharT)`. | ||
| 175 | */ | ||
| 176 | template<class CharT, class Traits> | ||
| 177 | [[nodiscard]] | ||
| 178 | const_buffer | ||
| 179 | 46x | make_buffer( | |
| 180 | std::basic_string_view<CharT, Traits> data) noexcept | ||
| 181 | { | ||
| 182 | 136x | return const_buffer( | |
| 183 | 91x | data.size() ? data.data() : nullptr, | |
| 184 | 47x | data.size() * sizeof(CharT)); | |
| 185 | } | ||
| 186 | |||
| 187 | /** Return a buffer from a `std::basic_string_view`, clamped to a maximum size. | ||
| 188 | |||
| 189 | @param data The view whose characters are referenced. The | ||
| 190 | underlying storage must outlive the returned buffer. | ||
| 191 | @param max_size The maximum size, in bytes, of the result. | ||
| 192 | @return A buffer referring to the view's storage whose size is | ||
| 193 | the smaller of `data.size() * sizeof(CharT)` and `max_size`. | ||
| 194 | */ | ||
| 195 | template<class CharT, class Traits> | ||
| 196 | [[nodiscard]] | ||
| 197 | const_buffer | ||
| 198 | 2x | make_buffer( | |
| 199 | std::basic_string_view<CharT, Traits> data, | ||
| 200 | std::size_t max_size) noexcept | ||
| 201 | { | ||
| 202 | 6x | return const_buffer( | |
| 203 | 4x | data.size() ? data.data() : nullptr, | |
| 204 | 2x | data.size() * sizeof(CharT) < max_size | |
| 205 | 3x | ? data.size() * sizeof(CharT) : max_size); | |
| 206 | } | ||
| 207 | |||
| 208 | // Contiguous ranges | ||
| 209 | |||
| 210 | namespace detail { | ||
| 211 | |||
| 212 | template<class T> | ||
| 213 | concept non_buffer_contiguous_range = | ||
| 214 | std::ranges::contiguous_range<T> && | ||
| 215 | std::ranges::sized_range<T> && | ||
| 216 | !std::convertible_to<T, const_buffer> && | ||
| 217 | !std::convertible_to<T, mutable_buffer> && | ||
| 218 | std::is_trivially_copyable_v<std::ranges::range_value_t<T>>; | ||
| 219 | |||
| 220 | template<class T> | ||
| 221 | concept mutable_contiguous_range = | ||
| 222 | non_buffer_contiguous_range<T> && | ||
| 223 | !std::is_const_v<std::remove_reference_t< | ||
| 224 | std::ranges::range_reference_t<T>>>; | ||
| 225 | |||
| 226 | template<class T> | ||
| 227 | concept const_contiguous_range = | ||
| 228 | non_buffer_contiguous_range<T> && | ||
| 229 | std::is_const_v<std::remove_reference_t< | ||
| 230 | std::ranges::range_reference_t<T>>>; | ||
| 231 | |||
| 232 | } // detail | ||
| 233 | |||
| 234 | /** Return a buffer from a mutable contiguous range. | ||
| 235 | |||
| 236 | Accepts any sized, contiguous range of trivially-copyable, | ||
| 237 | non-const elements, including `std::vector`, `std::array`, | ||
| 238 | `std::string`, `std::span`, `boost::span`, and built-in arrays, | ||
| 239 | whether passed as an lvalue or a temporary. The returned buffer | ||
| 240 | refers to the range's storage, which must outlive the buffer. | ||
| 241 | Its size, in bytes, is `size() * sizeof(element)`. | ||
| 242 | */ | ||
| 243 | template<detail::mutable_contiguous_range T> | ||
| 244 | [[nodiscard]] | ||
| 245 | mutable_buffer | ||
| 246 | 836x | make_buffer(T&& data) noexcept | |
| 247 | { | ||
| 248 | 2502x | return mutable_buffer( | |
| 249 | 1670x | std::ranges::size(data) ? std::ranges::data(data) : nullptr, | |
| 250 | 840x | std::ranges::size(data) * sizeof(std::ranges::range_value_t<T>)); | |
| 251 | } | ||
| 252 | |||
| 253 | /** Return a buffer from a mutable contiguous range, clamped to a maximum size. | ||
| 254 | |||
| 255 | Like the unclamped overload, but the result is no larger than | ||
| 256 | `max_size` bytes. | ||
| 257 | |||
| 258 | @param data The range whose storage is referenced. It must | ||
| 259 | outlive the returned buffer. | ||
| 260 | @param max_size The maximum size, in bytes, of the result. | ||
| 261 | @return A buffer whose size is the smaller of | ||
| 262 | `size() * sizeof(element)` and `max_size`. | ||
| 263 | */ | ||
| 264 | template<detail::mutable_contiguous_range T> | ||
| 265 | [[nodiscard]] | ||
| 266 | mutable_buffer | ||
| 267 | 53x | make_buffer( | |
| 268 | T&& data, | ||
| 269 | std::size_t max_size) noexcept | ||
| 270 | { | ||
| 271 | 53x | auto const n = std::ranges::size(data) * sizeof(std::ranges::range_value_t<T>); | |
| 272 | 111x | return mutable_buffer( | |
| 273 | 106x | std::ranges::size(data) ? std::ranges::data(data) : nullptr, | |
| 274 | 106x | n < max_size ? n : max_size); | |
| 275 | } | ||
| 276 | |||
| 277 | /** Return a buffer from a const contiguous range. | ||
| 278 | |||
| 279 | Accepts any sized, contiguous range of trivially-copyable | ||
| 280 | elements with const access, including const `std::vector`, | ||
| 281 | `std::array`, `std::string`, `std::span`, `boost::span`, and | ||
| 282 | string literals. The returned buffer refers to the range's | ||
| 283 | storage, which must outlive the buffer. Its size, in bytes, | ||
| 284 | is `size() * sizeof(element)`. | ||
| 285 | */ | ||
| 286 | template<detail::non_buffer_contiguous_range T> | ||
| 287 | [[nodiscard]] | ||
| 288 | const_buffer | ||
| 289 | 171x | make_buffer(T const& data) noexcept | |
| 290 | { | ||
| 291 | 513x | return const_buffer( | |
| 292 | 342x | std::ranges::size(data) ? std::ranges::data(data) : nullptr, | |
| 293 | 171x | std::ranges::size(data) * sizeof(std::ranges::range_value_t<T>)); | |
| 294 | } | ||
| 295 | |||
| 296 | /** Return a buffer from a const contiguous range, clamped to a maximum size. | ||
| 297 | |||
| 298 | Like the unclamped overload, but the result is no larger than | ||
| 299 | `max_size` bytes. | ||
| 300 | |||
| 301 | @param data The range whose storage is referenced. It must | ||
| 302 | outlive the returned buffer. | ||
| 303 | @param max_size The maximum size, in bytes, of the result. | ||
| 304 | @return A buffer whose size is the smaller of | ||
| 305 | `size() * sizeof(element)` and `max_size`. | ||
| 306 | */ | ||
| 307 | template<detail::non_buffer_contiguous_range T> | ||
| 308 | [[nodiscard]] | ||
| 309 | const_buffer | ||
| 310 | 722x | make_buffer( | |
| 311 | T const& data, | ||
| 312 | std::size_t max_size) noexcept | ||
| 313 | { | ||
| 314 | 722x | auto const n = std::ranges::size(data) * sizeof(std::ranges::range_value_t<T>); | |
| 315 | 1449x | return const_buffer( | |
| 316 | 1444x | std::ranges::size(data) ? std::ranges::data(data) : nullptr, | |
| 317 | 1444x | n < max_size ? n : max_size); | |
| 318 | } | ||
| 319 | |||
| 320 | } // capy | ||
| 321 | } // boost | ||
| 322 | |||
| 323 | BOOST_CAPY_MSVC_WARNING_POP | ||
| 324 | |||
| 325 | #endif | ||
| 326 |