blob: 1e15203855fe6cc93c67e78cf6a87024910a337b [file] [log] [blame]
// Copyright 2025 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef BASE_STRINGS_STRING_VIEW_UTIL_H_
#define BASE_STRINGS_STRING_VIEW_UTIL_H_
#include <string_view>
#include "base/compiler_specific.h"
#include "base/containers/span.h"
namespace base {
// Helper function for creating a std::string_view from a string literal that
// preserves internal NUL characters.
template <class CharT, size_t N>
std::basic_string_view<CharT> MakeStringViewWithNulChars(
const CharT (&lit LIFETIME_BOUND)[N])
ENABLE_IF_ATTR(lit[N - 1u] == CharT{0},
"requires string literal as input") {
return std::basic_string_view<CharT>(lit, N - 1u);
}
// Converts a span over byte-like elements to `std::string_view`.
//
// std:: has no direct equivalent for this; however, it eases span adoption in
// Chromium, which uses `string`s and `string_view`s in many cases that
// rightfully should be containers of `uint8_t`.
//
// TODO(C++23): Replace with direct use of the `std::string_view` range
// constructor.
constexpr auto as_string_view(span<const char> s) {
return std::string_view(s.begin(), s.end());
}
constexpr auto as_string_view(span<const unsigned char> s) {
return as_string_view(as_chars(s));
}
constexpr auto as_string_view(span<const char16_t> s) {
return std::u16string_view(s.begin(), s.end());
}
constexpr auto as_string_view(span<const wchar_t> s) {
return std::wstring_view(s.begin(), s.end());
}
} // namespace base
#endif // BASE_STRINGS_STRING_VIEW_UTIL_H_