Skip to main content

Local WebUI frontend for py-roller and pylrclib.

Project description

Rolling Pebble

PyPI Python

Rolling Pebble is a local lyrics workstation for searching, editing, timing, organizing, and publishing LRC lyrics.

It gives you a browser-based interface backed by a local Python server. Your projects, audio, lyrics, runtime environments, and model caches stay on your machine. Auto Timing is powered by py-roller in an isolated runtime so large audio dependencies do not pollute the main app environment.

What It Does

  • Import audio and lyrics from local files, LRCLIB, and supported online sources.
  • Edit metadata and lyric text in a focused LRC editor.
  • Synchronize timestamps manually when you want frame-level control.
  • Auto-time lyrics with py-roller using isolated CPU/CUDA runtime profiles.
  • Review and clean up projects, model caches, runtime environments, and app data.
  • Publish prepared lyrics through LRCLIB workflows.
  • Use multiple languages through the built-in i18n layer.

Typical Workflow

  1. Create or import a project with an audio file.
  2. Import lyrics from LRCLIB, a local file, or the editor.
  3. Clean up the lyric text and metadata.
  4. Use the Synchronizer for manual timing, or Auto Timing for py-roller based alignment.
  5. Review the generated LRC, export it, or publish it through LRCLIB.

Install

Rolling Pebble requires Python 3.10 or newer. Auto Timing additionally needs a Python 3.12 executable available on your system because the isolated py-roller runtime is built on Python 3.12.

Recommended install:

python -m venv rollingpebble-env
. rollingpebble-env/bin/activate
python -m pip install -U pip
python -m pip install rollingpebble
rollingpebble

On Windows PowerShell:

py -m venv rollingpebble-env
.\rollingpebble-env\Scripts\Activate.ps1
python -m pip install -U pip
python -m pip install rollingpebble
rollingpebble

Then open:

http://127.0.0.1:6789

First Run

Start Rolling Pebble:

rollingpebble

Then open:

http://127.0.0.1:6789

The default server binds to 127.0.0.1, so it is intended for local use.

Auto Timing

Auto Timing uses py-roller for lyric alignment. Rolling Pebble does not install Torch, Demucs, faster-whisper, or other heavy audio dependencies into the main app environment. Instead, it creates a separate runtime under the app data directory.

To set it up:

  1. Open Settings -> Auto Timing -> Runtime.
  2. Choose a runtime profile.
  3. Click Create Runtime.
  4. Run Runtime Check after creation completes.

If Python 3.12 is not detected automatically, set:

export LRC_ROLLER_RUNTIME_PYTHON=/path/to/python3.12

The current supported py-roller range is:

py-roller>=0.6.2,<0.8

Storage and Privacy

Rolling Pebble is local-first. It stores data under the user data directory, for example:

~/.local/share/rollingpebble

Inside the app, Settings -> Storage & Cleanup shows project data, model caches, runtime environments, and other app data. Model caches are stored separately from runtime environments so they can be reused across runtime repairs.

Rolling Pebble only contacts external services when you use features that need them, such as LRCLIB lookup/publishing, supported online source import, or model downloads for Auto Timing.

Developer Notes

For source development:

python -m venv .venv
. .venv/bin/activate
python -m pip install -U pip setuptools wheel
python -m pip install -e .
pnpm install

Run the backend and frontend together:

. .venv/bin/activate
rollingpebble dev

Or use two terminals:

# terminal 1
. .venv/bin/activate
rollingpebble serve --reload

# terminal 2
pnpm dev

Release packaging details live in RELEASE.md.

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

rollingpebble-0.6.2.tar.gz (1.6 MB view details)

Uploaded Source

Built Distribution

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

rollingpebble-0.6.2-py3-none-any.whl (1.6 MB view details)

Uploaded Python 3

File details

Details for the file rollingpebble-0.6.2.tar.gz.

File metadata

  • Download URL: rollingpebble-0.6.2.tar.gz
  • Upload date:
  • Size: 1.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for rollingpebble-0.6.2.tar.gz
Algorithm Hash digest
SHA256 18b7f14a6049950fdc6b946f404764dd24b115a561b95480baa11f05e8cadee3
MD5 1f8a74b2ee05b798a1d95635f2b1e2ec
BLAKE2b-256 03a0ab68c16e4b023ed4a7af63baf5e2d8de3b3359ca14d81eb95526dd2bfa17

See more details on using hashes here.

Provenance

The following attestation bundles were made for rollingpebble-0.6.2.tar.gz:

Publisher: python-publish.yml on Harmonese/rollingpebble

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

File details

Details for the file rollingpebble-0.6.2-py3-none-any.whl.

File metadata

  • Download URL: rollingpebble-0.6.2-py3-none-any.whl
  • Upload date:
  • Size: 1.6 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for rollingpebble-0.6.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d08b4217bbe94b4114d213a535df84a83ca43565be2f634ab11e5f237c835c49
MD5 95c83688cfe9db6bd8e0acfbfaf32a3e
BLAKE2b-256 4168a8a370bc01b63517810f1c148b25cb100e55c0a917cfa8bf479f99c95a40

See more details on using hashes here.

Provenance

The following attestation bundles were made for rollingpebble-0.6.2-py3-none-any.whl:

Publisher: python-publish.yml on Harmonese/rollingpebble

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