mirror of
https://github.com/tmux/tmux.git
synced 2025-09-01 20:57:00 +00:00
When adding a list of commands to the queue, instead of automatically
creating a new state for each group of commands, require the caller to create one and use it for all the commands in the list. This means the current target works even with list with multiple groups (which can happen if they are defined with newlines).
This commit is contained in:
23
cmd.c
23
cmd.c
@ -392,6 +392,13 @@ cmd_get_args(struct cmd *cmd)
|
||||
return (cmd->args);
|
||||
}
|
||||
|
||||
/* Get group for command. */
|
||||
u_int
|
||||
cmd_get_group(struct cmd *cmd)
|
||||
{
|
||||
return (cmd->group);
|
||||
}
|
||||
|
||||
/* Get file and line for command. */
|
||||
void
|
||||
cmd_get_source(struct cmd *cmd, const char **file, u_int *line)
|
||||
@ -646,24 +653,16 @@ cmd_list_print(struct cmd_list *cmdlist, int escaped)
|
||||
|
||||
/* Get first command in list. */
|
||||
struct cmd *
|
||||
cmd_list_first(struct cmd_list *cmdlist, u_int *group)
|
||||
cmd_list_first(struct cmd_list *cmdlist)
|
||||
{
|
||||
struct cmd *cmd;
|
||||
|
||||
cmd = TAILQ_FIRST(cmdlist->list);
|
||||
if (cmd != NULL && group != NULL)
|
||||
*group = cmd->group;
|
||||
return (cmd);
|
||||
return (TAILQ_FIRST(cmdlist->list));
|
||||
}
|
||||
|
||||
/* Get next command in list. */
|
||||
struct cmd *
|
||||
cmd_list_next(struct cmd *cmd, u_int *group)
|
||||
cmd_list_next(struct cmd *cmd)
|
||||
{
|
||||
cmd = TAILQ_NEXT(cmd, qentry);
|
||||
if (cmd != NULL && group != NULL)
|
||||
*group = cmd->group;
|
||||
return (cmd);
|
||||
return (TAILQ_NEXT(cmd, qentry));
|
||||
}
|
||||
|
||||
/* Do all of the commands in this command list have this flag? */
|
||||
|
Reference in New Issue
Block a user