X11 Window Manager inspired by Plan 9's rio
Clone or download

README.md

9wm

9wm is an X11 window manager inspired by the Plan 9 window manager 8½, also known as rio. It provides a very simple and clean user interface. It is click-to-type. It uses the X11 font system (which, unfortunately, means no Unicode support).

9wm does not provide virtual desktops, customization, key bindings, EWMH support, or compositing. It does not allocate any colors (if you disable COLOR), which will be great news if you are stuck in 1993.

It is a great place to start if you are interested in writing a window manager from scratch: many folks have done exactly this.

9wm is distributed under an MIT License.

Where do I get it?

The latest version of 9wm is held at:

https://github.com/9wm/9wm

How do I use it?

The focused window has a black border. Mouse and keyboard events go to this window. Left click a non-focused window (white border) to focus it.

Right-click anywhere other than the focused window, including in any non-focused window, to bring up a menu. All further actions are done with the right mouse button. The menu has options for:

  • New: launch a new xterm
  • Reshape: select a window, draw new rectangle for its size
  • Move: drag a window around
  • Delete: kill (close) a window
  • Hide: hide (iconify) a window

Beneath the first 5 items are a list of all hidden windows.

Middle-click anywhere other than the focused window to run "9wm-mm". It's up to you to write an "9wm-mm" program and put it in your path somewhere, if you want to use this for something. I have mine run "google-chrome-stable --show-app-list".

What if I find a bug?

Please submit it to Github.

If you can fix it, submit the fix as a pull request.

Known Problems/Bugs

9wm uses ideas from Plan 9's rio, but is following a different path and is not exactly the same.

In an attempt to avoid ludicrously long window names in the menu, 9wm shortens names with colons and dashes in them. The algorithm works well for most programs I've tried, but is bound to fail with something or other, rendering a near-useless icon name.

Windows that provide their own placement information aren't handled well right now. I'm working on it.

9wm has no idea how many monitors you have, nor what their dimensions are. It also can't deal with desktop geometry changes, like plugging in an external monitor. I run "9wm restart" to make it quickly reset its internal state and notice any changes.

9wm doesn't have Unicode support. In particular, if you have a browser page open with non-Latin characters in the name, and you hide that window, you will get a weird name for that window's entry in the list. Doing Unicode in X11 is a horrible mess requiring, among other things, a whole new library for rendering text. I may get to this in the future, but for now, I feel like learning about Wayland is a better use of my effort.

Lack of EWMH means some applications (especially games) will break when trying to go fullscreen.

Authors

See the credits for a full list of everybody who's helped.

9wm is maintained by Jacob Adams tookmund@gmail.com.

9wm was maintained by Neale Pickett neale@woozle.org.

9wm was written by David Hogan (dhog@cs.su.oz.au), a postgraduate student at the Basser Department of Computer Science, University of Sydney http://unauthorised.org/dhog/index.html David Hogan died in 2003.