From 2727705528aa70f46fab2666b76ab0043469ff80 Mon Sep 17 00:00:00 2001 From: Bruce Hill Date: Fri, 20 Feb 2026 00:18:03 -0500 Subject: Code cleanup and copy over some CString methods to path --- src/stdlib/c_strings.c | 6 ++++-- src/stdlib/c_strings.h | 3 +++ src/stdlib/paths.c | 3 +++ 3 files changed, 10 insertions(+), 2 deletions(-) (limited to 'src/stdlib') diff --git a/src/stdlib/c_strings.c b/src/stdlib/c_strings.c index cbe46b68..e70d6d81 100644 --- a/src/stdlib/c_strings.c +++ b/src/stdlib/c_strings.c @@ -47,7 +47,8 @@ PUREFUNC public bool CString$is_none(const void *c_str, const TypeInfo_t *info) return *(const char **)c_str == NULL; } -static void CString$serialize(const void *obj, FILE *out, Table_t *pointers, const TypeInfo_t *info) { +public +void CString$serialize(const void *obj, FILE *out, Table_t *pointers, const TypeInfo_t *info) { (void)info; const char *str = *(const char **)obj; int64_t len = (int64_t)strlen(str); @@ -55,7 +56,8 @@ static void CString$serialize(const void *obj, FILE *out, Table_t *pointers, con fwrite(str, sizeof(char), (size_t)len, out); } -static void CString$deserialize(FILE *in, void *out, List_t *pointers, const TypeInfo_t *info) { +public +void CString$deserialize(FILE *in, void *out, List_t *pointers, const TypeInfo_t *info) { (void)info; int64_t len = -1; Int64$deserialize(in, &len, pointers, &Int64$info); diff --git a/src/stdlib/c_strings.h b/src/stdlib/c_strings.h index eba3a3df..7a45e54a 100644 --- a/src/stdlib/c_strings.h +++ b/src/stdlib/c_strings.h @@ -12,6 +12,9 @@ Text_t CString$as_text(const char **str, bool colorize, const TypeInfo_t *info); PUREFUNC int CString$compare(const void *x, const void *y, const TypeInfo_t *type); PUREFUNC bool CString$equal(const void *x, const void *y, const TypeInfo_t *type); PUREFUNC uint64_t CString$hash(const void *str, const TypeInfo_t *type); +PUREFUNC bool CString$is_none(const void *c_str, const TypeInfo_t *info); const char *CString$join(const char *glue, List_t strings); +void CString$serialize(const void *obj, FILE *out, Table_t *pointers, const TypeInfo_t *info); +void CString$deserialize(FILE *in, void *out, List_t *pointers, const TypeInfo_t *info); extern const TypeInfo_t CString$info; diff --git a/src/stdlib/paths.c b/src/stdlib/paths.c index db596b04..907467bd 100644 --- a/src/stdlib/paths.c +++ b/src/stdlib/paths.c @@ -867,5 +867,8 @@ const TypeInfo_t Path$info = { .compare = CString$compare, .equal = CString$equal, .hash = CString$hash, + .is_none = CString$is_none, + .serialize = CString$serialize, + .deserialize = CString$deserialize, }, }; -- cgit v1.2.3