- Notifications
You must be signed in to change notification settings - Fork190
A tiling window manager for Adventurers
License
leftwm/leftwm
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
IMPORTANT NOTE: LeftWM has changed the config language fromTOML
toRON
with the0.4.0
release. Please useleftwm-check --migrate-toml-to-ron
to migrate your config and visit thewiki for more info.
- Why go left
- Dependencies
- Installation (with package manager)
- Manual Installation (no package manager)
- Theming
- Configuring
- Troubleshooting
- Support
LeftWM is a tiling window manager written inRust that aims to be stable and performant. LeftWM isdesigned to do one thing and to do that one thing well:be a window manager.LeftWM follows the following mantra:
LeftWM is not a compositor.LeftWM is not a lock screen.LeftWM is not a bar. But, there are lots of good bars out there. With themes, picking one is assimple as setting a symlink.
Because you probably want more than just a black screen, LeftWM is built around the concept ofthemes. With themes, you can choose between different bars, compositors, backgrounds, colors, docks,and whatever else makes you happy.
LeftWM was built from the very beginning to support multiple screens and ultrawide monitors. Thedefault keybindings support ultrawide monitors and multiple screens.
With LeftWM, there are two types of configuration files:
LeftWM Configuration files: LeftWM configurations are specific to you and don’t change fordifferent themes. These are settings like keybindings, workspace locations, and names ofdesktops/tags. These settings can be found in
$XDG_CONFIG_HOME/leftwm/config.ron
.Theme Configuration files: The appearance of your desktop is different. It’s fun to try newlooks and feels. It’s fun to tweak and customize the appearance (AKA:ricing). It’s fun to shareso others can experience your awesome desktop! LeftWM is built around this concept. By pulling allthese settings out into themes, you can now easily tweak, switch, and share your experiences. Thisconfiguration is spread between
theme.ron
and related files contained within a theme's folder.
Note: some example config and themes can be found in the share dir, e.g./usr/share/leftwm
oh Arch based disros.
While LeftWM has very few dependencies, this isn't always the case for themes.Themes typically require the following to be installed. However, this is up to theauthor of the theme and could be different.
List of LeftWM dependencies:
- xorg (runtime, build): specifically libx11, xrandr, xorg-server, libxinerama
- sh (runtime): any posix-compliant shell for starting up and down files
- rust (build): >= 1.74.0
- bash (optional): Most of the themes available use bash, though the scripts maybe converted to any posix-compliant shell
List of common dependencies for themes:
Dependency (git) | Ubuntu 20.4.1 sudo apt install {} | Arch sudo pacman -S {} | Fedora 33 sudo dnf install {} | PKGS |
---|---|---|---|---|
feh | feh | feh | feh | feh |
compton | compton | picom | compton | compton |
picom | manual ** | picom | picom | picom |
polybar | manual ** | polybar | polybar | polybar |
xmobar | xmobar | xmobar | xmobar | xmobar |
lemonbar | lemonbar | paru -S lemonbar* | manual ** | lemonbar |
conky | conky | conky | conky | conky |
dmenu | dmenu | dmenu | dmenu | dmenu |
* You can use whichever AUR wrapper you like. Seeparu andyay.** See the git page (link in first column) for how to install these manually
Gentoo (GURU)
sudo layman -a guru&& sudo emerge --syncsudo emerge --ask --verbose x11-wm/leftwm
Archlinux (AUR)
paru -S leftwm
paru is an AUR helper likeyay, but written inRust.
Fedora (copr)
sudo dnf coprenable th3-s4lm0n/leftwm -y&& sudo dnf install leftwm
NetBSD (Official repositories)
pkgin install leftwm
or, if you prefer to build it from source
cd /usr/pkgsrc/wm/leftwmmake install
Void (XBPS)
sudo xbps-install -S leftwm
Cargo (crates.io)
cargo install leftwm
If you install LeftWM with crates.io, you will need to link to thexsession desktop file if you wantto be able to login to LeftWM from a display manager (GDM, SSDM, LightDM, etc.):
sudo cp PATH_TO_LEFTWM/leftwm.desktop /usr/share/xsessions
Also seethe build options for more feature options, especially if you don't usesystemd
or want to use your own hotkey daemon likesxhkd
.
OpenBSD (OpenBSD)
At the moment LeftWM is not packaged with OpenBSD package manager, but it could be installed via Cargo.
cargo install leftwm --no-default-features --features lefthk
leftwm-config
not yet ported to OpenBSD, as it requires a nightly Rust compiler to build.The default config is generated by LeftWM when it is first started.
To start LeftWM withxenodm
add the following to your~/.xsession
. Make sure to remove or comment-out theexec
to the previous WM you had there.
exec dbus-launch~/.cargo/bin/leftwm>>~/.cache/leftwm.log2>&1
Dependencies: Rust, Cargo
Clone the repository and cd into the directory
git clone https://github.com/leftwm/leftwm.gitcd leftwm
Build leftwm
cargo build --profile optimized
For more options see thebuild options section.
Copy leftwm executables to the /usr/bin folder
sudo install -s -Dm755 ./target/optimized/leftwm ./target/optimized/leftwm-worker ./target/optimized/lefthk-worker ./target/optimized/leftwm-state ./target/optimized/leftwm-check ./target/optimized/leftwm-command -t /usr/bin
Copy leftwm.desktop to xsessions folder
sudo cp leftwm.desktop /usr/share/xsessions/
You should now see LeftWM in your list of available window managers. At this point, expect only asimple black screen on login. For a more customized look, install a theme.
If your goal is to continuously build leftwm and keep up to date with the latest releases, you mayprefer to symlink the leftwm executables instead of copying them. If you choose to install thisway, make sure you do not move the build directory as it will break your installation.
Note that if you want to build leftwm with another build profile, you will have to change the--profile <profile-name>
option and the target folder totarget/<profile-name>
.Currently available aredev
,release
andoptimized
.
Dependencies: Rust, Cargo
Clone the repository and cd into the directory
git clone https://github.com/leftwm/leftwm.gitcd leftwm
Build leftwm
# With systemd logging (view with 'journalctl -f -t leftwm-worker')cargo build --profile optimized
For more options seebuild options below.
Create the symlinks
sudo ln -s"$(pwd)"/target/optimized/leftwm /usr/bin/leftwmsudo ln -s"$(pwd)"/target/optimized/leftwm-worker /usr/bin/leftwm-workersudo ln -s"$(pwd)"/target/optimized/lefthk-worker /usr/bin/lefthk-workersudo ln -s"$(pwd)"/target/optimized/leftwm-state /usr/bin/leftwm-statesudo ln -s"$(pwd)"/target/optimized/leftwm-check /usr/bin/leftwm-checksudo ln -s"$(pwd)"/target/optimized/leftwm-command /usr/bin/leftwm-command
Copy leftwm.desktop to xsessions folder
sudo cp leftwm.desktop /usr/share/xsessions/
You should now see LeftWM in your list of available window managers. At this point, expect only asimple black screen on login. For a more customized look, install a theme.
Now if you want to get the newest version of leftwm run this command from your build directory:
git pull origin main
Build leftwm
# With systemd logging (view with 'journalctl -f -t leftwm-worker')cargo build --profile optimized
And press the following keybind to reload leftwm
Mod + Shift + R
SinceLeftWM
is targeting to be more and more modular, there are a few features that can be selected at compile time:
Usecargo
with the added flags--no-default-features --features=
and then commaseparated a selection from the following features:
feature | info | default |
---|---|---|
lefthk | built-in hotkey daemon, if you build with out make sure you bring your own (e.g.sxhkd ) to manage any keybinds, be sure you install thelefthk-worker binary if you build with this option | ✔ |
journald-log | logging tojournald , depends onsystemd | ✔ |
sys-log | use standard system logging | ✘ |
file-log | log to/tmp/leftwm/<log-file-by-datetime-of-launch> | ✘ |
xlib (*) | legacy backend linking tolibX11 | ✔ |
x11rb (*) | rust based backend usingx11rb | ✔ |
Example:
# With `lefthk` and logging to `sys-log` (`x11rb` backend)cargo build --profile optimized --no-default-features --features=x11rb,lefthk,sys-log# Without `lefthk` and logging to file (`xlib` backend)cargo build --profile optimized --no-default-features --features=xlib,file-log
There are also multiple levels of optimization. These are specified by the cargo profiles, available aredev
,release
andoptimized
. The dev and release profiles are default profiles used by cargo, whereas the optimized profile is recomended for production builds.
Example:
# With the dev profilecargo build --profile dev# With the release profilecargo build --profile release
For conveniece we also have a Makefile with the following rules:
make ... | info |
---|---|
all | impliesbuild andtest |
test | runs same tests as CI on github |
test-full | deprecated, do not use |
test-full-nix | same astest-full but additionally compiles the nix package, resulting in a full representation of ci checks |
build | builds with cargo profileoptimized by default; read build output on how to change the profile. |
clean | clean all buildfiles |
install | install by copying binaries to/usr/bin , also placesleftwm.desktop file to/usr/share/xsession and cleans build files |
install-linked | installs by symlinking, copiesleftwm.desktop , no clean |
uninstall | removesleftwm-* files from/usr/bin andleftwm.desktop file |
Note that forbuild
,install
andinstall-linked
, you can specify the build profile to use by adding theprofile=<profile-name>
argument. Currently available aredev
,release
andrelease-optimized
.
Make sure this is at the end of your.xinitrc
file:
# .xinitrcexec dbus-launch leftwm
On some distros like Archlinux, the environment variables are being setup by sourcing/etc/X11/xinit/xinitrc.d
, as described inthe Arch docs, please make sure you copy the default xinitrc like this:
cp /etc/X11/xinit/xinitrc~/.xinitrc
Note: In this case it is not necessary to start leftwm throughdbus-launch
and might even result in some cases in services likegnome-keyring
to fail. In such an occasion just use:
# .xinitrcexec leftwm
If you want to see more than a black screen when you login, select a theme:
WithLeftWM-Theme
leftwm-theme updateleftwm-theme install NAME_OF_THEME_YOU_LIKEleftwm-theme apply NAME_OF_THEME_YOU_LIKE
WithoutLeftWM-Theme
To set up your own custom theme, you will need to create a directory containing the theme files and then symlink it to$XDG_CONFIG_HOME/leftwm/themes/current
.
A theme directory contains at least 2 files:
up
: a script which is loaded with the theme.down
: a script which is called when the theme is unloaded.
These files need to be made executable. Many theme directories also contain:
theme.ron
: which contains additional configuration options specific to the theme.polybar.ini
: a configuration file for thepolybar
application.You need to have polybar installed!picom.conf
: a configuration file for thepicom
compositor.You need to have picom installed!
See thetheme guide for examples and further information. There is also acommunity repository for sharing themes.
You can configure key bindings, default mod key and many other options:
WithLeftWM-Config
leftwm-config -n# Generate new configleftwm-config# Open configuration file in $EDITORleftwm-config -t# Edit configuration via TUI (Beta)
$XDG_CONFIG_HOME/leftwm/config.ron
Note: The configuration file is automatically generated when leftwm or leftwm-check is run for the first time.
Keybinding | Description |
---|---|
Mod + (1-9) | Switch to a desktop/tag |
Mod + Shift + (1-9) | Move the focused window to desktop/tag |
Mod + W | Switch the desktops for each screen. Desktops [1][2] changes to [2][1] |
Mod + Shift + W | Move window to the other desktop |
Mod + (⬆️⬇️) | Focus on the different windows in the current workspace |
Mod + Shift + (⬆️⬇️) | Move the different windows in the current workspace |
Mod + Enter | Move selected window to the top of the stack in the current workspace |
Mod + Ctrl + (⬆️⬇️) | Switch between different layouts |
Mod + Shift + (⬅➡) | Switch between different workspaces |
Mod + Shift + Enter | Open a terminal |
Mod + Ctrl + L | Lock the screen |
Mod + Shift + X | Exit LeftWM |
Mod + Shift + Q | Close the current window |
Mod + Shift + R | Reload LeftWM and its config |
Mod + p | Use dmenu to start application |
Note: Although we encourage you to useAlacritty,LeftWM will set your default terminal to the first terminal it finds in this list (in the orderpresented):
- Alacritty
- Termite
- Kitty
- URXVT
- RXVT
- ST
- ROXTerm
- Eterm
- XTerm
- Terminator
- Terminology
- Gnome Terminal
- XFCE4 Terminal
- Konsole
- UXTerm
- Guake
You can optionally switch between tiling or floating mode for any window.
Keybinding | Description |
---|---|
Mod + MouseDrag | Switch a tiled window to floating mode |
Mod + RightMouseDrag | Resize a window |
Drag window onto a tile | Switch a floating window to tiling mode |
Mod + Shift + (1-9) | Switch a floating window to tiling mode |
Workspaces are how you view tags (desktops). A workspace is an area on a screen or most likely the whole screen. in these areas you can view a given tag.
Default:workspaces: []
(one workspace per screen)
Workspaces are only applied if the specified output is the name of a connected screen. The output is also used as identifier of the workspace.
You can get the output names by running xrandr in your terminal.
Example (two workspaces on a single ultrawide):
workspaces:[( output:"HDMI-1", y:0, x:0, height:1440, width:1720),( output:"HDMI-1", y:0, x:1720, height:1440, width:1720),],
The default tags are 1-9. They can be renamed in the config file by setting thelist of tags.
Here is an example config changing the list of available tags. NOTE: tag navigation (Mod + #)is based on the index of the tag in the list (starting with index 1).
tags:["Web","Code","Shell","Music","Connect"],
Leftwm supports user definable layouts. The relevant entries in the configuration file are thelayouts
andlayout_definitions
lists.
Only the layouts whose name appears inlayouts
will be accessible when switching layouts through the commandsNextLayout
,PreviousLayout
andSetLayout
. Each layout appearing in thelayouts
list must have a corresponding definition inlayout_definitions
.
Example:
layouts:["Monocle","MainAndDeck","MainAndVertStack",],layout_definitions:[(name:"Monocle", flip:None, rotate:North, reserve:None,columns:(flip:None, rotate:North, main:None,stack:(flip:None, rotate:North, split:None), second_stack:None)),(name:"MainAndDeck", flip:None, rotate:North, reserve:None,columns:(flip:None, rotate:North,main:(count:1, size:0.5, flip:None, rotate:North, split:None),stack:(flip:None, rotate:North, split:None), second_stack:None)),(name:"MainAndVertStack", flip:None, rotate:North, reserve:None,columns:(flip:None, rotate:North,main:(count:1, size:0.5, flip:None, rotate:North, split:Vertical),stack:(flip:None, rotate:North, split:Horizontal), second_stack:None)),]
More detailed configuration information can be found in the Wiki.
LeftWM isEWMH compliant
The default layouts areall of the kinds defined here.
Issue | Description | Solution |
---|---|---|
LeftWM not listed by login manager | You likely need to add the xsessions file to the right folder. | Seeinstallation |
Noconfig.ron file exists | LeftWM does not always ship with aconfig.ron . You will need to execute LeftWM at least once for one to be generated. | Try the following:leftwm-worker |
config.ron is not being parsed | LeftWM ships with a binary called leftwm-check. It might not be installed by the AUR. | Try the following:leftwm-check |
Keybinding doesn't work | It's likely you need to specify a value or have a typo. | See Wiki |
LeftWM now has aDiscord channel for faster help.
About
A tiling window manager for Adventurers