4 * Copyright (c) 2009 Tiago Cunha <me@tiagocunha.org>
5 * Copyright (c) 2009 Nicholas Marriott <nicm@openbsd.org>
7 * Permission to use, copy, modify, and distribute this software for any
8 * purpose with or without fee is hereby granted, provided that the above
9 * copyright notice and this permission notice appear in all copies.
11 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
12 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
13 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
14 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15 * WHATSOEVER RESULTING FROM LOSS OF MIND, USE, DATA OR PROFITS, WHETHER
16 * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
17 * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
20 #include <sys/types.h>
29 * Executes a tmux command if a shell command returns true or false.
32 enum cmd_retval
cmd_if_shell_exec(struct cmd
*, struct cmd_q
*);
34 void cmd_if_shell_callback(struct job
*);
35 void cmd_if_shell_done(struct cmd_q
*);
36 void cmd_if_shell_free(void *);
38 const struct cmd_entry cmd_if_shell_entry
= {
41 "[-b] " CMD_TARGET_PANE_USAGE
" shell-command command [command]",
48 struct cmd_if_shell_data
{
57 cmd_if_shell_exec(struct cmd
*self
, struct cmd_q
*cmdq
)
59 struct args
*args
= self
->args
;
60 struct cmd_if_shell_data
*cdata
;
63 struct session
*s
= NULL
;
64 struct winlink
*wl
= NULL
;
65 struct window_pane
*wp
= NULL
;
66 struct format_tree
*ft
;
68 if (args_has(args
, 't'))
69 wl
= cmd_find_pane(cmdq
, args_get(args
, 't'), &s
, &wp
);
71 c
= cmd_find_client(cmdq
, NULL
, 1);
72 if (c
!= NULL
&& c
->session
!= NULL
) {
75 wp
= wl
->window
->active
;
81 format_session(ft
, s
);
82 if (s
!= NULL
&& wl
!= NULL
)
83 format_winlink(ft
, s
, wl
);
85 format_window_pane(ft
, wp
);
86 shellcmd
= format_expand(ft
, args
->argv
[0]);
89 cdata
= xmalloc(sizeof *cdata
);
90 cdata
->cmd_if
= xstrdup(args
->argv
[1]);
92 cdata
->cmd_else
= xstrdup(args
->argv
[2]);
94 cdata
->cmd_else
= NULL
;
95 cdata
->bflag
= args_has(args
, 'b');
101 job_run(shellcmd
, s
, cmd_if_shell_callback
, cmd_if_shell_free
, cdata
);
105 return (CMD_RETURN_NORMAL
);
106 return (CMD_RETURN_WAIT
);
110 cmd_if_shell_callback(struct job
*job
)
112 struct cmd_if_shell_data
*cdata
= job
->data
;
113 struct cmd_q
*cmdq
= cdata
->cmdq
, *cmdq1
;
114 struct cmd_list
*cmdlist
;
120 if (!WIFEXITED(job
->status
) || WEXITSTATUS(job
->status
) != 0)
121 cmd
= cdata
->cmd_else
;
127 if (cmd_string_parse(cmd
, &cmdlist
, NULL
, 0, &cause
) != 0) {
129 cmdq_error(cmdq
, "%s", cause
);
137 cmdq1
= cmdq_new(cmdq
->client
);
138 cmdq1
->emptyfn
= cmd_if_shell_done
;
141 cmdq_run(cmdq1
, cmdlist
);
142 cmd_list_free(cmdlist
);
146 cmd_if_shell_done(struct cmd_q
*cmdq1
)
148 struct cmd_if_shell_data
*cdata
= cmdq1
->data
;
149 struct cmd_q
*cmdq
= cdata
->cmdq
;
151 if (!cmdq_free(cmdq
) && !cdata
->bflag
)
156 free(cdata
->cmd_else
);
162 cmd_if_shell_free(void *data
)
164 struct cmd_if_shell_data
*cdata
= data
;
165 struct cmd_q
*cmdq
= cdata
->cmdq
;
170 if (!cmdq_free(cmdq
) && !cdata
->bflag
)
173 free(cdata
->cmd_else
);