Window manager built on top of Hammerspoon -- the powerful automation framework for macOS.
Download the latest release from the side panel, decompress the file, and double click the Spoon.
Refer to the official documentation for more information on Spoons, and how to install them.
There are two primary concepts of wm.spoon
: layouts and geometries. To use wm.spoon
one must first define a layouts (or many), which is a table of geometries. A geometry is a built-in utility of Hammerspoon, hs.geometry, that represents the height, width, and x-and-y positions of a rectangle.
The user defines an table of layouts on config.layouts
, which are bound to <prefix> + 1, 2, 3, ... n
; using these hotkeys one can cycle through window layouts.
Then, the user can cycle the position of a window between the geometries of this layout using <prefix> + h
, and <prefix> + l
by default.
After moving windows to their desired positions, the state can be saved using the default binding of <prefix> + -
.
When initializing wm.spoon
, the user is required to define their layouts, however, they also have the option to tweak key bindings along with a variety of other options.
A collection of pre-defined geometries can be found in wm.builtins
.
local wm = require("modules.window")
wm.config.layouts = {
-- ┌-----------─┐
-- | [ ] |
-- | [ ] |
-- └------------┘
{
wm.builtins.full,
wm.builtins.pip_bottom_right,
},
-- ┌-----------─┐
-- | [ ][ ] |
-- | [ ][ ] |
-- └------------┘
{
wm.builtins.padded_left,
wm.builtins.padded_right,
wm.builtins.pip_bottom_right,
},
-- ┌-----------─┐
-- | [ ] |
-- | [ ] |
-- └------------┘
{
wm.builtins.padded_center,
wm.builtins.pip_bottom_right,
},
-- ┌-----------─┐
-- | [ ] |
-- | [ ] |
-- └------------┘
{
wm.builtins.skinny,
wm.builtins.pip_top_right,
},
}
wm:init()
Releases are triggered on tag creation as defined by the .github/workflows/release.yml
GitHub action.
git tag v0.1
git push origin v0.1
This is an opinionated window management system that adheres to the workflow that I find most intuitive. For several years I used the tiling window managers like i3wm, but did not find something that suited my needs on macOS. This is not intended to as powerful as a manager like that, nor is it a tiling window manager. Instead, this is the byproduct of me playing around with Hammerspoon in my spare time.
Feedback and contributions are welcome, however, drastic changes would likely be better suited as a fork.