aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Rice <peter@peterrice.xyz>2021-09-11 16:21:48 -0400
committerIsaac Freund <ifreund@ifreund.xyz>2021-09-14 22:57:17 +0200
commit81d103d4255b1439b86d6f856f1d7285809e3023 (patch)
treece17ecdbac5eb83552b7d83779d4d475389ac2ee
parent5f6428bafe41da2c5df6c6cb12ff65c225260322 (diff)
downloadriver-81d103d4255b1439b86d6f856f1d7285809e3023.tar.gz
river-81d103d4255b1439b86d6f856f1d7285809e3023.tar.xz
river: add send-to-previous-tags command
-rw-r--r--completions/bash/riverctl1
-rw-r--r--completions/fish/riverctl.fish1
-rw-r--r--completions/zsh/_riverctl1
-rw-r--r--doc/riverctl.1.scd4
-rw-r--r--river/command.zig1
-rw-r--r--river/command/tags.zig16
6 files changed, 24 insertions, 0 deletions
diff --git a/completions/bash/riverctl b/completions/bash/riverctl
index dd18ac5..bfee3f1 100644
--- a/completions/bash/riverctl
+++ b/completions/bash/riverctl
@@ -25,6 +25,7 @@ function __riverctl_completion ()
send-layout-cmd \
set-focused-tags \
focus-previous-tags \
+ send-to-previous-tags \
set-view-tags \
toggle-focused-tags \
toggle-view-tags \
diff --git a/completions/fish/riverctl.fish b/completions/fish/riverctl.fish
index c0112c1..cd76675 100644
--- a/completions/fish/riverctl.fish
+++ b/completions/fish/riverctl.fish
@@ -64,6 +64,7 @@ complete -c riverctl -x -n '__fish_riverctl_complete_no_subcommand' -a toggle-fo
complete -c riverctl -x -n '__fish_riverctl_complete_no_subcommand' -a toggle-view-tags -d 'Toggle the tags of the currently focused view'
complete -c riverctl -x -n '__fish_riverctl_complete_no_subcommand' -a spawn-tagmask -d 'Set a tagmask to filter the tags assigned to newly spawned views on the focused output'
complete -c riverctl -x -n '__fish_riverctl_complete_no_subcommand' -a focus-previous-tags -d 'Sets tags to their previous value on the focused output'
+complete -c riverctl -x -n '__fish_riverctl_complete_no_subcommand' -a send-to-previous-tags -d 'Assign the currently focused view the previous tags of the focused output'
# Mappings
complete -c riverctl -x -n '__fish_riverctl_complete_no_subcommand' -a declare-mode -d 'Create a new mode'
complete -c riverctl -x -n '__fish_riverctl_complete_no_subcommand' -a enter-mode -d 'Switch to given mode if it exists'
diff --git a/completions/zsh/_riverctl b/completions/zsh/_riverctl
index 1c7034a..74f3ea8 100644
--- a/completions/zsh/_riverctl
+++ b/completions/zsh/_riverctl
@@ -33,6 +33,7 @@ _riverctl_subcommands()
'toggle-view-tags:Toggle the tags of the currently focused view'
'spawn-tagmask:Set a tagmask to filter the tags assigned to newly spawned views on the focused output'
'focus-previous-tags:Sets tags to their previous value on the focused output'
+ 'send-to-previous-tags:Assign the currently focused view the previous tags of the focused output'
# Mappings
'declare-mode:Create a new mode'
'enter-mode:Switch to given mode if it exists'
diff --git a/doc/riverctl.1.scd b/doc/riverctl.1.scd
index dcb2148..31874bf 100644
--- a/doc/riverctl.1.scd
+++ b/doc/riverctl.1.scd
@@ -147,6 +147,10 @@ are ignored by river.
Sets tags to their previous value on the currently focused output,
allowing jumping back and forth between 2 tag setups.
+*send-to-previous-tags*
+ Assign the currently focused view the previous tags of the currently
+ focused output.
+
## MAPPINGS
Mappings are modal in river. Each mapping is associated with a mode and is
diff --git a/river/command.zig b/river/command.zig
index 9db3995..a9d3585 100644
--- a/river/command.zig
+++ b/river/command.zig
@@ -83,6 +83,7 @@ const str_to_impl_fn = [_]struct {
.{ .name = "toggle-fullscreen", .impl = @import("command/toggle_fullscreen.zig").toggleFullscreen },
.{ .name = "toggle-view-tags", .impl = @import("command/tags.zig").toggleViewTags },
.{ .name = "focus-previous-tags", .impl = @import("command/tags.zig").focusPreviousTags },
+ .{ .name = "send-to-previous-tags", .impl = @import("command/tags.zig").sendToPreviousTags },
.{ .name = "unmap", .impl = @import("command/map.zig").unmap },
.{ .name = "unmap-pointer", .impl = @import("command/map.zig").unmapPointer },
.{ .name = "xcursor-theme", .impl = @import("command/xcursor_theme.zig").xcursorTheme },
diff --git a/river/command/tags.zig b/river/command/tags.zig
index b9c223c..7551b67 100644
--- a/river/command/tags.zig
+++ b/river/command/tags.zig
@@ -121,6 +121,22 @@ pub fn focusPreviousTags(
}
}
+/// Set the tags of the focused view to the tags that were selected previously
+pub fn sendToPreviousTags(
+ allocator: *std.mem.Allocator,
+ seat: *Seat,
+ args: []const []const u8,
+ out: *?[]const u8,
+) Error!void {
+ const previous_tags = seat.focused_output.previous_tags;
+ if (seat.focused == .view) {
+ const view = seat.focused.view;
+ view.pending.tags = previous_tags;
+ seat.focus(null);
+ view.applyPending();
+ }
+}
+
fn parseTags(
allocator: *std.mem.Allocator,
args: []const [:0]const u8,