diff options
author | nicm <nicm> | 2017-03-08 13:36:12 +0000 |
---|---|---|
committer | nicm <nicm> | 2017-03-08 13:36:12 +0000 |
commit | 6b2009ad725b662853b8e94aee233fabdc5490f9 (patch) | |
tree | a38064466deb34fce243a7051e0139afc6c56080 /cmd-split-window.c | |
parent | 1e6e606f54537c732cce48e5d3eae7fc29281fe5 (diff) | |
download | rtmux-6b2009ad725b662853b8e94aee233fabdc5490f9.tar.gz rtmux-6b2009ad725b662853b8e94aee233fabdc5490f9.tar.bz2 rtmux-6b2009ad725b662853b8e94aee233fabdc5490f9.zip |
Add a helper function for the most common format_create/defaults/expand
pattern.
Diffstat (limited to 'cmd-split-window.c')
-rw-r--r-- | cmd-split-window.c | 16 |
1 files changed, 4 insertions, 12 deletions
diff --git a/cmd-split-window.c b/cmd-split-window.c index f05dc249..064d1f5f 100644 --- a/cmd-split-window.c +++ b/cmd-split-window.c @@ -54,6 +54,7 @@ static enum cmd_retval cmd_split_window_exec(struct cmd *self, struct cmdq_item *item) { struct args *args = self->args; + struct client *c = item->state.c; struct session *s = item->state.tflag.s; struct winlink *wl = item->state.tflag.wl; struct window *w = wl->window; @@ -65,7 +66,6 @@ cmd_split_window_exec(struct cmd *self, struct cmdq_item *item) int argc, size, percentage; enum layout_type type; struct layout_cell *lc; - struct format_tree *ft; struct environ_entry *envent; struct cmd_find_state fs; @@ -92,10 +92,8 @@ cmd_split_window_exec(struct cmd *self, struct cmdq_item *item) to_free = NULL; if (args_has(args, 'c')) { - ft = format_create(item, FORMAT_NONE, 0); - format_defaults(ft, item->state.c, s, NULL, NULL); - to_free = cwd = format_expand(ft, args_get(args, 'c')); - format_free(ft); + cwd = args_get(args, 'c'); + to_free = cwd = format_single(item, cwd, c, s, NULL, NULL); } else if (item->client != NULL && item->client->session == NULL) cwd = item->client->cwd; else @@ -168,15 +166,9 @@ cmd_split_window_exec(struct cmd *self, struct cmdq_item *item) if (args_has(args, 'P')) { if ((template = args_get(args, 'F')) == NULL) template = SPLIT_WINDOW_TEMPLATE; - - ft = format_create(item, FORMAT_NONE, 0); - format_defaults(ft, item->state.c, s, wl, new_wp); - - cp = format_expand(ft, template); + cp = format_single(item, template, c, s, wl, new_wp); cmdq_print(item, "%s", cp); free(cp); - - format_free(ft); } notify_window("window-layout-changed", w); |