-
-
Notifications
You must be signed in to change notification settings - Fork 657
Commands
This wiki page aims to explain some of the available commands in detail.
A short and concise overview of all commands available with your current installation is available using man yabai
or for the current development version as a → rendered document.
Messages can be passed to a running yabai instance using yabai --message
(or yabai -m
in short). These messages aim to have a very intuitive format that should be easy to remember.
The format for commands is yabai -m <category> <command>
.
You might remember this format from the previous chapter about → configuration options, which used the same message passing interface.
The → example skhdrc shows how you can integrate these commands with → skhd, a hotkey utility for macOS. This file is an example showing how to control yabai using keyboard shortcuts. Note that it is not a good example for all keyboard layouts and is highly opinionated. It is recommended to build your own skhdrc file from scratch to suit your needs.
Most commands will return a non-zero exit code upon failure, which is useful for scripting purposes.
The arrangement indices for displays can be seen in the Displays > Arrangement preference pane in the System Preferences.
# Focus display focused before the current one (so you can alternate)
yabai -m display --focus recent
# Focus previous display by arrangement index
yabai -m display --focus prev
# Focus next display by arrangement index
yabai -m display --focus next
# Focus display with arrangement index 2
yabai -m display --focus 2
The mission-control indices for spaces can be seen when mission control is active.
# Focus space focused before the current one (so you can alternate)
yabai -m space --focus recent
# Focus previous space by mission-control index
yabai -m space --focus prev
# Focus next space by mission-control index
yabai -m space --focus next
# Focus space with mission-control index 2
yabai -m space --focus 2
# Focus next space by mission-control index if one exists, otherwise focus the first space
yabai -m space --focus next || yabai -m space --focus first
# Focus previous space by mission-control index if one exists, otherwise focus the last space
yabai -m space --focus prev || yabai -m space --focus last
# Create space on the active display
yabai -m space --create
# Delete focused space and focus first space on display
yabai -m space --destroy
# Move space left
yabai -m space --move prev
# Move space right
yabai -m space --move next
# Send space to display 2 (by display arrangement index)
yabai -m space --display 2
Spaces can be given labels, which allow referring to a space by the given label in subsequent commands.
To label a space use the --label
command:
yabai -m space 1 --label main
yabai -m space 2 --label sm
yabai -m space --focus main
In bsp spaces commands can be used to modify the window tree, affecting all windows on the space.
# Balance out all windows both horizontally and vertically
# to occupy the same space
yabai -m space --balance
# Flip the tree horizontally
yabai -m space --mirror x-axis
# Flip the tree vertically
yabai -m space --mirror y-axis
# Rotate the window tree clock-wise (options: 90, 180, 270 degree)
yabai -m space --rotate 90
# Set layout of the space (options: bsp, float)
yabai -m space --layout bsp
# toggle padding on the current space
yabai -m space --toggle padding
# add 10 to the top padding, subtract 5 from the left and right padding
# format: top:bottom:left:right (rel = relative)
yabai -m space --padding rel:10:0:-5:-5
# set all padding to 20 (abs = absolute)
yabai -m space --padding abs:20:20:20:20
# toggle gap between windows on the current space
yabai -m space --toggle gap
# add 10 to gap between windows (rel = relative)
yabai -m space --gap rel:10
# set gap between windows to 0 (abs = absolute)
yabai -m space --gap abs:0
Window commands are special in that they can either be operated on the focused window or on any visible window if a) the window id is supplied and b) the command makes sense.
If you want to operate on an unfocused, visible window, replace yabai -m window
with yabai -m window window-id
below. This is mostly for automation. Window identifiers can be obtained through signals and the query system.
# focus window in direction of focused window (options: north, east, south, west)
yabai -m window --focus east
# focus window that was previously focused
yabai -m window --focus recent
# focus previous or next window in window tree (options: prev, next)
yabai -m window --focus prev
# focus first or last window in window tree (options: first, last)
yabai -m window --focus first
# focus window under cursor
yabai -m window --focus mouse
Tiled window can be swapped with other windows.
# swap window position and size with window in direction of focused window
# (options: north, east, south, west)
yabai -m window --swap north
# swap with previously focused window
yabai -m window --swap recent
# swap with previous or next window in window tree (options: prev, next)
yabai -m window --swap prev
# swap with first or last window in window tree (options: first, last)
yabai -m window --swap first
# swap with window under cursor
yabai -m window --swap mouse
The following illustrates how you can use the swap operation to implement window cycling.
cycle_clockwise.sh:
#!/bin/bash
win=$(yabai -m query --windows --window last | jq '.id')
while : ; do
yabai -m window $win --swap prev &> /dev/null
if [[ $? -eq 1 ]]; then
break
fi
done
cycle_counterclockwise.sh
#!/bin/bash
win=$(yabai -m query --windows --window first | jq '.id')
while : ; do
yabai -m window $win --swap next &> /dev/null
if [[ $? -eq 1 ]]; then
break
fi
done
Tiled windows can also be re-inserted ("warped") at other windows.
# warp at window in direction of focused window
# (options: north, east, south, west)
yabai -m window --warp north
# warp at previously focused window
yabai -m window --warp recent
# warp at previous or next window in window tree (options: prev, next)
yabai -m window --warp prev
# warp at first or last window in window tree (options: first, last)
yabai -m window --warp first
# warp at window under cursor
yabai -m window --warp mouse
Floating windows can be moved and resized to absolute coordinates and sizes.
# move focused window to (100, 200)
yabai -m window --move abs:100:200
# change window size to (500, 800)
yabai -m window --resize abs:500:800
Floating windows can also be moved and resized using relative coordinates and sizes.
# move focused window 100 to the right, 200 up
yabai -m window --move rel:100:-200
# grow window by 100 to the right, shrink by 200 at the bottom
# (options: top, left, bottom, right, top_left, top_right, bottom_right, bottom_left)
yabai -m window --resize bottom_right:100:-200
# change window size to (500, 800)
yabai -m window --resize abs:500:800
Floating windows can also be moved and resized at the same time by placing them on a grid. The grid format is <rows>:<cols>:<start-x>:<start-y>:<width>:<height>
, where rows and cols are how many rows and columns there are in total, start-x and start-y are the start indices for the row and column and width and height are how many rows and columns the window spans.
The grid respects the padding enabled for the space.
# move focused window to occupy the left two thirds of the screen.
yabai -m window --grid 1:3:0:0:2:1
Move window to another space or display. As with other commands this works using prev, next, last and mission-control index or arrangement index respectively.
# move window to previous space
yabai -m window --space prev
# move window to display focused before the current one
yabai -m window --display recent
# move window to space 2
yabai -m window --space 2
# move window to space 2 and switch to space 2 (works with both SIP enabled and disabled)
yabai -m window --space 2 --focus
Tiled windows may also be zoomed to either occupy the parent nodes space or the full screen, and windows may also be moved into their own space ("native fullscreen").
# options: zoom-parent, zoom-fullscreen, native-fullscreen
yabai -m window --toggle zoom-parent
Whether a window is split vertically or horizontally with its parent node can be toggled as well.
yabai -m window --toggle split
You can also toggle some other window properties.
# toggle whether the focused window should be tiled (only on bsp spaces)
yabai -m window --toggle float
# toggle whether the focused window should be shown on all spaces
yabai -m window --toggle sticky
Rules and signals can be used to automate window management. Rules define how windows that match app name and optionally title with the rule should be managed, and signals are asynchronous external actions that can be triggered on window management events, e.g. when a window is destroyed or the space is changed.
The → rules docs and → signals docs have detailed information on these. If you need help creating such an automation, feel free to search the issue board and, if no result was found, create an issue asking for help.
Here are some example rules and signals.
# float system preferences
yabai -m rule --add app="^System Preferences$" manage=off
# show digital colour meter topmost and on all spaces
yabai -m rule --add app="^Digital Colou?r Meter$" sticky=on
# refresh my Übersicht bar when the space changes
yabai -m signal --add event=space_changed \
action="osascript -e 'tell application \"Übersicht\" to refresh widget id \"spaces-widget\"'"
yabai can also query information about displays, spaces and windows. There are a total of 12 queries available, which can be enhanced easily using → jq to filter the JSON formatted output.
yabai -m query --displays |
yabai -m query --spaces |
yabai -m query --windows |
|
---|---|---|---|
Query all displays | Query all spaces | Query all windows | |
--display [arrangement index] |
Query focused/selected display | Query all spaces on focused/selected display | Query all windows on focused/selected display |
--space [mission-control index] |
Query display with focused/selected space | Query focused/selected space | Query all windows on focused/selected space |
--window [window id] |
Query display with focused/selected window | Query space with focused/selected window | Query focused/selected window |
For example, to get the window identifiers of all windows on space 2, you could run the following command:
yabai -m query --windows --space 2 | jq '.[].id'
This wiki is a community–driven documentation page. If you want to request a topic for this wiki to address or discuss its content, head over to issue #5.
General
Installation
Configuration
Commands
Tips and Tricks
- Quickly restart the yabai launch agent
- Split yabai configuration across multiple files
- Fix spaces reordering automatically
- Fix folders opened from Desktop not tiling
- Auto updating from HEAD via brew
- Tiling Emacs
- Flash highlight to identify focused window
- Constrain space focus to current display with optional cycling