summaryrefslogtreecommitdiff
path: root/concurrency.c
diff options
context:
space:
mode:
authorPeter Mikkelsen <peter@pmikkelsen.com>2022-02-23 11:44:40 +0000
committerPeter Mikkelsen <peter@pmikkelsen.com>2022-02-23 11:44:40 +0000
commit0f547edbd76814f7a8299f5e1647cd0816276ba8 (patch)
tree52253bf26bb967e929a47109ac04775d098ea28f /concurrency.c
parent40af1deff9db7b86532db6957ebdbc0aaff38db1 (diff)
Add seperate error handlers in threads
Diffstat (limited to 'concurrency.c')
-rw-r--r--concurrency.c15
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);