diff options
author | Peter Mikkelsen <peter@pmikkelsen.com> | 2022-02-23 11:44:40 +0000 |
---|---|---|
committer | Peter Mikkelsen <peter@pmikkelsen.com> | 2022-02-23 11:44:40 +0000 |
commit | 0f547edbd76814f7a8299f5e1647cd0816276ba8 (patch) | |
tree | 52253bf26bb967e929a47109ac04775d098ea28f /concurrency.c | |
parent | 40af1deff9db7b86532db6957ebdbc0aaff38db1 (diff) |
Add seperate error handlers in threads
Diffstat (limited to 'concurrency.c')
-rw-r--r-- | concurrency.c | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/concurrency.c b/concurrency.c index d04876d..81ff7b1 100644 --- a/concurrency.c +++ b/concurrency.c @@ -117,9 +117,18 @@ newprocfn(void *data) ThreadData *td = newthreaddata(); void **tdptr = threaddata(); *tdptr = td; - int done = 1; - send(sp->setupdone, &done); - runfunc(sp->func, sp->left, sp->right); + ErrorGuard *eg = newerrorguard(mkscalarint(0), nil); /* make a catch-all error guard */ + if(setjmp(eg->jmp)){ + print("Thread %d: %S%S%S\n", + threadid(), + errorstr(td->lasterror), + (td->lasterror && td->lasterrormsg) ? L": " : L"", + td->lasterrormsg ? td->lasterrormsg : L""); + }else{ + int done = 1; + send(sp->setupdone, &done); + runfunc(sp->func, sp->left, sp->right); + } lock(&threadlock); /* TODO remove thread */ unlock(&threadlock); |