summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@cvs.openbsd.org>2009-10-10 18:42:15 +0000
committerNicholas Marriott <nicm@cvs.openbsd.org>2009-10-10 18:42:15 +0000
commit14f792a4ac90dce6c3fb9105666c40d3b344cf9a (patch)
tree4e21ee45ca7ac1894747ea755aa930137afbd1f0
parent0da4ef9b26a9d6d78e660ef3a8767502bb15793a (diff)
Put all jobs on a global all_jobs list and use that in server.c instead of
running through all the clients.
-rw-r--r--usr.bin/tmux/job.c8
-rw-r--r--usr.bin/tmux/server.c40
-rw-r--r--usr.bin/tmux/tmux.h6
3 files changed, 15 insertions, 39 deletions
diff --git a/usr.bin/tmux/job.c b/usr.bin/tmux/job.c
index b905a692b0f..b54cf40eb03 100644
--- a/usr.bin/tmux/job.c
+++ b/usr.bin/tmux/job.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: job.c,v 1.1 2009/10/10 15:03:01 nicm Exp $ */
+/* $OpenBSD: job.c,v 1.2 2009/10/10 18:42:14 nicm Exp $ */
/*
* Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -30,6 +30,9 @@
* output.
*/
+/* All jobs list. */
+struct joblist all_jobs = SLIST_HEAD_INITIALIZER(&all_jobs);
+
RB_GENERATE(jobs, job, entry, job_cmp);
int
@@ -67,6 +70,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);
}
}
@@ -90,6 +94,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;
@@ -101,6 +106,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);
}
diff --git a/usr.bin/tmux/server.c b/usr.bin/tmux/server.c
index eaa3bf34a20..27bee8b9450 100644
--- a/usr.bin/tmux/server.c
+++ b/usr.bin/tmux/server.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: server.c,v 1.49 2009/10/10 15:03:01 nicm Exp $ */
+/* $OpenBSD: server.c,v 1.50 2009/10/10 18:42:14 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -73,9 +73,7 @@ void server_handle_windows(void);
void server_fill_clients(void);
void server_handle_clients(void);
void server_fill_jobs(void);
-void server_fill_jobs1(struct jobs *);
void server_handle_jobs(void);
-void server_handle_jobs1(struct jobs *);
void server_accept_client(int);
void server_handle_client(struct client *);
void server_handle_window(struct window *, struct window_pane *);
@@ -414,11 +412,7 @@ server_main(int srv_fd)
/* Set window names. */
set_window_names();
- /*
- * Handle window and client sockets. Clients can create
- * windows, so windows must come first to avoid messing up by
- * increasing the array size.
- */
+ /* Handle window and client sockets. */
server_handle_jobs();
server_handle_windows();
server_handle_clients();
@@ -764,22 +758,9 @@ server_fill_clients(void)
void
server_fill_jobs(void)
{
- struct client *c;
- u_int i;
-
- for (i = 0; i < ARRAY_LENGTH(&clients); i++) {
- c = ARRAY_ITEM(&clients, i);
- if (c != NULL)
- server_fill_jobs1(&c->status_jobs);
- }
-}
-
-void
-server_fill_jobs1(struct jobs *jobs)
-{
struct job *job;
- RB_FOREACH(job, jobs, jobs) {
+ SLIST_FOREACH(job, &all_jobs, lentry) {
if (job->fd == -1)
continue;
server_poll_add(job->fd, POLLIN);
@@ -790,23 +771,10 @@ server_fill_jobs1(struct jobs *jobs)
void
server_handle_jobs(void)
{
- struct client *c;
- u_int i;
-
- for (i = 0; i < ARRAY_LENGTH(&clients); i++) {
- c = ARRAY_ITEM(&clients, i);
- if (c != NULL)
- server_handle_jobs1(&c->status_jobs);
- }
-}
-
-void
-server_handle_jobs1(struct jobs *jobs)
-{
struct job *job;
struct pollfd *pfd;
- RB_FOREACH(job, jobs, jobs) {
+ SLIST_FOREACH(job, &all_jobs, lentry) {
if (job->fd == -1)
continue;
if ((pfd = server_poll_lookup(job->fd)) == NULL)
diff --git a/usr.bin/tmux/tmux.h b/usr.bin/tmux/tmux.h
index acae732b0e6..72cfed5dfb2 100644
--- a/usr.bin/tmux/tmux.h
+++ b/usr.bin/tmux/tmux.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: tmux.h,v 1.127 2009/10/10 17:19:38 nicm Exp $ */
+/* $OpenBSD: tmux.h,v 1.128 2009/10/10 18:42:14 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -578,8 +578,10 @@ struct job {
void *data;
RB_ENTRY(job) entry;
+ SLIST_ENTRY(job) lentry;
};
RB_HEAD(jobs, job);
+SLIST_HEAD(joblist, job);
/* Screen selection. */
struct screen_sel {
@@ -1199,7 +1201,7 @@ struct options_entry *options_set_data(
void *options_get_data(struct options *, const char *);
/* job.c */
-extern struct jobs jobs_tree;
+extern struct joblist all_jobs;
int job_cmp(struct job *, struct job *);
RB_PROTOTYPE(jobs, job, entry, job_cmp);
void job_tree_init(struct jobs *);