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/string.cpp | |
| 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/string.cpp')
| -rw-r--r-- | zencore/string.cpp | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/zencore/string.cpp b/zencore/string.cpp index 8ea10d2a3..ce1b6d675 100644 --- a/zencore/string.cpp +++ b/zencore/string.cpp @@ -912,4 +912,44 @@ TEST_CASE("filepath") CHECK(FilepathFindExtension(".txt") == std::string_view(".txt")); } +TEST_CASE("string") +{ + using namespace std::literals; + + SUBCASE("ForEachStrTok") + { + const auto Tokens = "here,is,my,different,tokens"sv; + int32_t ExpectedTokenCount = 5; + int32_t TokenCount = 0; + StringBuilder<512> Sb; + + TokenCount = ForEachStrTok(Tokens, ',', [&Sb](const std::string_view& Token) { + if (Sb.Size()) + { + Sb << ","; + } + Sb << Token; + return true; + }); + + CHECK(TokenCount == ExpectedTokenCount); + CHECK(Sb.ToString() == Tokens); + + ExpectedTokenCount = 1; + const auto Str = "mosdef"sv; + + Sb.Reset(); + TokenCount = ForEachStrTok(Str, ' ', [&Sb](const std::string_view& Token) { + Sb << Token; + return true; + }); + CHECK(Sb.ToString() == Str); + CHECK(TokenCount == ExpectedTokenCount); + + ExpectedTokenCount = 0; + TokenCount = ForEachStrTok(""sv, ',', [](const std::string_view&) { return true; }); + CHECK(TokenCount == ExpectedTokenCount); + } +} + } // namespace zen |