A `bspc` analyzer & a utility for bspwm
Project description
bspcq, q for query
A bspc
analyzer (utility for bspwm)
This is a small program that prints a user friendly, visual representation, of
your current bsp
tree.
The aim is to assist in using bspwm
so new users have an easier time getting
into tiling window managers, and have some toys to play with.
It's essentially the same as running:
bspc query -M -m <monitor-name> | jq
Except there are fewer parameters, a less complex syntax to remember and an intuitive visual.
Installation
I'd recommend just copying the script from the root of this directory, bspcq
,
and changing the shebang.
git clone https://github.com/aidenlangley/bspcq
mv bspcq/bspcq ~/bin/bspcq # or ~/.local/bin/bspcq
chmod +x ~/bin/bspcq
Then edit the shebang - my shebang:
#! /usr/bin/env python3.10
Your shebang might need to be be:
#! /usr/bin/env python3
Dependencies
In addition, some Python modules are required, as is xtitle
.
rich
rich
is responsible for the nicely formatted tree.
python -m pip install rich
xtitle
xtitle
assists in getting the title name of a node/window in X.
Requires C/C++ development tools, varies by distro.
git clone https://github.com/baskerville/xtitle
cd xtitle
make && make install
I've actually included it here, under contrib, so you can just copy it to ~/bin
.
Via pipx
https://pypi.org/project/bspcq/
python -m pipx install bspcq
Upgrade
python -m pipx upgrade bspcq
Usage
# Prints the full tree, including output from all monitors.
bspcq
# Provides a simpler view, perfect for finding window class names.
bspcq -s
# Grabs info on all nodes that belong to the specified domain.
bspcq -M/D/N
# For a simplified view.
bspcq -M/D/N -s
# Passes through a query to `bspc query` and prints our tree, valid identifiers
# are names, ID's or the address output by `bspc -M/D/N`.
bspcq -m/d/n <monitor/desktop/node-identifier>
Preview
Plans
My goals currently are to:
- Align
bspcq
as closely as possible withbspc query
. I would like forbspcq
to behave almost identically tobspc query
- it just adds a visual element. - Remain as lean as possible. A nice-to-have feature would be 0 reliance on
external libraries, so I'd like to remove
rich
and implement a way to display thetree
myself.
This was just an afternoon project that's turning into a week long project since it's quite a lot of fun!
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 bspcq-0.1.58.tar.gz
.
File metadata
- Download URL: bspcq-0.1.58.tar.gz
- Upload date:
- Size: 6.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.8.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 57abb77fdeb97137f0794313fad3f658edc06c9dc8010ce34d21a93f113c4c94 |
|
MD5 | 339d04bc74f547cc20a25681bed11c1a |
|
BLAKE2b-256 | 67f41c40172236275c43b69a078ce702cd0a20c4066800576fd0105be2c499ce |
File details
Details for the file bspcq-0.1.58-py3-none-any.whl
.
File metadata
- Download URL: bspcq-0.1.58-py3-none-any.whl
- Upload date:
- Size: 7.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.8.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 43b1c32b2e0ab285aeb0b6572edef4c0a843fe7998598d43481758ad5bf6225a |
|
MD5 | dcfc92e05a4b58d0c30ef79369cb0258 |
|
BLAKE2b-256 | cc25cc9f59049a5f8220424a65dcbee60f4e54a0cce5396ef9f1b7c23cdbf347 |