Metadata-Version: 2.1
Name: bspcq
Version: 0.1.57
Summary: A `bspc` analyzer & a utility for bspwm
Home-page: https://github.com/aidenlangley/bspcq
Author: Aiden Langley
Author-email: aiden@nedia.dev
License: UNKNOWN
Project-URL: Bug Tracker, https://github.com/aidenlangley/bspcq/issues
Keywords: bspwm
Platform: UNKNOWN
Classifier: Environment :: Console
Classifier: Environment :: X11 Applications
Classifier: Intended Audience :: End Users/Desktop
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: POSIX :: Linux
Classifier: Programming Language :: Python :: 3
Classifier: Topic :: Desktop Environment :: Window Managers
Requires-Python: >=3.10
Description-Content-Type: text/markdown
License-File: LICENSE

# bspcq, q for query

## A `bspc` analyzer (utility for [bspwm](https://github.com/baskerville/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:

```sh
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.

```sh
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:

```sh
#! /usr/bin/env python3.10
```

Your shebang might need to be be:

```sh
#! /usr/bin/env python3
```

### Dependencies

In addition, some Python modules are required, as is `xtitle`.

#### [`rich`](https://pypi.org/project/rich/)

`rich` is responsible for the nicely formatted tree.

```
python -m pip install rich
```

#### [`xtitle`](https://github.com/baskerville/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/

```sh
python -m pipx install bspcq
```

## Upgrade

```sh
python -m pipx upgrade bspcq
```

## Usage

```sh
# Prints the full tree, including output from all monitors.
bspcq
```

```sh
# Provides a simpler view, perfect for finding window class names.
bspcq -s
```

```sh
# Grabs info on all nodes that belong to the specified domain.
bspcq -M/D/N

# For a simplified view.
bspcq -M/D/N -s
```

```sh
# 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](https://user-images.githubusercontent.com/684721/150789813-da7d0b56-1762-4bf7-af6b-7d031f779030.png)

![2022-01-25_02-17](https://user-images.githubusercontent.com/684721/150789957-06765616-661b-4486-b69a-a7b570e204e1.png)

### 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!


