diff options
author | Tiago Cunha <tcunha@gmx.com> | 2009-10-12 00:12:33 +0000 |
---|---|---|
committer | Tiago Cunha <tcunha@gmx.com> | 2009-10-12 00:12:33 +0000 |
commit | d7fa9bc056be2bc89af85825ffc6e6144759a806 (patch) | |
tree | 64bd55becedefe7d8fb3a24708f7ec7385366f9a /job.c | |
parent | 256a55b33b812ca1ecd03149f879828a960592fe (diff) | |
download | rtmux-d7fa9bc056be2bc89af85825ffc6e6144759a806.tar.gz rtmux-d7fa9bc056be2bc89af85825ffc6e6144759a806.tar.bz2 rtmux-d7fa9bc056be2bc89af85825ffc6e6144759a806.zip |
Sync OpenBSD patchset 379:
Put all jobs on a global all_jobs list and use that in server.c instead of
running through all the clients.
Diffstat (limited to 'job.c')
-rw-r--r-- | job.c | 8 |
1 files changed, 7 insertions, 1 deletions
@@ -1,4 +1,4 @@ -/* $Id: job.c,v 1.2 2009-10-11 23:59:34 tcunha Exp $ */ +/* $Id: job.c,v 1.3 2009-10-12 00:12:32 tcunha Exp $ */ /* * Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net> @@ -29,6 +29,9 @@ * output. */ +/* All jobs list. */ +struct joblist all_jobs = SLIST_HEAD_INITIALIZER(&all_jobs); + RB_GENERATE(jobs, job, entry, job_cmp); int @@ -66,6 +69,7 @@ job_tree_free(struct jobs *jobs) while (!RB_EMPTY(jobs)) { job = RB_ROOT(jobs); RB_REMOVE(jobs, jobs, job); + SLIST_REMOVE(&all_jobs, job, job, lentry); job_free(job); } } @@ -89,6 +93,7 @@ job_add(struct jobs *jobs, struct client *c, const char *cmd, job = xmalloc(sizeof *job); job->cmd = xstrdup(cmd); + job->pid = -1; job->client = c; @@ -100,6 +105,7 @@ job_add(struct jobs *jobs, struct client *c, const char *cmd, job->data = data; RB_INSERT(jobs, jobs, job); + SLIST_INSERT_HEAD(&all_jobs, job, lentry); return (job); } |