diff --git a/src/builtin_string.cpp b/src/builtin_string.cpp index e04c78923..03dfa1f07 100644 --- a/src/builtin_string.cpp +++ b/src/builtin_string.cpp @@ -29,6 +29,7 @@ #include "io.h" #include "parse_util.h" #include "pcre2.h" +#include "wcstringutil.h" #include "wgetopt.h" #include "wildcard.h" #include "wutil.h" // IWYU pragma: keep @@ -1096,35 +1097,6 @@ static int string_replace(parser_t &parser, io_streams_t &streams, int argc, wch return replacer->replace_count() > 0 ? STATUS_CMD_OK : STATUS_CMD_ERROR; } -/// Given iterators into a string (forward or reverse), splits the haystack iterators -/// about the needle sequence, up to max times. Inserts splits into the output array. -/// If the iterators are forward, this does the normal thing. -/// If the iterators are backward, this returns reversed strings, in reversed order! -/// If the needle is empty, split on individual elements (characters). -template -void split_about(ITER haystack_start, ITER haystack_end, ITER needle_start, ITER needle_end, - wcstring_list_t *output, long max) { - long remaining = max; - ITER haystack_cursor = haystack_start; - while (remaining > 0 && haystack_cursor != haystack_end) { - ITER split_point; - if (needle_start == needle_end) { // empty needle, we split on individual elements - split_point = haystack_cursor + 1; - } else { - split_point = std::search(haystack_cursor, haystack_end, needle_start, needle_end); - } - if (split_point == haystack_end) { // not found - break; - } - output->push_back(wcstring(haystack_cursor, split_point)); - remaining--; - // Need to skip over the needle for the next search note that the needle may be empty. - haystack_cursor = split_point + std::distance(needle_start, needle_end); - } - // Trailing component, possibly empty. - output->push_back(wcstring(haystack_cursor, haystack_end)); -} - static int string_split(parser_t &parser, io_streams_t &streams, int argc, wchar_t **argv) { options_t opts; opts.quiet_valid = true; diff --git a/src/wcstringutil.h b/src/wcstringutil.h index 4a86f86e9..a9c03385d 100644 --- a/src/wcstringutil.h +++ b/src/wcstringutil.h @@ -2,6 +2,7 @@ #ifndef FISH_WCSTRINGUTIL_H #define FISH_WCSTRINGUTIL_H +#include #include #include @@ -20,4 +21,32 @@ typedef std::pair wcstring_range; wcstring_range wcstring_tok(wcstring& str, const wcstring& needle, wcstring_range last = wcstring_range(0, 0)); +/// Given iterators into a string (forward or reverse), splits the haystack iterators +/// about the needle sequence, up to max times. Inserts splits into the output array. +/// If the iterators are forward, this does the normal thing. +/// If the iterators are backward, this returns reversed strings, in reversed order! +/// If the needle is empty, split on individual elements (characters). +template +void split_about(ITER haystack_start, ITER haystack_end, ITER needle_start, ITER needle_end, + wcstring_list_t *output, long max) { + long remaining = max; + ITER haystack_cursor = haystack_start; + while (remaining > 0 && haystack_cursor != haystack_end) { + ITER split_point; + if (needle_start == needle_end) { // empty needle, we split on individual elements + split_point = haystack_cursor + 1; + } else { + split_point = std::search(haystack_cursor, haystack_end, needle_start, needle_end); + } + if (split_point == haystack_end) { // not found + break; + } + output->push_back(wcstring(haystack_cursor, split_point)); + remaining--; + // Need to skip over the needle for the next search note that the needle may be empty. + haystack_cursor = split_point + std::distance(needle_start, needle_end); + } + // Trailing component, possibly empty. + output->push_back(wcstring(haystack_cursor, haystack_end)); +} #endif