mirror of
https://github.com/tmux/tmux.git
synced 2025-01-07 08:18:48 +00:00
Use window target if specified and exists even when looking for an
index, fixes neww -a with -t as well.
This commit is contained in:
parent
896c1da7da
commit
e24a077752
11
cmd-find.c
11
cmd-find.c
@ -437,15 +437,15 @@ cmd_find_get_window_with_session(struct cmd_find_state *fs, const char *window)
|
|||||||
if (window[0] != '+' && window[0] != '-') {
|
if (window[0] != '+' && window[0] != '-') {
|
||||||
idx = strtonum(window, 0, INT_MAX, &errstr);
|
idx = strtonum(window, 0, INT_MAX, &errstr);
|
||||||
if (errstr == NULL) {
|
if (errstr == NULL) {
|
||||||
if (fs->flags & CMD_FIND_WINDOW_INDEX) {
|
|
||||||
fs->idx = idx;
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
fs->wl = winlink_find_by_index(&fs->s->windows, idx);
|
fs->wl = winlink_find_by_index(&fs->s->windows, idx);
|
||||||
if (fs->wl != NULL) {
|
if (fs->wl != NULL) {
|
||||||
fs->w = fs->wl->window;
|
fs->w = fs->wl->window;
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
if (fs->flags & CMD_FIND_WINDOW_INDEX) {
|
||||||
|
fs->idx = idx;
|
||||||
|
return (0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1182,7 +1182,8 @@ cmd_find_target(struct cmd_find_state *fs, struct cmdq_item *item,
|
|||||||
/* This will fill in session, winlink and window. */
|
/* This will fill in session, winlink and window. */
|
||||||
if (cmd_find_get_window(fs, window, window_only) != 0)
|
if (cmd_find_get_window(fs, window, window_only) != 0)
|
||||||
goto no_window;
|
goto no_window;
|
||||||
fs->wp = fs->wl->window->active;
|
if (fs->wl != NULL) /* can be NULL if index only */
|
||||||
|
fs->wp = fs->wl->window->active;
|
||||||
goto found;
|
goto found;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,7 +63,7 @@ cmd_new_window_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
struct environ_entry *envent;
|
struct environ_entry *envent;
|
||||||
struct cmd_find_state fs;
|
struct cmd_find_state fs;
|
||||||
|
|
||||||
if (args_has(args, 'a')) {
|
if (args_has(args, 'a') && wl != NULL) {
|
||||||
if ((idx = winlink_shuffle_up(s, wl)) == -1) {
|
if ((idx = winlink_shuffle_up(s, wl)) == -1) {
|
||||||
cmdq_error(item, "no free window indexes");
|
cmdq_error(item, "no free window indexes");
|
||||||
return (CMD_RETURN_ERROR);
|
return (CMD_RETURN_ERROR);
|
||||||
|
Loading…
Reference in New Issue
Block a user