-
-
Notifications
You must be signed in to change notification settings - Fork 154
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Bind/run multiple actions at once #914
Comments
Idea from @calops for CLI:
Though, I'm not sure if you can run a clap parser on stdin to parse the arguments. |
You should be able to run a clap parser on any string manually. It would have to be a subset of the global parser but it sounds doable. |
Clap doesn't support it currently, someone mentioned this as a workaround:
This breaks |
This issue only seems to relate to chaining commands in the program arguments. You can still use the exact same workaround you're talking about with the contents of stdin instead of splitting on |
I started working on this, I'm currently ignoring The hotkey overlay is pretty annoying to deal with, when looking for certain actions should it ignore multi-action binds entirely for now since it can't display them? Or prefer single actions over multi-actions, and display only the relevant action for multi-action binds? For cli, clap doesn't support custom subcommand parsing, it's pretty much the same problem as #965, currently the best workaround I can think of is adding: #[derive(Subcommand)]
pub enum Msg {
// ...
/// Perform an action.
Action {
#[command(subcommand)]
action: Option<Action>,
#[clap(skip)]
actions: Vec<Action>,
},
// ...
} To both make clap parse the action and make room to marshal Sub::Msg { mut msg, json } => {
if let Msg::Action { action: None, .. } = msg {
let stdin = io::stdin();
let actions = stdin
.map(BufReader::read_line)
.map(Action::try_parse_from)
.collect();
msg = Msg::Action {
action: None,
actions,
}
}
handle_msg(msg, json)?;
return Ok(());
} |
I say ignore multi-action binds for the hotkey overlay.
That |
Maybe instead of that field, add a separate |
Allow binds to run several actions sequentially, e.g.:
And, more importantly, add some way to run several actions as a batch through IPC and
niri msg action
. This will allow doing several actions as one atomic sequence and with no delay in-between, which is currently impossible.Here the binds and the IPC part should be straightforward, but I'm not sure how to parse the arguments in
niri msg action
. Maybe clap offers something?Another question is what to do if only one action in the sequence fails a check like
allow-when-locked
. Here I guess we ignore just the action that fails the check, same as what would happen if you were to run severalniri msg action
commands one after another.The text was updated successfully, but these errors were encountered: