aboutsummaryrefslogtreecommitdiff
path: root/server-client.c
diff options
context:
space:
mode:
authorTiago Cunha <tcunha@gmx.com>2012-07-11 19:37:32 +0000
committerTiago Cunha <tcunha@gmx.com>2012-07-11 19:37:32 +0000
commit1f5e6e35d5046693f0ef5ec76535f517757b7122 (patch)
treee53808c90f3a53279554f8580d2b96df606baec3 /server-client.c
parenta432fcd30617610b46d65f49b7513bf5da5694de (diff)
downloadrtmux-1f5e6e35d5046693f0ef5ec76535f517757b7122.tar.gz
rtmux-1f5e6e35d5046693f0ef5ec76535f517757b7122.tar.bz2
rtmux-1f5e6e35d5046693f0ef5ec76535f517757b7122.zip
Sync OpenBSD patchset 1151:
Make command exec functions return an enum rather than -1/0/1 values and add a new value to mean "leave client running but don't attach" to fix problems with using some commands in a command sequence. Most of the work by Thomas Adam, problem reported by "jspenguin" on SF bug 3535531.
Diffstat (limited to 'server-client.c')
-rw-r--r--server-client.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/server-client.c b/server-client.c
index e2a5b957..1f407e4f 100644
--- a/server-client.c
+++ b/server-client.c
@@ -867,8 +867,16 @@ server_client_msg_command(struct client *c, struct msg_command_data *data)
}
cmd_free_argv(argc, argv);
- if (cmd_list_exec(cmdlist, &ctx) != 1)
+ switch (cmd_list_exec(cmdlist, &ctx))
+ {
+ case CMD_RETURN_ERROR:
+ case CMD_RETURN_NORMAL:
c->flags |= CLIENT_EXIT;
+ break;
+ case CMD_RETURN_ATTACH:
+ case CMD_RETURN_YIELD:
+ break;
+ }
cmd_list_free(cmdlist);
return;