aboutsummaryrefslogtreecommitdiff
path: root/zencore/include
diff options
context:
space:
mode:
authorPer Larsson <[email protected]>2021-09-17 13:10:12 +0200
committerPer Larsson <[email protected]>2021-09-17 13:10:12 +0200
commitca33b89e2ec26355b17e589fb254fa59438c87d8 (patch)
treea874c2abfc65fe62013cb5b4bfd149e501f499b0 /zencore/include
parentMerge branch 'main' of https://github.com/EpicGames/zen (diff)
downloadzen-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.h39
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