diff options
| author | Joel Klinghed <the_jk@spawned.biz> | 2025-09-28 22:50:56 +0200 |
|---|---|---|
| committer | Joel Klinghed <the_jk@spawned.biz> | 2025-09-28 22:52:31 +0200 |
| commit | 0ca22c7d6d650c80906bd1217fccf32066cc2502 (patch) | |
| tree | 518c864de533308dd491d72b24338ad6bd596a1c | |
| parent | fb776823ec3174354f14866495ce11d38cbe5701 (diff) | |
str: Add trim()
| -rw-r--r-- | src/str.cc | 19 | ||||
| -rw-r--r-- | src/str.hh | 3 | ||||
| -rw-r--r-- | test/str.cc | 29 |
3 files changed, 51 insertions, 0 deletions
@@ -6,6 +6,15 @@ namespace str { +namespace { + +[[nodiscard]] +inline bool is_space(char c) { + return c == ' ' || c == '\t' || c == '\r' || c == '\n'; +} + +} // namespace + void split(std::string_view str, std::vector<std::string_view>& out, char separator, bool keep_empty) { out.clear(); @@ -31,4 +40,14 @@ std::vector<std::string_view> split(std::string_view str, char separator, return vec; } +std::string_view trim(std::string_view str) { + size_t s = 0; + size_t e = str.size(); + while (s < e && is_space(str[s])) + ++s; + while (e > s && is_space(str[e - 1])) + --e; + return str.substr(s, e - s); +} + } // namespace str @@ -13,6 +13,9 @@ void split(std::string_view str, std::vector<std::string_view>& out, char separator = ' ', bool keep_empty = false); +[[nodiscard]] +std::string_view trim(std::string_view str); + } // namespace str #endif // STR_HH diff --git a/test/str.cc b/test/str.cc index 1339bb0..6d7edf2 100644 --- a/test/str.cc +++ b/test/str.cc @@ -36,3 +36,32 @@ TEST(str, split) { EXPECT_EQ("a", ret[1]); EXPECT_EQ("b", ret[2]); } + +TEST(str, trim) { + auto ret = str::trim(""); + EXPECT_EQ("", ret); + + ret = str::trim(" "); + EXPECT_EQ("", ret); + + ret = str::trim(" "); + EXPECT_EQ("", ret); + + ret = str::trim("foo"); + EXPECT_EQ("foo", ret); + + ret = str::trim(" foo"); + EXPECT_EQ("foo", ret); + + ret = str::trim(" foo "); + EXPECT_EQ("foo", ret); + + ret = str::trim("foo "); + EXPECT_EQ("foo", ret); + + ret = str::trim(" foo bar "); + EXPECT_EQ("foo bar", ret); + + ret = str::trim("\tfoo bar\r\n"); + EXPECT_EQ("foo bar", ret); +} |
