Blame docs/code/queue-work/main.c

Packit b5b901
#include <stdio.h>
Packit b5b901
#include <stdlib.h>
Packit b5b901
#include <unistd.h>
Packit b5b901
Packit b5b901
#include <uv.h>
Packit b5b901
Packit b5b901
#define FIB_UNTIL 25
Packit b5b901
uv_loop_t *loop;
Packit b5b901
Packit b5b901
long fib_(long t) {
Packit b5b901
    if (t == 0 || t == 1)
Packit b5b901
        return 1;
Packit b5b901
    else
Packit b5b901
        return fib_(t-1) + fib_(t-2);
Packit b5b901
}
Packit b5b901
Packit b5b901
void fib(uv_work_t *req) {
Packit b5b901
    int n = *(int *) req->data;
Packit b5b901
    if (random() % 2)
Packit b5b901
        sleep(1);
Packit b5b901
    else
Packit b5b901
        sleep(3);
Packit b5b901
    long fib = fib_(n);
Packit b5b901
    fprintf(stderr, "%dth fibonacci is %lu\n", n, fib);
Packit b5b901
}
Packit b5b901
Packit b5b901
void after_fib(uv_work_t *req, int status) {
Packit b5b901
    fprintf(stderr, "Done calculating %dth fibonacci\n", *(int *) req->data);
Packit b5b901
}
Packit b5b901
Packit b5b901
int main() {
Packit b5b901
    loop = uv_default_loop();
Packit b5b901
Packit b5b901
    int data[FIB_UNTIL];
Packit b5b901
    uv_work_t req[FIB_UNTIL];
Packit b5b901
    int i;
Packit b5b901
    for (i = 0; i < FIB_UNTIL; i++) {
Packit b5b901
        data[i] = i;
Packit b5b901
        req[i].data = (void *) &data[i];
Packit b5b901
        uv_queue_work(loop, &req[i], fib, after_fib);
Packit b5b901
    }
Packit b5b901
Packit b5b901
    return uv_run(loop, UV_RUN_DEFAULT);
Packit b5b901
}