summaryrefslogtreecommitdiff
path: root/src/std/str.c
diff options
context:
space:
mode:
authoromniscient <17525998+omnisci3nce@users.noreply.github.com>2024-03-05 21:31:01 +1100
committeromniscient <17525998+omnisci3nce@users.noreply.github.com>2024-03-05 21:31:01 +1100
commit428765380da3e7fdb8122e440b5d4065620fc8fb (patch)
tree045c1ea373fe3a71f46fca5a47d3678afb656be6 /src/std/str.c
parent3854bef8b853a369c4fc3a39abff5e2e9cd77625 (diff)
parenta627f75cc956a463e3910a8f5f615932bad3a418 (diff)
Merge branch 'master' into cel-41-port-over-a-basic-3d-scene-example
Diffstat (limited to 'src/std/str.c')
-rw-r--r--src/std/str.c22
1 files changed, 20 insertions, 2 deletions
diff --git a/src/std/str.c b/src/std/str.c
index 3b2770e..1c687fa 100644
--- a/src/std/str.c
+++ b/src/std/str.c
@@ -1,6 +1,6 @@
#include "str.h"
+#include <assert.h>
#include <string.h>
-
#include "mem.h"
str8 str8_create(u8* buf, size_t len) { return (str8){ .buf = buf, .len = len }; }
@@ -41,4 +41,22 @@ 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); }