Difference between revisions of "WM"

From Things and Stuff Wiki
Jump to navigation Jump to search
 
(39 intermediate revisions by the same user not shown)
Line 32: Line 32:
  
 
* [http://box-look.org/ Box-Look.org] - Stuff for your Windowmanager
 
* [http://box-look.org/ Box-Look.org] - Stuff for your Windowmanager
 +
 +
* [https://jichu4n.com/posts/how-x-window-managers-work-and-how-to-write-one-part-i/ How X Window Managers Work, And How To Write One (Part I)] - [https://news.ycombinator.com/item?id=29091070]
 +
  
 
=== xwm ===
 
=== xwm ===
Line 150: Line 153:
  
  
* https://en.wikipedia.org/wiki/FVWM95 - based on the popular FVWM 2 window manager. It is similar to the original FVWM, but is designed to closely resemble the look of Windows 95.
+
* https://github.com/mintsuki/fvwm95 - a fork of fvwm95 meant to be compilable on and play nice with newer Unix-like operating systems.It is based off the code from the source package in Debian Sarge, slightly modified so that it compiles without errors on modern OSes, and with a more sane configuration to adapt to modern day needs.
 +
** https://en.wikipedia.org/wiki/FVWM95 - based on the popular FVWM 2 window manager. It is similar to the original FVWM, but is designed to closely resemble the look of Windows 95.
  
  
Line 177: Line 181:
 
1996 / 1998
 
1996 / 1998
  
* http://www.all-day-breakfast.com/wm2/
+
* http://www.all-day-breakfast.com/wm2
* http://www.all-day-breakfast.com/wmx/
+
** https://github.com/cannam/wm2 - a window manager for X. It provides an unusual style of window decoration and as little functionality as comfortable. wm2 is not configurable, except by editing the source and recompiling the code, and is really intended for people who don't particularly want their window manager to be too friendly.
 +
 
 +
 
 +
* http://www.all-day-breakfast.com/wmx
  
 
=== Window Maker ===
 
=== Window Maker ===
Line 411: Line 418:
 
** https://en.wikipedia.org/wiki/dwm
 
** https://en.wikipedia.org/wiki/dwm
 
** http://web.archive.org/web/20120120161931/http://lubutu.com/rant/dwm-faq
 
** http://web.archive.org/web/20120120161931/http://lubutu.com/rant/dwm-faq
 +
  
 
* https://sourceforge.net/projects/adwm/ - old fork
 
* https://sourceforge.net/projects/adwm/ - old fork
 +
 +
 +
* https://github.com/bakkeby/dwm-flexipatch - A dwm build with preprocessor directives to decide which patches to include during build time
  
 
=== spectrwm ===
 
=== spectrwm ===
Line 438: Line 449:
 
2007
 
2007
  
* [http://xmonad.org/ xmonad] is a dynamically tiling X11 window manager that is written and configured in Haskell. In a normal WM, you spend half your time aligning and searching for windows. xmonad makes work easier, by automating this.
+
* [http://xmonad.org/ xmonad] is a dynamically tiling X11 window manager that is written and configured in Haskell. In a normal WM, you spend half your time aligning and searching for windows. xmonad makes work easier, by automating this. [https://news.ycombinator.com/item?id=28793941] 
  
 
* [http://xmonad.org/documentation.html documentation]
 
* [http://xmonad.org/documentation.html documentation]
Line 485: Line 496:
 
2007
 
2007
  
* [https://awesomewm.org/ awesome] - a highly configurable, next generation framework window manager for X. It is very fast, extensible and licensed under the GNU GPLv2 license.It is primarily targeted at power users, developers and any people dealing with every day computing tasks and who want to have fine-grained control on their graphical environment.
+
See [[Awesome]]
 
 
 
 
* http://awesome.naquadah.org/doc/manpages/awesome.1.html
 
 
 
* https://awesomewm.org/doc/manpages/awesomerc.5.html
 
 
 
 
 
* https://awesomewm.org/apidoc
 
 
 
 
 
* https://wiki.archlinux.org/index.php/Awesome
 
 
 
 
 
 
 
* https://github.com/atsepkov/awesome-awesome-wm - A curated list of awesome tools/scripts/configs for Awesome Window Manager.
 
 
 
 
 
 
 
==== Config ====
 
* [http://awesome.naquadah.org/wiki/My_first_awesome#Personalize_your_tags layouts] [http://awesome.naquadah.org/wiki/Layout]
 
 
 
* http://awesome.naquadah.org/doc/api
 
 
 
 
 
echo 'naughty.notify({ text = "hello from tty" })' | awesome-client
 
 
 
debug rc.lua changes;
 
Xephyr :1 -ac -br -noreset -screen 1152x720 &
 
DISPLAY=:1.0 awesome -c ~/.config/awesome/rc.lua.new
 
 
 
If xdg/awesome default config loads instead of .config/awesome, this is due to error in the rc.lua.
 
 
 
 
 
 
 
* https://github.com/manjaro/desktop-settings/blob/master/community/awesome/skel/.config/awesome/rc.lua
 
 
 
 
 
 
 
 
 
* https://github.com/lcpz/awesome-copycats
 
 
 
 
 
* https://github.com/pw4ever/awesome-wm-config
 
 
 
 
 
* https://github.com/Elv13/awesome-1/blob/doc_tests_and_notif/lib/awful/client/focus.lua#L155-L192
 
 
 
* https://github.com/Elv13/awesome-configs
 
 
 
* https://github.com/WillPower3309/awesome-dotfiles
 
 
 
* https://github.com/worron/awesome-config
 
 
 
 
 
* [https://pouyanh.github.io/carrot/ :carrot:] - Carrot awesomeWM personalization application
 
 
 
 
 
* https://awesomewm.org/apidoc/input_handling/awful.key.html
 
 
 
 
 
==== Multihead ====
 
* http://awesome.naquadah.org/wiki/Using_Multiple_Screens
 
 
 
 
 
==== Wibox ====
 
* comp.window-managers.awesome: [http://comments.gmane.org/gmane.comp.window-managers.awesome/5460 Re: Multiple row wibox]
 
 
 
 
 
 
 
* https://github.com/cool-cool-sweat/fenetre - awesome 4 wibar global titlebar with client title + controls/property indicators
 
 
 
==== Widgets ====
 
* http://awesome.naquadah.org/wiki/Awesome_3.3_to_3.4#Widget_Layouts
 
 
 
 
 
* [http://awesome.naquadah.org/wiki/Vicious Vicious]
 
 
 
 
 
* [http://git.mercenariesguild.net/?p=obvious.git;a=tree Obvious]
 
 
 
 
 
* [http://solitudo.net/software/awesome/delightful/ Delightful]
 
 
 
 
 
 
 
* [https://pavelmakhov.com/awesome-wm-widgets/#tabMain Widgets for Awesome WM] - Set of super simple widgets compatible with Awesome Window Manager v.4+.
 
** https://github.com/streetturtle/awesome-wm-widgets
 
 
 
 
 
 
 
* https://github.com/macunha1/awesomewm-media-player-widget -  AwesomeWM generic Media Player Widget implementation in pure Lua through MPRIS D-Bus interface spec
 
 
 
* [https://www.reddit.com/r/awesomewm/comments/dcdu0s/mpris_widget/ mpris widget : awesomewm]
 
 
 
* https://github.com/AlterationBrick/awesome-playerctl-widget - Music player widget for the Awesome window manager using playerctl
 
 
 
* https://github.com/Stebalien/awesomewm-config/blob/master/music.lua
 
 
 
==== Theme ====
 
The color format in awesome is either a standard X color name (blue, darkblue, lightred, etc) or a hexadecimal formatted color (#rrggbb or #rrggbbaa). By using the hexadecimal format, you can also specify an alpha channel: that means that #00ff00 will draw pure green, but #00ff00aa will set the alpha channel to ‘aa’ and will blend the green with the color under it.
 
 
 
 
 
* https://github.com/lcpz/awesome-copycats - Awesome WM themes
 
 
 
==== Text format ====
 
You can use [http://developer.gnome.org/pango/stable/PangoMarkupFormat.html Pango] markup in a text string. This allows formating the text rendered inside widgets. Pango markup documentation can be found in the Pango documentation at http://library.gnome.org/devel/pango/stable/PangoMarkupFormat.html.
 
 
 
A Pango markup example: <span weight="bold" foreground="#336699">…</span>.
 
 
 
 
 
==== Scripts ====
 
* https://github.com/montagdude/awesome-appmenu - a tool to create a menu of installed applications for the awesome window manager. It searches for and parses .desktop files to find the name, execution command, and icon of installed applications. These are then grouped into categories, sorted, and written to a lua script ($HOME/.config/awesome/appmenu.lua) that can be used in your awesome WM configuration script.
 
 
 
 
 
* https://github.com/blueyed/awesome-cyclefocus -  Alt-Tab for the awesome window manager (and more)
 
 
 
 
 
* https://github.com/intrntbrn/smart_borders#custom-menues - full titlebar functionality without sacrificing space
 
 
 
 
 
* https://github.com/Veratil/awesome-retain -  Awesome Lua module for retaining tags and their layouts between restarts and screen adds/removes
 
 
 
 
 
* https://github.com/crater2150/awesome-modalbind - Modal keybindings for AwesomeWM
 
 
 
 
 
* https://awesome.naquadah.org/wiki/Shifty
 
 
 
* https://github.com/bioe007/awesome-shifty/tree/2.0
 
 
 
* https://bbs.archlinux.org/viewtopic.php?id=124725
 
 
 
* http://aur.archlinux.org/packages.php?ID=32463
 
 
 
* http://git.naquadah.org/?p=awesome.git;a=summary
 
 
 
 
 
 
 
* https://github.com/Elv13/radical - unified interface to generate multiple types of menus.
 
 
 
 
 
* https://github.com/Elv13/repetitive - Focus tagFocus client and restore cursor positionRecord/Play mouse+keyboards macros
 
 
 
 
 
* https://github.com/Elv13/tyrannical -  Dynamic tagging configuration system for awesomeWM
 
 
 
 
 
 
 
* https://github.com/Drauthius/awesome-sharedtags - A simple implementation for creating tags shared on multiple screens for awesome window manager.
 
 
 
 
 
* https://github.com/seberm/awesome-vim-bindings -  Awesome window manager with Vim-like control
 
 
 
 
 
 
 
* https://github.com/intrntbrn/awesomewm-vim-tmux-navigator - lets you navigate seamlessly between system windows, vim splits and tmux panes using a consisent set of hotkeys. It's based on christoomey/vim-tmux-navigator and fogine/vim-i3wm-tmux-navigator
 
 
 
 
 
 
 
* [https://gkaczorek.com/2020-09-25-adding-an-alacritty-based-drop-down-terminal-in-awesomewm/ Adding an Alacritty based drop-down terminal in AwesomeWM]
 
** https://github.com/lcpz/lain/blob/33c0e0c2360a04fcc6f51bccb0ad2a7a9e9c07b3/util/quake.lua
 
 
 
 
 
 
 
==== Layouts ====
 
* https://github.com/worron/awesome-config
 
** YouTube: [https://www.youtube.com/watch?v=ZWD_YMMCoMU Awesome WM custom layout demo]
 
 
 
 
 
* https://github.com/lcpz/lain - Layouts, widgets and utilities for Awesome WM 4.x
 
 
 
 
 
* https://github.com/JamesWilmot/AwesomeWMColumnsLayout -  Awesome WM layout columns layout with arbitrary number of columns.
 
 
 
 
 
* https://gist.github.com/mikaelz/b85c8d97fcee55c33b88
 
 
 
 
 
* https://github.com/michaelbeaumont/awesome-leaved - Layout for AwesomeWM based on i3 and arranging clients into containers
 
 
 
 
 
* https://github.com/ciiqr/thrizen -  A three column layout for awesome wm
 
 
 
 
 
* https://github.com/jcrd/awesome-dovetail - a layout for Awesome featuring two visible tiled clients. It is similar to the deck layout in other dynamic window managers.
 
 
 
 
 
* https://github.com/drewby/basl - Big Ass Screen Layout for AwesomeWM
 
 
 
* https://github.com/groboclown/awesomewm-petronia -  Custom Layout and Keybindings to make Petronia style interactions in Awesome WM
 
 
 
==== hints ====
 
* https://github.com/zackpete/hints -Window picker with hints for Awesome
 
 
 
==== Revelation ====
 
* http://awesome.naquadah.org/wiki/Revelation - Expose-like client selection.
 
** https://github.com/guotsuan/awesome-revelation
 
 
 
==== Radical ====
 
* https://github.com/Elv13/radical - This is Radical, one of the largest Awesome extension module. It provides a unified interface to generate multiple types of menus.
 
 
 
==== Freedesktop menu ====
 
* https://github.com/terceiro/awesome-freedesktop
 
 
 
==== MPD ====
 
* http://awesome.naquadah.org/wiki/Awesompd_widget
 
 
 
==== Other ====
 
 
 
* https://github.com/uzsolt/keychains - A simple keychain module which allows to use keychains in awesome window
 
manager.
 
  
 
=== subtle ===
 
=== subtle ===
Line 744: Line 544:
  
 
=== i3 ===
 
=== i3 ===
2009
+
See [[i3]]
 
 
Based on wmii, tiling/floating.
 
 
 
 
 
* http://i3wm.org
 
 
 
* https://github.com/Airblader/i3 - i3-gaps
 
 
 
 
 
* http://i3wm.org/docs/refcard.html
 
 
 
* http://i3wm.org/docs/userguide.html
 
 
 
 
 
* YouTube: [https://youtu.be/j1I63wGcvU4?t=178 i3wm: Jump Start (1/3)] - configuration guides
 
* YouTube: [https://www.youtube.com/watch?v=AWA8Pl57UBY i3 screencast: containers and the tree data structure]
 
* YouTube: [http://youtube.com/watch?v=pSPcQ7Sdoh4 i3 Window Manager Overview]
 
* YouTube: [http://youtube.com/watch?v=QnYN2CTb1hM i3 - An Improved Tiling Window Manager]
 
 
 
 
 
* https://www.reddit.com/r/i3wm
 
 
 
 
 
 
 
i3-msg exec application
 
  # start your application on the workspace where it was called
 
 
 
 
 
* http://i3wm.org/docs/ipc.html
 
 
 
* https://github.com/ziberna/i3-py/tree/master/examples
 
 
 
* https://pypi.python.org/pypi/i3ipc
 
 
 
 
 
 
 
* http://i3wm.org/docs/userguide.html#_configuring_i3bar
 
 
 
* http://i3wm.org/i3bar/manpage.html
 
 
 
* https://i3wm.org/i3status/manpage.html
 
 
 
* http://i3wm.org/docs/user-contributed/py3status.html
 
** https://github.com/ultrabug/py3status
 
** https://github.com/ultrabug/py3status/blob/master/py3status/modules/README.md
 
 
 
* https://github.com/greshake/i3status-rust - a feature-rich and resource-friendly replacement for i3status, written in pure Rust. It provides a way to display "blocks" of system information (time, battery status, volume, etc) on the i3 bar. It is also compatible with sway.
 
 
 
 
 
* https://github.com/RasmusLindroth/i3keys - lists all the keys that are bound to some action in i3 or sway, and all keys that are not bound to any actions.
 
 
 
 
 
* [https://faq.i3wm.org/question/2172/how-do-i-find-the-criteria-for-use-with-i3-config-commands-like-for_window-eg-to-force-splashscreens-and-dialogs-to-show-in-floating-mode.1.html How do I find the criteria for use with i3 config commands like for_window (e.g. to force splashscreens and dialogs to show in floating mode)?]
 
** Gist: [https://gist.github.com/major/ff11ccdd73941109abb4ac2d35c976eb  i3-get-window-criteria.sh ]
 
 
 
 
 
* http://i3wm.org/docs/userguide.html#_changing_colors
 
 
 
* http://kumarcode.com/Colorful-i3/
 
 
 
* https://github.com/acrisci/i3-style
 
 
 
* https://github.com/s-ol/themer
 
 
 
 
 
bindsym $mod+n exec i3-msg move to container workspace $(($(wmctrl -d | wc -l) + 1))
 
  # move to next numbered workspace whether existing or empty
 
 
 
* http://unix.stackexchange.com/questions/138425/open-a-specific-application-in-a-new-workspace-with-i3wm
 
 
 
* https://i3wm.org/docs/user-contributed/swapping-workspaces.html
 
 
 
* https://faq.i3wm.org/question/61/forcing-windows-as-always-floating.1.html
 
 
 
* https://faq.i3wm.org/question/1457/assign-program-to-specific-workspace-on-specific-output.1.html
 
 
 
* https://www.reddit.com/r/i3wm/comments/2m1knu/struggling_to_move_workspaces_between_monitors/
 
 
 
* https://i3wm.org/docs/user-contributed/lzap-config.html
 
 
 
* https://github.com/MicroJoe/i3_dtags
 
 
 
* https://github.com/OliverUv/quickswitch-for-i3
 
 
 
* https://github.com/tmfink/i3-wk-switch
 
 
 
* https://github.com/saneki/i3-swap
 
 
 
* https://gist.github.com/wwwtyro/9bc63c06861732760a3d
 
 
 
* https://github.com/un-def/i3-workspace-switcher
 
 
 
* https://github.com/cameronleger/i3-workspacer - simplifying large amounts of i3 workspaces with naming and infinite* workspace traversal
 
 
 
* https://github.com/Chimrod/i3_workspaces - allow you to configure your workspace easily. I use it for setting a wallpaper to each workspace, or launch application on some workspaces.
 
 
 
 
 
 
 
* https://faq.i3wm.org/question/5721/how-do-i-subscribe-to-i3-events-using-bash-easily - i3subscribe
 
 
 
 
 
* http://i3wm.org/docs/layout-saving.html
 
 
 
* https://web.archive.org/web/20160420173541/http://www.kelvinblog.tk/i3wm-restore-layout - "i3 can only swallow new windows, but not existing ones. ... I use xdotool to unmap all visible windows and map them again (Mapping a window means to let the WM manage it). This is the script I use"
 
 
 
* https://github.com/joepestro/i3session - remembers what's running in your i3 workspaces by saving a session file (in ~/.i3/session). It is then able to restore the running processes (and their simple orientation) to one or more workspaces. Since i3session executes i3 commands sequentially (tree traversal), changing focus during restore will affect where clients open. By default, the i3-nagbar will appear during restore with a message to remind you of this.
 
 
 
* https://github.com/pitkley/i3nator -  Tmuxinator for the i3 window manager. It allows you to manage what are called "projects", which are used to easily restore saved i3 layouts (see Layout saving in i3) and extending i3's base functionality by allowing you to automatically start applications too.
 
 
 
* https://github.com/JonnyHaystack/i3-resurrect - Simple solution to saving and restoring i3 workspaces
 
 
 
 
 
 
 
* https://github.com/jamesofarrell/i3-swallow - used to swallow (send to the scratchpad) a terminal window after a blocking application is run in i3.
 
 
 
 
 
jq:
 
.[].num
 
 
.[] | select(.visible and .focused).num+1)
 
 
if ([(.[][] | select(.visible == true) | select(.focused == true).num)+1] as $desk | [.[][].num] as $array | $array | contains($desk)) == true then "one" else "two" end
 
 
 
 
 
 
 
* https://github.com/olemartinorg/i3-alternating-layout -  Scripts to open new windows in i3wm using alternating layouts (splith/splitv) for each new window
 
  
 
=== TinyWM ===
 
=== TinyWM ===
Line 1,168: Line 842:
  
 
* http://emacsist.com/10473
 
* http://emacsist.com/10473
 +
 +
 +
* https://github.com/johanwiden/exwm-setup/blob/master/README.org - A complete configuration for the EXWM X11 window manager
  
 
=== katriawm ===
 
=== katriawm ===
Line 1,202: Line 879:
  
 
* https://github.com/jaelpark/chamferwm - A tiling window manager with Vulkan based compositor.
 
* https://github.com/jaelpark/chamferwm - A tiling window manager with Vulkan based compositor.
 +
 +
 +
 +
=== dovetail ===
 +
* https://github.com/jcrd/dovetail -dovetail is an opinionated window manager based on awesome.
  
 
=== Twindy ===
 
=== Twindy ===
Line 1,222: Line 904:
 
=== sowm ===
 
=== sowm ===
 
* https://github.com/dylanaraps/sowm - An itsy bitsy floating window manager with roots in catwm.
 
* https://github.com/dylanaraps/sowm - An itsy bitsy floating window manager with roots in catwm.
 +
 +
=== SWM ===
 +
 +
 +
* [https://dspace.cvut.cz/bitstream/handle/10467/87816/F8-DP-2020-Bina-Jan-thesis.pdf?sequence=-1&isAllowed=y SWM -- Simple Window Manager - F8-DP-2020-Bina-Jan-thesis.pdf] -
  
 
=== nimdow ===
 
=== nimdow ===
Line 1,229: Line 916:
 
* [http://leftwm.org/ LeftWM] - a tiling window manager written in rust for stability and performance. The core of left is designed to do one thing and one thing well. Be a window manager. Because you probably want more than just a black screen LeftWM is built around the concept of theming. With themes you can choose between different bar / compositor / background / colors, whatever makes you happy.LeftWM has been built from the very beginning to support multiple screens and has been built around ultrawide monitors. You will see this with the default key bindings.
 
* [http://leftwm.org/ LeftWM] - a tiling window manager written in rust for stability and performance. The core of left is designed to do one thing and one thing well. Be a window manager. Because you probably want more than just a black screen LeftWM is built around the concept of theming. With themes you can choose between different bar / compositor / background / colors, whatever makes you happy.LeftWM has been built from the very beginning to support multiple screens and has been built around ultrawide monitors. You will see this with the default key bindings.
 
** https://github.com/leftwm/leftwm
 
** https://github.com/leftwm/leftwm
 +
 +
 +
=== page ===
 +
* https://github.com/gschwind/page - mouse friendly tiling window manager for linux. page organizes windows in tiles and groups them in tabs. It allow to reconfigure dynamically tile and tabs with your mouse pointer. page can be used with desktop environment that allow to replace the window manager, for instance MATE or XFCE. page is under development and implement ICCCM and EWMH. It is implemented in C++11 and depend on Xlib, xcb, glib, pango and cairo. The code is distributed under GPLv3.
  
 
=== instantWM ===
 
=== instantWM ===
Line 1,243: Line 934:
 
* https://github.com/mcpcpc/xwm [https://news.ycombinator.com/item?id=25033613]
 
* https://github.com/mcpcpc/xwm [https://news.ycombinator.com/item?id=25033613]
  
=== Other tiling ===
+
=== tofu ===
 +
* https://github.com/periish/tofu - a shell based window manager for x11fs. It uses x11fs to parse events and control windows. tofu is built to be easily extensible, and scriptable. It is a simple shell script itself. tofc is a program that can be used in tandem with tofu. It controls windows. tofu on it's own does not enforce any particular behaviour for windows, however some example workflows exist in the contrib directory. tofu does not handle keybinds - sxhkd or XBindkeys is reccomended.
 +
 
 +
=== hfwm ===
 +
* https://github.com/katef/hfwm - Half Finished Window Manager
 +
 
 +
=== shod ===
 +
* https://github.com/phillbush/shod - tabbed window manager that can tile windows inside floating containers
 +
 
 +
=== chamferwm ===
 +
* https://github.com/jaelpark/chamferwm - A tiling window manager with Vulkan based compositor. Vulkan compositor for external X11 window managers
 +
 
 +
=== Other ===
 
See also [[Wayland]]
 
See also [[Wayland]]
  
Line 1,250: Line 953:
  
 
* https://github.com/jjttjj/wm - a clojure(script) library which provides an immutable datastructure that's useful for implementing a tiling window manager.
 
* https://github.com/jjttjj/wm - a clojure(script) library which provides an immutable datastructure that's useful for implementing a tiling window manager.
 +
 +
 +
* https://github.com/sminez/penrose -  A library for writing an X11 tiling window manager

Latest revision as of 01:40, 2 March 2024

Window Managers


xwm


xnwm

uwm

1985

developed by the Digital Equipment Corporation for their Ultrix operating system. It was released in 1985. Shortly thereafter, it became included as part of the base X Window System distribution, beginning with X10R3. Initially, it was distributed alongside two other window managers (xwm and xnwm).

In 1986, the X Window System switched to version 11 of the protocol. Only uwm was ported, so it became the only window manager for X Window System until X11R4 release, where it was replaced by twm. uwm has never been updated since.

twm

1987

The name originally stood for Tom's Window Manager, but the software was renamed Tab Window Manager by the X Consortium when they adopted it in 1989 (X11R4).

twm is a re-parenting window manager that provides title bars, shaped windows and icon management. It is highly configurable and extensible. twm was a breakthrough achievement in its time, but it has been largely superseded by other window managers which, unlike twm, use a widget toolkit rather than writing directly against Xlib.

Various other window managers—such as vtwm, tvtwm, CTWM, and FVWM—were built on twm's source code.

awm

1988

descended from uwm.

olvm / olvwm

1989 / 1996?

OPEN LOOK Window Manager was the default stacking window manager for OpenWindows, the original desktop environment included with SunOS and Solaris. Its unique characteristic is its implementation of the OPEN LOOK look and feel.

Scott Oaks developed a variant of olwm, called olvwm (the OPEN LOOK Virtual Window Manager), which implements a virtual root window with dimensions greater than those of the video display.

swm

1989

Developed by Tom LaStrange at Solbourne Computer (computer workstations and servers based on the SPARC microprocessor architecture, largely compatible with Sun Microsystems' Sun-4 systems) in 1990. The most important innovation of swm was the introduction of the virtual desktop. It also introduced a primitive form of session management (restoring programs in use at the time of shutdown) to X.

Vtwm

1990

tvtwm

1991

Derived from twm to which it adds the virtual desktop feature from swm. All of these window managers were originally written by Tom LaStrange.

Unlike most more recent virtual window managers, tvtwm models the root window as a single large space, with the physical desktop being a viewport onto that virtual root window. The user can scroll the viewport around the virtual desktop either by pressing certain keys or by clicking into a scaled down representation of the virtual desktop, the so-called panner.

CTWM

1992

Claude Lecommandeur from the source code for twm, which, inspired by HP's vuewm, he extended to allow for virtual desktops ("workspaces" in CTWM's terminology.)

PieWM

1992

tvtwm fork, Has pie menus (circle around the mouse).

mwm

1992

Motif Window Manager

FVWM

1993

Derived from twm, has lots of forks: Afterstep, Xfce, Enlightenment, WindowMaker, Metisse, Bowman, AmiWM, FVWM-XPM (pre-Enlightenment), NWM, MVLWM, SCWM


  • https://github.com/mintsuki/fvwm95 - a fork of fvwm95 meant to be compilable on and play nice with newer Unix-like operating systems.It is based off the code from the source package in Debian Sarge, slightly modified so that it compiles without errors on modern OSes, and with a more sane configuration to adapt to modern day needs.
    • WP: FVWM95 - based on the popular FVWM 2 window manager. It is similar to the original FVWM, but is designed to closely resemble the look of Windows 95.



9wm

1994

ADAM

1995

AmiWM

1996?

wm2 / wmx

1996 / 1998

  • http://www.all-day-breakfast.com/wm2
    • https://github.com/cannam/wm2 - a window manager for X. It provides an unusual style of window decoration and as little functionality as comfortable. wm2 is not configurable, except by editing the source and recompiling the code, and is really intended for people who don't particularly want their window manager to be too friendly.


Window Maker

1997


Blackbox

1997

IceWM

1997


MLVWM

1997

Xfwm

Xfwm - used in Xfce, intially based on fvwm2, itself derived from twm, redesigned to minimize memory consumption, provide a 3-D look to window frames, and provide a simple virtual desktop.

4Dwm

1998?

derived from mwm. uses the Motif widget toolkit, normally used on Silicon Graphics workstations running IRIX.

aewm

1998

AfterStep

1999

Scwm

1999

plwm

1999

PWM

2000

Tiling

Succeeded by Ion

Ion

2000

Tiling

Successor to PWM, development dead

Fork: Notion

Sawfish

2000

  • Sawfish is an extensible window manager using a Lisp-based scripting language. Its policy is very minimal compared to most window managers. Its aim is simply to manage windows in the most flexible and attractive manner possible. All high-level WM functions are implemented in Lisp for future extensibility or redefinition. what i wanted when using litestep

larswm

2000

ratpoison

2000

PLWM

2000

Fluxbox

2001

WindowLab

2001

Fork of aewm. Stacking.

evilwm

2001

Stacking, minimal/small.

Openbox

2002

Metacity

2002

miwm

2002

Hackedbox

2002

Oroborus

2002

NovaWM

2002

Stumpwm

2003

cwm

2004

Calm Window Manager, stacking. was based on evilwm, rewritten as a 9wn fork, then rewritten

wmii

2005

Tiling/stacking, plan9 like interface.

PekWM

2005

Stacking

JWM

2005

Stacking, Windows 98 like.

whimsy

2005

Python, stackable.

dwm

2006

Tiling, configuration in source header file.



spectrwm

2006

  • spectrwm is a small dynamic tiling window manager for X11. It tries to stay out of the way so that valuable screen real estate can be used for much more important stuff. It has sane defaults and does not require one to learn a language to do any configuration. It was written by hackers for hackers and it strives to be small, compact and fast. It was largely inspired by xmonad and dwm.

FLWM

2006?

Stacking, based on the FLTK toolkit

Matchbox

2007

  • Matchbox - an Open Source base environment for the X Window System running on non-desktop embedded platforms such as handhelds, set-top boxes, kiosks and anything else for which screen space, input mechanisms or system resources are limited.Matchbox consists of a number of interchangeable and optional applications that can be tailored to a specific non desktop platform to enhance usability in a ‘constrained’ environment.

xmonad

2007

  • xmonad is a dynamically tiling X11 window manager that is written and configured in Haskell. In a normal WM, you spend half your time aligning and searching for windows. xmonad makes work easier, by automating this. [4]

Config

cabal --recompile
  after changing ~/.xmonad/xmonad.hs

Hotkeys

mod shift enter
  start terminal
mod shift c
  close current window

mod w
  reload xmonad

mod space
  rotate through window layouts
mod shift space
  reset to workspace default
mod tab
  tab through windows
super 2
  switch to workspace 2

Awesome

2007

See Awesome

subtle

2007

  • subtle is a manual tiling window manager with a rather uncommon approach of tiling: Instead of relying on predefined layouts, subtle divides the screen into a grid with customizeable slots (called gravities). For better understanding, the default config uses a 3x3 grid and maps each gravity to one key of the numpad. With those keys, windows can be moved directly to the desired gravity - the same can be done with tagging rules in the config. Another unique concept is the strict tagging: Unlike other tiling window managers, subtle doesn't allow weak tagging and always maps windows to virtual desktops (called views) with matching tags, regardless of the current active view.

Echinus

2007

Tritium

2007?

  • https://github.com/stew/tritium - a tabbed/tiling window manager. tritium is a tiling/tabbed window manager for the X Window System inspired by the ion3 window manager. It was written completely from scratch in python and shares no actual code with ion3. tritium is implemented in python using the plwm ("pointless window manager") library

SithWM

2007

wmfs

2008

CLFSWM

2008

Lucca WM

2008?

i3

See i3

TinyWM

  • tinywm - a tiny window manager that I created as an exercise in minimalism. It is also maybe helpful in learning some of the very basics of creating a window manager. It is only around 50 lines of C. There is also a Python version using python-xlib. It lets you do four basic things: Move windows interactively with Alt+Button1 drag (left mouse button), Resize windows interactively with Alt+Button3 drag (right mouse button), Raise windows with Alt+F1 (not high on usability I know, but I needed a keybinding in there somewhere), Focus windows with the mouse pointer (X does this on its own) [5]

Notion

2010

Tiling, tabbed



Fork of Ion

Musca

2009

Bluetile

2010

  • Bluetile is a tiling window manager for Linux, designed to integrate with the GNOME desktop environment. It provides both a traditional, stacking layout mode as well as tiling layouts where windows are arranged to use the entire screen without overlapping. Bluetile tries to make the tiling paradigm easily accessible to users coming from traditional window managers by drawing on known conventions and providing both mouse and keyboard access for all features. based on Xmonad

mcwm

2010

catwm

2010

euclid-wm

2010

wind

2010

Wind is a window manager for the X Window System. It supports virtual desktops, optional Xft font rendering, and is pretty standards compliant. It provides overlapping window management with click-to-type focus. Unlike most window managers, Wind does not have the concept of minimized or hidden windows. Instead of hiding and unhiding windows, the virtual desktops abstraction makes it easy to group similar tasks and switch between these groups instantly using convenient key bindings. Standards compliancy is a prominent goal of the project, and Wind supports almost all mandatory parts of the ICCCM and the Extended Window Manager Hints specifications. Full compliancy is expected in the next major release.

marco

2011

Fork of metacity, used by MATE.

i5

2011

Tiling, fork of i3 with touchscreen features.

herbstluftwm

2011

  • herbstluftwm is a manual tiling window manager for X11 using Xlib and Glib. Its main features can be described with: the layout is based on splitting frames into subframes which can be split again or can be filled with windows (similar to i3/ musca). tags (or workspaces or virtual desktops or …) can be added/removed at runtime. Each tag contains an own layout. exactly one tag is viewed on each monitor. The tags are monitor independent (similar to xmonad). it is configured at runtime via ipc calls from herbstclient. So the configuration file is just a script which is run on startup. (similar to wmii/ musca)

monsterwm

2011

  • monsterwm is a minimal, lightweight, tiny but monstrous dynamic tiling window manager. It will try to stay as small as possible. Currently under 700 lines with the config file included. It provides a set of four different layout modes (vertical stack, bottom stack, grid and monocle/fullscreen) by default, and has floating mode support. Each virtual desktop has its own properties, unaffected by other desktops' settings. Finally monsterwm supports multiple monitors setups.

tilenol

2011

nwm

2011

  • nwm - A dynamic window manager for X11 written with Node.js

Mer

2011

dminiwm / snapwm

2011

Minimal and lightweight dynamic tiling window manager. Fork of catwm.

wingo

2011

Floating and tiling, per monitor desktops. Written in Go.

no-wm

2011

Foo-Wm

Aura

TTWM / Alopex

2012

  • https://github.com/TrilbyWhite/alopex
  • https://wiki.archlinux.org/index.php/Alopex
  • TTWM is a minimal tiling window manager combining concepts or elements from TinyWM, DWM, and i3wm. Inspiration has also been drawn from other great tilers like MonserWM. TinyTiler is currently under 650 lines of code. In contrast to other tilers, TinyTiler does not have modes nor does have window rules. TinyTiler has only two layouts: right stack and bottom stack. These choices were by design. TinyTiler instead provides two screen sections, the master and the stack. In TinyTiler only one stack window is visibile at a time, the others have tabs in the statusbar.

Qtile

2012

Goomwwm

2012

bspwm

2012

Very nice and atomic.

bspc set focused_border_color '#ff0000'
bspc set border_width '3px'
bspc set window_gap 0
bspc set focus_follows_pointer true








external rules

Deep Space Window Manager

2012

Piwm

2013

  • Piwm is a very small window manager written in Bash. Following are the 5 task it performs : 1) Ctrl + t : Opens xterm, 2) Ctrl + f : Makes current window full screen, 3) Alt + Mouseleft : Moves the window, 4) Alt + Mouseright : Rescales the window, 5) Ctrl + F1 : Refocus the window

Guile-WM

2013

2bwm

swc

2013

  • https://github.com/michaelforney/swc - a small Wayland compositor implemented as a library.It has been designed primary with tiling window managers in mind. Additionally, notable features include:Easy to follow code baseXWayland supportCan place borders around windows

velox

2014

  • https://github.com/michaelforney/velox - a simple window manager based on swc. It is inspired by dwm and xmonad. velox uses tag-based window management similar to dwm. This allows you to construct your workspace by selecting a set of tags to work with. However, in contrast with dwm, windows do not have any screen associated with them; they are shown on whichever screen has their tag selected, allowing you to easily move windows between screens by selecting their tag on a different screen. This is similar to the multi-monitor workspace switching in xmonad.To ensure that we never attempt to show a window in two places at once, we have to impose several constraints. First, each window must have exactly one tag. In practice, I've found that I rarely intentionally mark a window with more than one tag anyway. Second, when you select a tag that is currently display on a different screen, the tag is first deselected from that screen.

FrankenWM

2014

dynamic tiling WM featuring the v-stack, b-stack, grid, fibonacci, dualstack, equal and monocle layouts out of the box. If you want to, you can add gaps between the windows as well. monsterwm-xcb fork, thus coming from monsterwm, thus coming from dminiwm, thus coming from catwm.

howm

2014

wtftw

2014

written in rust

adwm

2014

  • https://github.com/bbidulock/adwm - originally a fork of Echinus which in turn was a fork of dwm, and borrows concepts from velox, awesome and spectrwm. What it includes is a full rewrite with significant updates and additions resulting in full EWMH (NetwM), WMH (WinWM), MWMH (CDE/Motif), ICCCM 2.0 compliance and support.

See also the XDE apps.

eggwm

2014

swm

2014

Moksha

exwm

2015


katriawm

2015

non-reparenting, tiling window manager with window decorations. It’s a learning project started in December 2015.

Lunchbox Window Manager

2015


aphelia

Petronia

2016

LeftWM

  • LeftWM - a tiling window manager written in rust for stability and performance. The core of left is designed to do one thing and one thing well. Be a window manager. Because you probably want more than just a black screen LeftWM is built around the concept of theming. With themes you can choose between different bar / compositor / background / colors, whatever makes you happy. LeftWM has been built from the very beginning to support multiple screens and has been built around ultrawide monitors. You will see this with the default key bindings.


chamferwm

2018


dovetail

Twindy

  • Twindy - a window manager for linux (and possibly any system running an X server?) inspired byTracktion, the multitrack audio editor/sequencer for Windows and OS X. Twindy tries to apply Tracktion's workflow, where everything is on screen at once, to a window manager. As such, there are two panels, a main panel where new windows/programs open by default and may be selected using tabs, and a lower panel, which can only hold one window/program at a time.The idea is that you'll do your main work in the top panel, and use the bottom panel for a terminal, or a file manager you'd want to keep open.

berry

Xlambda

karuiwm

Wmderland

sowm

SWM

nimdow

  • https://github.com/avahe-kellenberger/nimdow - written in Nim. NOTE: This is a WIP and currently only usable on single monitor setups. I am using this project to learn Nim, x11, and to replace my build of dwm (written in C).

LeftWM

  • LeftWM - a tiling window manager written in rust for stability and performance. The core of left is designed to do one thing and one thing well. Be a window manager. Because you probably want more than just a black screen LeftWM is built around the concept of theming. With themes you can choose between different bar / compositor / background / colors, whatever makes you happy.LeftWM has been built from the very beginning to support multiple screens and has been built around ultrawide monitors. You will see this with the default key bindings.


page

  • https://github.com/gschwind/page - mouse friendly tiling window manager for linux. page organizes windows in tiles and groups them in tabs. It allow to reconfigure dynamically tile and tabs with your mouse pointer. page can be used with desktop environment that allow to replace the window manager, for instance MATE or XFCE. page is under development and implement ICCCM and EWMH. It is implemented in C++11 and depend on Xlib, xcb, glib, pango and cairo. The code is distributed under GPLv3.

instantWM

dylwm?

InfiniteGlass

xwm

tofu

  • https://github.com/periish/tofu - a shell based window manager for x11fs. It uses x11fs to parse events and control windows. tofu is built to be easily extensible, and scriptable. It is a simple shell script itself. tofc is a program that can be used in tandem with tofu. It controls windows. tofu on it's own does not enforce any particular behaviour for windows, however some example workflows exist in the contrib directory. tofu does not handle keybinds - sxhkd or XBindkeys is reccomended.

hfwm

shod

chamferwm

Other

See also Wayland


  • https://github.com/jjttjj/wm - a clojure(script) library which provides an immutable datastructure that's useful for implementing a tiling window manager.