dewm

by driusan

driusan / dewm

A pure go autotiling window manager written with literate programming

215 Stars 17 Forks Last release: Not found Other 16 Commits 0 Releases

Available items

No Items, yet!

The developer of this repository has not created any items for sale yet. Need a bug fixed? Help with integration? A different license? Create a request here:

dewm - a window manager written with literate programming

dewm is a pure Go autotiling window manager. It's intended to make the text editor de feel more similar to acme when windows are spawned with the p9p plumber, with the window management handled at a window manager level, rather than integrated into the text editor. (If you're unfamiliar with acme, it's a text editor written by Rob Pike for Plan 9 after he got drunk one night and forgot that he wrote "cat -v considered harmful.")

dewm is written in a literate programming style, in the hopes that it can inspire anyone else who's ever wanted to write their own window manager that they can learn enough to do it. I knew next to nothing about the X11 protocol or ICCCM conventions when I started this (and still don't), so if I got anything wrong please feel free to either send a pull request or email me so I can correct it. I don't want to misinform anyone who reads the markdown source in the src/ directory.

Basics

dewm arranges the screen into columns, and divides columns up between windows that are in that column. Windows always spawn in the first empty column, or the end of the last column if there are no empty columns. (If no columns exist, the first one is created automatically.)

By default, all columns are equally sized, and each window in any given column is equally sized, but they can be resized dynamically (see keybindings below).

Keybindings

These keybindings are currently hardcoded, but may one day be configurable.

Window Management

  • Alt-H/Alt-L
    move the current window left or right 1 column.
  • Alt-J/Alt-K
    move the current window up or down 1 window in current column
  • Ctrl-Alt-Up/Down
    increase/decrease the size of the current window. Other windows will be dynamically resized to make sure the column still takes the whole height of the screen.)
  • Ctrl-Alt-Left/Right
    increase/decrease the size of the column with the currently active window. (Other columns will be dynamically resized to make up for it.)
  • Ctrl-Alt-Enter
    toggle whether or not the current window is maximized.
  • Ctrl-Shift-N
    create a new column
  • Ctrl-Shift-D
    delete any empty columns

Other

  • Alt-E
    spawn an xterm
  • Alt-Q
    close the current window
  • Alt-Shift-Q
    destroy the current window
  • Ctrl-Alt-Backspace
    quit dewm

Screenshots

This is what dewm looks like with two windows in two columns:

dewm with two columns

And this is it looks like if, after browsing a bit, you threw an xterm into the mix.

dewm with multiple windows in a column

Installation

The generated go files are included in this repo, so that you can install dewm with the standard go get tool (

go get github.com/driusan/dewm
)

You should then be able to add:

dewm

to the end of your

.xinitrc
or
.xsession
file (assuming
$GOBIN
is in your path, otherwise you'll have to include the full the path to the executable, wherever
go get
compiled it to.)

License

Any code that I've written is MIT licensed. I've often used taowm as a reference when figuring out how to do things. I don't think any reasonable person would say this is a derivative work, but to be safe, LICENSE.taowm contains the taowm (3-clause BSD) license and applies to any code that explicltly comes from there.

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.