mirror of
https://github.com/boostorg/beast.git
synced 2025-08-02 14:24:31 +02:00
String comparisons are public interfaces
This commit is contained in:
@@ -1,3 +1,9 @@
|
|||||||
|
Version 60:
|
||||||
|
|
||||||
|
* String comparisons are public interfaces
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
Version 59:
|
Version 59:
|
||||||
|
|
||||||
* Integrated Beast INTERFACE (cmake)
|
* Integrated Beast INTERFACE (cmake)
|
||||||
|
@@ -142,10 +142,10 @@
|
|||||||
<colspec colname="e"/>
|
<colspec colname="e"/>
|
||||||
<thead>
|
<thead>
|
||||||
<row>
|
<row>
|
||||||
<entry valign="center" namest="a" nameend="d">
|
<entry valign="center" namest="a" nameend="e">
|
||||||
<bridgehead renderas="sect2">Core</bridgehead>
|
<bridgehead renderas="sect2">Core</bridgehead>
|
||||||
</entry>
|
</entry>
|
||||||
<entry valign="center" namest="e" nameend="e">
|
<entry valign="center" namest="f" nameend="f">
|
||||||
<bridgehead renderas="sect2">ZLib</bridgehead>
|
<bridgehead renderas="sect2">ZLib</bridgehead>
|
||||||
</entry>
|
</entry>
|
||||||
</row>
|
</row>
|
||||||
@@ -169,10 +169,17 @@
|
|||||||
<member><link linkend="beast.ref.beast__error_category">error_category</link></member>
|
<member><link linkend="beast.ref.beast__error_category">error_category</link></member>
|
||||||
<member><link linkend="beast.ref.beast__error_code">error_code</link></member>
|
<member><link linkend="beast.ref.beast__error_code">error_code</link></member>
|
||||||
<member><link linkend="beast.ref.beast__error_condition">error_condition</link></member>
|
<member><link linkend="beast.ref.beast__error_condition">error_condition</link></member>
|
||||||
|
</simplelist>
|
||||||
|
</entry>
|
||||||
|
<entry valign="top">
|
||||||
|
<bridgehead renderas="sect3"> </bridgehead>
|
||||||
|
<simplelist type="vert" columns="1">
|
||||||
<member><link linkend="beast.ref.beast__flat_buffer">flat_buffer</link></member>
|
<member><link linkend="beast.ref.beast__flat_buffer">flat_buffer</link></member>
|
||||||
<member><link linkend="beast.ref.beast__handler_alloc">handler_alloc</link></member>
|
<member><link linkend="beast.ref.beast__handler_alloc">handler_alloc</link></member>
|
||||||
<member><link linkend="beast.ref.beast__handler_ptr">handler_ptr</link></member>
|
<member><link linkend="beast.ref.beast__handler_ptr">handler_ptr</link></member>
|
||||||
<member><link linkend="beast.ref.beast__handler_type">handler_type</link></member>
|
<member><link linkend="beast.ref.beast__handler_type">handler_type</link></member>
|
||||||
|
<member><link linkend="beast.ref.beast__iequal">iequal</link></member>
|
||||||
|
<member><link linkend="beast.ref.beast__iless">iless</link></member>
|
||||||
<member><link linkend="beast.ref.beast__multi_buffer">multi_buffer</link></member>
|
<member><link linkend="beast.ref.beast__multi_buffer">multi_buffer</link></member>
|
||||||
<member><link linkend="beast.ref.beast__static_buffer">static_buffer</link></member>
|
<member><link linkend="beast.ref.beast__static_buffer">static_buffer</link></member>
|
||||||
<member><link linkend="beast.ref.beast__static_buffer_n">static_buffer_n</link></member>
|
<member><link linkend="beast.ref.beast__static_buffer_n">static_buffer_n</link></member>
|
||||||
@@ -189,6 +196,7 @@
|
|||||||
<member><link linkend="beast.ref.beast__buffer_cat">buffer_cat</link></member>
|
<member><link linkend="beast.ref.beast__buffer_cat">buffer_cat</link></member>
|
||||||
<member><link linkend="beast.ref.beast__buffer_prefix">buffer_prefix</link></member>
|
<member><link linkend="beast.ref.beast__buffer_prefix">buffer_prefix</link></member>
|
||||||
<member><link linkend="beast.ref.beast__buffers">buffers</link></member>
|
<member><link linkend="beast.ref.beast__buffers">buffers</link></member>
|
||||||
|
<member><link linkend="beast.ref.beast__iequals">iequals</link></member>
|
||||||
<member><link linkend="beast.ref.beast__ostream">ostream</link></member>
|
<member><link linkend="beast.ref.beast__ostream">ostream</link></member>
|
||||||
<member><link linkend="beast.ref.beast__read_size">read_size</link></member>
|
<member><link linkend="beast.ref.beast__read_size">read_size</link></member>
|
||||||
<member><link linkend="beast.ref.beast__read_size_or_throw">read_size_or_throw</link></member>
|
<member><link linkend="beast.ref.beast__read_size_or_throw">read_size_or_throw</link></member>
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
#ifndef BEAST_EXAMPLE_HTTP_MIME_TYPE_H_INCLUDED
|
#ifndef BEAST_EXAMPLE_HTTP_MIME_TYPE_H_INCLUDED
|
||||||
#define BEAST_EXAMPLE_HTTP_MIME_TYPE_H_INCLUDED
|
#define BEAST_EXAMPLE_HTTP_MIME_TYPE_H_INCLUDED
|
||||||
|
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <boost/filesystem/path.hpp>
|
#include <boost/filesystem/path.hpp>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
@@ -11,7 +11,7 @@
|
|||||||
#include <beast/core/async_result.hpp>
|
#include <beast/core/async_result.hpp>
|
||||||
#include <beast/core/bind_handler.hpp>
|
#include <beast/core/bind_handler.hpp>
|
||||||
#include <beast/core/flat_buffer.hpp>
|
#include <beast/core/flat_buffer.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/type_traits.hpp>
|
#include <beast/core/type_traits.hpp>
|
||||||
#include <beast/websocket/teardown.hpp>
|
#include <beast/websocket/teardown.hpp>
|
||||||
#include <beast/test/fail_counter.hpp>
|
#include <beast/test/fail_counter.hpp>
|
||||||
|
@@ -28,7 +28,7 @@
|
|||||||
#include <beast/core/static_buffer.hpp>
|
#include <beast/core/static_buffer.hpp>
|
||||||
#include <beast/core/static_string.hpp>
|
#include <beast/core/static_string.hpp>
|
||||||
#include <beast/core/string_param.hpp>
|
#include <beast/core/string_param.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/type_traits.hpp>
|
#include <beast/core/type_traits.hpp>
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -1,105 +0,0 @@
|
|||||||
//
|
|
||||||
// Copyright (c) 2013-2017 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_DETAIL_CI_CHAR_TRAITS_HPP
|
|
||||||
#define BEAST_DETAIL_CI_CHAR_TRAITS_HPP
|
|
||||||
|
|
||||||
#include <beast/core/string_view.hpp>
|
|
||||||
#include <boost/range/algorithm/equal.hpp>
|
|
||||||
|
|
||||||
namespace beast {
|
|
||||||
namespace detail {
|
|
||||||
|
|
||||||
inline
|
|
||||||
char
|
|
||||||
tolower(signed char c)
|
|
||||||
{
|
|
||||||
static unsigned char constexpr tab[256] = {
|
|
||||||
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
|
|
||||||
16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
|
|
||||||
32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
|
|
||||||
48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
|
|
||||||
64, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111,
|
|
||||||
112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 91, 92, 93, 94, 95,
|
|
||||||
96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111,
|
|
||||||
112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, 124, 125, 126, 127,
|
|
||||||
128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143,
|
|
||||||
144, 145, 146, 147, 148, 149, 150, 151, 152, 153, 154, 155, 156, 157, 158, 159,
|
|
||||||
160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175,
|
|
||||||
176, 177, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187, 188, 189, 190, 191,
|
|
||||||
192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207,
|
|
||||||
208, 209, 210, 211, 212, 213, 214, 215, 216, 217, 218, 219, 220, 221, 222, 223,
|
|
||||||
224, 225, 226, 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239,
|
|
||||||
240, 241, 242, 243, 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, 255
|
|
||||||
};
|
|
||||||
return static_cast<char>(
|
|
||||||
tab[static_cast<unsigned char>(c)]);
|
|
||||||
}
|
|
||||||
|
|
||||||
template<std::size_t N>
|
|
||||||
inline
|
|
||||||
string_view
|
|
||||||
string_helper(const char (&s)[N])
|
|
||||||
{
|
|
||||||
return string_view{s, N-1};
|
|
||||||
}
|
|
||||||
|
|
||||||
template<class T>
|
|
||||||
inline
|
|
||||||
T const&
|
|
||||||
string_helper(T const& t)
|
|
||||||
{
|
|
||||||
return t;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Case-insensitive less
|
|
||||||
struct ci_less
|
|
||||||
{
|
|
||||||
static bool const is_transparent = true;
|
|
||||||
|
|
||||||
template<class S1, class S2>
|
|
||||||
bool
|
|
||||||
operator()(S1 const& lhs, S2 const& rhs) const noexcept
|
|
||||||
{
|
|
||||||
using std::begin;
|
|
||||||
using std::end;
|
|
||||||
auto const s1 = string_helper(lhs);
|
|
||||||
auto const s2 = string_helper(rhs);
|
|
||||||
return std::lexicographical_compare(
|
|
||||||
begin(s1), end(s1), begin(s2), end(s2),
|
|
||||||
[](char lhs, char rhs)
|
|
||||||
{
|
|
||||||
return tolower(lhs) < tolower(rhs);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// Case-insensitive equal
|
|
||||||
struct ci_equal_pred
|
|
||||||
{
|
|
||||||
bool
|
|
||||||
operator()(char c1, char c2) const noexcept
|
|
||||||
{
|
|
||||||
return tolower(c1) == tolower(c2);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// Case-insensitive equal
|
|
||||||
template<class S1, class S2>
|
|
||||||
bool
|
|
||||||
ci_equal(S1 const& lhs, S2 const& rhs)
|
|
||||||
{
|
|
||||||
return boost::range::equal(
|
|
||||||
string_helper(lhs), string_helper(rhs),
|
|
||||||
ci_equal_pred{});
|
|
||||||
}
|
|
||||||
|
|
||||||
} // detail
|
|
||||||
} // beast
|
|
||||||
|
|
||||||
#endif
|
|
@@ -8,7 +8,7 @@
|
|||||||
#ifndef BEAST_DETAIL_STATIC_STRING_HPP
|
#ifndef BEAST_DETAIL_STATIC_STRING_HPP
|
||||||
#define BEAST_DETAIL_STATIC_STRING_HPP
|
#define BEAST_DETAIL_STATIC_STRING_HPP
|
||||||
|
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
|
|
||||||
|
@@ -9,7 +9,7 @@
|
|||||||
#define BEAST_STATIC_STRING_HPP
|
#define BEAST_STATIC_STRING_HPP
|
||||||
|
|
||||||
#include <beast/config.hpp>
|
#include <beast/config.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/detail/static_string.hpp>
|
#include <beast/core/detail/static_string.hpp>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
104
include/beast/core/string.hpp
Normal file
104
include/beast/core/string.hpp
Normal file
@@ -0,0 +1,104 @@
|
|||||||
|
//
|
||||||
|
// Copyright (c) 2013-2017 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_STRING_HPP
|
||||||
|
#define BEAST_STRING_HPP
|
||||||
|
|
||||||
|
#include <boost/spirit/home/support/char_encoding/ascii.hpp>
|
||||||
|
#include <boost/utility/string_ref.hpp>
|
||||||
|
|
||||||
|
namespace beast {
|
||||||
|
|
||||||
|
/// The type of string view used by the library
|
||||||
|
using string_view = boost::string_ref;
|
||||||
|
|
||||||
|
/// The type of basic string view used by the library
|
||||||
|
template<class CharT, class Traits>
|
||||||
|
using basic_string_view =
|
||||||
|
boost::basic_string_ref<CharT, Traits>;
|
||||||
|
|
||||||
|
namespace detail {
|
||||||
|
|
||||||
|
template<class = void>
|
||||||
|
bool
|
||||||
|
iequals(
|
||||||
|
beast::string_view const& lhs,
|
||||||
|
beast::string_view const& rhs)
|
||||||
|
{
|
||||||
|
auto n = lhs.size();
|
||||||
|
if(rhs.size() != n)
|
||||||
|
return false;
|
||||||
|
auto p1 = lhs.data();
|
||||||
|
auto p2 = rhs.data();
|
||||||
|
using namespace boost::spirit::char_encoding;
|
||||||
|
while(n--)
|
||||||
|
if(ascii::tolower(*p1) != ascii::tolower(*p2))
|
||||||
|
return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // detail
|
||||||
|
|
||||||
|
/** Returns `true` if two strings are equal, using a case-insensitive comparison.
|
||||||
|
|
||||||
|
The case-comparison operation is defined only for low-ASCII characters.
|
||||||
|
|
||||||
|
@param lhs The string on the left side of the equality
|
||||||
|
|
||||||
|
@param rhs The string on the right side of the equality
|
||||||
|
*/
|
||||||
|
inline
|
||||||
|
bool
|
||||||
|
iequals(
|
||||||
|
beast::string_view const& lhs,
|
||||||
|
beast::string_view const& rhs)
|
||||||
|
{
|
||||||
|
return detail::iequals(lhs, rhs);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** A strictly less predicate for strings, using a case-insensitive comparison.
|
||||||
|
|
||||||
|
The case-comparison operation is defined only for low-ASCII characters.
|
||||||
|
*/
|
||||||
|
struct iless
|
||||||
|
{
|
||||||
|
bool
|
||||||
|
operator()(
|
||||||
|
beast::string_view const& lhs,
|
||||||
|
beast::string_view const& rhs) const
|
||||||
|
{
|
||||||
|
using std::begin;
|
||||||
|
using std::end;
|
||||||
|
using namespace boost::spirit::char_encoding;
|
||||||
|
return std::lexicographical_compare(
|
||||||
|
begin(lhs), end(lhs), begin(rhs), end(rhs),
|
||||||
|
[](char lhs, char rhs)
|
||||||
|
{
|
||||||
|
return ascii::tolower(lhs) < ascii::tolower(rhs);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/** A predicate for string equality, using a case-insensitive comparison.
|
||||||
|
|
||||||
|
The case-comparison operation is defined only for low-ASCII characters.
|
||||||
|
*/
|
||||||
|
struct iequal
|
||||||
|
{
|
||||||
|
bool
|
||||||
|
operator()(
|
||||||
|
beast::string_view const& lhs,
|
||||||
|
beast::string_view const& rhs) const
|
||||||
|
{
|
||||||
|
return iequals(lhs, rhs);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
} // beast
|
||||||
|
|
||||||
|
#endif
|
@@ -9,7 +9,7 @@
|
|||||||
#define BEAST_STRING_PARAM_HPP
|
#define BEAST_STRING_PARAM_HPP
|
||||||
|
|
||||||
#include <beast/config.hpp>
|
#include <beast/config.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/detail/static_ostream.hpp>
|
#include <beast/core/detail/static_ostream.hpp>
|
||||||
#include <beast/core/detail/type_traits.hpp>
|
#include <beast/core/detail/type_traits.hpp>
|
||||||
|
|
||||||
|
@@ -1,25 +0,0 @@
|
|||||||
//
|
|
||||||
// Copyright (c) 2013-2017 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_STRING_VIEW_HPP
|
|
||||||
#define BEAST_STRING_VIEW_HPP
|
|
||||||
|
|
||||||
#include <boost/utility/string_ref.hpp>
|
|
||||||
|
|
||||||
namespace beast {
|
|
||||||
|
|
||||||
/// The type of string view used by the library
|
|
||||||
using string_view = boost::string_ref;
|
|
||||||
|
|
||||||
/// The type of basic string view used by the library
|
|
||||||
template<class CharT, class Traits>
|
|
||||||
using basic_string_view =
|
|
||||||
boost::basic_string_ref<CharT, Traits>;
|
|
||||||
|
|
||||||
} // beast
|
|
||||||
|
|
||||||
#endif
|
|
@@ -10,7 +10,7 @@
|
|||||||
|
|
||||||
#include <beast/config.hpp>
|
#include <beast/config.hpp>
|
||||||
#include <beast/core/error.hpp>
|
#include <beast/core/error.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/http/field.hpp>
|
#include <beast/http/field.hpp>
|
||||||
#include <beast/http/verb.hpp>
|
#include <beast/http/verb.hpp>
|
||||||
#include <beast/http/detail/basic_parser.hpp>
|
#include <beast/http/detail/basic_parser.hpp>
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
#ifndef BEAST_HTTP_DETAIL_BASIC_PARSED_LIST_HPP
|
#ifndef BEAST_HTTP_DETAIL_BASIC_PARSED_LIST_HPP
|
||||||
#define BEAST_HTTP_DETAIL_BASIC_PARSED_LIST_HPP
|
#define BEAST_HTTP_DETAIL_BASIC_PARSED_LIST_HPP
|
||||||
|
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/detail/empty_base_optimization.hpp>
|
#include <beast/core/detail/empty_base_optimization.hpp>
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
|
@@ -8,8 +8,7 @@
|
|||||||
#ifndef BEAST_HTTP_DETAIL_BASIC_PARSER_HPP
|
#ifndef BEAST_HTTP_DETAIL_BASIC_PARSER_HPP
|
||||||
#define BEAST_HTTP_DETAIL_BASIC_PARSER_HPP
|
#define BEAST_HTTP_DETAIL_BASIC_PARSER_HPP
|
||||||
|
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/detail/ci_char_traits.hpp>
|
|
||||||
#include <beast/http/error.hpp>
|
#include <beast/http/error.hpp>
|
||||||
#include <beast/http/detail/rfc7230.hpp>
|
#include <beast/http/detail/rfc7230.hpp>
|
||||||
#include <boost/version.hpp>
|
#include <boost/version.hpp>
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
#ifndef BEAST_HTTP_DETAIL_RFC7230_HPP
|
#ifndef BEAST_HTTP_DETAIL_RFC7230_HPP
|
||||||
#define BEAST_HTTP_DETAIL_RFC7230_HPP
|
#define BEAST_HTTP_DETAIL_RFC7230_HPP
|
||||||
|
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
|
@@ -9,7 +9,7 @@
|
|||||||
#define BEAST_HTTP_FIELD_HPP
|
#define BEAST_HTTP_FIELD_HPP
|
||||||
|
|
||||||
#include <beast/config.hpp>
|
#include <beast/config.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <iosfwd>
|
#include <iosfwd>
|
||||||
|
|
||||||
namespace beast {
|
namespace beast {
|
||||||
|
@@ -10,8 +10,7 @@
|
|||||||
|
|
||||||
#include <beast/config.hpp>
|
#include <beast/config.hpp>
|
||||||
#include <beast/core/string_param.hpp>
|
#include <beast/core/string_param.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/detail/ci_char_traits.hpp>
|
|
||||||
#include <beast/http/field.hpp>
|
#include <beast/http/field.hpp>
|
||||||
#include <boost/asio/buffer.hpp>
|
#include <boost/asio/buffer.hpp>
|
||||||
#include <boost/intrusive/list.hpp>
|
#include <boost/intrusive/list.hpp>
|
||||||
@@ -94,15 +93,18 @@ public:
|
|||||||
value() const;
|
value() const;
|
||||||
};
|
};
|
||||||
|
|
||||||
/// A function that compares keys as LessThanComparable
|
/** A strictly less predicate for comparing keys, using a case-insensitive comparison.
|
||||||
struct key_compare : private beast::detail::ci_less
|
|
||||||
|
The case-comparison operation is defined only for low-ASCII characters.
|
||||||
|
*/
|
||||||
|
struct key_compare : beast::iless
|
||||||
{
|
{
|
||||||
/// Returns `true` if lhs is less than rhs using a strict ordering
|
/// Returns `true` if lhs is less than rhs using a strict ordering
|
||||||
template<class String>
|
template<class String>
|
||||||
bool
|
bool
|
||||||
operator()(String const& lhs, value_type const& rhs) const
|
operator()(String const& lhs, value_type const& rhs) const
|
||||||
{
|
{
|
||||||
return ci_less::operator()(lhs, rhs.name_string());
|
return iless::operator()(lhs, rhs.name_string());
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns `true` if lhs is less than rhs using a strict ordering
|
/// Returns `true` if lhs is less than rhs using a strict ordering
|
||||||
@@ -110,15 +112,14 @@ public:
|
|||||||
bool
|
bool
|
||||||
operator()(value_type const& lhs, String const& rhs) const
|
operator()(value_type const& lhs, String const& rhs) const
|
||||||
{
|
{
|
||||||
return ci_less::operator()(lhs.name_string(), rhs);
|
return iless::operator()(lhs.name_string(), rhs);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns `true` if lhs is less than rhs using a strict ordering
|
/// Returns `true` if lhs is less than rhs using a strict ordering
|
||||||
bool
|
bool
|
||||||
operator()(value_type const& lhs, value_type const& rhs) const
|
operator()(value_type const& lhs, value_type const& rhs) const
|
||||||
{
|
{
|
||||||
return ci_less::operator()(
|
return iless::operator()(lhs.name_string(), rhs.name_string());
|
||||||
lhs.name_string(), rhs.name_string());
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -546,6 +547,7 @@ public:
|
|||||||
//
|
//
|
||||||
//--------------------------------------------------------------------------
|
//--------------------------------------------------------------------------
|
||||||
|
|
||||||
|
/// Returns a copy of the key comparison function
|
||||||
key_compare
|
key_compare
|
||||||
key_comp() const
|
key_comp() const
|
||||||
{
|
{
|
||||||
|
@@ -10,7 +10,6 @@
|
|||||||
|
|
||||||
#include <beast/core/static_string.hpp>
|
#include <beast/core/static_string.hpp>
|
||||||
#include <beast/core/type_traits.hpp>
|
#include <beast/core/type_traits.hpp>
|
||||||
#include <beast/core/detail/ci_char_traits.hpp>
|
|
||||||
#include <beast/core/detail/clamp.hpp>
|
#include <beast/core/detail/clamp.hpp>
|
||||||
#include <beast/http/error.hpp>
|
#include <beast/http/error.hpp>
|
||||||
#include <beast/http/rfc7230.hpp>
|
#include <beast/http/rfc7230.hpp>
|
||||||
|
@@ -8,7 +8,6 @@
|
|||||||
#ifndef BEAST_HTTP_IMPL_FIELD_IPP
|
#ifndef BEAST_HTTP_IMPL_FIELD_IPP
|
||||||
#define BEAST_HTTP_IMPL_FIELD_IPP
|
#define BEAST_HTTP_IMPL_FIELD_IPP
|
||||||
|
|
||||||
#include <beast/core/detail/ci_char_traits.hpp>
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <array>
|
#include <array>
|
||||||
#include <boost/assert.hpp>
|
#include <boost/assert.hpp>
|
||||||
@@ -435,13 +434,13 @@ string_to_field(string_view s)
|
|||||||
auto const& v = get_field_strings();
|
auto const& v = get_field_strings();
|
||||||
auto const it = std::lower_bound(
|
auto const it = std::lower_bound(
|
||||||
v.begin(), v.end(), s,
|
v.begin(), v.end(), s,
|
||||||
beast::detail::ci_less{});
|
beast::iless{});
|
||||||
if(it == v.end())
|
if(it == v.end())
|
||||||
return field::unknown;
|
return field::unknown;
|
||||||
if(! beast::detail::ci_equal(s, *it))
|
if(! iequals(s, *it))
|
||||||
return field::unknown;
|
return field::unknown;
|
||||||
BOOST_ASSERT(beast::detail::ci_equal(s,
|
BOOST_ASSERT(iequals(s, to_string(
|
||||||
to_string(static_cast<field>(it - v.begin()))));
|
static_cast<field>(it - v.begin()))));
|
||||||
return static_cast<field>(it - v.begin());
|
return static_cast<field>(it - v.begin());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -10,7 +10,6 @@
|
|||||||
|
|
||||||
#include <beast/core/buffer_cat.hpp>
|
#include <beast/core/buffer_cat.hpp>
|
||||||
#include <beast/core/static_string.hpp>
|
#include <beast/core/static_string.hpp>
|
||||||
#include <beast/core/detail/ci_char_traits.hpp>
|
|
||||||
#include <beast/http/verb.hpp>
|
#include <beast/http/verb.hpp>
|
||||||
#include <beast/http/rfc7230.hpp>
|
#include <beast/http/rfc7230.hpp>
|
||||||
#include <beast/http/status.hpp>
|
#include <beast/http/status.hpp>
|
||||||
@@ -298,7 +297,7 @@ value_type(field name,
|
|||||||
, f_(name)
|
, f_(name)
|
||||||
{
|
{
|
||||||
//BOOST_ASSERT(name == field::unknown ||
|
//BOOST_ASSERT(name == field::unknown ||
|
||||||
// detail::ci_equal(sname, to_string(name)));
|
// iequals(sname, to_string(name)));
|
||||||
char* p = reinterpret_cast<char*>(this + 1);
|
char* p = reinterpret_cast<char*>(this + 1);
|
||||||
p[off_-2] = ':';
|
p[off_-2] = ':';
|
||||||
p[off_-1] = ' ';
|
p[off_-1] = ' ';
|
||||||
@@ -585,7 +584,7 @@ insert(field name,
|
|||||||
}
|
}
|
||||||
auto const last = std::prev(before);
|
auto const last = std::prev(before);
|
||||||
// VFALCO is it worth comparing `field name` first?
|
// VFALCO is it worth comparing `field name` first?
|
||||||
if(! beast::detail::ci_equal(sname, last->name_string()))
|
if(! iequals(sname, last->name_string()))
|
||||||
{
|
{
|
||||||
BOOST_ASSERT(count(sname) == 0);
|
BOOST_ASSERT(count(sname) == 0);
|
||||||
set_.insert_before(before, e);
|
set_.insert_before(before, e);
|
||||||
@@ -779,8 +778,7 @@ has_chunked_impl() const
|
|||||||
{
|
{
|
||||||
auto cur = it++;
|
auto cur = it++;
|
||||||
if(it == v.end())
|
if(it == v.end())
|
||||||
return beast::detail::ci_equal(
|
return iequals(*cur, "chunked");
|
||||||
*cur, "chunked");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -925,7 +923,7 @@ set_element(value_type& e)
|
|||||||
{
|
{
|
||||||
auto it = set_.lower_bound(
|
auto it = set_.lower_bound(
|
||||||
e.name_string(), key_compare{});
|
e.name_string(), key_compare{});
|
||||||
if(it == set_.end() || ! beast::detail::ci_equal(
|
if(it == set_.end() || ! iequals(
|
||||||
e.name_string(), it->name_string()))
|
e.name_string(), it->name_string()))
|
||||||
{
|
{
|
||||||
set_.insert_before(it, e);
|
set_.insert_before(it, e);
|
||||||
@@ -941,8 +939,7 @@ set_element(value_type& e)
|
|||||||
delete_element(*it);
|
delete_element(*it);
|
||||||
it = next;
|
it = next;
|
||||||
if(it == set_.end() ||
|
if(it == set_.end() ||
|
||||||
! beast::detail::ci_equal(
|
! iequals(e.name_string(), it->name_string()))
|
||||||
e.name_string(), it->name_string()))
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
set_.insert_before(it, e);
|
set_.insert_before(it, e);
|
||||||
|
@@ -9,7 +9,6 @@
|
|||||||
#define BEAST_HTTP_IMPL_MESSAGE_IPP
|
#define BEAST_HTTP_IMPL_MESSAGE_IPP
|
||||||
|
|
||||||
#include <beast/core/error.hpp>
|
#include <beast/core/error.hpp>
|
||||||
#include <beast/core/detail/ci_char_traits.hpp>
|
|
||||||
#include <beast/core/detail/type_traits.hpp>
|
#include <beast/core/detail/type_traits.hpp>
|
||||||
#include <boost/assert.hpp>
|
#include <boost/assert.hpp>
|
||||||
#include <boost/throw_exception.hpp>
|
#include <boost/throw_exception.hpp>
|
||||||
|
@@ -8,7 +8,6 @@
|
|||||||
#ifndef BEAST_HTTP_IMPL_RFC7230_IPP
|
#ifndef BEAST_HTTP_IMPL_RFC7230_IPP
|
||||||
#define BEAST_HTTP_IMPL_RFC7230_IPP
|
#define BEAST_HTTP_IMPL_RFC7230_IPP
|
||||||
|
|
||||||
#include <beast/core/detail/ci_char_traits.hpp>
|
|
||||||
#include <beast/http/detail/rfc7230.hpp>
|
#include <beast/http/detail/rfc7230.hpp>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
|
|
||||||
@@ -291,7 +290,7 @@ find(T const& s) ->
|
|||||||
return std::find_if(begin(), end(),
|
return std::find_if(begin(), end(),
|
||||||
[&s](value_type const& v)
|
[&s](value_type const& v)
|
||||||
{
|
{
|
||||||
return beast::detail::ci_equal(s, v.first);
|
return iequals(s, v.first);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -537,7 +536,7 @@ exists(T const& s)
|
|||||||
return std::find_if(begin(), end(),
|
return std::find_if(begin(), end(),
|
||||||
[&s](value_type const& v)
|
[&s](value_type const& v)
|
||||||
{
|
{
|
||||||
return beast::detail::ci_equal(s, v);
|
return iequals(s, v);
|
||||||
}
|
}
|
||||||
) != end();
|
) != end();
|
||||||
}
|
}
|
||||||
|
@@ -13,7 +13,7 @@
|
|||||||
#include <beast/http/verb.hpp>
|
#include <beast/http/verb.hpp>
|
||||||
#include <beast/http/status.hpp>
|
#include <beast/http/status.hpp>
|
||||||
#include <beast/http/type_traits.hpp>
|
#include <beast/http/type_traits.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/detail/integer_sequence.hpp>
|
#include <beast/core/detail/integer_sequence.hpp>
|
||||||
#include <boost/optional.hpp>
|
#include <boost/optional.hpp>
|
||||||
#include <boost/throw_exception.hpp>
|
#include <boost/throw_exception.hpp>
|
||||||
|
@@ -11,7 +11,7 @@
|
|||||||
#include <beast/config.hpp>
|
#include <beast/config.hpp>
|
||||||
#include <beast/core/buffer_cat.hpp>
|
#include <beast/core/buffer_cat.hpp>
|
||||||
#include <beast/core/consuming_buffers.hpp>
|
#include <beast/core/consuming_buffers.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/type_traits.hpp>
|
#include <beast/core/type_traits.hpp>
|
||||||
#include <beast/http/message.hpp>
|
#include <beast/http/message.hpp>
|
||||||
#include <beast/http/detail/chunk_encode.hpp>
|
#include <beast/http/detail/chunk_encode.hpp>
|
||||||
|
@@ -9,7 +9,7 @@
|
|||||||
#define BEAST_HTTP_STATUS_HPP
|
#define BEAST_HTTP_STATUS_HPP
|
||||||
|
|
||||||
#include <beast/config.hpp>
|
#include <beast/config.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <iosfwd>
|
#include <iosfwd>
|
||||||
|
|
||||||
namespace beast {
|
namespace beast {
|
||||||
|
@@ -9,7 +9,7 @@
|
|||||||
#define BEAST_HTTP_STRING_VIEW_BODY
|
#define BEAST_HTTP_STRING_VIEW_BODY
|
||||||
|
|
||||||
#include <beast/config.hpp>
|
#include <beast/config.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/http/message.hpp>
|
#include <beast/http/message.hpp>
|
||||||
#include <boost/asio/buffer.hpp>
|
#include <boost/asio/buffer.hpp>
|
||||||
#include <boost/optional.hpp>
|
#include <boost/optional.hpp>
|
||||||
|
@@ -10,7 +10,7 @@
|
|||||||
|
|
||||||
#include <beast/config.hpp>
|
#include <beast/config.hpp>
|
||||||
#include <beast/core/error.hpp>
|
#include <beast/core/error.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/type_traits.hpp>
|
#include <beast/core/type_traits.hpp>
|
||||||
#include <beast/http/detail/type_traits.hpp>
|
#include <beast/http/detail/type_traits.hpp>
|
||||||
#include <boost/asio/buffer.hpp>
|
#include <boost/asio/buffer.hpp>
|
||||||
|
@@ -9,7 +9,7 @@
|
|||||||
#define BEAST_HTTP_VERB_HPP
|
#define BEAST_HTTP_VERB_HPP
|
||||||
|
|
||||||
#include <beast/config.hpp>
|
#include <beast/config.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <iosfwd>
|
#include <iosfwd>
|
||||||
|
|
||||||
namespace beast {
|
namespace beast {
|
||||||
|
@@ -17,7 +17,7 @@
|
|||||||
#include <beast/http/detail/chunk_encode.hpp>
|
#include <beast/http/detail/chunk_encode.hpp>
|
||||||
#include <beast/core/error.hpp>
|
#include <beast/core/error.hpp>
|
||||||
#include <beast/core/async_result.hpp>
|
#include <beast/core/async_result.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <boost/variant.hpp>
|
#include <boost/variant.hpp>
|
||||||
#include <iosfwd>
|
#include <iosfwd>
|
||||||
#include <limits>
|
#include <limits>
|
||||||
|
@@ -9,7 +9,7 @@
|
|||||||
#define BEAST_WEBSOCKET_DETAIL_HYBI13_HPP
|
#define BEAST_WEBSOCKET_DETAIL_HYBI13_HPP
|
||||||
|
|
||||||
#include <beast/core/static_string.hpp>
|
#include <beast/core/static_string.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/detail/base64.hpp>
|
#include <beast/core/detail/base64.hpp>
|
||||||
#include <beast/core/detail/sha1.hpp>
|
#include <beast/core/detail/sha1.hpp>
|
||||||
#include <boost/assert.hpp>
|
#include <boost/assert.hpp>
|
||||||
|
@@ -11,7 +11,6 @@
|
|||||||
#include <beast/core/error.hpp>
|
#include <beast/core/error.hpp>
|
||||||
#include <beast/core/consuming_buffers.hpp>
|
#include <beast/core/consuming_buffers.hpp>
|
||||||
#include <beast/core/read_size.hpp>
|
#include <beast/core/read_size.hpp>
|
||||||
#include <beast/core/detail/ci_char_traits.hpp>
|
|
||||||
#include <beast/zlib/deflate_stream.hpp>
|
#include <beast/zlib/deflate_stream.hpp>
|
||||||
#include <beast/zlib/inflate_stream.hpp>
|
#include <beast/zlib/inflate_stream.hpp>
|
||||||
#include <beast/websocket/option.hpp>
|
#include <beast/websocket/option.hpp>
|
||||||
@@ -77,16 +76,15 @@ pmd_read(pmd_offer& offer, Fields const& fields)
|
|||||||
offer.server_no_context_takeover = false;
|
offer.server_no_context_takeover = false;
|
||||||
offer.client_no_context_takeover = false;
|
offer.client_no_context_takeover = false;
|
||||||
|
|
||||||
using beast::detail::ci_equal;
|
|
||||||
http::ext_list list{
|
http::ext_list list{
|
||||||
fields["Sec-WebSocket-Extensions"]};
|
fields["Sec-WebSocket-Extensions"]};
|
||||||
for(auto const& ext : list)
|
for(auto const& ext : list)
|
||||||
{
|
{
|
||||||
if(ci_equal(ext.first, "permessage-deflate"))
|
if(iequals(ext.first, "permessage-deflate"))
|
||||||
{
|
{
|
||||||
for(auto const& param : ext.second)
|
for(auto const& param : ext.second)
|
||||||
{
|
{
|
||||||
if(ci_equal(param.first,
|
if(iequals(param.first,
|
||||||
"server_max_window_bits"))
|
"server_max_window_bits"))
|
||||||
{
|
{
|
||||||
if(offer.server_max_window_bits != 0)
|
if(offer.server_max_window_bits != 0)
|
||||||
@@ -114,7 +112,7 @@ pmd_read(pmd_offer& offer, Fields const& fields)
|
|||||||
return; // MUST decline
|
return; // MUST decline
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(ci_equal(param.first,
|
else if(iequals(param.first,
|
||||||
"client_max_window_bits"))
|
"client_max_window_bits"))
|
||||||
{
|
{
|
||||||
if(offer.client_max_window_bits != 0)
|
if(offer.client_max_window_bits != 0)
|
||||||
@@ -142,7 +140,7 @@ pmd_read(pmd_offer& offer, Fields const& fields)
|
|||||||
offer.client_max_window_bits = -1;
|
offer.client_max_window_bits = -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(ci_equal(param.first,
|
else if(iequals(param.first,
|
||||||
"server_no_context_takeover"))
|
"server_no_context_takeover"))
|
||||||
{
|
{
|
||||||
if(offer.server_no_context_takeover)
|
if(offer.server_no_context_takeover)
|
||||||
@@ -161,7 +159,7 @@ pmd_read(pmd_offer& offer, Fields const& fields)
|
|||||||
}
|
}
|
||||||
offer.server_no_context_takeover = true;
|
offer.server_no_context_takeover = true;
|
||||||
}
|
}
|
||||||
else if(ci_equal(param.first,
|
else if(iequals(param.first,
|
||||||
"client_no_context_takeover"))
|
"client_no_context_takeover"))
|
||||||
{
|
{
|
||||||
if(offer.client_no_context_takeover)
|
if(offer.client_no_context_takeover)
|
||||||
|
@@ -10,7 +10,7 @@
|
|||||||
|
|
||||||
#include <beast/config.hpp>
|
#include <beast/config.hpp>
|
||||||
#include <beast/core/static_string.hpp>
|
#include <beast/core/static_string.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/http/message.hpp>
|
#include <beast/http/message.hpp>
|
||||||
#include <array>
|
#include <array>
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
@@ -18,7 +18,7 @@
|
|||||||
#include <beast/http/detail/type_traits.hpp>
|
#include <beast/http/detail/type_traits.hpp>
|
||||||
#include <beast/core/async_result.hpp>
|
#include <beast/core/async_result.hpp>
|
||||||
#include <beast/core/buffered_read_stream.hpp>
|
#include <beast/core/buffered_read_stream.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/detail/type_traits.hpp>
|
#include <beast/core/detail/type_traits.hpp>
|
||||||
#include <boost/asio.hpp>
|
#include <boost/asio.hpp>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
@@ -37,8 +37,8 @@ unit-test core-tests :
|
|||||||
core/read_size.cpp
|
core/read_size.cpp
|
||||||
core/static_buffer.cpp
|
core/static_buffer.cpp
|
||||||
core/static_string.cpp
|
core/static_string.cpp
|
||||||
|
core/string.cpp
|
||||||
core/string_param.cpp
|
core/string_param.cpp
|
||||||
core/string_view.cpp
|
|
||||||
core/type_traits.cpp
|
core/type_traits.cpp
|
||||||
core/base64.cpp
|
core/base64.cpp
|
||||||
core/empty_base_optimization.cpp
|
core/empty_base_optimization.cpp
|
||||||
|
@@ -32,8 +32,8 @@ add_executable (core-tests
|
|||||||
read_size.cpp
|
read_size.cpp
|
||||||
static_buffer.cpp
|
static_buffer.cpp
|
||||||
static_string.cpp
|
static_string.cpp
|
||||||
|
string.cpp
|
||||||
string_param.cpp
|
string_param.cpp
|
||||||
string_view.cpp
|
|
||||||
type_traits.cpp
|
type_traits.cpp
|
||||||
base64.cpp
|
base64.cpp
|
||||||
empty_base_optimization.cpp
|
empty_base_optimization.cpp
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
#include <beast/core/flat_buffer.hpp>
|
#include <beast/core/flat_buffer.hpp>
|
||||||
#include <beast/core/multi_buffer.hpp>
|
#include <beast/core/multi_buffer.hpp>
|
||||||
#include <beast/core/read_size.hpp>
|
#include <beast/core/read_size.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/unit_test/suite.hpp>
|
#include <beast/unit_test/suite.hpp>
|
||||||
#include <boost/asio/streambuf.hpp>
|
#include <boost/asio/streambuf.hpp>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
#ifndef BEAST_TEST_BUFFER_TEST_HPP
|
#ifndef BEAST_TEST_BUFFER_TEST_HPP
|
||||||
#define BEAST_TEST_BUFFER_TEST_HPP
|
#define BEAST_TEST_BUFFER_TEST_HPP
|
||||||
|
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/read_size.hpp>
|
#include <beast/core/read_size.hpp>
|
||||||
#include <beast/core/type_traits.hpp>
|
#include <beast/core/type_traits.hpp>
|
||||||
#include <beast/core/detail/type_traits.hpp>
|
#include <beast/core/detail/type_traits.hpp>
|
||||||
|
@@ -12,7 +12,7 @@
|
|||||||
|
|
||||||
#include <beast/core/ostream.hpp>
|
#include <beast/core/ostream.hpp>
|
||||||
#include <beast/core/read_size.hpp>
|
#include <beast/core/read_size.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/test/test_allocator.hpp>
|
#include <beast/test/test_allocator.hpp>
|
||||||
#include <beast/unit_test/suite.hpp>
|
#include <beast/unit_test/suite.hpp>
|
||||||
#include <boost/lexical_cast.hpp>
|
#include <boost/lexical_cast.hpp>
|
||||||
|
@@ -11,7 +11,7 @@
|
|||||||
#include "buffer_test.hpp"
|
#include "buffer_test.hpp"
|
||||||
|
|
||||||
#include <beast/core/ostream.hpp>
|
#include <beast/core/ostream.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/core/type_traits.hpp>
|
#include <beast/core/type_traits.hpp>
|
||||||
#include <beast/test/test_allocator.hpp>
|
#include <beast/test/test_allocator.hpp>
|
||||||
#include <beast/unit_test/suite.hpp>
|
#include <beast/unit_test/suite.hpp>
|
||||||
|
@@ -11,7 +11,7 @@
|
|||||||
#include "buffer_test.hpp"
|
#include "buffer_test.hpp"
|
||||||
|
|
||||||
#include <beast/core/ostream.hpp>
|
#include <beast/core/ostream.hpp>
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
||||||
#include <beast/unit_test/suite.hpp>
|
#include <beast/unit_test/suite.hpp>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
@@ -6,4 +6,4 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
// Test that header file is self-contained.
|
// Test that header file is self-contained.
|
||||||
#include <beast/core/string_view.hpp>
|
#include <beast/core/string.hpp>
|
@@ -9,7 +9,6 @@
|
|||||||
#include <beast/http/field.hpp>
|
#include <beast/http/field.hpp>
|
||||||
|
|
||||||
#include <beast/unit_test/suite.hpp>
|
#include <beast/unit_test/suite.hpp>
|
||||||
#include <boost/lexical_cast.hpp>
|
|
||||||
|
|
||||||
namespace beast {
|
namespace beast {
|
||||||
namespace http {
|
namespace http {
|
||||||
@@ -23,8 +22,7 @@ public:
|
|||||||
auto const match =
|
auto const match =
|
||||||
[&](field f, string_view s)
|
[&](field f, string_view s)
|
||||||
{
|
{
|
||||||
BEAST_EXPECT(
|
BEAST_EXPECT(iequals(to_string(f), s));
|
||||||
beast::detail::ci_equal(to_string(f), s));
|
|
||||||
BEAST_EXPECT(string_to_field(s) == f);
|
BEAST_EXPECT(string_to_field(s) == f);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user