Tiling window manager for macOS along the lines of xmonad.
A quick screencast of basic functionality can be found here. (It's rough, and I'd love to see a better one if someone has the skills and inclination to make one.)
Amethyst is available for direct download on the releases page or using homebrew cask.
brew cask install amethyst
Note: that Amethyst now is only supported on OS X 10.12+.
Amethyst must be given permissions to use the accessibility APIs under the Privacy tab of the Security & Privacy preferences pane as shown below.
Amethyst uses two modifier combinations.
mod1
-option + shift
mod2
-ctrl + option + shift
And defines the following commands, mostly a mapping to xmonad key combinations.
mod1 + space
— cycle to next layoutmod2 + space
- cycle to previous layoutmod1 + w
- focus 1st screenmod1 + e
- focus 2nd screenmod1 + r
- focus 3rd screenmod2 + w
- move focused window to 1st screenmod2 + e
- move focused window to 2nd screenmod2 + r
- move focused window to 3rd screenmod2 + [n]
- move focused window to nth spacemod2 + left
- move focused window left one spacemod2 + right
- move focused window right one spacemod1 + h
- shrink the main panemod1 + l
- expand the main panemod1 + ,
- increase the number of windows in the main panemod1 + .
- decrease the number of windows in the main panemod1 + j
- focus the next window counterclockwisemod1 + k
- focus the next window clockwisemod2 + j
- move the focused window one space counterclockwisemod2 + k
- move the focused window one space clockwisemod2 + h
- move the focused window one window counterclockwisemod2 + l
- move the focused window one window clockwisemod1 + return
- swap the focused window with the main windowmod1 + t
- toggle whether or not the focused window is floatingmod2 + t
- toggle globally whether or not Amethyst tiles windowsmod1 + i
- display the current layout for each screenmod1 + z
- force windows to be reevalulated
Amethyst allows you to cycle among several different window layouts. Layouts can also be enabled/disabled to control whether they appear in the cycle sequence at all.
- Tall
The default layout. This gives you one "main pane" on the left, and one other pane on the right. By default, one window is placed in the main pane (extending the full height of the screen), and all remaining windows are placed in the other pane. If either pane has more than one window, that pane will be evenly split into rows, to show them all. You can use the keyboard shortcuts above to control which window(s), and how many, are in the main pane, as well as the horizontal size of the main pane vs. the other pane.
- Tall-Right
Exactly the same as Tall, but the main pane is on the right, with the other pane on the left.
- Wide
The rotated version of Tall, where the main pane is on the top (extending the full width of the screen), and the other pane is on the bottom. If either pane has more than one window, that pane will split into columns instead of rows.
- 3Column-Left
A three-column version of Tall, with one main pane on the left (extending the full height of the screen) and two other panes, one in the middle and one on the right. Like Tall, if any pane has more than one window, that pane will be split into rows. You can control how many windows are in the main pane as usual; other windows will be assigned as evenly as possible between the other two panes.
- 3Column-Middle
Exactly like 3Column-Left, but the main pane is in the middle, with the other panes on either side. (In previous versions of Amethyst, this layout was known as Middle-Wide.)
- 3Column-Right
Exactly like 3Column-Left, but the main pane is on the right, with the other panes in the middle and on the left.
- Widescreen-Tall
This mode is like Tall, but if there are multiple windows in the main pane, the main pane splits into columns rather than rows. The other pane still splits windows into rows, like Tall. This layout gets its name because it probably makes the most sense on very wide screens, with a large main pane consisting of several columns, and all remaining windows stacked into the final column. Other layouts that work well on very wide screens include any that allow for more than two columns (to take advantage of the screen width), such as any of the 3Column-* layouts, or Column.
- Fullscreen
In this layout, the currently focused window takes up the entire screen, and the other windows are not visible at all. You can rotate between each of the windows using the "focus the next window" shortcut, as usual.
- Column
This layout has one column per window, with each window extending the full height of the screen. The farthest-left window is considered the "main" window in the sense that you can change its size with the "shrink/expand the main pane" shortcuts; the other windows split the remaining space evenly.
- Row
The rotated version of Column, where each window takes up an entire row, extending the full width of the screen.
- Floating
This mode makes all windows "floating", allowing you to move and resize them as if Amethyst were temporarily deactivated. Unlike the other modes, this will mean that windows can be placed "on top of" each other, obscuring your view of some windows.
- Binary Space Partitioning (BSP)
This layout does not have a main pane in the way that other layouts do. When adding windows, any given pane can be split evenly into two panes along whatever axis is longer. This is recursive such that pane A can be split in the middle into pane A on the left and pane B on the right; pane B can then be split into pane B on top and pane C on bottom; pane C can then be split into pane C on the left and pane D on the right; and so on.
Spaces are, unfortunately, not supported right out of the box. To enable it you
must activate Mission Control's keyboard shortcuts for switching to specific
Desktops, as Mac OS X calls them. This option is in the Keyboard Shortcuts tab
of the Keyboard preferences pane. The shortcuts will be of the form ctrl + [n]
. Amethyst is only able to send a window to the n
th space if the shortcut
ctrl + n
is enabled.
Amethyst currently supports sending windows to up to 10 spaces, despite macOS' limit of 16 spaces per display.
Important note: You will probably want to disable Automatically rearrange Spaces based on most recent use
(found under Mission Control in System Preferences). This setting is enabled by default, and will cause your Spaces to swap places based on use. This makes keyboard navigation between Spaces unpredictable.
If you would like to see features or particular bugs fixed check out the Trello board here and vote on things. It'll give me a better sense of what people want so I can prioritize.
If you'd like to contribute please branch off of the development
branch and open pull requests against it rather than master
. Otherwise just try to stick to the general style of the code. There is a setup script to guide you through the process of installing necessary tools and getting dependencies built. To get started run
$ ./bin/setup.sh
If you have questions or feedback you have a plethora of options. You can email me, tweet at me, or get on gitter.
Amethyst is free and always will be. That said, a couple of people have expressed their desire to donate money in appreciation. Given the current political climate I would recommend donating to one of these organizations instead:
- American Civil Liberties Union
- Planned Parenthood
- Southern Poverty Law Center
- National Resources Defense Council
- International Refugee Assistance Project
- NAACP Legal Defense Fund
- The Trevor Project
- Mexican American Legal Defense Fund
- ProPublica
And a bunch of technology-oriented ones:
- National Center for Women & Information Technology
- girls who code
- MotherCoders
- Trans*H4CK
- Black Girls CODE
Alternatively, I have a Patreon page set up here. Any proceeds will be donated to one of the above organizations.