docs » hs.expose

Keyboard-driven expose replacement/enhancement

Warning: this module is still somewhat experimental. Should you encounter any issues, please feel free to report them on or #hammerspoon on

With this module you can configure a hotkey to show thumbnails for open windows when invoked; each thumbnail will have an associated keyboard "hint" (usually one or two characters) that you can type to quickly switch focus to that window; in conjunction with keyboard modifiers, you can additionally minimize (alt by default) or close (shift by default) any window without having to focus it first.

When used in combination with a windowfilter you can include or exclude specific apps, window titles, screens, window roles, etc. Additionally, each expose instance can be customized to include or exclude minimized or hidden windows, windows residing in other Mission Control Spaces, or only windows for the current application. You can further customize hint length, colors, fonts and sizes, whether to show window thumbnails and/or titles, and more.

To improve responsiveness, this module will update its thumbnail layout in the background (so to speak), so that it can show the expose without delay on invocation. Be aware that on particularly heavy Hammerspoon configurations this could adversely affect overall performance; you can disable this behaviour with hs.expose.ui.fitWindowsInBackground=false


-- set up your instance(s)
expose =,{showThumbnails=false}) -- default windowfilter, no thumbnails
expose_app =,{onlyActiveApplication=true}) -- show windows for the current application
expose_space =,{includeOtherSpaces=false}) -- only windows in the current Mission Control Space
expose_browsers ={'Safari','Google Chrome'} -- specialized expose using a custom windowfilter
-- for your dozens of browser windows :)

-- then bind to a hotkey
hs.hotkey.bind('ctrl-cmd-shift','e','App Expose',function()expose_app:toggleShow()end)

API Overview

  • Variables - Configurable values
  • Constructors - API calls which return an object, typically one that offers API methods
  • Methods - API calls which can only be made on an object returned by a constructor

API Documentation



Signature hs.expose.ui
Type Variable
Description Allows customization of the expose behaviour and user interface



Signature[windowfilter[, uiPrefs][, logname, [loglevel]]]) -> hs.expose object
Type Constructor
Description Creates a new hs.expose instance; it can use a windowfilter to determine which windows to show
  • windowfilter - (optional) if omitted or nil, use the default windowfilter; otherwise it must be a windowfilter
  • instance or constructor table
  • uiPrefs - (optional) a table to override UI preferences for this instance; its keys and values
  • must follow the conventions described in `hs.expose.ui`; this parameter allows you to have multiple
  • expose instances with different behaviour (for example, with and without thumbnails and/or titles)
  • using different hotkeys
  • logname - (optional) name of the `hs.logger` instance for the new expose; if omitted, the class logger will be used
  • loglevel - (optional) log level for the `hs.logger` instance for the new expose
  • the new instance
  • by default expose will show invisible windows and (unlike the OSX expose) windows from other spaces; use
  • `hs.expose.ui` or the `uiPrefs` parameter to change these behaviours.



Signature hs.expose:hide()
Type Method
Description Hides the expose, if visible, and exits the modal mode.
  • None
  • None


Signature hs.expose:show([activeApplication])
Type Method
Description Shows an expose-like screen with modal keyboard hints for switching to, closing or minimizing/unminimizing windows.
  • activeApplication - (optional) if true, only show windows of the active application (within the
  • scope of the instance windowfilter); otherwise show all windows allowed by the instance windowfilter
  • None
  • passing `true` for `activeApplication` will simply hide hints/thumbnails for applications other
  • than the active one, without recalculating the hints layout; conversely, setting `onlyActiveApplication=true`
  • for an expose instance's `ui` will calculate an optimal layout for the current active application's windows
  • Completing a hint will exit the expose and focus the selected window.
  • Pressing esc will exit the expose and with no action taken.
  • If shift is being held when a hint is completed (the background will be red), the selected
  • window will be closed. If it's the last window of an application, the application will be closed.
  • If alt is being held when a hint is completed (the background will be blue), the selected
  • window will be minimized (if visible) or unminimized/unhidden (if minimized or hidden).


Signature hs.expose:toggleShow([activeApplication])
Type Method
Description Toggles the expose - see hs.expose:show() and hs.expose:hide()
  • None

results matching ""

    No results matching ""