From 47e3d475df6244a48b73421cd4210b64c392df8d Mon Sep 17 00:00:00 2001 From: Nicholas Noll Date: Tue, 19 Oct 2021 09:35:59 -0700 Subject: feat(rc): cleaner process watching for each job --- sys/cmd/rc/job.c | 82 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 82 insertions(+) create mode 100644 sys/cmd/rc/job.c (limited to 'sys/cmd/rc/job.c') diff --git a/sys/cmd/rc/job.c b/sys/cmd/rc/job.c new file mode 100644 index 0000000..779ce6c --- /dev/null +++ b/sys/cmd/rc/job.c @@ -0,0 +1,82 @@ +#include "rc.h" + +#include +#include + +// ----------------------------------------------------------------------- +// exports + +Thread * +getjob(int pid, int *index) +{ + int i; + Thread *job; + for(i=0,job=shell.jobs; job && job->pid != pid; i++, job=job->next) + ; + + return job; +} + +void +report(Thread *job, int index) +{ + switch(job->wait.status){ + case PDone: + print(shell.err, "job %d [%d]: done\n", index, job->pid); + break; + case PStop: + print(shell.err, "job %d [%d]: suspended\n", index, job->pid); + break; + case PAgain: + print(shell.err, "job %d [%d]: continued\n", index, job->pid); + break; + case PRun: + print(shell.err, "job %d [%d]: running\n", index, job->pid); + break; + default: + fatal("bad wait status: %d\n", job->wait.status); + } +} + +void +wakeup(Thread *t) +{ + int i; + t->wait.status = PRun; + for(i=0; i < t->wait.len; i++){ + if(t->wait.on[i].status == PStop) + t->wait.on[i].status = PRun; + } +} + +void +foreground(Thread *job, int signal) +{ + tcsetpgrp(0, job->pgid); + if(signal){ + if(kill(-job->pgid, SIGCONT) < 0) + perror("kill[SIGCONT]"); + } + + waitall(job); + + tcsetpgrp(0, shell.pid); +} + +void +addjob(Thread *job) +{ + job->next = shell.jobs; + shell.jobs = job; +} + +void +deljob(Thread *job) +{ + Thread **jp; + + for(jp = &shell.jobs; *jp && *jp != job; jp = &(*jp)->next) + ; + + *jp = job->next; +} -- cgit v1.2.1