summaryrefslogtreecommitdiffstats
path: root/usr.bin/tmux/cmd-list-windows.c
diff options
context:
space:
mode:
authornicm <nicm@openbsd.org>2011-03-28 23:13:00 +0000
committernicm <nicm@openbsd.org>2011-03-28 23:13:00 +0000
commitc8b80c745f1958386c00643e230ae7fe4fe4ef7c (patch)
tree0ab190a4a7a9206e0ee23a242e3c4f48c12503a8 /usr.bin/tmux/cmd-list-windows.c
parentsync from www/build/mirrors.dat (diff)
downloadwireguard-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.c39
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);
}