Files
boost_beast/include/boost/beast/core/string.hpp

156 lines
3.2 KiB
C++
Raw Normal View History

//
2017-07-24 09:42:36 -07:00
// Copyright (c) 2016-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)
//
2017-07-20 13:40:34 -07:00
// Official repository: https://github.com/boostorg/beast
//
2017-07-20 13:40:34 -07:00
#ifndef BOOST_BEAST_STRING_HPP
#define BOOST_BEAST_STRING_HPP
2017-07-20 13:40:34 -07:00
#include <boost/beast/config.hpp>
#include <boost/version.hpp>
2017-07-20 13:40:34 -07:00
#ifndef BOOST_BEAST_NO_BOOST_STRING_VIEW
# if BOOST_VERSION >= 106400
2017-07-20 13:40:34 -07:00
# define BOOST_BEAST_NO_BOOST_STRING_VIEW 0
# else
2017-07-20 13:40:34 -07:00
# define BOOST_BEAST_NO_BOOST_STRING_VIEW 1
# endif
#endif
2017-07-20 13:40:34 -07:00
#if BOOST_BEAST_NO_BOOST_STRING_VIEW
#include <boost/utility/string_ref.hpp>
#else
2017-06-24 11:33:04 -07:00
#include <boost/utility/string_view.hpp>
#endif
2017-06-16 21:38:17 -07:00
#include <algorithm>
2017-07-20 13:40:34 -07:00
namespace boost {
namespace beast {
2017-07-20 13:40:34 -07:00
#if BOOST_BEAST_NO_BOOST_STRING_VIEW
/// 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>;
#else
/// The type of string view used by the library
2017-06-24 11:33:04 -07:00
using string_view = boost::string_view;
/// The type of basic string view used by the library
template<class CharT, class Traits>
using basic_string_view =
2017-06-24 11:33:04 -07:00
boost::basic_string_view<CharT, Traits>;
#endif
namespace detail {
2017-06-16 21:38:17 -07:00
inline
char
ascii_tolower(char c)
{
if(c >= 'A' && c <= 'Z')
c += 'a' - 'A';
return c;
}
template<class = void>
bool
iequals(
2017-07-12 16:35:52 -07:00
beast::string_view lhs,
beast::string_view rhs)
{
auto n = lhs.size();
if(rhs.size() != n)
return false;
auto p1 = lhs.data();
auto p2 = rhs.data();
2017-06-26 10:46:17 -07:00
char a, b;
while(n--)
2017-06-26 10:46:17 -07:00
{
a = *p1++;
b = *p2++;
if(a != b)
goto slow;
}
return true;
while(n--)
{
slow:
if(ascii_tolower(a) != ascii_tolower(b))
return false;
2017-06-26 10:46:17 -07:00
a = *p1++;
b = *p2++;
}
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(
2017-07-12 16:35:52 -07:00
beast::string_view lhs,
beast::string_view rhs)
{
return detail::iequals(lhs, rhs);
}
2017-06-26 10:46:17 -07:00
/** A case-insensitive less predicate for strings.
The case-comparison operation is defined only for low-ASCII characters.
*/
struct iless
{
bool
operator()(
2017-07-12 16:35:52 -07:00
string_view lhs,
string_view rhs) const
{
using std::begin;
using std::end;
return std::lexicographical_compare(
begin(lhs), end(lhs), begin(rhs), end(rhs),
2017-06-18 14:57:32 -07:00
[](char c1, char c2)
{
2017-06-18 14:57:32 -07:00
return detail::ascii_tolower(c1) < detail::ascii_tolower(c2);
}
);
}
};
2017-06-26 10:46:17 -07:00
/** A case-insensitive equality predicate for strings.
The case-comparison operation is defined only for low-ASCII characters.
*/
struct iequal
{
bool
operator()(
2017-07-12 16:35:52 -07:00
string_view lhs,
string_view rhs) const
{
return iequals(lhs, rhs);
}
};
} // beast
2017-07-20 13:40:34 -07:00
} // boost
#endif