diff options
| author | Lexi Winter <lexi@le-fay.org> | 2025-07-01 17:07:04 +0100 |
|---|---|---|
| committer | Lexi Winter <lexi@le-fay.org> | 2025-07-01 17:07:04 +0100 |
| commit | 2e2d1bd3b6c7776b77c33b94f30ead89367a71e6 (patch) | |
| tree | 54d37ffadf8e677938d9b7a28e4e9b71be1e75c1 /nihil.util/next_word.ccm | |
| parent | 36427c0966faa7aecd586b397ed9b845f18172f5 (diff) | |
| download | nihil-2e2d1bd3b6c7776b77c33b94f30ead89367a71e6.tar.gz nihil-2e2d1bd3b6c7776b77c33b94f30ead89367a71e6.tar.bz2 | |
add nihil.std
Diffstat (limited to 'nihil.util/next_word.ccm')
| -rw-r--r-- | nihil.util/next_word.ccm | 37 |
1 files changed, 10 insertions, 27 deletions
diff --git a/nihil.util/next_word.ccm b/nihil.util/next_word.ccm index c5d3ad7..89eeaee 100644 --- a/nihil.util/next_word.ccm +++ b/nihil.util/next_word.ccm @@ -1,44 +1,27 @@ -/* - * This source code is released into the public domain. - */ - -module; - -#include <algorithm> -#include <locale> -#include <ranges> -#include <string> -#include <utility> - +// This source code is released into the public domain. export module nihil.util:next_word; import :skipws; namespace nihil { -/* - * Return the next word from a string_view. Skips leading whitespace, so - * calling this repeatedly will return each word from the string. - */ - -export template<typename Char> [[nodiscard]] -auto next_word(std::basic_string_view<Char> text, - std::locale const &locale = std::locale()) - -> std::pair<std::basic_string_view<Char>, - std::basic_string_view<Char>> +// Return the next word from a string_view. Skips leading whitespace, so +// calling this repeatedly will return each word from the string. +export template <typename Char> +[[nodiscard]] +auto next_word(std::basic_string_view<Char> text, std::locale const &locale = std::locale()) + -> std::pair<std::basic_string_view<Char>, std::basic_string_view<Char>> { text = skipws(text, locale); auto is_space = ctype_is(std::ctype_base::space, locale); auto split_pos = std::ranges::find_if(text, is_space); - return {{std::ranges::begin(text), split_pos}, - {split_pos, std::ranges::end(text)}}; + return {{std::ranges::begin(text), split_pos}, {split_pos, std::ranges::end(text)}}; } -export template<typename Char> -auto next_word(std::basic_string_view<Char> *text, - std::locale const &locale = std::locale()) +export template <typename Char> +auto next_word(std::basic_string_view<Char> *text, std::locale const &locale = std::locale()) -> std::basic_string_view<Char> { auto [word, rest] = next_word(*text, locale); |
