/* * Copyright (c) 2018-2020, Andreas Kling * Copyright (c) 2020, Fei Wu * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include namespace AK { enum class CaseSensitivity { CaseInsensitive, CaseSensitive, }; enum class TrimMode { Left, Right, Both }; enum class TrimWhitespace { Yes, No, }; struct MaskSpan { size_t start; size_t length; bool operator==(const MaskSpan& other) const { return start == other.start && length == other.length; } bool operator!=(const MaskSpan& other) const { return !(*this == other); } }; namespace StringUtils { bool matches(const StringView& str, const StringView& mask, CaseSensitivity = CaseSensitivity::CaseInsensitive, Vector* match_spans = nullptr); template Optional convert_to_int(const StringView&, TrimWhitespace = TrimWhitespace::Yes); template Optional convert_to_uint(const StringView&, TrimWhitespace = TrimWhitespace::Yes); template Optional convert_to_uint_from_hex(const StringView&, TrimWhitespace = TrimWhitespace::Yes); bool equals_ignoring_case(const StringView&, const StringView&); bool ends_with(const StringView& a, const StringView& b, CaseSensitivity); bool starts_with(const StringView&, const StringView&, CaseSensitivity); bool contains(const StringView&, const StringView&, CaseSensitivity); bool is_whitespace(const StringView&); StringView trim(const StringView& string, const StringView& characters, TrimMode mode); StringView trim_whitespace(const StringView& string, TrimMode mode); Optional find(StringView const& haystack, char needle, size_t start = 0); Optional find(StringView const& haystack, StringView const& needle, size_t start = 0); Optional find_last(StringView const& haystack, char needle); Vector find_all(StringView const& haystack, StringView const& needle); enum class SearchDirection { Forward, Backward }; Optional find_any_of(StringView const& haystack, StringView const& needles, SearchDirection); String to_snakecase(const StringView&); String to_titlecase(StringView const&); } } using AK::CaseSensitivity; using AK::TrimMode; using AK::TrimWhitespace;