mirror of
https://github.com/fish-shell/fish-shell
synced 2024-12-31 23:28:45 +00:00
Simplify and add tests for ifind
This commit is contained in:
parent
fcd4a44b98
commit
ac241b7132
2 changed files with 21 additions and 21 deletions
30
src/common.h
30
src/common.h
|
@ -353,35 +353,23 @@ bool string_suffixes_string_case_insensitive(const wcstring &proposed_suffix,
|
||||||
bool string_prefixes_string_case_insensitive(const wcstring &proposed_prefix,
|
bool string_prefixes_string_case_insensitive(const wcstring &proposed_prefix,
|
||||||
const wcstring &value);
|
const wcstring &value);
|
||||||
|
|
||||||
/// Helper struct for ifind, templated to allow using it with both std::string and std::wstring
|
|
||||||
/// Supports locale-specific search for characters that transform into a different character
|
|
||||||
/// when upper/lower-cased, such as those in Turkish and German.
|
|
||||||
template<typename T>
|
|
||||||
struct string_iequal_t {
|
|
||||||
private:
|
|
||||||
const std::locale &_locale;
|
|
||||||
public:
|
|
||||||
string_iequal_t(const std::locale &locale)
|
|
||||||
: _locale(locale) {}
|
|
||||||
bool operator() (T char1, T char2) {
|
|
||||||
return std::toupper(char1, _locale) == std::toupper(char2, _locale);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
/// Case-insensitive string search, templated for use with both std::string and std::wstring.
|
/// Case-insensitive string search, templated for use with both std::string and std::wstring.
|
||||||
/// Modeled after std::string::find().
|
/// Modeled after std::string::find().
|
||||||
/// \return the offset of the first case-insensitive matching instance of `needle` within
|
/// \return the offset of the first case-insensitive matching instance of `needle` within
|
||||||
/// `haystack`, or `string::npos()` if no results were found.
|
/// `haystack`, or `string::npos()` if no results were found.
|
||||||
template<typename T>
|
template <typename T>
|
||||||
size_t ifind(const T &haystack, const T &needle,
|
size_t ifind(const T &haystack, const T &needle) {
|
||||||
const std::locale &locale = std::locale()) {
|
using char_t = typename T::value_type;
|
||||||
auto result = std::search(haystack.begin(), haystack.end(), needle.begin(), needle.end(),
|
auto icase_eq = [](char_t c1, char_t c2) {
|
||||||
string_iequal_t<typename T::value_type>(locale));
|
auto locale = std::locale();
|
||||||
|
return std::toupper(c1, locale) == std::toupper(c2, locale);
|
||||||
|
};
|
||||||
|
auto result =
|
||||||
|
std::search(haystack.begin(), haystack.end(), needle.begin(), needle.end(), icase_eq);
|
||||||
if (result != haystack.end()) {
|
if (result != haystack.end()) {
|
||||||
return result - haystack.begin();
|
return result - haystack.begin();
|
||||||
}
|
}
|
||||||
|
|
||||||
return T::npos;
|
return T::npos;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1731,6 +1731,17 @@ static void test_fuzzy_match() {
|
||||||
err(L"test_fuzzy_match failed on line %ld", __LINE__);
|
err(L"test_fuzzy_match failed on line %ld", __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void test_ifind() {
|
||||||
|
say(L"Testing ifind");
|
||||||
|
do_test(ifind(std::string{"alpha"}, std::string{"alpha"}) == 0);
|
||||||
|
do_test(ifind(wcstring{L"alphab"}, wcstring{L"alpha"}) == 0);
|
||||||
|
do_test(ifind(std::string{"alpha"}, std::string{"balpha"}) == std::string::npos);
|
||||||
|
do_test(ifind(std::string{"balpha"}, std::string{"alpha"}) == 1);
|
||||||
|
do_test(ifind(std::string{"alphab"}, std::string{"balpha"}) == std::string::npos);
|
||||||
|
do_test(ifind(std::string{"balpha"}, std::string{"lPh"}) == 2);
|
||||||
|
do_test(ifind(std::string{"balpha"}, std::string{"Plh"}) == std::string::npos);
|
||||||
|
}
|
||||||
|
|
||||||
static void test_abbreviations() {
|
static void test_abbreviations() {
|
||||||
say(L"Testing abbreviations");
|
say(L"Testing abbreviations");
|
||||||
env_push(true);
|
env_push(true);
|
||||||
|
@ -4786,6 +4797,7 @@ int main(int argc, char **argv) {
|
||||||
if (should_test_function("lru")) test_lru();
|
if (should_test_function("lru")) test_lru();
|
||||||
if (should_test_function("expand")) test_expand();
|
if (should_test_function("expand")) test_expand();
|
||||||
if (should_test_function("fuzzy_match")) test_fuzzy_match();
|
if (should_test_function("fuzzy_match")) test_fuzzy_match();
|
||||||
|
if (should_test_function("ifind")) test_ifind();
|
||||||
if (should_test_function("abbreviations")) test_abbreviations();
|
if (should_test_function("abbreviations")) test_abbreviations();
|
||||||
if (should_test_function("test")) test_test();
|
if (should_test_function("test")) test_test();
|
||||||
if (should_test_function("path")) test_path();
|
if (should_test_function("path")) test_path();
|
||||||
|
|
Loading…
Reference in a new issue