Skip to main content

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

PyPI AUR License: MIT Platform CI Coverage


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
  1. Splash — animated intro, main window appears after ~2 s
  2. Home — lists all paired Bluetooth devices; Nothing / CMF devices get a NOTHING badge
  3. Scan — tap SCAN FOR DEVICES to run a 30 s BlueZ discovery
  4. 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
  5. Close — hides to background; run something-x again 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

MIT

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

something_x_dev-1.8.0.dev20.tar.gz (65.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

something_x_dev-1.8.0.dev20-py3-none-any.whl (36.3 kB view details)

Uploaded Python 3

File details

Details for the file something_x_dev-1.8.0.dev20.tar.gz.

File metadata

  • Download URL: something_x_dev-1.8.0.dev20.tar.gz
  • Upload date:
  • Size: 65.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for something_x_dev-1.8.0.dev20.tar.gz
Algorithm Hash digest
SHA256 d3cdb1b1e7778ba908ea74e34226c712ba0039d068930bf1fde463a7b43a7eed
MD5 1cac31060586f9cfb2a13963d0f75ccd
BLAKE2b-256 63e5611d9790fb64cb1cc6b99fb2cf333013609b8868a3fc914252b01d5c157f

See more details on using hashes here.

Provenance

The following attestation bundles were made for something_x_dev-1.8.0.dev20.tar.gz:

Publisher: release-dev.yml on SoaOaoS/something-x

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file something_x_dev-1.8.0.dev20-py3-none-any.whl.

File metadata

File hashes

Hashes for something_x_dev-1.8.0.dev20-py3-none-any.whl
Algorithm Hash digest
SHA256 b3b83a3a83a5eb1b20d9dca4ac16f918326b2c52688c4613bf9f8b25840455f2
MD5 c0d1ac7801211aa7567f34761fe8ae23
BLAKE2b-256 4780e455cd4c6de9d75f3a976408b08f1f2fbe13250a78fc38a0b003e4197687

See more details on using hashes here.

Provenance

The following attestation bundles were made for something_x_dev-1.8.0.dev20-py3-none-any.whl:

Publisher: release-dev.yml on SoaOaoS/something-x

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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