mirror of
https://github.com/boostorg/beast.git
synced 2025-07-30 12:57:31 +02:00
prepared_buffers is private (API Change)
This commit is contained in:
@ -20,6 +20,7 @@ WebSocket
|
|||||||
API Changes:
|
API Changes:
|
||||||
|
|
||||||
* Refactor message and message_headers declarations
|
* Refactor message and message_headers declarations
|
||||||
|
* prepared_buffers is private
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -165,7 +165,6 @@
|
|||||||
<member><link linkend="beast.ref.error_code">error_code</link></member>
|
<member><link linkend="beast.ref.error_code">error_code</link></member>
|
||||||
<member><link linkend="beast.ref.error_condition">error_condition</link></member>
|
<member><link linkend="beast.ref.error_condition">error_condition</link></member>
|
||||||
<member><link linkend="beast.ref.handler_alloc">handler_alloc</link></member>
|
<member><link linkend="beast.ref.handler_alloc">handler_alloc</link></member>
|
||||||
<member><link linkend="beast.ref.prepared_buffers">prepared_buffers</link></member>
|
|
||||||
<member><link linkend="beast.ref.static_streambuf">static_streambuf</link></member>
|
<member><link linkend="beast.ref.static_streambuf">static_streambuf</link></member>
|
||||||
<member><link linkend="beast.ref.static_streambuf_n">static_streambuf_n</link></member>
|
<member><link linkend="beast.ref.static_streambuf_n">static_streambuf_n</link></member>
|
||||||
<member><link linkend="beast.ref.static_string">static_string</link></member>
|
<member><link linkend="beast.ref.static_string">static_string</link></member>
|
||||||
|
@ -5,38 +5,104 @@
|
|||||||
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef BEAST_IMPL_PREPARE_BUFFERS_IPP
|
#ifndef BEAST_DETAIL_PREPARED_BUFFERS_HPP
|
||||||
#define BEAST_IMPL_PREPARE_BUFFERS_IPP
|
#define BEAST_DETAIL_PREPARED_BUFFERS_HPP
|
||||||
|
|
||||||
|
#include <beast/core/prepare_buffer.hpp>
|
||||||
#include <boost/asio/buffer.hpp>
|
#include <boost/asio/buffer.hpp>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
#include <type_traits>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
namespace beast {
|
namespace beast {
|
||||||
|
namespace detail {
|
||||||
|
|
||||||
|
/** A buffer sequence adapter that shortens the sequence size.
|
||||||
|
|
||||||
|
The class adapts a buffer sequence to efficiently represent
|
||||||
|
a shorter subset of the original list of buffers starting
|
||||||
|
with the first byte of the original sequence.
|
||||||
|
|
||||||
|
@tparam BufferSequence The buffer sequence to adapt.
|
||||||
|
*/
|
||||||
template<class BufferSequence>
|
template<class BufferSequence>
|
||||||
void
|
class prepared_buffers
|
||||||
prepared_buffers<BufferSequence>::
|
|
||||||
setup(std::size_t n)
|
|
||||||
{
|
{
|
||||||
for(end_ = bs_.begin(); end_ != bs_.end(); ++end_)
|
using iter_type =
|
||||||
|
typename BufferSequence::const_iterator;
|
||||||
|
|
||||||
|
BufferSequence bs_;
|
||||||
|
iter_type back_;
|
||||||
|
iter_type end_;
|
||||||
|
std::size_t size_;
|
||||||
|
|
||||||
|
template<class Deduced>
|
||||||
|
prepared_buffers(Deduced&& other,
|
||||||
|
std::size_t nback, std::size_t nend)
|
||||||
|
: bs_(std::forward<Deduced>(other).bs_)
|
||||||
|
, back_(std::next(bs_.begin(), nback))
|
||||||
|
, end_(std::next(bs_.begin(), nend))
|
||||||
|
, size_(other.size_)
|
||||||
{
|
{
|
||||||
auto const len =
|
|
||||||
boost::asio::buffer_size(*end_);
|
|
||||||
if(n <= len)
|
|
||||||
{
|
|
||||||
size_ = n;
|
|
||||||
back_ = end_++;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
n -= len;
|
|
||||||
}
|
}
|
||||||
size_ = 0;
|
|
||||||
back_ = end_;
|
void
|
||||||
}
|
setup(std::size_t n);
|
||||||
|
|
||||||
|
public:
|
||||||
|
/// The type for each element in the list of buffers.
|
||||||
|
using value_type = typename std::conditional<
|
||||||
|
std::is_convertible<typename
|
||||||
|
std::iterator_traits<iter_type>::value_type,
|
||||||
|
boost::asio::mutable_buffer>::value,
|
||||||
|
boost::asio::mutable_buffer,
|
||||||
|
boost::asio::const_buffer>::type;
|
||||||
|
|
||||||
|
#if GENERATING_DOCS
|
||||||
|
/// A bidirectional iterator type that may be used to read elements.
|
||||||
|
using const_iterator = implementation_defined;
|
||||||
|
|
||||||
|
#else
|
||||||
|
class const_iterator;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/// Move constructor.
|
||||||
|
prepared_buffers(prepared_buffers&&);
|
||||||
|
|
||||||
|
/// Copy constructor.
|
||||||
|
prepared_buffers(prepared_buffers const&);
|
||||||
|
|
||||||
|
/// Move assignment.
|
||||||
|
prepared_buffers& operator=(prepared_buffers&&);
|
||||||
|
|
||||||
|
/// Copy assignment.
|
||||||
|
prepared_buffers& operator=(prepared_buffers const&);
|
||||||
|
|
||||||
|
/** Construct a shortened buffer sequence.
|
||||||
|
|
||||||
|
@param n The maximum number of bytes in the wrapped
|
||||||
|
sequence. If this is larger than the size of passed,
|
||||||
|
buffers, the resulting sequence will represent the
|
||||||
|
entire input sequence.
|
||||||
|
|
||||||
|
@param buffers The buffer sequence to adapt. A copy of
|
||||||
|
the sequence will be made, but ownership of the underlying
|
||||||
|
memory is not transferred.
|
||||||
|
*/
|
||||||
|
prepared_buffers(std::size_t n, BufferSequence const& buffers);
|
||||||
|
|
||||||
|
/// Get a bidirectional iterator to the first element.
|
||||||
|
const_iterator
|
||||||
|
begin() const;
|
||||||
|
|
||||||
|
/// Get a bidirectional iterator to one past the last element.
|
||||||
|
const_iterator
|
||||||
|
end() const;
|
||||||
|
};
|
||||||
|
|
||||||
template<class BufferSequence>
|
template<class BufferSequence>
|
||||||
class prepared_buffers<BufferSequence>::const_iterator
|
class prepared_buffers<BufferSequence>::const_iterator
|
||||||
@ -130,6 +196,27 @@ private:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
template<class BufferSequence>
|
||||||
|
void
|
||||||
|
prepared_buffers<BufferSequence>::
|
||||||
|
setup(std::size_t n)
|
||||||
|
{
|
||||||
|
for(end_ = bs_.begin(); end_ != bs_.end(); ++end_)
|
||||||
|
{
|
||||||
|
auto const len =
|
||||||
|
boost::asio::buffer_size(*end_);
|
||||||
|
if(n <= len)
|
||||||
|
{
|
||||||
|
size_ = n;
|
||||||
|
back_ = end_++;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
n -= len;
|
||||||
|
}
|
||||||
|
size_ = 0;
|
||||||
|
back_ = end_;
|
||||||
|
}
|
||||||
|
|
||||||
template<class BufferSequence>
|
template<class BufferSequence>
|
||||||
prepared_buffers<BufferSequence>::const_iterator::
|
prepared_buffers<BufferSequence>::const_iterator::
|
||||||
const_iterator(const_iterator&& other)
|
const_iterator(const_iterator&& other)
|
||||||
@ -163,6 +250,8 @@ prepared_buffers<BufferSequence>::const_iterator::
|
|||||||
operator=(const_iterator const& other) ->
|
operator=(const_iterator const& other) ->
|
||||||
const_iterator&
|
const_iterator&
|
||||||
{
|
{
|
||||||
|
if(&other == this)
|
||||||
|
return *this;
|
||||||
b_ = other.b_;
|
b_ = other.b_;
|
||||||
it_ = other.it_;
|
it_ = other.it_;
|
||||||
return *this;
|
return *this;
|
||||||
@ -246,14 +335,7 @@ prepared_buffers<BufferSequence>::end() const ->
|
|||||||
return const_iterator{*this, true};
|
return const_iterator{*this, true};
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class BufferSequence>
|
} // detail
|
||||||
inline
|
|
||||||
prepared_buffers<BufferSequence>
|
|
||||||
prepare_buffers(std::size_t n, BufferSequence const& buffers)
|
|
||||||
{
|
|
||||||
return prepared_buffers<BufferSequence>{n, buffers};
|
|
||||||
}
|
|
||||||
|
|
||||||
} // beast
|
} // beast
|
||||||
|
|
||||||
#endif
|
#endif
|
68
include/beast/core/prepare_buffer.hpp
Normal file
68
include/beast/core/prepare_buffer.hpp
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
//
|
||||||
|
// Copyright (c) 2013-2016 Vinnie Falco (vinnie dot falco at gmail dot com)
|
||||||
|
//
|
||||||
|
// 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 BEAST_PREPARE_BUFFER_HPP
|
||||||
|
#define BEAST_PREPARE_BUFFER_HPP
|
||||||
|
|
||||||
|
#include <boost/asio/buffer.hpp>
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
|
namespace beast {
|
||||||
|
|
||||||
|
/** Return a shortened buffer.
|
||||||
|
|
||||||
|
The returned buffer points to the same memory as the
|
||||||
|
passed buffer, but with a size that is equal to or less
|
||||||
|
than the size of the original buffer.
|
||||||
|
|
||||||
|
@param n The size of the returned buffer.
|
||||||
|
|
||||||
|
@param buffer The buffer to shorten. Ownership of the
|
||||||
|
underlying memory is not transferred.
|
||||||
|
|
||||||
|
@return A new buffer that points to the first `n` bytes
|
||||||
|
of the original buffer.
|
||||||
|
*/
|
||||||
|
inline
|
||||||
|
boost::asio::const_buffer
|
||||||
|
prepare_buffer(std::size_t n,
|
||||||
|
boost::asio::const_buffer buffer)
|
||||||
|
{
|
||||||
|
using boost::asio::buffer_cast;
|
||||||
|
using boost::asio::buffer_size;
|
||||||
|
return { buffer_cast<void const*>(buffer),
|
||||||
|
(std::min)(n, buffer_size(buffer)) };
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Return a shortened buffer.
|
||||||
|
|
||||||
|
The returned buffer points to the same memory as the
|
||||||
|
passed buffer, but with a size that is equal to or less
|
||||||
|
than the size of the original buffer.
|
||||||
|
|
||||||
|
@param n The size of the returned buffer.
|
||||||
|
|
||||||
|
@param buffer The buffer to shorten. Ownership of the
|
||||||
|
underlying memory is not transferred.
|
||||||
|
|
||||||
|
@return A new buffer that points to the first `n` bytes
|
||||||
|
of the original buffer.
|
||||||
|
*/
|
||||||
|
inline
|
||||||
|
boost::asio::mutable_buffer
|
||||||
|
prepare_buffer(std::size_t n,
|
||||||
|
boost::asio::mutable_buffer buffer)
|
||||||
|
{
|
||||||
|
using boost::asio::buffer_cast;
|
||||||
|
using boost::asio::buffer_size;
|
||||||
|
return { buffer_cast<void*>(buffer),
|
||||||
|
(std::min)(n, buffer_size(buffer)) };
|
||||||
|
}
|
||||||
|
|
||||||
|
} // beast
|
||||||
|
|
||||||
|
#endif
|
@ -8,6 +8,7 @@
|
|||||||
#ifndef BEAST_PREPARE_BUFFERS_HPP
|
#ifndef BEAST_PREPARE_BUFFERS_HPP
|
||||||
#define BEAST_PREPARE_BUFFERS_HPP
|
#define BEAST_PREPARE_BUFFERS_HPP
|
||||||
|
|
||||||
|
#include <beast/core/detail/prepare_buffers.hpp>
|
||||||
#include <boost/asio/buffer.hpp>
|
#include <boost/asio/buffer.hpp>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
@ -18,142 +19,6 @@
|
|||||||
|
|
||||||
namespace beast {
|
namespace beast {
|
||||||
|
|
||||||
/** Return a shortened buffer.
|
|
||||||
|
|
||||||
The returned buffer points to the same memory as the
|
|
||||||
passed buffer, but with a size that is equal to or less
|
|
||||||
than the size of the original buffer.
|
|
||||||
|
|
||||||
@param n The size of the returned buffer.
|
|
||||||
|
|
||||||
@param buffer The buffer to shorten. Ownership of the
|
|
||||||
underlying memory is not transferred.
|
|
||||||
|
|
||||||
@return A new buffer that points to the first `n` bytes
|
|
||||||
of the original buffer.
|
|
||||||
*/
|
|
||||||
inline
|
|
||||||
boost::asio::const_buffer
|
|
||||||
prepare_buffer(std::size_t n,
|
|
||||||
boost::asio::const_buffer buffer)
|
|
||||||
{
|
|
||||||
using boost::asio::buffer_cast;
|
|
||||||
using boost::asio::buffer_size;
|
|
||||||
return { buffer_cast<void const*>(buffer),
|
|
||||||
(std::min)(n, buffer_size(buffer)) };
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Return a shortened buffer.
|
|
||||||
|
|
||||||
The returned buffer points to the same memory as the
|
|
||||||
passed buffer, but with a size that is equal to or less
|
|
||||||
than the size of the original buffer.
|
|
||||||
|
|
||||||
@param n The size of the returned buffer.
|
|
||||||
|
|
||||||
@param buffer The buffer to shorten. Ownership of the
|
|
||||||
underlying memory is not transferred.
|
|
||||||
|
|
||||||
@return A new buffer that points to the first `n` bytes
|
|
||||||
of the original buffer.
|
|
||||||
*/
|
|
||||||
inline
|
|
||||||
boost::asio::mutable_buffer
|
|
||||||
prepare_buffer(std::size_t n,
|
|
||||||
boost::asio::mutable_buffer buffer)
|
|
||||||
{
|
|
||||||
using boost::asio::buffer_cast;
|
|
||||||
using boost::asio::buffer_size;
|
|
||||||
return { buffer_cast<void*>(buffer),
|
|
||||||
(std::min)(n, buffer_size(buffer)) };
|
|
||||||
}
|
|
||||||
|
|
||||||
/** A buffer sequence adapter that shortens the sequence size.
|
|
||||||
|
|
||||||
The class adapts a buffer sequence to efficiently represent
|
|
||||||
a shorter subset of the original list of buffers starting
|
|
||||||
with the first byte of the original sequence.
|
|
||||||
|
|
||||||
@tparam BufferSequence The buffer sequence to adapt.
|
|
||||||
*/
|
|
||||||
template<class BufferSequence>
|
|
||||||
class prepared_buffers
|
|
||||||
{
|
|
||||||
using iter_type =
|
|
||||||
typename BufferSequence::const_iterator;
|
|
||||||
|
|
||||||
BufferSequence bs_;
|
|
||||||
iter_type back_;
|
|
||||||
iter_type end_;
|
|
||||||
std::size_t size_;
|
|
||||||
|
|
||||||
template<class Deduced>
|
|
||||||
prepared_buffers(Deduced&& other,
|
|
||||||
std::size_t nback, std::size_t nend)
|
|
||||||
: bs_(std::forward<Deduced>(other).bs_)
|
|
||||||
, back_(std::next(bs_.begin(), nback))
|
|
||||||
, end_(std::next(bs_.begin(), nend))
|
|
||||||
, size_(other.size_)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
setup(std::size_t n);
|
|
||||||
|
|
||||||
public:
|
|
||||||
/// The type for each element in the list of buffers.
|
|
||||||
using value_type = typename std::conditional<
|
|
||||||
std::is_convertible<typename
|
|
||||||
std::iterator_traits<iter_type>::value_type,
|
|
||||||
boost::asio::mutable_buffer>::value,
|
|
||||||
boost::asio::mutable_buffer,
|
|
||||||
boost::asio::const_buffer>::type;
|
|
||||||
|
|
||||||
#if GENERATING_DOCS
|
|
||||||
/// A bidirectional iterator type that may be used to read elements.
|
|
||||||
using const_iterator = implementation_defined;
|
|
||||||
|
|
||||||
#else
|
|
||||||
class const_iterator;
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/// Move constructor.
|
|
||||||
prepared_buffers(prepared_buffers&&);
|
|
||||||
|
|
||||||
/// Copy constructor.
|
|
||||||
prepared_buffers(prepared_buffers const&);
|
|
||||||
|
|
||||||
/// Move assignment.
|
|
||||||
prepared_buffers& operator=(prepared_buffers&&);
|
|
||||||
|
|
||||||
/// Copy assignment.
|
|
||||||
prepared_buffers& operator=(prepared_buffers const&);
|
|
||||||
|
|
||||||
/** Construct a shortened buffer sequence.
|
|
||||||
|
|
||||||
@param n The maximum number of bytes in the wrapped
|
|
||||||
sequence. If this is larger than the size of passed,
|
|
||||||
buffers, the resulting sequence will represent the
|
|
||||||
entire input sequence.
|
|
||||||
|
|
||||||
@param buffers The buffer sequence to adapt. A copy of
|
|
||||||
the sequence will be made, but ownership of the underlying
|
|
||||||
memory is not transferred.
|
|
||||||
*/
|
|
||||||
prepared_buffers(std::size_t n, BufferSequence const& buffers);
|
|
||||||
|
|
||||||
/// Get a bidirectional iterator to the first element.
|
|
||||||
const_iterator
|
|
||||||
begin() const;
|
|
||||||
|
|
||||||
/// Get a bidirectional iterator to one past the last element.
|
|
||||||
const_iterator
|
|
||||||
end() const;
|
|
||||||
};
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
/** Return a shortened buffer sequence.
|
/** Return a shortened buffer sequence.
|
||||||
|
|
||||||
This function returns a new buffer sequence which adapts the
|
This function returns a new buffer sequence which adapts the
|
||||||
@ -171,11 +36,17 @@ public:
|
|||||||
memory is not transferred.
|
memory is not transferred.
|
||||||
*/
|
*/
|
||||||
template<class BufferSequence>
|
template<class BufferSequence>
|
||||||
prepared_buffers<BufferSequence>
|
#if GENERATING_DOCS
|
||||||
prepare_buffers(std::size_t n, BufferSequence const& buffers);
|
implementation_defined
|
||||||
|
#else
|
||||||
|
inline
|
||||||
|
detail::prepared_buffers<BufferSequence>
|
||||||
|
#endif
|
||||||
|
prepare_buffers(std::size_t n, BufferSequence const& buffers)
|
||||||
|
{
|
||||||
|
return detail::prepared_buffers<BufferSequence>(n, buffers);
|
||||||
|
}
|
||||||
|
|
||||||
} // beast
|
} // beast
|
||||||
|
|
||||||
#include <beast/core/impl/prepare_buffers.ipp>
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Reference in New Issue
Block a user