summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoshua Rowe <17525998+omnisci3nce@users.noreply.github.com>2024-02-26 20:51:58 +1100
committerGitHub <noreply@github.com>2024-02-26 20:51:58 +1100
commit7c71005794ee7904ad113d5fff2c7a9aca3cda53 (patch)
tree84935541a3740305aa3dc7b6cbc9565b112af211
parent06ed6edcedf30fd8f7e036fffe8f81e8ca89d4b0 (diff)
parent055b213beac82f1ca0fb10b2eebce6df3cb216b2 (diff)
Merge pull request #4 from paulkayode/string-subviews
string subview functions
-rw-r--r--src/std/str.c32
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);
+}
+
+