diff options
| author | 2011-03-28 23:13:00 +0000 | |
|---|---|---|
| committer | 2011-03-28 23:13:00 +0000 | |
| commit | c8b80c745f1958386c00643e230ae7fe4fe4ef7c (patch) | |
| tree | 0ab190a4a7a9206e0ee23a242e3c4f48c12503a8 /usr.bin/tmux/cmd-list-windows.c | |
| parent | sync from www/build/mirrors.dat (diff) | |
| download | wireguard-openbsd-c8b80c745f1958386c00643e230ae7fe4fe4ef7c.tar.xz wireguard-openbsd-c8b80c745f1958386c00643e230ae7fe4fe4ef7c.zip | |
Add -a and -s options to lsp to list all panes in the server or session
respectively. Likewise add -s to lsw. From Ben Boeckel.
Diffstat (limited to 'usr.bin/tmux/cmd-list-windows.c')
| -rw-r--r-- | usr.bin/tmux/cmd-list-windows.c | 39 |
1 files changed, 31 insertions, 8 deletions
diff --git a/usr.bin/tmux/cmd-list-windows.c b/usr.bin/tmux/cmd-list-windows.c index 2a27ad74c94..203336d415f 100644 --- a/usr.bin/tmux/cmd-list-windows.c +++ b/usr.bin/tmux/cmd-list-windows.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmd-list-windows.c,v 1.11 2011/01/04 00:42:46 nicm Exp $ */ +/* $OpenBSD: cmd-list-windows.c,v 1.12 2011/03/28 23:13:00 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> @@ -28,10 +28,13 @@ int cmd_list_windows_exec(struct cmd *, struct cmd_ctx *); +void cmd_list_windows_server(struct cmd_ctx *); +void cmd_list_windows_session(struct session *, struct cmd_ctx *); + const struct cmd_entry cmd_list_windows_entry = { "list-windows", "lsw", - "t:", 0, 0, - CMD_TARGET_SESSION_USAGE, + "at:", 0, 0, + "[-a] " CMD_TARGET_SESSION_USAGE, 0, NULL, NULL, @@ -43,12 +46,34 @@ cmd_list_windows_exec(struct cmd *self, struct cmd_ctx *ctx) { struct args *args = self->args; struct session *s; + + if (args_has(args, 'a')) + cmd_list_windows_server(ctx); + else { + s = cmd_find_session(ctx, args_get(args, 't')); + if (s == NULL) + return (-1); + cmd_list_windows_session(s, ctx); + } + + return (0); +} + +void +cmd_list_windows_server(struct cmd_ctx *ctx) +{ + struct session *s; + + RB_FOREACH(s, sessions, &sessions) + cmd_list_windows_session(s, ctx); +} + +void +cmd_list_windows_session(struct session *s, struct cmd_ctx *ctx) +{ struct winlink *wl; char *layout; - if ((s = cmd_find_session(ctx, args_get(args, 't'))) == NULL) - return (-1); - RB_FOREACH(wl, winlinks, &s->windows) { layout = layout_dump(wl->window); ctx->print(ctx, "%d: %s [%ux%u] [layout %s]%s", @@ -56,6 +81,4 @@ cmd_list_windows_exec(struct cmd *self, struct cmd_ctx *ctx) layout, wl == s->curw ? " (active)" : ""); xfree(layout); } - - return (0); } |
