diff options
| author | Bruce Hill <bruce@bruce-hill.com> | 2025-02-10 19:04:30 -0500 |
|---|---|---|
| committer | Bruce Hill <bruce@bruce-hill.com> | 2025-02-10 19:04:30 -0500 |
| commit | 04dddda811afe6ee0a9edc65f2a0486bdd88d520 (patch) | |
| tree | 3d3be205b55a295508dfcd254088b0785baa7620 | |
| parent | 481beaf40ef5ebf94968c6e92366341e602fd3b0 (diff) | |
Add missing files
| -rw-r--r-- | stdlib/mutexeddata.c | 38 | ||||
| -rw-r--r-- | stdlib/mutexeddata.h | 17 |
2 files changed, 55 insertions, 0 deletions
diff --git a/stdlib/mutexeddata.c b/stdlib/mutexeddata.c new file mode 100644 index 00000000..f47adfc1 --- /dev/null +++ b/stdlib/mutexeddata.c @@ -0,0 +1,38 @@ +// Mutexed data methods/type info +#include <ctype.h> +#include <err.h> +#include <gc.h> +#include <stdbool.h> +#include <stdint.h> +#include <stdlib.h> +#include <sys/param.h> + +#include "bools.h" +#include "metamethods.h" +#include "optionals.h" +#include "text.h" +#include "util.h" + +static Text_t MutexedData$as_text(const void *m, bool colorize, const TypeInfo_t *type) +{ + auto mutexed = type->MutexedDataInfo; + Text_t typename = generic_as_text(NULL, false, mutexed.type); + if (!m) { + return Texts(colorize ? Text("\x1b[34;1mmutexed\x1b[m(") : Text("mutexed("), typename, Text(")")); + } + return Text$format(colorize ? "\x1b[34;1mmutexed %k<%p>\x1b[m" : "mutexed %k<%p>", &typename, *((MutexedData_t*)m)); +} + +static bool MutexedData$is_none(const void *m, const TypeInfo_t *) +{ + return *((MutexedData_t*)m) == NULL; +} + +public const metamethods_t MutexedData$metamethods = { + .as_text=MutexedData$as_text, + .is_none=MutexedData$is_none, + .serialize=cannot_serialize, + .deserialize=cannot_deserialize, +}; + +// vim: ts=4 sw=0 et cino=L2,l1,(0,W4,m1,\:0 diff --git a/stdlib/mutexeddata.h b/stdlib/mutexeddata.h new file mode 100644 index 00000000..47686195 --- /dev/null +++ b/stdlib/mutexeddata.h @@ -0,0 +1,17 @@ +#pragma once + +// Metamethods and type info for mutexed data + +#include "types.h" +#include "optionals.h" +#include "util.h" + +#define NONE_MUTEXED_DATA ((MutexedData_t)NULL) + +extern const metamethods_t MutexedData$metamethods; + +#define MutexedData$info(t) &((TypeInfo_t){.size=sizeof(MutexedData_t), .align=__alignof(MutexedData_t), \ + .tag=MutexedDataInfo, .MutexedDataInfo.type=t, \ + .metamethods=MutexedData$metamethods}) + +// vim: ts=4 sw=0 et cino=L2,l1,(0,W4,m1,\:0 |
