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 * Fix strict aliasing warnings in buffers_view
* Tidy up buffer_prefix overloads and test * Tidy up buffer_prefix overloads and test
* Add write limit to test::string_ostream * Add write limit to test::string_ostream
* Additional constructors for consuming_buffers
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------

View File

@ -10,6 +10,7 @@
#include <beast/config.hpp> #include <beast/config.hpp>
#include <boost/asio/buffer.hpp> #include <boost/asio/buffer.hpp>
#include <boost/optional.hpp>
#include <cstdint> #include <cstdint>
#include <iterator> #include <iterator>
#include <type_traits> #include <type_traits>
@ -78,6 +79,9 @@ public:
#endif #endif
/// Default constructor.
consuming_buffers();
/// Move constructor. /// Move constructor.
consuming_buffers(consuming_buffers&&); consuming_buffers(consuming_buffers&&);
@ -98,6 +102,13 @@ public:
explicit explicit
consuming_buffers(BufferSequence const& buffers); 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. /// Get a bidirectional iterator to the first element.
const_iterator const_iterator
begin() const; 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> template<class BufferSequence>
consuming_buffers<BufferSequence>:: consuming_buffers<BufferSequence>::
consuming_buffers(consuming_buffers&& other) consuming_buffers(consuming_buffers&& other)
@ -167,6 +175,21 @@ consuming_buffers(BufferSequence const& bs)
"BufferSequence requirements not met"); "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> template<class BufferSequence>
inline inline
auto auto

View File

@ -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/ostream.hpp> #include <beast/core/ostream.hpp>
#include <beast/unit_test/suite.hpp> #include <beast/unit_test/suite.hpp>
#include <boost/asio/buffer.hpp> #include <boost/asio/buffer.hpp>
@ -56,7 +57,8 @@ public:
BEAST_EXPECT(test::size_rev_post(buffers) == n); BEAST_EXPECT(test::size_rev_post(buffers) == n);
} }
void testMatrix() void
testMatrix()
{ {
using boost::asio::buffer; using boost::asio::buffer;
using boost::asio::const_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_copy;
using boost::asio::buffer_size; using boost::asio::buffer_size;
@ -112,7 +143,8 @@ public:
BEAST_EXPECT(buffer_copy(cb2, cb) == 0); BEAST_EXPECT(buffer_copy(cb2, cb) == 0);
} }
void testIterator() void
testIterator()
{ {
using boost::asio::const_buffer; using boost::asio::const_buffer;
std::array<const_buffer, 3> ba; std::array<const_buffer, 3> ba;
@ -126,6 +158,8 @@ public:
void run() override void run() override
{ {
testMatrix(); testMatrix();
testDefaultCtor();
testInPlace();
testNullBuffers(); testNullBuffers();
testIterator(); testIterator();
} }