aboutsummaryrefslogtreecommitdiffstats
path: root/pkgs
diff options
context:
space:
mode:
Diffstat (limited to 'pkgs')
-rw-r--r--pkgs/by-name/ri/river-mk-keymap/src/key_map/commands.rs16
-rw-r--r--pkgs/by-name/ri/river-mk-keymap/src/key_map/mod.rs5
2 files changed, 20 insertions, 1 deletions
diff --git a/pkgs/by-name/ri/river-mk-keymap/src/key_map/commands.rs b/pkgs/by-name/ri/river-mk-keymap/src/key_map/commands.rs
index 058606c9..52a6ba8a 100644
--- a/pkgs/by-name/ri/river-mk-keymap/src/key_map/commands.rs
+++ b/pkgs/by-name/ri/river-mk-keymap/src/key_map/commands.rs
@@ -145,9 +145,23 @@ impl KeyMap {
(Some(mode_name), acc_vec)
});
+ let command = if value.once {
+ vec![
+ "spawn".to_owned(),
+ format!(
+ "riverctl {} && {}",
+ shlex::try_join(value.command.iter().map(String::as_str))
+ .expect("Should work"),
+ shlex::try_join(["riverctl", "enter-mode", "normal"])
+ .expect("Should work"),
+ ),
+ ]
+ } else {
+ value.command
+ };
base.extend(key_to_command(
mapping[0],
- &value.command,
+ &command,
final_mode.as_ref().map_or("normal", |v| v.as_str()),
value.allow_locked,
));
diff --git a/pkgs/by-name/ri/river-mk-keymap/src/key_map/mod.rs b/pkgs/by-name/ri/river-mk-keymap/src/key_map/mod.rs
index 5c89c2e2..16dc02f4 100644
--- a/pkgs/by-name/ri/river-mk-keymap/src/key_map/mod.rs
+++ b/pkgs/by-name/ri/river-mk-keymap/src/key_map/mod.rs
@@ -30,6 +30,10 @@ pub struct KeyConfig {
#[serde(default)]
allow_locked: bool,
+ /// Whether to go back to the normal mode, after running this command.
+ #[serde(default)]
+ once: bool,
+
/// Use a different description to display this command, instead of the `command`.
description: Option<String>,
}
@@ -51,6 +55,7 @@ impl FromStr for KeyMap {
.collect::<Option<_>>()
.ok_or(anyhow!("A array contained a non-string value: {value:#?}"))?,
allow_locked: false,
+ once: false,
description: None,
}
} else if let Some(object) = value.as_object() {