7.3 KiB
Swaysome
Description
This binary helps you configure sway to work a bit more like AwesomeWM. This currently means
workspaces that are name-spaced on a per-screen basis.
example: with workspace 11 on the first screen, and workspace 21 on the second screen, typing the swaysome
shortcut to get workspace 1 would lead you to workspace 11 if your focus is on the first screen, and workspace 21
is the focus is on the second one.
swaysome also supports what we call "workspace groups". These are groups of workspaces sharing the same tens number
and tied to an output.
By default, swaysome init will create a workspace group per active output, but you may create other groups while working.
Here is a common use-case for this:
output-1:- workspace group 1:
- workspace
11: chats - workspace
12: emails
- workspace
- workspace group 1:
output-2:- workspace group 2:
- workspace
21: IDE for first project - workspace
22: browser for first project - workspace
23: terminals for first project
- workspace
- workspace group 3:
- workspace
31: IDE for second project - workspace
32: browser for second project - workspace
33: terminals for second project
- workspace
- workspace group 2:
That way, when output-2 is focused on workspace group 2, be it workspace 21 or 22, the quick $mod+<number>
shortcut won't leave workspace group 2, allowing you to open multiple projects in parallel without the hassle of
manually remembering how to namespace them.
swaysome may also work with i3, but this is untested.
swaysome should be compatible with sworkstyle.
Installation
Arch Linux: Found on the AUR as swaysome-git.
If you have Rust installed, then you can just cargo install swaysome and you're good to go.
Otherwise, you may grab a pre-built
binary from the
CI and put it in your $PATH.
WARNING: please double-check that your swaysome binary is in sway's $PATH. Depending on your setup, the
$PATH you have in your shell may not be the same as sway's, and if swaysome can't be called by sway, the
symptoms will only look like non-functional shortcuts.
If you're in this situation, a quick workaround is to call swaysome with its full absolute path from sway's config
to check that everything works before fixing your $PATH issue.
Usage
Then create the file (and the directory if needed) ~/.config/sway/config.d/swaysome.conf and paste this inside:
# Change focus between workspaces
unbindcode $mod+10
unbindcode $mod+11
unbindcode $mod+12
unbindcode $mod+13
unbindcode $mod+14
unbindcode $mod+15
unbindcode $mod+16
unbindcode $mod+17
unbindcode $mod+18
unbindcode $mod+19
bindcode $mod+10 exec "swaysome focus 1"
bindcode $mod+11 exec "swaysome focus 2"
bindcode $mod+12 exec "swaysome focus 3"
bindcode $mod+13 exec "swaysome focus 4"
bindcode $mod+14 exec "swaysome focus 5"
bindcode $mod+15 exec "swaysome focus 6"
bindcode $mod+16 exec "swaysome focus 7"
bindcode $mod+17 exec "swaysome focus 8"
bindcode $mod+18 exec "swaysome focus 9"
bindcode $mod+19 exec "swaysome focus 0"
# Move containers between workspaces
unbindcode $mod+Shift+10
unbindcode $mod+Shift+11
unbindcode $mod+Shift+12
unbindcode $mod+Shift+13
unbindcode $mod+Shift+14
unbindcode $mod+Shift+15
unbindcode $mod+Shift+16
unbindcode $mod+Shift+17
unbindcode $mod+Shift+18
unbindcode $mod+Shift+19
bindcode $mod+Shift+10 exec "swaysome move 1"
bindcode $mod+Shift+11 exec "swaysome move 2"
bindcode $mod+Shift+12 exec "swaysome move 3"
bindcode $mod+Shift+13 exec "swaysome move 4"
bindcode $mod+Shift+14 exec "swaysome move 5"
bindcode $mod+Shift+15 exec "swaysome move 6"
bindcode $mod+Shift+16 exec "swaysome move 7"
bindcode $mod+Shift+17 exec "swaysome move 8"
bindcode $mod+Shift+18 exec "swaysome move 9"
bindcode $mod+Shift+19 exec "swaysome move 0"
# Focus workspace groups
unbindcode $mod+Ctrl+10
unbindcode $mod+Ctrl+11
unbindcode $mod+Ctrl+12
unbindcode $mod+Ctrl+13
unbindcode $mod+Ctrl+14
unbindcode $mod+Ctrl+15
unbindcode $mod+Ctrl+16
unbindcode $mod+Ctrl+17
unbindcode $mod+Ctrl+18
unbindcode $mod+Ctrl+19
bindcode $mod+Ctrl+10 exec "swaysome focus-group 1"
bindcode $mod+Ctrl+11 exec "swaysome focus-group 2"
bindcode $mod+Ctrl+12 exec "swaysome focus-group 3"
bindcode $mod+Ctrl+13 exec "swaysome focus-group 4"
bindcode $mod+Ctrl+14 exec "swaysome focus-group 5"
bindcode $mod+Ctrl+15 exec "swaysome focus-group 6"
bindcode $mod+Ctrl+16 exec "swaysome focus-group 7"
bindcode $mod+Ctrl+17 exec "swaysome focus-group 8"
bindcode $mod+Ctrl+18 exec "swaysome focus-group 9"
bindcode $mod+Ctrl+19 exec "swaysome focus-group 0"
# Move containers to other workspace groups
unbindcode $mod+Ctrl+Shift+10
unbindcode $mod+Ctrl+Shift+11
unbindcode $mod+Ctrl+Shift+12
unbindcode $mod+Ctrl+Shift+13
unbindcode $mod+Ctrl+Shift+14
unbindcode $mod+Ctrl+Shift+15
unbindcode $mod+Ctrl+Shift+16
unbindcode $mod+Ctrl+Shift+17
unbindcode $mod+Ctrl+Shift+18
unbindcode $mod+Ctrl+Shift+19
bindcode $mod+Ctrl+Shift+10 exec "swaysome move-to-group 1"
bindcode $mod+Ctrl+Shift+11 exec "swaysome move-to-group 2"
bindcode $mod+Ctrl+Shift+12 exec "swaysome move-to-group 3"
bindcode $mod+Ctrl+Shift+13 exec "swaysome move-to-group 4"
bindcode $mod+Ctrl+Shift+14 exec "swaysome move-to-group 5"
bindcode $mod+Ctrl+Shift+15 exec "swaysome move-to-group 6"
bindcode $mod+Ctrl+Shift+16 exec "swaysome move-to-group 7"
bindcode $mod+Ctrl+Shift+17 exec "swaysome move-to-group 8"
bindcode $mod+Ctrl+Shift+18 exec "swaysome move-to-group 9"
bindcode $mod+Ctrl+Shift+19 exec "swaysome move-to-group 0"
# Move focused container to next output
bindcode $mod+o exec "swaysome next-output"
# Move focused container to previous output
bindcode $mod+Shift+o exec "swaysome prev-output"
# Init workspaces for every screen
exec "swaysome init 1"
Finally append your sway configuration with this:
include ~/.config/sway/config.d/*.conf
You should end-up with workspaces from 1 to 0, prefixed with a screen index,
giving you workspace 11 on the first screen, and workspace 21 on the second
one, both accessible with shortcut $mod+1 when focused on the right output.
The init command simply walks through every screen to initialize a prefixed
workspace. It does it backwards so that you end-up focused on the first screen,
as usual.
Exhaustive swaysome commands list
move [name]: move the focused container to[name]on the same groupmove-to-group [id]: move the focused container to the same relative workspace on the[id]workspace groupnext-output: move the focused container to the next outputprev-output: move the focused container to the previous outputfocus [name]: change focus to[name]on the same groupfocus-all-outputs [name]: change all outputs focus to[name]focus-group [id]: change focus to group[id]next-group: change focus to the next workspace groupprevious-group: change focus to the previous workspace groupinit [name]: cycle all outputs to create a default workspace with name[name]rearrange-workspacesRearrange already opened workspaces to the correct outputs, useful when plugging or unplugging screens
Breaking changes
- Starting with 2.0,
next_outputandprev_outputhave been changed tonext-outputandprev-output.