Skip to main content

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

2022-01-25_02-17_1

2022-01-25_02-17

Plans

My goals currently are to:

  • Align bspcq as closely as possible with bspc query. I would like for bspcq to behave almost identically to bspc 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 the tree 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bspcq-0.1.58.tar.gz (6.9 kB view details)

Uploaded Source

Built Distribution

bspcq-0.1.58-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

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

Hashes for bspcq-0.1.58.tar.gz
Algorithm Hash digest
SHA256 57abb77fdeb97137f0794313fad3f658edc06c9dc8010ce34d21a93f113c4c94
MD5 339d04bc74f547cc20a25681bed11c1a
BLAKE2b-256 67f41c40172236275c43b69a078ce702cd0a20c4066800576fd0105be2c499ce

See more details on using hashes here.

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

Hashes for bspcq-0.1.58-py3-none-any.whl
Algorithm Hash digest
SHA256 43b1c32b2e0ab285aeb0b6572edef4c0a843fe7998598d43481758ad5bf6225a
MD5 dcfc92e05a4b58d0c30ef79369cb0258
BLAKE2b-256 cc25cc9f59049a5f8220424a65dcbee60f4e54a0cce5396ef9f1b7c23cdbf347

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page