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


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.5.0.dev12.tar.gz (33.5 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.5.0.dev12-py3-none-any.whl (34.7 kB view details)

Uploaded Python 3

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

Hashes for something_x_dev-1.5.0.dev12.tar.gz
Algorithm Hash digest
SHA256 f7de74c525a2c457eb09ceb4dc2ebff926ccf46e585293e0ca258d54763f110f
MD5 c4d70a0a0a58bfda773a96a068714771
BLAKE2b-256 7e5ec61a7e00b7e7abab7aed5b47ec7de12532d93b3c9b0e2efcc19b3cc61a69

See more details on using hashes here.

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

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.5.0.dev12-py3-none-any.whl.

File metadata

File hashes

Hashes for something_x_dev-1.5.0.dev12-py3-none-any.whl
Algorithm Hash digest
SHA256 cdcf7279112e6a6f5a198e815d93f082ac4ffa9231a402f3891832aed780157b
MD5 7402135939dc4aa8e29cf12a1931d0e0
BLAKE2b-256 5741b0b7dbf470d77bd1d64ea62fac41cf7c92325904c45ac652c221eba917ac

See more details on using hashes here.

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

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