aboutsummaryrefslogtreecommitdiff
path: root/stdlib/threads.c
blob: beb6771e111b7754b3e225fb1530054f42f61dbe (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
// 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 <sys/random.h>

#include "arrays.h"
#include "datatypes.h"
#include "text.h"
#include "threads.h"
#include "types.h"
#include "util.h"

static void *run_thread(Closure_t *closure)
{
    long seed;
    getrandom(&seed, sizeof(seed), 0);
    Int$init_random(seed);
    ((void(*)(void*))closure->fn)(closure->userdata);
    return NULL;
}

public Thread_t Thread$new(Closure_t fn)
{
    Thread_t thread = new(pthread_t);
    Closure_t *doop = new(Closure_t, .fn=fn.fn, .userdata=fn.userdata);
    pthread_create(thread, NULL, (void*)run_thread, doop);
    return thread;
}

public void Thread$join(Thread_t thread)
{
    pthread_join(*thread, NULL);
}

public void Thread$cancel(Thread_t thread)
{
    pthread_cancel(*thread);
}

public void Thread$detach(Thread_t thread)
{
    pthread_detach(*thread);
}

Text_t Thread$as_text(const Thread_t *thread, bool colorize, const TypeInfo_t *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_t Thread$info = {
    .size=sizeof(Thread_t), .align=__alignof(Thread_t),
    .tag=CustomInfo,
    .CustomInfo={.as_text=(void*)Thread$as_text},
};

// vim: ts=4 sw=0 et cino=L2,l1,(0,W4,m1,\:0