diff options
| author | Tyge Løvset <[email protected]> | 2023-02-26 20:16:01 +0100 |
|---|---|---|
| committer | Tyge Løvset <[email protected]> | 2023-02-26 20:16:01 +0100 |
| commit | 1871ee8e9b4ca4edde387be973035c259fc9191f (patch) | |
| tree | 1efe5529a46099d61fd1ae7b89f15f08b78064bf /misc/examples/coroutines.c | |
| parent | 00313bfa4f448253ac95640ed962130ec3d14b19 (diff) | |
| download | STC-modified-1871ee8e9b4ca4edde387be973035c259fc9191f.tar.gz STC-modified-1871ee8e9b4ca4edde387be973035c259fc9191f.zip | |
Addition to coroutine.h. Allow dynamic allocation of context.
Diffstat (limited to 'misc/examples/coroutines.c')
| -rw-r--r-- | misc/examples/coroutines.c | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/misc/examples/coroutines.c b/misc/examples/coroutines.c index 120f11b8..66a1275e 100644 --- a/misc/examples/coroutines.c +++ b/misc/examples/coroutines.c @@ -4,15 +4,13 @@ // Use coroutine to create a fibonacci sequence generator: -typedef long long intll_t; - struct fibonacci { int n; int cco_state; - intll_t a, b, idx; + int64_t a, b, idx; }; -intll_t fibonacci(struct fibonacci* F) { +int64_t fibonacci(struct fibonacci* F) { assert (F->n < 95); cco_begin(F); @@ -20,7 +18,7 @@ intll_t fibonacci(struct fibonacci* F) { F->b = 1; for (F->idx = 0; F->idx < F->n; F->idx++) { cco_yield(F->a); - intll_t sum = F->a + F->b; // NB! locals only lasts until next cco_yield! + int64_t sum = F->a + F->b; // NB! locals only lasts until next cco_yield! F->a = F->b; F->b = sum; } @@ -50,16 +48,16 @@ bool iterate(struct iterate* I, struct fibonacci* F) { } } cco_final: + puts("final"); cco_end(); return false; } int main(void) { - printf("Fibonacci numbers:\n"); struct fibonacci fib = {.n = 14}; - struct iterate iter = {3, 3}; + struct iterate it = {3, 3}; - while (iterate(&iter, &fib)) - printf("%d %d. Fib: %lld\n", iter.x, iter.y, fib.a); + while (iterate(&it, &fib)) + printf("Iter=(%d, %d). Fib=%lld\n", it.x, it.y, (long long)fib.a); } |
