Add mutable scratch functionality to qtile
Project description
qtile MutableScratch
This package is a series of functions and a class to create a "scratch" space
in qtile more similar to i3's. qtile has the ScratchPad
group type, but the
(documented) purpose is to only host Dropdown
windows that must be specified
ahead of time.
Instead, what MutableScratch
does is piggybacks onto an "invisible" qtile
Group
(ie. a group named ''
) and provide functions to dynamically add and
remove windows to this group. Viewing the "hidden" windows is done via a toggle
function, which cycles through the windows in the Scratch group. All windows
added to the MutableScratch
group will be automatically converted to
floating. This emulates the scratch functionality of i3 as closely as possible.
See repository README for most up-to-date documentation.
Installation
You can now install via pip
:
pip install qtile_mutable_scratch
Setup
Put the following default configuration in your config.py
:
import qtile_mutable_scratch
from libqtile.config import EzKey
from libqtile import hook
...
mutscr = qtile_mutable_scratch.MutableScratch()
groups.append(Group('')) # Must be after `groups` is created
keys.extend( [
EzKey('M-S-<minus>', mutscr.add_current_window()),
EzKey('M-C-<minus>', mutscr.remove_current_window()),
EzKey('M-<minus>', mutscr.toggle()),
] )
hook.subscribe.startup_complete(mutscr.qtile_startup)
Each MutableScratch
instance has two parameters to chose from, scratch_group_name
and
win_attr
.
It's not necessary to set these, as the default configuration
should work for every configuration.
scratch_group_name
(default ''
, or the empty name group) sets the name of the group that will old the scratch windows.
win_attr
(default mutscratch
) sets the attribute that will be set on each window to tag it as being apart of the MutableScratch
system.
Usage
- Add the current window to the
MutableScratch
group viaMutableScratch.add_current_window()
- This will move the window to the invisible group
- Rotate through windows in the
MutableScratch
group viaMutableScratch.toggle()
- If the current window is apart of the
MutableScratch
group, then it will be moved back to the invisible group - If the current window is not apart of the
MutableScratch
, then the nextMutableScratch
window in the stack will be moved to the current group
- If the current window is apart of the
- To remove a window from the
MutableScratch
group, useMutableScratch.remove()
Hastily thrown together demo video:
It's ugly, but it get's the point across...hopefully.
Implementation Details
Tracking members of the MutableScratch
group
This is done by dynamically adding an attribute (by default mutscratch
) to
the window object that simply stores a boolean.
Cycling through windows in MutableScratch
MutableScratch
has something similar to qtile's focus_history
for groups.
It's effectively just a stack of windows belonging to the MutableScratch
group, where windows are pushed and popped from the stack.
Doing this,MutableScratch
controls the order in which the windows are stored in the stack.
This ensures that the every window in the MutableScratch
group can be accessed via toggle.
Initializing the MutableScratch
on qtile start
When restarting qtile, the MutableScratch
instance in config.py
will be overwritten, losing the stack history and the floating window status of it's windows.
To stop this, we add a hook
function to startup_complete
that will reinitialize a new MutableScratch
instance with the windows that are located in the MutableScratch.scratch_group_name
.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file qtile-mutable_scratch-0.0.3.tar.gz
.
File metadata
- Download URL: qtile-mutable_scratch-0.0.3.tar.gz
- Upload date:
- Size: 6.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 195de5b4d6ff7114b96b5640bf663748dcb91bb8cfb55fe4dc5fa0c17ae91264 |
|
MD5 | a071eee604a8afaa56ca0ad9f125ae54 |
|
BLAKE2b-256 | 70571d0fea9423d8d3e523d01964be14fdff539091cb5e187f49856563846a19 |
File details
Details for the file qtile_mutable_scratch-0.0.3-py3-none-any.whl
.
File metadata
- Download URL: qtile_mutable_scratch-0.0.3-py3-none-any.whl
- Upload date:
- Size: 3.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2eb29f30ad8eb97f8d2d298c7902a008a3e68dd47c57cfd870f17814f22a6bef |
|
MD5 | ea17b75f45d24e461db8110447e5f262 |
|
BLAKE2b-256 | 0443cab928571cc346c5453fb9a7948e27b6b8b92a92607995ef638321225835 |