Bspwm Better Scratchpad
2 min read
July 22, 2023
259 words
Better scratchpad bspwm
Preface
The scratchpad scripts I found for bspwm SUCK. Some either stop working if you kill the terminal or bug out when you manage your window states. Here's a script I wrote that get's the job done RIGHT!
bspwm-scratch.png
I'm running tmux if you were wondering.
Setup stuff
The "scratchy" script checks to see if a terminal with the classname "scratchy" exists. If it doesn't exist, it creates it. If it does exist, it hides it.
>> /path/to/scratchy
#!/bin/sh
id=$(xdotool search --class scratchy);
if [ -z "$id" ]; then
st -c scratchy;
else
if [ ! -f /tmp/hide_scratch ]; then
touch /tmp/hide_scratch && xdo hide "$id"
elif [ -f /tmp/hide_scratch ]; then
rm /tmp/hide_scratch && xdo show "$id"
fi
fi
Next we'll assign special attributes for the window with the classname scratchy in our bspwmrc. I have it configured to automatically adjust the window position based on the size of the monitor. To get the window to be exactly centered, just do (1/2 monitor width)-(1/2 window width) as the X offset
>> /path/to/bspwmrc
# Calculate the center of the screen for a 600x400 scratchpad
scratchpad_xy="600x400"
display_xy=$(xdpyinfo | grep -i dimensions | awk '{ print $2 }')
half_display=$(echo $display_xy | tr 'x' ' ' | cut -f1 -d' ' | xargs -I _ echo _/2 | bc)
half_scratchpad=$(echo $scratchpad_xy | tr 'x' ' ' | cut -f1 -d' ' | xargs -I _ echo _/2 | bc)
offset=$(echo ${half_display}-${half_scratchpad} | bc)
# rectangle=WidthxHeight+Xoffset+Yoffset
bspc rule -a scratchy sticky=on state=floating rectangle=${scratchpad_xy}+${offs et}+0
>> /path/to/sxhkdrc
super + semicolon
scratchy