mirror of
https://github.com/boostorg/beast.git
synced 2025-07-30 04:47:29 +02:00
consuming_buffers members and coverage
This commit is contained in:
@ -3,6 +3,7 @@ Version 54:
|
|||||||
* static_buffer coverage
|
* static_buffer coverage
|
||||||
* flat_buffer coverage
|
* flat_buffer coverage
|
||||||
* multi_buffer coverage
|
* multi_buffer coverage
|
||||||
|
* consuming_buffers members and coverage
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -80,21 +80,15 @@ public:
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/// Default constructor.
|
/// Constructor
|
||||||
consuming_buffers();
|
consuming_buffers();
|
||||||
|
|
||||||
/// Move constructor.
|
/// Move constructor
|
||||||
consuming_buffers(consuming_buffers&&);
|
consuming_buffers(consuming_buffers&&);
|
||||||
|
|
||||||
/// Copy constructor.
|
/// Copy constructor
|
||||||
consuming_buffers(consuming_buffers const&);
|
consuming_buffers(consuming_buffers const&);
|
||||||
|
|
||||||
/// Move assignment.
|
|
||||||
consuming_buffers& operator=(consuming_buffers&&);
|
|
||||||
|
|
||||||
/// Copy assignment.
|
|
||||||
consuming_buffers& operator=(consuming_buffers const&);
|
|
||||||
|
|
||||||
/** Construct to represent a buffer sequence.
|
/** Construct to represent a buffer sequence.
|
||||||
|
|
||||||
A copy of the buffer sequence is made. Ownership of the
|
A copy of the buffer sequence is made. Ownership of the
|
||||||
@ -110,6 +104,12 @@ public:
|
|||||||
template<class... Args>
|
template<class... Args>
|
||||||
consuming_buffers(boost::in_place_init_t, Args&&... args);
|
consuming_buffers(boost::in_place_init_t, Args&&... args);
|
||||||
|
|
||||||
|
/// Move assignment
|
||||||
|
consuming_buffers& operator=(consuming_buffers&&);
|
||||||
|
|
||||||
|
/// Copy assignmen
|
||||||
|
consuming_buffers& operator=(consuming_buffers const&);
|
||||||
|
|
||||||
/// Get a bidirectional iterator to the first element.
|
/// Get a bidirectional iterator to the first element.
|
||||||
const_iterator
|
const_iterator
|
||||||
begin() const;
|
begin() const;
|
||||||
|
@ -17,13 +17,13 @@
|
|||||||
|
|
||||||
namespace beast {
|
namespace beast {
|
||||||
|
|
||||||
template<class BufferSequence>
|
template<class Buffers>
|
||||||
class consuming_buffers<BufferSequence>::const_iterator
|
class consuming_buffers<Buffers>::const_iterator
|
||||||
{
|
{
|
||||||
friend class consuming_buffers<BufferSequence>;
|
friend class consuming_buffers<Buffers>;
|
||||||
|
|
||||||
using iter_type =
|
using iter_type =
|
||||||
typename BufferSequence::const_iterator;
|
typename Buffers::const_iterator;
|
||||||
|
|
||||||
iter_type it_;
|
iter_type it_;
|
||||||
consuming_buffers const* b_ = nullptr;
|
consuming_buffers const* b_ = nullptr;
|
||||||
@ -109,16 +109,18 @@ private:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template<class BufferSequence>
|
//------------------------------------------------------------------------------
|
||||||
consuming_buffers<BufferSequence>::
|
|
||||||
|
template<class Buffers>
|
||||||
|
consuming_buffers<Buffers>::
|
||||||
consuming_buffers()
|
consuming_buffers()
|
||||||
: begin_(bs_.begin())
|
: begin_(bs_.begin())
|
||||||
, end_(bs_.end())
|
, end_(bs_.end())
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class BufferSequence>
|
template<class Buffers>
|
||||||
consuming_buffers<BufferSequence>::
|
consuming_buffers<Buffers>::
|
||||||
consuming_buffers(consuming_buffers&& other)
|
consuming_buffers(consuming_buffers&& other)
|
||||||
: consuming_buffers(std::move(other),
|
: consuming_buffers(std::move(other),
|
||||||
std::distance<iter_type>(
|
std::distance<iter_type>(
|
||||||
@ -126,8 +128,8 @@ consuming_buffers(consuming_buffers&& other)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class BufferSequence>
|
template<class Buffers>
|
||||||
consuming_buffers<BufferSequence>::
|
consuming_buffers<Buffers>::
|
||||||
consuming_buffers(consuming_buffers const& other)
|
consuming_buffers(consuming_buffers const& other)
|
||||||
: consuming_buffers(other,
|
: consuming_buffers(other,
|
||||||
std::distance<iter_type>(
|
std::distance<iter_type>(
|
||||||
@ -135,9 +137,36 @@ consuming_buffers(consuming_buffers const& other)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class BufferSequence>
|
template<class Buffers>
|
||||||
|
consuming_buffers<Buffers>::
|
||||||
|
consuming_buffers(Buffers const& bs)
|
||||||
|
: bs_(bs)
|
||||||
|
, begin_(bs_.begin())
|
||||||
|
{
|
||||||
|
static_assert(
|
||||||
|
is_const_buffer_sequence<Buffers>::value||
|
||||||
|
is_mutable_buffer_sequence<Buffers>::value,
|
||||||
|
"BufferSequence requirements not met");
|
||||||
|
}
|
||||||
|
|
||||||
|
template<class Buffers>
|
||||||
|
template<class... Args>
|
||||||
|
consuming_buffers<Buffers>::
|
||||||
|
consuming_buffers(boost::in_place_init_t, Args&&... args)
|
||||||
|
: bs_(std::forward<Args>(args)...)
|
||||||
|
, begin_(bs_.begin())
|
||||||
|
, end_(bs_.end())
|
||||||
|
{
|
||||||
|
static_assert(sizeof...(Args) > 0,
|
||||||
|
"Missing constructor arguments");
|
||||||
|
static_assert(
|
||||||
|
std::is_constructible<Buffers, Args...>::value,
|
||||||
|
"Buffers not constructible from arguments");
|
||||||
|
}
|
||||||
|
|
||||||
|
template<class Buffers>
|
||||||
auto
|
auto
|
||||||
consuming_buffers<BufferSequence>::
|
consuming_buffers<Buffers>::
|
||||||
operator=(consuming_buffers&& other) ->
|
operator=(consuming_buffers&& other) ->
|
||||||
consuming_buffers&
|
consuming_buffers&
|
||||||
{
|
{
|
||||||
@ -149,9 +178,9 @@ operator=(consuming_buffers&& other) ->
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class BufferSequence>
|
template<class Buffers>
|
||||||
auto
|
auto
|
||||||
consuming_buffers<BufferSequence>::
|
consuming_buffers<Buffers>::
|
||||||
operator=(consuming_buffers const& other) ->
|
operator=(consuming_buffers const& other) ->
|
||||||
consuming_buffers&
|
consuming_buffers&
|
||||||
{
|
{
|
||||||
@ -163,56 +192,29 @@ operator=(consuming_buffers const& other) ->
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class BufferSequence>
|
template<class Buffers>
|
||||||
consuming_buffers<BufferSequence>::
|
|
||||||
consuming_buffers(BufferSequence const& bs)
|
|
||||||
: bs_(bs)
|
|
||||||
, begin_(bs_.begin())
|
|
||||||
{
|
|
||||||
static_assert(
|
|
||||||
is_const_buffer_sequence<BufferSequence>::value||
|
|
||||||
is_mutable_buffer_sequence<BufferSequence>::value,
|
|
||||||
"BufferSequence requirements not met");
|
|
||||||
}
|
|
||||||
|
|
||||||
template<class BufferSequence>
|
|
||||||
template<class... Args>
|
|
||||||
consuming_buffers<BufferSequence>::
|
|
||||||
consuming_buffers(boost::in_place_init_t, Args&&... args)
|
|
||||||
: bs_(std::forward<Args>(args)...)
|
|
||||||
, begin_(bs_.begin())
|
|
||||||
, end_(bs_.end())
|
|
||||||
{
|
|
||||||
static_assert(sizeof...(Args) > 0,
|
|
||||||
"Missing constructor arguments");
|
|
||||||
static_assert(
|
|
||||||
std::is_constructible<BufferSequence, Args...>::value,
|
|
||||||
"BufferSequence is not constructible from arguments");
|
|
||||||
}
|
|
||||||
|
|
||||||
template<class BufferSequence>
|
|
||||||
inline
|
inline
|
||||||
auto
|
auto
|
||||||
consuming_buffers<BufferSequence>::
|
consuming_buffers<Buffers>::
|
||||||
begin() const ->
|
begin() const ->
|
||||||
const_iterator
|
const_iterator
|
||||||
{
|
{
|
||||||
return const_iterator{*this, begin_};
|
return const_iterator{*this, begin_};
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class BufferSequence>
|
template<class Buffers>
|
||||||
inline
|
inline
|
||||||
auto
|
auto
|
||||||
consuming_buffers<BufferSequence>::
|
consuming_buffers<Buffers>::
|
||||||
end() const ->
|
end() const ->
|
||||||
const_iterator
|
const_iterator
|
||||||
{
|
{
|
||||||
return const_iterator{*this, bs_.end()};
|
return const_iterator{*this, bs_.end()};
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class BufferSequence>
|
template<class Buffers>
|
||||||
void
|
void
|
||||||
consuming_buffers<BufferSequence>::
|
consuming_buffers<Buffers>::
|
||||||
consume(std::size_t n)
|
consume(std::size_t n)
|
||||||
{
|
{
|
||||||
using boost::asio::buffer_size;
|
using boost::asio::buffer_size;
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
#include <beast/core/consuming_buffers.hpp>
|
#include <beast/core/consuming_buffers.hpp>
|
||||||
|
|
||||||
#include "buffer_test.hpp"
|
#include "buffer_test.hpp"
|
||||||
|
|
||||||
#include <beast/core/buffer_cat.hpp>
|
#include <beast/core/buffer_cat.hpp>
|
||||||
#include <beast/core/ostream.hpp>
|
#include <beast/core/ostream.hpp>
|
||||||
#include <beast/unit_test/suite.hpp>
|
#include <beast/unit_test/suite.hpp>
|
||||||
@ -20,15 +21,6 @@ namespace beast {
|
|||||||
class consuming_buffers_test : public beast::unit_test::suite
|
class consuming_buffers_test : public beast::unit_test::suite
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
template<class ConstBufferSequence>
|
|
||||||
static
|
|
||||||
std::string
|
|
||||||
to_string(ConstBufferSequence const& bs)
|
|
||||||
{
|
|
||||||
return boost::lexical_cast<
|
|
||||||
std::string>(buffers(bs));
|
|
||||||
}
|
|
||||||
|
|
||||||
template<class BufferSequence>
|
template<class BufferSequence>
|
||||||
static
|
static
|
||||||
consuming_buffers<BufferSequence>
|
consuming_buffers<BufferSequence>
|
||||||
@ -44,6 +36,7 @@ public:
|
|||||||
bool
|
bool
|
||||||
eq(Buffers1 const& lhs, Buffers2 const& rhs)
|
eq(Buffers1 const& lhs, Buffers2 const& rhs)
|
||||||
{
|
{
|
||||||
|
using namespace test;
|
||||||
return to_string(lhs) == to_string(rhs);
|
return to_string(lhs) == to_string(rhs);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57,9 +50,24 @@ public:
|
|||||||
BEAST_EXPECT(test::size_rev_post(buffers) == n);
|
BEAST_EXPECT(test::size_rev_post(buffers) == n);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
testMembers()
|
||||||
|
{
|
||||||
|
char buf[12];
|
||||||
|
consuming_buffers<
|
||||||
|
boost::asio::const_buffers_1> cb1{
|
||||||
|
boost::in_place_init, buf, sizeof(buf)};
|
||||||
|
consuming_buffers<
|
||||||
|
boost::asio::const_buffers_1> cb2{
|
||||||
|
boost::in_place_init, nullptr, 0};
|
||||||
|
cb2 = cb1;
|
||||||
|
cb1 = std::move(cb2);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
testMatrix()
|
testMatrix()
|
||||||
{
|
{
|
||||||
|
using namespace test;
|
||||||
using boost::asio::buffer;
|
using boost::asio::buffer;
|
||||||
using boost::asio::const_buffer;
|
using boost::asio::const_buffer;
|
||||||
char buf[12];
|
char buf[12];
|
||||||
@ -104,6 +112,7 @@ public:
|
|||||||
void
|
void
|
||||||
testDefaultCtor()
|
testDefaultCtor()
|
||||||
{
|
{
|
||||||
|
using namespace test;
|
||||||
class test_buffer : public boost::asio::const_buffers_1
|
class test_buffer : public boost::asio::const_buffers_1
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -120,6 +129,7 @@ public:
|
|||||||
void
|
void
|
||||||
testInPlace()
|
testInPlace()
|
||||||
{
|
{
|
||||||
|
using namespace test;
|
||||||
consuming_buffers<buffer_cat_view<
|
consuming_buffers<buffer_cat_view<
|
||||||
boost::asio::const_buffers_1,
|
boost::asio::const_buffers_1,
|
||||||
boost::asio::const_buffers_1>> cb(
|
boost::asio::const_buffers_1>> cb(
|
||||||
@ -157,6 +167,7 @@ public:
|
|||||||
|
|
||||||
void run() override
|
void run() override
|
||||||
{
|
{
|
||||||
|
testMembers();
|
||||||
testMatrix();
|
testMatrix();
|
||||||
testDefaultCtor();
|
testDefaultCtor();
|
||||||
testInPlace();
|
testInPlace();
|
||||||
|
Reference in New Issue
Block a user