Pop Shell is a keyboard-driven layer for GNOME Shell which allows for quick and sensible navigation and management of windows. The core feature of Pop Shell is the addition of advanced tiling window management — a feature that has been highly sought within our community. For many — ourselves included — i3wm has become the leading competitor to the GNOME desktop.
Tiling window management in GNOME is virtually nonexistent, which makes the desktop awkward to interact with when your needs exceed that of two windows at a given time. Luckily, GNOME Shell is an extensible desktop with the foundations that make it possible to implement a tiling window manager on top of the desktop.
Therefore, we see an opportunity here to advance the usability of the GNOME desktop to better accommodate the needs of our community with Pop Shell. Advanced tiling window management is a must for the desktop, so we've merged i3-like tiling window management with the GNOME desktop for the best of both worlds.
A proposal for integration of the tiling window management features from Pop Shell into GNOME is currently under development. It will be created as a GitLab issue on GNOME Shell for future discussion, once we have invested our time into producing a functioning prototype, and learned what does and does not work in practice.
Ideally, the features explored in Pop Shell will be available for any environment using Mutter — far extending the half-monitor tiling capability currently present. By starting out as a shell extension, anyone using GNOME Shell can install this onto their system, without having to install a Pop-specific fork of GNOME on their system.
So, why is this a problem for us, and why do so many of our users switch to i3wm?
GNOME currently only supports half-tiling, which tiles one window to one side of the screen, and another window to the other side of the screen. If you have more than two windows, it is expected to place them on separate workspaces, monitors, or to alternate between windows with Alt
+ Tab
.
This tends to work fine if you only have a small handful of applications. If you need more than two windows at a time on a display, your only option is to manually drag windows into position, and resize them to fit alongside each other — a very time-consuming process that could easily be automated and streamlined.
Suppose you are a lucky — or perhaps unlucky — owner of an ultra-wide display. A maximized window will have much of its preferences and controls dispersed across the far left and far right corners. The application may place a panel with buttons on the far left, while other buttons get shifted to either the distant center or far right.
Half-tiling in this scenario means that each window will be as large as an entire 2560x1440 or 4K display. In either scenario, at such extreme sizes, the mouse becomes completely useless — and applications become unbearable to use — in practice.
As you struggle with fighting the window manager, it quickly becomes clear that any attempt to manage windows in a traditional stacking manner — where you need to manually move windows into place, and then manually resize them — is futile. Humans are nowhere near as precise or as quick as algorithms at aligning windows alongside each other on a display.
The GNOME desktop comes with many useful desktop integration features, which are lost when switching to an i3wm session. Although possible to connect various GNOME session services to an i3wm session, much of the GNOME desktop experience is still lost in the process. The application overview, the GNOME panel, and GNOME extensions.
Even worse, many users are completely unfamiliar with tiling window managers, and may never feel comfortable switching "cold turkey" to one. By offering tiling window management as a feature that can be opted into, we can empower the user to ease into gaining greater control over their desktop, so that the idea of tiling window management suddenly becomes accessible.
There are additionally those who do want the traditional stacking window management experience, but they also want to be able to opt into advanced tiling window management, too. So it should be possible to opt into tiling window management as necessary. Other operating systems have successfully combined tiling window management features with the traditional stacking window management experience, and we feel that we can do this with GNOME as well.
Use the branch corresponding to your GNOME Shell version (git checkout branch_name
):
master_focal
branch.master_jammy
branch.master_mantic
branch.master_noble
branch.GNU Make and TypeScript are also required to build the project.
Proper functionality of the shell requires modifying GNOME's default keyboard shortcuts. For a local installation, run make local-install
.
If you want to uninstall the extension, you may invoke make uninstall
, and then open the "Keyboard Shortcuts" panel in GNOME Settings to select the "Reset All.." button in the header bar.
Note that if you are packaging for your Linux distribution, many features in Pop Shell will not work out of the box because they require changes to GNOME's default keyboard shortcuts. A local install is necessary if you aren't packaging your GNOME session with these default keyboard shortcuts unset or changed.
sudo dnf install gnome-shell-extension-pop-shell xprop
emerge gnome-shell-extension-pop-shell
sudo zypper install gnome-shell-extension-pop-shell
yay -S gnome-shell-extension-pop-shell
yay -S gnome-shell-extension-pop-shell-bin
yay -S gnome-shell-extension-pop-shell-git
Features that are shared between stacking and auto-tiling modes.
These are key to many of the shortcuts utilized by tiling window managers. This document will henceforth refer to these keys as <Direction>
, which default to the following keys:
Left
or h
Down
or j
Up
or k
Right
or l
Super
+ q
: Close windowSuper
+ m
: Maximize the focused windowSuper
+ ,
: Minimize the focused windowSuper
+ Esc
: Lock screenSuper
+ f
: FilesSuper
+ e
: EmailSuper
+ b
: Web BrowserSuper
+ t
: TerminalThis mode is activated with
Super
+Return
.
Window management mode activates additional keyboard control over the size and location of the currently-focused window. The behavior of this mode changes slightly based on whether you are in auto-tile mode, or in the default stacking mode. In the default mode, an overlay is displayed snapped to a grid, which represents a possible future location and size of your focused window. This behavior changes slightly in auto-tiling mode, where resizes are performed immediately and overlays are only shown when swapping windows.
Activating this enables the following behaviors:
<Direction>
Shift
+ <Direction>
Ctrl
+ <Direction>
Return
is pressed, window positions will be swappedShift
+ Ctrl
+ <Direction>
O
: Toggles between horizontal and vertical tiling in auto-tile mode~
: Toggles between floating and tiling in auto-tile modeReturn
: Applies the changes that have been requestedEsc
: Cancels any changes that were requestedWhen not in window management mode, pressing Super
+ <Direction>
will shift window focus to a window in the given direction. This is calculated based on the distance between the center of the side of the focused window that the window is being shifted from, and the opposite side of windows surrounding it.
Switching focus to the left will calculate from the center of the east side of the focused window to the center of the west side of all other windows. The window with the least distance is the window we pick.
Pop Shell provides an integrated launcher which interfaces directly with our pop-launcher service. JSON IPC is used to communicate between the shell and the launcher in an asynchronous fashion. This functionality was separated from the shell due to performance and maintainability issues. The new launcher is written in Rust and fully async. The launcher has extensive features that would be useful for implementing desktop launchers beyond a shell extension.
Gaps improve the aesthetics of tiled windows and make it easier to grab the edge of a specific window. We've decided to add support for inner and outer gaps, and made these settings configurable in the extension's popup menu.
Windows with server-side decorations may have their title bars completely hidden, resulting in additional screen real estate for your applications, and a visually cleaner environment. This feature can be toggled in the extension's popup menu. Windows can be moved with the mouse by holding Super
when clicking and dragging a window to another location, or using the keyboard shortcuts native to pop-shell. Windows may be closed by pressing Super
+ Q
, and maximized with Super
+ M
.
This is the default mode of Pop Shell, which combines traditional stacking window management, with optional tiling window management features.
In this mode, displays are split into a grid of columns and rows. When entering tile mode, windows are snapped to this grid as they are placed. The number of rows and columns are configurable in the extension's popup menu in the panel.
An optional feature to improve your tiling experience is the ability to snap windows to the grid when using your mouse to move and resize them. This provides the same precision as entering window management mode to position a window with your keyboard, but with the convenience and familiarity of a mouse. This feature can be enabled through the extension's popup menu.
Disabled by default, this mode manages windows using a tree-based tiling window manager. Similar to i3, each node of the tree represents two branches. A branch may be a window, a fork containing more branches, or a stack that contains many windows. Each branch represents a rectangular area of space on the screen, and can be subdivided by creating more branches inside of a branch. As windows are created, they are assigned to the window or stack that is actively focused, which creates a new fork on a window, or attaches the window to the focused stack. As windows are destroyed, the opposite is performed to compress the tree and rearrange windows to their new dimensions.
Super
+ O
Super
+ G
There is file $XDG_CONFIG_HOME/pop-shell/config.json
where you can add the following structure:
{
class: "<WM_CLASS String from xprop>",
title: "<Optional Window Title>"
}
For example, doing xprop
on GNOME Settings (or GNOME Control Center), the WM_CLASS values are gnome-control-center
and Gnome-control-center
. Use the second value (Gnome-control-center), which pop-shell will read. The title
field is optional.
After applying changes in config.json
, you can reload the tiling if it doesn't work the first time.
Due to the risky nature of plain JavaScript, this GNOME Shell extension is written in TypeScript. In addition to supplying static type-checking and self-documenting classes and interfaces, it allows us to write modern JavaScript syntax whilst supporting the generation of code for older targets.
Please install the following as dependencies when developing:
Node.js
LTS+ (v12+)npm
(comes with NodeJS)npm install typescript@latest
While working on the shell, you can recompile, reconfigure, reinstall, and restart GNOME Shell with logging with make debug
. Note that this only works reliably in X11 sessions, since Wayland will exit to the login screen on restarting the shell.
Discussions welcome on Pop Chat
Licensed under the GNU General Public License, Version 3.0, (LICENSE or https://www.gnu.org/licenses/gpl-3.0.en.html)
Any contribution intentionally submitted for inclusion in the work by you shall be licensed under the GNU GPLv3.