mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-23 18:02:05 -05:00
7ceeb74535
This commit has no behavior changes. In particular, this does not fix any of the wrong uses of the previous default parameter (which used to be 'false', meaning "only replace the first occurence in the string"). It simply replaces the default uses by String::replace(..., ReplaceMode::FirstOnly), leaving them incorrect.
98 lines
2.6 KiB
C++
98 lines
2.6 KiB
C++
/*
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
* Copyright (c) 2020, Fei Wu <f.eiwu@yahoo.com>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/Concepts.h>
|
|
#include <AK/Forward.h>
|
|
|
|
namespace AK {
|
|
|
|
namespace Detail {
|
|
template<Concepts::AnyString T, Concepts::AnyString U>
|
|
inline constexpr bool IsHashCompatible<T, U> = true;
|
|
}
|
|
|
|
enum class CaseSensitivity {
|
|
CaseInsensitive,
|
|
CaseSensitive,
|
|
};
|
|
|
|
enum class ReplaceMode {
|
|
All,
|
|
FirstOnly,
|
|
};
|
|
|
|
enum class TrimMode {
|
|
Left,
|
|
Right,
|
|
Both
|
|
};
|
|
|
|
enum class TrimWhitespace {
|
|
Yes,
|
|
No,
|
|
};
|
|
|
|
struct MaskSpan {
|
|
size_t start;
|
|
size_t length;
|
|
|
|
bool operator==(MaskSpan const& other) const
|
|
{
|
|
return start == other.start && length == other.length;
|
|
}
|
|
bool operator!=(MaskSpan const& other) const
|
|
{
|
|
return !(*this == other);
|
|
}
|
|
};
|
|
|
|
namespace StringUtils {
|
|
|
|
bool matches(StringView str, StringView mask, CaseSensitivity = CaseSensitivity::CaseInsensitive, Vector<MaskSpan>* match_spans = nullptr);
|
|
template<typename T = int>
|
|
Optional<T> convert_to_int(StringView, TrimWhitespace = TrimWhitespace::Yes);
|
|
template<typename T = unsigned>
|
|
Optional<T> convert_to_uint(StringView, TrimWhitespace = TrimWhitespace::Yes);
|
|
template<typename T = unsigned>
|
|
Optional<T> convert_to_uint_from_hex(StringView, TrimWhitespace = TrimWhitespace::Yes);
|
|
template<typename T = unsigned>
|
|
Optional<T> convert_to_uint_from_octal(StringView, TrimWhitespace = TrimWhitespace::Yes);
|
|
bool equals_ignoring_case(StringView, StringView);
|
|
bool ends_with(StringView a, StringView b, CaseSensitivity);
|
|
bool starts_with(StringView, StringView, CaseSensitivity);
|
|
bool contains(StringView, StringView, CaseSensitivity);
|
|
bool is_whitespace(StringView);
|
|
StringView trim(StringView string, StringView characters, TrimMode mode);
|
|
StringView trim_whitespace(StringView string, TrimMode mode);
|
|
|
|
Optional<size_t> find(StringView haystack, char needle, size_t start = 0);
|
|
Optional<size_t> find(StringView haystack, StringView needle, size_t start = 0);
|
|
Optional<size_t> find_last(StringView haystack, char needle);
|
|
Vector<size_t> find_all(StringView haystack, StringView needle);
|
|
enum class SearchDirection {
|
|
Forward,
|
|
Backward
|
|
};
|
|
Optional<size_t> find_any_of(StringView haystack, StringView needles, SearchDirection);
|
|
|
|
String to_snakecase(StringView);
|
|
String to_titlecase(StringView);
|
|
String invert_case(StringView);
|
|
|
|
String replace(StringView, StringView needle, StringView replacement, ReplaceMode);
|
|
size_t count(StringView, StringView needle);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
using AK::CaseSensitivity;
|
|
using AK::ReplaceMode;
|
|
using AK::TrimMode;
|
|
using AK::TrimWhitespace;
|