summaryrefslogtreecommitdiffstats
path: root/server-client.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@openbsd.org>2010-02-06 22:55:31 +0000
committerNicholas Marriott <nicm@openbsd.org>2010-02-06 22:55:31 +0000
commitbb53c20c1882cbc909d4fe2ae3c6ad665da6abf6 (patch)
tree345afb7897f7639b2c8981674e064d976f68ab57 /server-client.c
parent0a86d3579edb44ee559cfe6498f43d6637a08bd9 (diff)
Support attaching a client read-only with a new -r flag to the attach-session
command.
Diffstat (limited to 'server-client.c')
-rw-r--r--server-client.c25
1 files changed, 16 insertions, 9 deletions
diff --git a/server-client.c b/server-client.c
index 03560c1c..03d5c84b 100644
--- a/server-client.c
+++ b/server-client.c
@@ -271,6 +271,8 @@ server_client_handle_key(int key, struct mouse_event *mouse, void *data)
/* Special case: number keys jump to pane in identify mode. */
if (c->flags & CLIENT_IDENTIFY && key >= '0' && key <= '9') {
+ if (c->flags & CLIENT_READONLY)
+ return;
wp = window_pane_at_index(w, key - '0');
if (wp != NULL && window_pane_visible(wp))
window_set_active_pane(w, wp);
@@ -279,15 +281,20 @@ server_client_handle_key(int key, struct mouse_event *mouse, void *data)
}
/* Handle status line. */
- status_message_clear(c);
- server_clear_identify(c);
+ if (!(c->flags & CLIENT_READONLY)) {
+ status_message_clear(c);
+ server_clear_identify(c);
+ }
if (c->prompt_string != NULL) {
- status_prompt_key(c, key);
+ if (!(c->flags & CLIENT_READONLY))
+ status_prompt_key(c, key);
return;
}
/* Check for mouse keys. */
if (key == KEYC_MOUSE) {
+ if (c->flags & CLIENT_READONLY)
+ return;
if (options_get_number(oo, "mouse-select-pane")) {
window_set_active_at(w, mouse->x, mouse->y);
server_redraw_window_borders(w);
@@ -313,9 +320,10 @@ server_client_handle_key(int key, struct mouse_event *mouse, void *data)
c->flags |= CLIENT_PREFIX;
else {
/* Try as a non-prefix key binding. */
- if ((bd = key_bindings_lookup(key)) == NULL)
- window_pane_key(wp, c, key);
- else
+ if ((bd = key_bindings_lookup(key)) == NULL) {
+ if (!(c->flags & CLIENT_READONLY))
+ window_pane_key(wp, c, key);
+ } else
key_bindings_dispatch(bd, c);
}
return;
@@ -329,7 +337,7 @@ server_client_handle_key(int key, struct mouse_event *mouse, void *data)
c->flags &= ~CLIENT_REPEAT;
if (isprefix)
c->flags |= CLIENT_PREFIX;
- else
+ else if (!(c->flags & CLIENT_READONLY))
window_pane_key(wp, c, key);
}
return;
@@ -340,7 +348,7 @@ server_client_handle_key(int key, struct mouse_event *mouse, void *data)
c->flags &= ~CLIENT_REPEAT;
if (isprefix)
c->flags |= CLIENT_PREFIX;
- else
+ else if (!(c->flags & CLIENT_READONLY))
window_pane_key(wp, c, key);
return;
}
@@ -660,7 +668,6 @@ server_client_msg_command(struct client *c, struct msg_command_data *data)
{
struct cmd_ctx ctx;
struct cmd_list *cmdlist = NULL;
- struct cmd *cmd;
int argc;
char **argv, *cause;