Skip to content

Commit

Permalink
refactor(i18): use string_view for separator list in parse_locale
Browse files Browse the repository at this point in the history
In parse_locale, don't mix pointer style and string_view style; use
string_view style consistently.
  • Loading branch information
strager committed Oct 27, 2023
1 parent 9070a39 commit a8b7bee
Showing 1 changed file with 11 additions and 10 deletions.
21 changes: 11 additions & 10 deletions src/quick-lint-js/i18n/locale.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,11 @@
#include <string>
#include <vector>

using namespace std::literals::string_view_literals;

namespace quick_lint_js {
namespace {
constexpr const char locale_part_separators[] = "_.@";
constexpr std::string_view locale_part_separators = "_.@"sv;

struct Locale_Parts {
// language, territory, codeset, modifier
Expand All @@ -32,23 +34,22 @@ Locale_Parts parse_locale(std::string_view locale_name) {
std::size_t length;
std::size_t which_separator;
};
auto find_next_separator = [](std::string_view s,
const char* separators) -> Found_Separator {
auto find_next_separator =
[](std::string_view s, std::string_view separators) -> Found_Separator {
std::size_t length = s.find_first_of(separators);
if (length == s.npos) {
return Found_Separator{.length = s.size(),
.which_separator = static_cast<std::size_t>(-1)};
}
const char* separator = std::strchr(separators, s[length]);
QLJS_ASSERT(separator);
return Found_Separator{
.length = length,
.which_separator = narrow_cast<std::size_t>(separator - separators)};
std::size_t which_separator = separators.find(s[length]);
QLJS_ASSERT(which_separator != separators.npos);
return Found_Separator{.length = length,
.which_separator = which_separator};
};

Locale_Parts parts;

const char* current_separators = &locale_part_separators[0];
std::string_view current_separators = locale_part_separators;
std::string_view* current_part = &parts.language();
std::string_view remaining_locale_name = locale_name;
for (;;) {
Expand All @@ -61,7 +62,7 @@ Locale_Parts parse_locale(std::string_view locale_name) {
}

QLJS_ASSERT(part.which_separator != static_cast<std::size_t>(-1));
current_separators += part.which_separator + 1;
current_separators = current_separators.substr(part.which_separator + 1);
current_part += part.which_separator + 1;
remaining_locale_name = remaining_locale_name.substr(1);
}
Expand Down

0 comments on commit a8b7bee

Please sign in to comment.