25#ifndef TGUI_STRING_VIEW_HPP
26#define TGUI_STRING_VIEW_HPP
32#if TGUI_COMPILED_WITH_CPP_VER >= 17
33 #include <string_view>
38#if TGUI_COMPILED_WITH_CPP_VER >= 17
41 inline namespace literals
43 inline namespace string_view_literals
47 using namespace std::literals::string_view_literals;
55#if TGUI_COMPILED_WITH_CPP_VER >= 17
56 using StringView = std::u32string_view;
57 using CharStringView = std::string_view;
59 template <
typename Type>
65 template<
typename Type>
66 using TypeIdentity_t =
typename TypeIdentity<Type>::type;
68 template <
typename CharType>
72 using const_iterator =
const CharType*;
74 constexpr StringViewImpl() =
default;
75 constexpr StringViewImpl(
const StringViewImpl& other) =
default;
77 constexpr StringViewImpl(
const CharType* str, std::size_t strLength) :
83 constexpr StringViewImpl(
const CharType* str) :
85 m_length(std::char_traits<CharType>::length(str))
89 constexpr StringViewImpl(
const std::basic_string<CharType>& str) :
91 m_length(str.length())
95 TGUI_NODISCARD
constexpr const_iterator begin() const noexcept
99 TGUI_NODISCARD
constexpr const_iterator cbegin() const noexcept
104 TGUI_NODISCARD
constexpr const_iterator end() const noexcept
106 return m_string +
static_cast<std::ptrdiff_t
>(m_length);
108 TGUI_NODISCARD
constexpr const_iterator cend() const noexcept
110 return m_string +
static_cast<std::ptrdiff_t
>(m_length);
113 TGUI_NODISCARD
constexpr const CharType& operator[](std::size_t index)
const
115 return m_string[index];
118 TGUI_NODISCARD
constexpr const CharType& front()
const
123 TGUI_NODISCARD
constexpr const CharType& back()
const
125 return m_string[m_length-1];
128 TGUI_NODISCARD
constexpr const CharType* data() const noexcept
133 TGUI_NODISCARD
constexpr std::size_t size() const noexcept
137 TGUI_NODISCARD
constexpr std::size_t length() const noexcept
142 TGUI_NODISCARD
constexpr bool empty() const noexcept
144 return (m_length == 0);
147 TGUI_NODISCARD
constexpr StringViewImpl substr(std::size_t pos = 0, std::size_t count = std::u32string::npos)
const
149 if (count != std::u32string::npos)
150 return StringViewImpl(&m_string[pos], count);
152 return StringViewImpl(&m_string[pos], m_length - pos);
155 TGUI_NODISCARD
constexpr int compare(StringViewImpl strView)
const noexcept
157 const std::size_t rlen = std::min(length(), strView.length());
158 const int ret = std::char_traits<CharType>::compare(data(), strView.data(), rlen);
162 if (length() < strView.length())
164 else if (length() > strView.length())
170 TGUI_NODISCARD
constexpr std::size_t find(StringViewImpl strView, std::size_t pos = 0) const noexcept
172 if (empty() || (strView.length() > m_length))
173 return std::u32string::npos;
178 for (std::size_t i = pos; i <= m_length - strView.length(); ++i)
180 if (m_string[i] != strView[0])
184 for (std::size_t j = 1; j < strView.length(); ++j)
186 if (m_string[i+j] != strView[j])
197 return std::u32string::npos;
200 TGUI_NODISCARD
constexpr std::size_t find(CharType ch, std::size_t pos = 0) const noexcept
202 return find(StringViewImpl(&ch, 1), pos);
204 TGUI_NODISCARD
constexpr std::size_t find(
const CharType* str, std::size_t pos, std::size_t count)
const
206 return find(StringViewImpl(str, count), pos);
208 TGUI_NODISCARD
constexpr std::size_t find(
const CharType* str, std::size_t pos = 0)
const
210 return find(StringViewImpl(str), pos);
214 const CharType* m_string =
nullptr;
215 std::size_t m_length = 0;
218 template <
typename CharType>
219 TGUI_NODISCARD
constexpr bool operator==(StringViewImpl<CharType> lhs, TypeIdentity_t<StringViewImpl<CharType>> rhs)
noexcept
221 return lhs.compare(rhs) == 0;
224 template <
typename CharType>
225 TGUI_NODISCARD
constexpr bool operator!=(StringViewImpl<CharType> lhs, TypeIdentity_t<StringViewImpl<CharType>> rhs)
noexcept
227 return lhs.compare(rhs) != 0;
230 template <
typename CharType>
231 TGUI_NODISCARD
constexpr bool operator<(StringViewImpl<CharType> lhs, TypeIdentity_t<StringViewImpl<CharType>> rhs)
noexcept
233 return lhs.compare(rhs) < 0;
236 template <
typename CharType>
237 TGUI_NODISCARD
constexpr bool operator<=(StringViewImpl<CharType> lhs, TypeIdentity_t<StringViewImpl<CharType>> rhs)
noexcept
239 return lhs.compare(rhs) <= 0;
242 template <
typename CharType>
243 TGUI_NODISCARD
constexpr bool operator>(StringViewImpl<CharType> lhs, TypeIdentity_t<StringViewImpl<CharType>> rhs)
noexcept
245 return lhs.compare(rhs) > 0;
248 template <
typename CharType>
249 TGUI_NODISCARD
constexpr bool operator>=(StringViewImpl<CharType> lhs, TypeIdentity_t<StringViewImpl<CharType>> rhs)
noexcept
251 return lhs.compare(rhs) >= 0;
254 using StringView = StringViewImpl<char32_t>;
255 using CharStringView = StringViewImpl<char>;
259#if defined(__clang__)
260# pragma clang diagnostic push
261# pragma clang diagnostic ignored "-Wuser-defined-literals"
262#elif defined(__GNUC__)
263# pragma GCC diagnostic push
264# pragma GCC diagnostic ignored "-Wliteral-suffix"
265#elif defined (_MSC_VER)
266# pragma warning(push)
267# pragma warning(disable: 4455)
269 inline namespace literals
271 inline namespace string_view_literals
273 inline constexpr StringViewImpl<char>
operator""sv(
const char* str,
size_t len)
noexcept
275 return StringViewImpl<char>{str, len};
278 inline constexpr StringViewImpl<wchar_t>
operator""sv(
const wchar_t* str,
size_t len)
noexcept
280 return StringViewImpl<wchar_t>{str, len};
283 inline constexpr StringViewImpl<char16_t>
operator""sv(
const char16_t* str,
size_t len)
noexcept
285 return StringViewImpl<char16_t>{str, len};
288 inline constexpr StringViewImpl<char32_t>
operator""sv(
const char32_t* str,
size_t len)
noexcept
290 return StringViewImpl<char32_t>{str, len};
294#if defined(__clang__)
295# pragma clang diagnostic pop
296#elif defined(__GNUC__)
297# pragma GCC diagnostic pop
298#elif defined (_MSC_VER)
314 return std::equal(view1.begin(), view1.end(), view2.begin(), view2.end(),
315 [](
char char1,
char char2)
320 return std::tolower(static_cast<unsigned char>(char1)) == std::tolower(static_cast<unsigned char>(char2));
335 return std::equal(view1.begin(), view1.end(), view2.begin(), view2.end(),
336 [](
char32_t char1,
char32_t char2)
340 else if ((char1 < 128) && (char2 < 128))
341 return std::tolower(static_cast<unsigned char>(char1)) == std::tolower(static_cast<unsigned char>(char2));
348#if TGUI_COMPILED_WITH_CPP_VER >= 17 && defined(__cpp_lib_starts_ends_with) && (__cpp_lib_starts_ends_with >= 201711L)
357 TGUI_NODISCARD
inline bool viewStartsWith(CharStringView viewToLookInto, CharStringView viewToLookFor)
359 return viewToLookInto.starts_with(viewToLookFor);
370 TGUI_NODISCARD
inline bool viewStartsWith(CharStringView viewToLookInto,
char charToLookFor)
372 return viewToLookInto.starts_with(charToLookFor);
383 TGUI_NODISCARD
inline bool viewEndsWith(CharStringView viewToLookInto, CharStringView viewToLookFor)
385 return viewToLookInto.ends_with(viewToLookFor);
396 TGUI_NODISCARD
inline bool viewEndsWith(CharStringView viewToLookInto,
char charToLookFor)
398 return viewToLookInto.ends_with(charToLookFor);
409 TGUI_NODISCARD
inline bool viewStartsWith(StringView viewToLookInto, StringView viewToLookFor)
411 return viewToLookInto.starts_with(viewToLookFor);
422 TGUI_NODISCARD
inline bool viewStartsWith(StringView viewToLookInto,
char32_t charToLookFor)
424 return viewToLookInto.starts_with(charToLookFor);
435 TGUI_NODISCARD
inline bool viewEndsWith(StringView viewToLookInto, StringView viewToLookFor)
437 return viewToLookInto.ends_with(viewToLookFor);
448 TGUI_NODISCARD
inline bool viewEndsWith(StringView viewToLookInto,
char32_t charToLookFor)
450 return viewToLookInto.ends_with(charToLookFor);
461 TGUI_NODISCARD
inline bool viewStartsWith(CharStringView viewToLookInto, CharStringView viewToLookFor)
463 if (viewToLookFor.length() > viewToLookInto.length())
466 return viewToLookInto.substr(0, viewToLookFor.length()) == viewToLookFor;
477 TGUI_NODISCARD
inline bool viewStartsWith(CharStringView viewToLookInto,
char charToLookFor)
479 return !viewToLookInto.empty() && (viewToLookInto.front() == charToLookFor);
490 TGUI_NODISCARD
inline bool viewEndsWith(CharStringView viewToLookInto, CharStringView viewToLookFor)
492 if (viewToLookFor.length() > viewToLookInto.length())
495 return CharStringView(viewToLookInto.data() + (viewToLookInto.length() - viewToLookFor.length()), viewToLookFor.length()).compare(viewToLookFor) == 0;
506 TGUI_NODISCARD
inline bool viewEndsWith(CharStringView viewToLookInto,
char charToLookFor)
508 return !viewToLookInto.empty() && (viewToLookInto.back() == charToLookFor);
519 TGUI_NODISCARD
inline bool viewStartsWith(StringView viewToLookInto, StringView viewToLookFor)
521 if (viewToLookFor.length() > viewToLookInto.length())
524 return viewToLookInto.substr(0, viewToLookFor.length()) == viewToLookFor;
535 TGUI_NODISCARD
inline bool viewStartsWith(StringView viewToLookInto,
char32_t charToLookFor)
537 return !viewToLookInto.empty() && (viewToLookInto.front() == charToLookFor);
548 TGUI_NODISCARD
inline bool viewEndsWith(StringView viewToLookInto, StringView viewToLookFor)
550 if (viewToLookFor.length() > viewToLookInto.length())
553 return StringView(viewToLookInto.data() + (viewToLookInto.length() - viewToLookFor.length()), viewToLookFor.length()).compare(viewToLookFor) == 0;
564 TGUI_NODISCARD
inline bool viewEndsWith(StringView viewToLookInto,
char32_t charToLookFor)
566 return !viewToLookInto.empty() && (viewToLookInto.back() == charToLookFor);
Namespace that contains all TGUI functions and classes.
Definition AbsoluteOrRelativeValue.hpp:36
bool viewStartsWith(CharStringView viewToLookInto, CharStringView viewToLookFor)
Checks whether the view starts with the given substring.
Definition StringView.hpp:461
bool viewEqualIgnoreCase(CharStringView view1, CharStringView view2)
Returns whether two view are equal if letters would have been lowercase.
Definition StringView.hpp:312
bool viewEndsWith(CharStringView viewToLookInto, CharStringView viewToLookFor)
Checks whether the view ends with the given substring.
Definition StringView.hpp:490