diff options
author | Joshua Rowe <17525998+omnisci3nce@users.noreply.github.com> | 2024-02-26 20:51:58 +1100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-02-26 20:51:58 +1100 |
commit | 7c71005794ee7904ad113d5fff2c7a9aca3cda53 (patch) | |
tree | 84935541a3740305aa3dc7b6cbc9565b112af211 | |
parent | 06ed6edcedf30fd8f7e036fffe8f81e8ca89d4b0 (diff) | |
parent | 055b213beac82f1ca0fb10b2eebce6df3cb216b2 (diff) |
Merge pull request #4 from paulkayode/string-subviews
string subview functions
-rw-r--r-- | src/std/str.c | 32 |
1 files changed, 30 insertions, 2 deletions
diff --git a/src/std/str.c b/src/std/str.c index 3b2770e..7dafef1 100644 --- a/src/std/str.c +++ b/src/std/str.c @@ -1,6 +1,6 @@ #include "str.h" #include <string.h> - +#include <assert.h> #include "mem.h" str8 str8_create(u8* buf, size_t len) { return (str8){ .buf = buf, .len = len }; } @@ -41,4 +41,32 @@ str8 str8_concat(arena* a, str8 left, str8 right) { dest[n_bytes - 1] = '\0'; return str8_create(dest, n_bytes); -}
\ No newline at end of file +} + +str8 str8_substr(str8 s, u64 min, u64 max) { + assert(min >= 0); + assert(min < s.len); + assert(max >= 0); + assert(max <= s.len); + uint8_t * start = s.buf + (ptrdiff_t)min; + size_t new_len = max - min; + return (str8) {.buf = start, .len = new_len }; +} + +str8 str8_take(str8 s, u64 first_n) { + return str8_substr(s, 0, first_n); +} + +str8 str8_drop(str8 s, u64 last_n) { + return str8_substr(s, s.len - last_n, s.len); +} + +str8 str8_skip(str8 s, u64 n) { + return str8_substr(s, n, s.len); +} + +str8 str8_chop(str8 s, u64 n) { + return str8_substr(s, 0, s.len - n); +} + + |