diff options
author | Mattias Andrée <maandree@kth.se> | 2023-11-25 19:23:41 +0100 |
---|---|---|
committer | Mattias Andrée <maandree@kth.se> | 2023-11-25 19:23:41 +0100 |
commit | 391791f6165653ebe4c4f25af953841a3b0fc6c7 (patch) | |
tree | 2c97d82e061ad8ffbc5a96e0c72a870109011cd4 /xorg-xrandr/resolution-changed | |
parent | Misc updates (diff) | |
download | dotfiles-391791f6165653ebe4c4f25af953841a3b0fc6c7.tar.gz dotfiles-391791f6165653ebe4c4f25af953841a3b0fc6c7.tar.bz2 dotfiles-391791f6165653ebe4c4f25af953841a3b0fc6c7.tar.xz |
Update setres
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to 'xorg-xrandr/resolution-changed')
-rwxr-xr-x | xorg-xrandr/resolution-changed | 42 |
1 files changed, 36 insertions, 6 deletions
diff --git a/xorg-xrandr/resolution-changed b/xorg-xrandr/resolution-changed index a53c7b6..e1457ce 100755 --- a/xorg-xrandr/resolution-changed +++ b/xorg-xrandr/resolution-changed @@ -1,11 +1,23 @@ #!/bin/dash -# Reset rat size in case DPI change modified scaling -xsetroot -cursor_name left_ptr || : +reset_wallpaper_twice=0 -# Reset rat speed in case DPI changed -if test "${DESKTOP_SESSION}" = xmonad && test ! "${NO_MATE}" = y; then - (exec mate-settings-daemon --replace &) || : +if ! test "$(hostname | tr '[A-Z]' '[a-z]')" = zenith; then + # Reset rat size in case DPI change modified scaling + xsetroot -cursor_name left_ptr || : + + # Reset rat speed in case DPI changed + if test "${DESKTOP_SESSION}" = xmonad && test ! "${NO_MATE}" = y; then + msd=/usr/lib/mate-settings-daemon/mate-settings-daemon + if ! test -x "$msd"; then + msd=mate-settings-daemon + fi + (exec $msd --replace &) || : + # mate-settings-daemon will change the keyboard layout + (sleep 1; setkeys) & + # mate-settings-daemon may change the wallpaper + reset_wallpaper_twice=1 + fi fi # Reset background in case resolution change damaged it @@ -15,6 +27,24 @@ for file in ~/.config/background.${SESSION_} \ ~/.config/background; do if test -r "$file"; then xwallpaper --zoom "$file" - (sleep 2 ; xwallpaper --zoom "$file") & # Again, with delay, in case mate-settings-daemon changes it + if test ${reset_wallpaper_twice} = 1; then + # Again, with delay, in case mate-settings-daemon changes it + (sleep 2 ; xwallpaper --zoom "$file") & + fi fi done + +# Broadcast resolution change +if test -n "${XDG_RUNTIME_DIR}"; then + if test -n "${DISPLAY}"; then + mkdir -p -- "${XDG_RUNTIME_DIR}/x-display/${DISPLAY}/" + printf -- '%ix%i%+i%+i\n' "$@" > "${XDG_RUNTIME_DIR}/x-display/${DISPLAY}/resolution~" + mv -- "${XDG_RUNTIME_DIR}/x-display/${DISPLAY}/resolution~" "${XDG_RUNTIME_DIR}/x-display/${DISPLAY}/resolution" + fi + if test -z "${BUS_VIDEO}"; then + BUS_VIDEO="${XDG_RUNTIME_DIR}/@bus/video" + fi +fi +if test -n "${BUS_VIDEO}"; then + bus broadcast "${BUS_VIDEO}" "resolution changed:$(printf -- ' %ix%i%+i%+i' "$@")" +fi |