summaryrefslogtreecommitdiff
path: root/archive/src/std/str.c
diff options
context:
space:
mode:
authoromniscient <17525998+omnisci3nce@users.noreply.github.com>2024-10-26 21:55:23 +1100
committeromniscient <17525998+omnisci3nce@users.noreply.github.com>2024-10-26 21:55:23 +1100
commit43bee361397315c7105b7214316325b185135331 (patch)
treeb339f728b4cd6f37b37912b62c8d0af75dc9551d /archive/src/std/str.c
parent24573518c3320673eb87d6d659522d77e05cb75c (diff)
move archive into /src
Diffstat (limited to 'archive/src/std/str.c')
-rw-r--r--archive/src/std/str.c74
1 files changed, 0 insertions, 74 deletions
diff --git a/archive/src/std/str.c b/archive/src/std/str.c
deleted file mode 100644
index 89c76a0..0000000
--- a/archive/src/std/str.c
+++ /dev/null
@@ -1,74 +0,0 @@
-#include "str.h"
-#include <assert.h>
-#include <string.h>
-#include "log.h"
-#include "mem.h"
-
-Str8 Str8_create(u8* buf, size_t len) { return (Str8){ .buf = buf, .len = len }; }
-
-Str8 Str8_cstr_view(char* string) { return Str8_create((u8*)string, strlen(string)); }
-
-bool Str8_equals(Str8 a, Str8 b) {
- if (a.len != b.len) {
- return false;
- }
-
- for (size_t i = 0; i < a.len; i++) {
- if (a.buf[i] != b.buf[i]) {
- return false;
- }
- }
- return true;
-}
-
-char* Str8_to_cstr(arena* a, Str8 s) {
- bool is_null_terminated = s.buf[s.len - 1] == 0;
- size_t n_bytes = is_null_terminated ? s.len : s.len + 1;
-
- u8* dest = arena_alloc(a, n_bytes);
-
- memcpy(dest, s.buf, s.len);
- if (is_null_terminated) {
- dest[s.len] = '\0';
- }
- return (char*)dest;
-}
-
-char* Clone_cstr(arena* a, const char* s) {
- if (s == NULL) {
- WARN("Tried to clone a NULL char*");
- return NULL;
- }
- Str8 st = Str8_cstr_view(s);
- return Str8_to_cstr(a, st);
-}
-
-Str8 Str8_concat(arena* a, Str8 left, Str8 right) {
- size_t n_bytes = left.len + right.len + 1;
-
- u8* dest = arena_alloc(a, n_bytes);
- memcpy(dest, left.buf, left.len);
- memcpy(dest + right.len, right.buf, right.len);
-
- dest[n_bytes - 1] = '\0';
-
- return Str8_create(dest, n_bytes);
-}
-
-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); }