Additional constructors for consuming_buffers

This commit is contained in:
Vinnie Falco
2017-05-20 19:46:30 -07:00
parent 384b5d53e7
commit 39697ea37f
4 changed files with 72 additions and 3 deletions

View File

@ -4,6 +4,7 @@ Version 43
* Fix strict aliasing warnings in buffers_view
* Tidy up buffer_prefix overloads and test
* Add write limit to test::string_ostream
* Additional constructors for consuming_buffers
--------------------------------------------------------------------------------

View File

@ -10,6 +10,7 @@
#include <beast/config.hpp>
#include <boost/asio/buffer.hpp>
#include <boost/optional.hpp>
#include <cstdint>
#include <iterator>
#include <type_traits>
@ -78,6 +79,9 @@ public:
#endif
/// Default constructor.
consuming_buffers();
/// Move constructor.
consuming_buffers(consuming_buffers&&);
@ -98,6 +102,13 @@ public:
explicit
consuming_buffers(BufferSequence const& buffers);
/** Construct a buffer sequence in-place.
@param args Arguments forwarded to the contained buffers constructor.
*/
template<class... Args>
consuming_buffers(boost::in_place_init_t, Args&&... args);
/// Get a bidirectional iterator to the first element.
const_iterator
begin() const;

View File

@ -109,6 +109,14 @@ private:
}
};
template<class BufferSequence>
consuming_buffers<BufferSequence>::
consuming_buffers()
: begin_(bs_.begin())
, end_(bs_.end())
{
}
template<class BufferSequence>
consuming_buffers<BufferSequence>::
consuming_buffers(consuming_buffers&& other)
@ -167,6 +175,21 @@ consuming_buffers(BufferSequence const& bs)
"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
auto

View File

@ -9,6 +9,7 @@
#include <beast/core/consuming_buffers.hpp>
#include "buffer_test.hpp"
#include <beast/core/buffer_cat.hpp>
#include <beast/core/ostream.hpp>
#include <beast/unit_test/suite.hpp>
#include <boost/asio/buffer.hpp>
@ -56,7 +57,8 @@ public:
BEAST_EXPECT(test::size_rev_post(buffers) == n);
}
void testMatrix()
void
testMatrix()
{
using boost::asio::buffer;
using boost::asio::const_buffer;
@ -98,8 +100,37 @@ public:
}
}}}}
}
void
testDefaultCtor()
{
class test_buffer : public boost::asio::const_buffers_1
{
public:
test_buffer()
: boost::asio::const_buffers_1("\r\n", 2)
{
}
};
void testNullBuffers()
consuming_buffers<test_buffer> cb;
BEAST_EXPECT(to_string(cb) == "\r\n");
}
void
testInPlace()
{
consuming_buffers<buffers_view<
boost::asio::const_buffers_1,
boost::asio::const_buffers_1>> cb(
boost::in_place_init,
boost::asio::const_buffers_1("\r", 1),
boost::asio::const_buffers_1("\n", 1));
BEAST_EXPECT(to_string(cb) == "\r\n");
}
void
testNullBuffers()
{
using boost::asio::buffer_copy;
using boost::asio::buffer_size;
@ -112,7 +143,8 @@ public:
BEAST_EXPECT(buffer_copy(cb2, cb) == 0);
}
void testIterator()
void
testIterator()
{
using boost::asio::const_buffer;
std::array<const_buffer, 3> ba;
@ -126,6 +158,8 @@ public:
void run() override
{
testMatrix();
testDefaultCtor();
testInPlace();
testNullBuffers();
testIterator();
}