From 938f745f052c14fccaa987b98ea4ac84e70c1fcc Mon Sep 17 00:00:00 2001 From: Omniscient <17525998+omnisci3nce@users.noreply.github.com> Date: Sun, 25 Feb 2024 13:49:12 +1100 Subject: chore: format --- examples/standard_lib/ex_std.c | 30 ++++++++++++++++++++++++++++++ src/platform/file.h | 4 ++-- src/std/str.h | 20 ++++++++++---------- 3 files changed, 42 insertions(+), 12 deletions(-) create mode 100644 examples/standard_lib/ex_std.c diff --git a/examples/standard_lib/ex_std.c b/examples/standard_lib/ex_std.c new file mode 100644 index 0000000..9d474de --- /dev/null +++ b/examples/standard_lib/ex_std.c @@ -0,0 +1,30 @@ +#include +#include +#include "file.h" +#include "str.h" + +int main() { + // Examples of how to work with arenas and strings + size_t arena_size = 1024; + arena scratch = arena_create(malloc(arena_size), arena_size); + arena* a = &scratch; + + str8 hello = str8lit("Hello World"); + + // this works but we should be careful because str8 is not *guaranteed* to point to + // a null-terminated string + printf("String before: '%s' (null-terminated: %s) \n ", hello.buf, + str8_is_null_term(hello) ? "true" : "false"); + + char* c = str8_to_cstr(&scratch, hello); + + printf("String after: %s\n", c); + + str8_opt test_file = str8_from_file(&scratch, str8lit("assets/shaders/ui_rect.vert")); + if (test_file.has_value) { + printf("Contents: %.*s \n", (int)test_file.contents.len, test_file.contents.buf); + printf("Null-terminated: %s\n", str8_is_null_term(test_file.contents) ? "true" : "false"); + } + + return 0; +} diff --git a/src/platform/file.h b/src/platform/file.h index fa09891..8bb22c8 100644 --- a/src/platform/file.h +++ b/src/platform/file.h @@ -10,8 +10,8 @@ #include "str.h" typedef struct str8_opt { - str8 contents; - bool has_value; + str8 contents; + bool has_value; } str8_opt; const char* string_from_file(const char* path); diff --git a/src/std/str.h b/src/std/str.h index d2fa891..f6f8820 100644 --- a/src/std/str.h +++ b/src/std/str.h @@ -1,12 +1,12 @@ /** * @file str.h * @author your name (you@domain.com) - * @brief + * @brief * @version 0.1 * @date 2024-02-25 - * + * * @copyright Copyright (c) 2024 - * + * */ #pragma once @@ -19,22 +19,22 @@ 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))} +#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 +#define cstr(a, s) (str8_to_cstr(a, s)) // Shorthand // --- Comparisons @@ -43,8 +43,8 @@ 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. + * @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. */ @@ -69,5 +69,5 @@ 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 + return a.buf[a.len] == 0; // This doesn't seem safe. YOLO } \ No newline at end of file -- cgit v1.2.3-70-g09d2