Merge remote-tracking branch 'AnthonyYoManz/3743-support-focus-in-sway'
This commit is contained in:
commit
72e181e099
|
@ -23,7 +23,7 @@ declare-option -docstring \
|
|||
"Ordered list of windowing modules to try and load. An empty list disables
|
||||
both automatic module loading and environment detection, enabling complete
|
||||
manual control of the module loading." \
|
||||
str-list windowing_modules 'tmux' 'screen' 'kitty' 'iterm' 'wayland' 'x11'
|
||||
str-list windowing_modules 'tmux' 'screen' 'kitty' 'iterm' 'sway' 'wayland' 'x11'
|
||||
|
||||
hook -group windowing global KakBegin .* %{
|
||||
|
||||
|
|
51
rc/windowing/sway.kak
Normal file
51
rc/windowing/sway.kak
Normal file
|
@ -0,0 +1,51 @@
|
|||
provide-module sway %{
|
||||
|
||||
# Ensure we're actually in Sway
|
||||
evaluate-commands %sh{
|
||||
[ -z "${kak_opt_windowing_modules}" ] ||
|
||||
[ -n "$SWAYSOCK" ] ||
|
||||
echo 'fail SWAYSOCK is not set'
|
||||
}
|
||||
|
||||
require-module 'wayland'
|
||||
|
||||
define-command sway-focus-pid -hidden %{
|
||||
evaluate-commands %sh{
|
||||
pid=$kak_client_pid
|
||||
|
||||
# Try to focus a window with the current PID, walking up the tree of
|
||||
# parent processes until the focus eventually succeeds
|
||||
while ! swaymsg [pid=$pid] focus > /dev/null 2> /dev/null ; do
|
||||
# Replace the current PID with its parent PID
|
||||
pid=$(ps -p $pid -o ppid=)
|
||||
|
||||
# If we couldn't get a PPID for some reason, or it's 1 or less, we
|
||||
# should just fail.
|
||||
if [ -z $pid ] || [ $pid -le 1 ]; then
|
||||
echo "fail Can't find PID for Sway window to focus"
|
||||
break
|
||||
fi
|
||||
done
|
||||
}
|
||||
}
|
||||
|
||||
define-command sway-focus -params ..1 -docstring '
|
||||
sway-focus [<kakoune_client>]: focus a given client''s window.
|
||||
If no client is passed, then the current client is used' \
|
||||
%{
|
||||
# Quick branch to make sure we're calling sway-focus-pid from the client
|
||||
# the user wants to focus on.
|
||||
evaluate-commands %sh{
|
||||
if [ $# -eq 1 ]; then
|
||||
printf "evaluate-commands -client '%s' sway-focus-pid" "$1"
|
||||
else
|
||||
echo sway-focus-pid
|
||||
fi
|
||||
}
|
||||
}
|
||||
complete-command sway-focus client
|
||||
|
||||
unalias global focus
|
||||
alias global focus sway-focus
|
||||
|
||||
}
|
|
@ -49,7 +49,7 @@ define-command wayland-focus -params ..1 -docstring '
|
|||
wayland-focus [<kakoune_client>]: focus a given client''s window
|
||||
If no client is passed, then the current client is used' \
|
||||
%{
|
||||
fail There is no way to focus another window on Wayland
|
||||
fail 'Focusing specific windows in most Wayland window managers is unsupported'
|
||||
}
|
||||
complete-command wayland-focus client
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user