30#if __cpp_char8_t >= 201811L
31namespace essence::detail {
32 template <std::
size_t N>
33 struct char8_t_string_literal {
34 static constexpr std::size_t size = N;
37 std::array<char8_t, N> sequence;
39 constexpr char8_t_string_literal(
char8_t ch)
noexcept
40 : char_literal{
true}, sequence{ch} {}
42 template <std::size_t... Is>
43 constexpr char8_t_string_literal(
const char8_t (&sequence)[N], std::index_sequence<Is...>) noexcept
44 : char_literal{}, sequence{sequence[Is]...} {}
46 constexpr char8_t_string_literal(
const char8_t (&sequence)[N])
noexcept
47 : char8_t_string_literal{sequence, std::make_index_sequence<N>{}} {}
50 char8_t_string_literal(
char8_t) -> char8_t_string_literal<1>;
52 template <std::
size_t N>
53 char8_t_string_literal(
const char8_t (&)[N]) -> char8_t_string_literal<N>;
55 template <char8_t_string_literal Literal, std::size_t... Is>
56 inline constexpr char as_char_array_v[
sizeof...(Is)]{
static_cast<char>(Literal.sequence[Is])...};
58 template <char8_t_string_literal Literal, std::size_t... Is>
59 constexpr const char (&make_as_char_array(std::index_sequence<Is...>)
noexcept)[
sizeof...(Is)] {
60 return as_char_array_v<Literal, Is...>;
65 template <detail::
char8_t_
string_literal Literal>
66 inline constexpr decltype(
auto) as_char_v = []() ->
decltype(
auto) {
67 if constexpr (Literal.char_literal) {
68 return static_cast<char>(Literal.sequence.front());
70 return detail::make_as_char_array<Literal>(std::make_index_sequence<
decltype(Literal)::size>{});
74#define U8(x) (essence::as_char_v<(u8##x)>)
76 inline std::string from_u8string(std::u8string_view str) {
77 return {str.begin(), str.end()};
80 inline std::u8string to_u8string(std::string_view str) {
81 return {str.begin(), str.end()};
88 inline std::string from_u8string(std::string_view str) {
89 return std::string{str};
92 inline std::string from_u8string(std::string&& str)
noexcept {
93 return std::move(str);
96 inline std::string to_u8string(std::string_view str) {
97 return std::string{str};
100 inline std::string to_u8string(std::string&& str)
noexcept {
101 return std::move(str);