summaryrefslogtreecommitdiff
path: root/src/std/str.h
diff options
context:
space:
mode:
authorJoshua Rowe <17525998+omnisci3nce@users.noreply.github.com>2024-02-25 13:50:16 +1100
committerGitHub <noreply@github.com>2024-02-25 13:50:16 +1100
commitb5b7cea24c46d28a4b72bc18ca8ccb2d532007d3 (patch)
treefe49ddad815c65ef0deb87dd76e172051e6c49e7 /src/std/str.h
parentfc287c6e4f958242a4272da5cb1704e3e789fe07 (diff)
parent938f745f052c14fccaa987b98ea4ac84e70c1fcc (diff)
Merge pull request #3 from omnisci3nce/feature/some-string-utils
Port String utils but using arena for allocation
Diffstat (limited to 'src/std/str.h')
-rw-r--r--src/std/str.h57
1 files changed, 50 insertions, 7 deletions
diff --git a/src/std/str.h b/src/std/str.h
index 3d3cb41..f6f8820 100644
--- a/src/std/str.h
+++ b/src/std/str.h
@@ -1,30 +1,73 @@
/**
+ * @file str.h
+ * @author your name (you@domain.com)
* @brief
+ * @version 0.1
+ * @date 2024-02-25
+ *
+ * @copyright Copyright (c) 2024
*
*/
#pragma once
#include "defines.h"
+#include "mem.h"
/**
- * @brief Fat pointer representing a UTF8 (TODO) encoded string
- * @note when using `printf` you must use %s.*s length, string
+ * @brief Fat pointer representing a UTF8 encoded string
+ * @note when using `printf` you must use %s.*s length, string until our own modified
+ print routines are written. alternatively wrap in `cstr()` and pass to `%s`.
*/
typedef struct {
- u8 *buf;
+ u8* buf;
size_t len;
} str8;
+// --- Constructors
+
+/** @brief Take a string literal and turn it into a `str8` */
+#define str8lit(s) \
+ (str8) { (u8*)s, ((sizeof(s) / sizeof(*(s)) - 1)) }
+
+str8 str8_create(u8* buf, size_t len);
+
+/** @brief Return a null-terminated C string cloned onto an arena */
+char* str8_to_cstr(arena* a, str8 s);
+
+#define cstr(a, s) (str8_to_cstr(a, s)) // Shorthand
+
+// --- Comparisons
+
/** @brief Compare two strings for exact equality */
bool str8_equals(str8 a, str8 b);
/**
* @brief Compare the first `first_nchars` of each string for equality
- If either of the strings are shorter than the number only the characters up until the end
- of the shorter string will be compared.
+ * @details If either of the strings are shorter than the number only the characters up until the
+ end of the shorter string will be compared.
* @returns 0 if they are fully equal up until `first_nchars`, i.e they never differed, else it
- returns the index at which the first string differed from the second string.
+ returns the index at which the first string differed from the second string.
*/
size_t str8_nequals(str8 a, str8 b, size_t first_nchars);
-bool str8_ends_with(str8 input_str, str8 suffix); \ No newline at end of file
+bool str8_ends_with(str8 input_str, str8 suffix);
+
+/// --- Subviews
+
+str8 str8_substr(str8 s, u64 min, u64 max);
+/** @brief Keeps only the `first_n` chars of `s` */
+str8 str8_take(str8 s, u64 first_n);
+/** @brief Keeps only the `last_n` chars of `s` */
+str8 str8_drop(str8 s, u64 last_n);
+/** @brief Keeps everything after the first `n` chars of `s` */
+str8 str8_skip(str8 s, u64 n);
+/** @brief Keeps everything before the last `n` chars of `s` */
+str8 str8_chop(str8 s, u64 n);
+
+str8 str8_concat(arena* a, str8 left, str8 right);
+
+/// --- Misc
+
+static inline bool str8_is_null_term(str8 a) {
+ return a.buf[a.len] == 0; // This doesn't seem safe. YOLO
+} \ No newline at end of file