aboutsummaryrefslogtreecommitdiff
path: root/job.c
diff options
context:
space:
mode:
authorTiago Cunha <tcunha@gmx.com>2009-10-12 00:12:33 +0000
committerTiago Cunha <tcunha@gmx.com>2009-10-12 00:12:33 +0000
commitd7fa9bc056be2bc89af85825ffc6e6144759a806 (patch)
tree64bd55becedefe7d8fb3a24708f7ec7385366f9a /job.c
parent256a55b33b812ca1ecd03149f879828a960592fe (diff)
downloadrtmux-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.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/job.c b/job.c
index d5b2c389..df53c736 100644
--- a/job.c
+++ b/job.c
@@ -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);
}