diff options
| author | Bruce Hill <bruce@bruce-hill.com> | 2024-09-13 20:08:20 -0400 |
|---|---|---|
| committer | Bruce Hill <bruce@bruce-hill.com> | 2024-09-13 20:08:20 -0400 |
| commit | 4380039acc881703ef9d144bbf39d82da4beb936 (patch) | |
| tree | 111eda9fedaa13f593cdf47f75277d740207c637 /builtins/threads.c | |
| parent | 51c346bbc5f6c5179b56b09b75eec466acbe7ad7 (diff) | |
Rename builtins to use plurals when appropriate
Diffstat (limited to 'builtins/threads.c')
| -rw-r--r-- | builtins/threads.c | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/builtins/threads.c b/builtins/threads.c new file mode 100644 index 00000000..74e73832 --- /dev/null +++ b/builtins/threads.c @@ -0,0 +1,55 @@ +// Logic for the Thread type, representing a pthread + +#include <ctype.h> +#include <err.h> +#include <gc.h> +#include <math.h> +#include <stdbool.h> +#include <stdint.h> +#include <stdlib.h> +#include <pthread.h> +#include <sys/param.h> + +#include "arrays.h" +#include "text.h" +#include "types.h" +#include "util.h" + +public pthread_t *Thread$new(Closure_t fn) +{ + pthread_t *thread = new(pthread_t); + pthread_create(thread, NULL, fn.fn, fn.userdata); + return thread; +} + +public void Thread$join(pthread_t *thread) +{ + pthread_join(*thread, NULL); +} + +public void Thread$cancel(pthread_t *thread) +{ + pthread_cancel(*thread); +} + +public void Thread$detach(pthread_t *thread) +{ + pthread_detach(*thread); +} + +Text_t Thread$as_text(const pthread_t **thread, bool colorize, const TypeInfo *type) +{ + (void)type; + if (!thread) { + return colorize ? Text("\x1b[34;1mThread\x1b[m") : Text("Thread"); + } + return Text$format(colorize ? "\x1b[34;1mThread(%p)\x1b[m" : "Thread(%p)", *thread); +} + +public const TypeInfo Thread = { + .size=sizeof(pthread_t*), .align=__alignof(pthread_t*), + .tag=CustomInfo, + .CustomInfo={.as_text=(void*)Thread$as_text}, +}; + +// vim: ts=4 sw=0 et cino=L2,l1,(0,W4,m1,\:0 |
