diff options
| author | Per Larsson <[email protected]> | 2021-09-17 13:10:12 +0200 |
|---|---|---|
| committer | Per Larsson <[email protected]> | 2021-09-17 13:10:12 +0200 |
| commit | ca33b89e2ec26355b17e589fb254fa59438c87d8 (patch) | |
| tree | a874c2abfc65fe62013cb5b4bfd149e501f499b0 /zencore/include | |
| parent | Merge branch 'main' of https://github.com/EpicGames/zen (diff) | |
| download | zen-ca33b89e2ec26355b17e589fb254fa59438c87d8.tar.xz zen-ca33b89e2ec26355b17e589fb254fa59438c87d8.zip | |
Added helper function for iterating string tokens.
Diffstat (limited to 'zencore/include')
| -rw-r--r-- | zencore/include/zencore/string.h | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/zencore/include/zencore/string.h b/zencore/include/zencore/string.h index 2b5f20f86..bb9b1c896 100644 --- a/zencore/include/zencore/string.h +++ b/zencore/include/zencore/string.h @@ -622,6 +622,45 @@ ToLower(const std::string_view& InString) ////////////////////////////////////////////////////////////////////////// +template<typename Fn> +uint32_t +ForEachStrTok(const std::string_view& Str, char Delim, Fn&& Func) +{ + auto It = Str.begin(); + auto End = Str.end(); + uint32_t Count = 0; + + while (It != End) + { + if (*It == Delim) + { + It++; + continue; + } + + std::string_view Remaining{It, End}; + size_t Idx = Remaining.find(Delim, 0); + + if (Idx == std::string_view::npos) + { + Idx = Remaining.size(); + } + + Count++; + std::string_view Token{It, It + Idx}; + if (!Func(Token)) + { + break; + } + + It = It + Idx; + } + + return Count; +} + +////////////////////////////////////////////////////////////////////////// + void string_forcelink(); // internal } // namespace zen |