Something X device manager for Omarchy / Linux
Project description
Something X
A Linux-native companion app for Nothing and CMF Bluetooth devices.
Built for Omarchy · GTK4 · Pure black · JetBrains Mono · Nothing Red
Features
| Feature | Details | |
|---|---|---|
| 🎧 | Earbud visual | Cairo-rendered glowing battery rings for L / R / Case, live updates |
| 🔇 | ANC control | Off · Noise Cancellation · Transparency over real RFCOMM protocol |
| 🎵 | EQ presets | Balanced · More Bass · More Treble · Voice |
| 🔊 | Volume slider | Direct PulseAudio / PipeWire A2DP sink control via pactl |
| 💾 | Per-device profiles | ANC + EQ saved per device address, restored automatically on reconnect |
| 🔋 | Battery notifications | Desktop alerts at 20 %, 15 %, 10 %, and 5 % per earbud and case |
| 🔗 | Auto-connect RFCOMM | Connects to the device protocol as soon as BlueZ reports it paired |
| 🏃 | Background mode | Closing the window keeps the app running; relaunch to reopen |
| 💻 | CLI | Control your earbuds from the terminal without opening the GUI |
| 📱 | Device discovery | BlueZ D-Bus scan with Nothing / CMF devices highlighted |
| ℹ️ | Device info | Firmware version and serial number read over RFCOMM |
Device support
| Device | Battery | ANC | EQ | Volume | Firmware |
|---|---|---|---|---|---|
| Nothing Ear (1) | ✅ | ✅ | ✅ | ✅ | ✅ |
| Nothing Ear (2) | ✅ | ✅ | ✅ | ✅ | ✅ |
| Nothing Ear (a) | ✅ | ✅ | ✅ | ✅ | ✅ |
| Nothing Ear (stick) | ✅ | — | ✅ | ✅ | ✅ |
| CMF Buds / Buds Pro | ✅ | ✅ | ✅ | ✅ | ✅ |
| Nothing Phone (1/2) | ✅ | — | — | — | — |
| Other Bluetooth devices | ✅* | — | — | ✅ | — |
* via BlueZ Battery1 interface · RFCOMM features require an active connection
Installation
Arch / Omarchy (recommended)
Install system dependencies first:
sudo pacman -S python-gobject python-dbus python-cairo gtk4 libadwaita
Then install from AUR:
yay -S something-x
# or: paru -S something-x
Or via pip:
pip install something-x
Other distros
Ubuntu 24.04+
sudo apt install python3-gi python3-dbus python3-cairo gir1.2-gtk-4.0 gir1.2-adw-1
pip install something-x
Fedora 39+
sudo dnf install python3-gobject python3-dbus python3-cairo gtk4 libadwaita
pip install something-x
NixOS
nix run github:SoaOaoS/something-x
A flake.nix is included for reproducible builds.
Run from source
git clone https://github.com/SoaOaoS/something-x
cd something-x
pip install -e .
something-x
Usage
GUI
something-x
- Splash — animated intro, main window appears after ~2 s
- Home — lists all paired Bluetooth devices; Nothing / CMF devices get a
NOTHINGbadge - Scan — tap
SCAN FOR DEVICESto run a 30 s BlueZ discovery - Device page — tap a card to open controls:
- Battery rings (L / R / Case) update in real time
- ANC and EQ apply immediately over RFCOMM and are saved to your profile
- Volume slider drives the A2DP sink via
pactl - Firmware version and serial number appear after RFCOMM connects
- Close — hides to background; run
something-xagain to reopen
CLI
Control your earbuds without opening the GUI:
# Battery levels
something-x --battery
# ANC mode
something-x --anc off
something-x --anc on
something-x --anc transparency
# EQ preset
something-x --eq balanced
something-x --eq bass
something-x --eq treble
something-x --eq voice
# Combine
something-x --anc on --eq bass
# Target a specific device by address
something-x --device AA:BB:CC:DD:EE:FF --battery
Development releases
The develop branch publishes pre-release builds to PyPI automatically as something-x-dev:
pip install something-x-dev
something-x-dev
Dev builds use version numbers like 1.3.0.dev42. Not for production use.
Releases & versioning
Pushing to main triggers automatic versioning, a GitHub Release, a PyPI publish, and an AUR update — all from Conventional Commits:
| Commit prefix | Version bump |
|---|---|
feat!: / BREAKING CHANGE: |
Major x.0.0 |
feat: |
Minor 1.x.0 |
fix: / perf: / refactor: |
Patch 1.0.x |
docs: / chore: / style: / ci: / test: |
No release |
Architecture
nothing_app/
├── application.py Adw.Application — lifecycle, CSS, CLI arg handling, background mode
├── window.py AdwNavigationView — home ↔ device routing, RFCOMM auto-connect manager
├── bluetooth.py BlueZ D-Bus manager — device discovery, connect/disconnect signals
├── protocol.py Nothing Ear 0x55 RFCOMM protocol (reverse-engineered from APK)
├── profiles.py Per-device ANC/EQ persistence (~/.config/something-x/profiles.json)
├── splash.py Animated splash screen (Cairo, typewriter, ripple rings)
├── data/
│ └── style.css Glass-morphism CSS theme
└── pages/
├── home.py Device list + scan button
└── device.py ANC / EQ / volume / settings + Cairo earbud visual
Protocol
Frame format: [SOF=0x55][ctrl:2 LE][cmd:2 LE][len:2 LE][FSN:1][payload][CRC16:2 LE]
All outgoing frames use ctrl=0x0160 with CRC16-ARC. The device silently drops SET commands if any frame in the session was sent without CRC.
Enable raw frame logging:
SOMETHING_X_DEBUG=1 something-x
Contributing
The RFCOMM protocol in nothing_app/protocol.py is reverse-engineered from the official Android APK. If your device uses different command IDs, channels, or ANC values, patches are very welcome — please include the raw RFCOMM dump (SOMETHING_X_DEBUG=1) in your issue or PR.
License
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file something_x_dev-1.5.0.dev12.tar.gz.
File metadata
- Download URL: something_x_dev-1.5.0.dev12.tar.gz
- Upload date:
- Size: 33.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f7de74c525a2c457eb09ceb4dc2ebff926ccf46e585293e0ca258d54763f110f
|
|
| MD5 |
c4d70a0a0a58bfda773a96a068714771
|
|
| BLAKE2b-256 |
7e5ec61a7e00b7e7abab7aed5b47ec7de12532d93b3c9b0e2efcc19b3cc61a69
|
Provenance
The following attestation bundles were made for something_x_dev-1.5.0.dev12.tar.gz:
Publisher:
release-dev.yml on SoaOaoS/something-x
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
something_x_dev-1.5.0.dev12.tar.gz -
Subject digest:
f7de74c525a2c457eb09ceb4dc2ebff926ccf46e585293e0ca258d54763f110f - Sigstore transparency entry: 1779485334
- Sigstore integration time:
-
Permalink:
SoaOaoS/something-x@f428a63d91e0c3438d90c0b90c62c25e3382bde0 -
Branch / Tag:
refs/heads/develop - Owner: https://github.com/SoaOaoS
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-dev.yml@f428a63d91e0c3438d90c0b90c62c25e3382bde0 -
Trigger Event:
push
-
Statement type:
File details
Details for the file something_x_dev-1.5.0.dev12-py3-none-any.whl.
File metadata
- Download URL: something_x_dev-1.5.0.dev12-py3-none-any.whl
- Upload date:
- Size: 34.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cdcf7279112e6a6f5a198e815d93f082ac4ffa9231a402f3891832aed780157b
|
|
| MD5 |
7402135939dc4aa8e29cf12a1931d0e0
|
|
| BLAKE2b-256 |
5741b0b7dbf470d77bd1d64ea62fac41cf7c92325904c45ac652c221eba917ac
|
Provenance
The following attestation bundles were made for something_x_dev-1.5.0.dev12-py3-none-any.whl:
Publisher:
release-dev.yml on SoaOaoS/something-x
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
something_x_dev-1.5.0.dev12-py3-none-any.whl -
Subject digest:
cdcf7279112e6a6f5a198e815d93f082ac4ffa9231a402f3891832aed780157b - Sigstore transparency entry: 1779485403
- Sigstore integration time:
-
Permalink:
SoaOaoS/something-x@f428a63d91e0c3438d90c0b90c62c25e3382bde0 -
Branch / Tag:
refs/heads/develop - Owner: https://github.com/SoaOaoS
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-dev.yml@f428a63d91e0c3438d90c0b90c62c25e3382bde0 -
Trigger Event:
push
-
Statement type: