diff options
Diffstat (limited to 'archive/src/std/str.h')
-rw-r--r-- | archive/src/std/str.h | 89 |
1 files changed, 89 insertions, 0 deletions
diff --git a/archive/src/std/str.h b/archive/src/std/str.h new file mode 100644 index 0000000..a29bf9a --- /dev/null +++ b/archive/src/std/str.h @@ -0,0 +1,89 @@ +/** + * @file str.h + * @author your name (you@domain.com) + * @brief + * @version 0.1 + * @date 2024-02-25 + * + * @copyright Copyright (c) 2024 + * + */ +#pragma once + +#include <ctype.h> + +#include "defines.h" +#include "mem.h" + +/** + * @brief Fat pointer representing a UTF8 (TODO some APIs supporting 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; + size_t len; +} Str8; + +// --- Constructors + +/** @brief Take a string literal and turn it into a `str8` */ +#define str8(s) \ + (Str8) { (u8*)s, ((sizeof(s) / sizeof(*(s)) - 1)) } + +Str8 Str8_create(u8* buf, size_t len); + +// TODO: Str8_OntoArena(arena* a, Str8 s); + +/** @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 + +/** @brief Return a Str8 that references a statically allocated string. + `string` therefore must already be null-terminated. + @note The backing `string` cannot be modified. */ +Str8 Str8_cstr_view(char* string); + +char* Clone_cstr(arena* a, const char* s); + +// --- 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 + * @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. +*/ +size_t Str8_nequals(Str8 a, Str8 b, size_t first_nchars); + +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 +} + +// TODO: move or delete this and replace with handling using our internal type +static void skip_space(char* p) { + while (isspace((unsigned char)*p)) ++p; +} |