mirror of
https://github.com/XRPLF/rippled.git
synced 2025-11-21 03:26:01 +00:00
* Fix warnings * Port cmake scripts to linux * Add command line options for running test suites * Add examples to CMakeLists * Return std::uint64_t from writer::content_length * basic_parser::write takes asio::const_buffer instead of pointer and size * Turn message test back on now that it passes * Rename to http::headers, use std::allocator, remove http_headers * http::message::method is now a string * Refactor to_string for ConstBufferSequence * Remove chunk_encode from the public interface * Initialize members for default constructed iterators * Disallow default construction for dependent buffer sequences Refactor http::message serialization: * Serialization no longer creates a copy of the headers and modifies them * New function prepare(), sets Connection, Transfer-Encoding, Content-Length based on the body attributes and caller options. Callers can use prepare() to have the fields set automatically, or they can set the fields manually. * Use write for operator<< * Tests for serialization
64 lines
1.8 KiB
C++
64 lines
1.8 KiB
C++
//
|
|
// 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_WRITE_STREAMBUF_HPP
|
|
#define BEAST_WRITE_STREAMBUF_HPP
|
|
|
|
#include <beast/type_check.hpp>
|
|
#include <beast/detail/write_streambuf.hpp>
|
|
#include <type_traits>
|
|
#include <utility>
|
|
|
|
namespace beast {
|
|
|
|
/** Write to a Streambuf.
|
|
|
|
This function appends the serialized representation of each provided
|
|
argument into the stream buffer. It is capable of converting the
|
|
following types of arguments:
|
|
|
|
@li `boost::asio::const_buffer`
|
|
|
|
@li `boost::asio::mutable_buffer`
|
|
|
|
@li A type for which the call to `boost::asio::buffer()` is defined
|
|
|
|
@li A type meeting the requirements of `ConstBufferSequence`
|
|
|
|
@li A type meeting the requirements of `MutableBufferSequence`
|
|
|
|
For all types not listed above, the function will invoke
|
|
`boost::lexical_cast` on the argument in an attempt to convert to
|
|
a string, which is then appended to the stream buffer.
|
|
|
|
When this function serializes numbers, it converts them to
|
|
their text representation as if by a call to `std::to_string`.
|
|
|
|
@param streambuf The stream buffer to write to.
|
|
|
|
@param args A list of one or more arguments to write.
|
|
|
|
@throws unspecified Any exceptions thrown by `boost::lexical_cast`.
|
|
|
|
@note This function participates in overload resolution only if
|
|
the `streambuf` parameter meets the requirements of Streambuf.
|
|
*/
|
|
template<class Streambuf, class... Args>
|
|
#if GENERATING_DOCS
|
|
void
|
|
#else
|
|
typename std::enable_if<is_Streambuf<Streambuf>::value>::type
|
|
#endif
|
|
write(Streambuf& streambuf, Args const&... args)
|
|
{
|
|
detail::write_streambuf(streambuf, args...);
|
|
}
|
|
|
|
} // beast
|
|
|
|
#endif
|