This adds an option to the detach-client command to use -a which will detach
all clients except (-a) the target client specified with -t.
---
 trunk/cmd-detach-client.c |   16 ++++++++++++----
 trunk/tmux.1              |    5 +++++
 2 files changed, 17 insertions(+), 4 deletions(-)

diff --git a/trunk/cmd-detach-client.c b/trunk/cmd-detach-client.c
index d1010a5..a12c246 100644
--- a/trunk/cmd-detach-client.c
+++ b/trunk/cmd-detach-client.c
@@ -28,8 +28,8 @@ int   cmd_detach_client_exec(struct cmd *, struct cmd_ctx *);
 
 const struct cmd_entry cmd_detach_client_entry = {
        "detach-client", "detach",
-       "s:t:P", 0, 0,
-       "[-P] [-s target-session] " CMD_TARGET_CLIENT_USAGE,
+       "as:t:P", 0, 0,
+       "[-P] [-a] [-s target-session] " CMD_TARGET_CLIENT_USAGE,
        CMD_READONLY,
        NULL,
        NULL,
@@ -40,7 +40,7 @@ int
 cmd_detach_client_exec(struct cmd *self, struct cmd_ctx *ctx)
 {
        struct args     *args = self->args;
-       struct client   *c;
+       struct client   *c, *c2;
        struct session  *s;
        enum msgtype     msgtype;
        u_int            i;
@@ -65,7 +65,15 @@ cmd_detach_client_exec(struct cmd *self, struct cmd_ctx *ctx)
                if (c == NULL)
                        return (-1);
 
-               server_write_client(c, msgtype, NULL, 0);
+               if (args_has(args, 'a')) {
+                       for (i = 0; i < ARRAY_LENGTH(&clients); i++) {
+                               c2 = ARRAY_ITEM(&clients, i);
+                               if (c2 != NULL && c != c2)
+                                       server_write_client(
+                                               c2, msgtype, NULL, 0);
+                       }
+               } else
+                       server_write_client(c, msgtype, NULL, 0);
        }
 
        return (0);
diff --git a/trunk/tmux.1 b/trunk/tmux.1
index 34d0232..2394c54 100644
--- a/trunk/tmux.1
+++ b/trunk/tmux.1
@@ -589,6 +589,7 @@ recently used
 session.
 .It Xo Ic detach-client
 .Op Fl P
+.Op Fl a
 .Op Fl s Ar target-session
 .Op Fl t Ar target-client
 .Xc
@@ -597,6 +598,10 @@ Detach the current client if bound to a key, the client 
specified with
 .Fl t ,
 or all clients currently attached to the session specified by
 .Fl s .
+The
+.Fl a
+option kills all but the client given with
+.Fl t .
 If
 .Fl P
 is given, send SIGHUP to the parent process of the client, typically causing it
-- 
1.7.10


------------------------------------------------------------------------------
Live Security Virtual Conference
Exclusive live event will cover all the ways today's security and 
threat landscape has changed and how IT managers can respond. Discussions 
will include endpoint security, mobile security and the latest in malware 
threats. http://www.accelacomm.com/jaw/sfrnl04242012/114/50122263/
_______________________________________________
tmux-users mailing list
tmux-users@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/tmux-users

Reply via email to