Skip to main content

Tools for publishing albums to the web and digital stores

Project description

Bandcrash

Bandcrash is a standalone program that automatically encodes an album of songs into a bunch of different formats for distribution on various platforms, such as itch.io, or for hosting on your own website.

See it in action!

Documentation Status

Features

  • Output as mp3, ogg, FLAC, and web preview (HTML5+mp3 at a lower bitrate)
  • Optionally upload everything to your page on itch using butler
  • High-quality encoding and metadata, with support for cover songs, per-track artwork, embedded lyrics, and more
  • Web player also supports per-track artwork

Usage

Please see the online documentation for installation and usage instructions.

Contributing

Development environment notes

If you are developing under Windows, you will probably need to use a POSIX environment under Windows (such as msys or Git Bash) rather than WSL.

If you are developing under macOS, please use a universal2 build of Python (such as the ones installable from python.org) and you need to ensure that you've created your environment against that (e.g. poetry env use /usr/local/bin/python3.11).

Roadmap

See the github issues for details, but roughly:

  • Local GUI and/or web UI to make setting up the album.json easier (and easier installation, especially on Windows!)
  • Various player improvements
  • Easy embedding into websites (opengraph et al)

FAQ

How is this different from blamscamp, scritch, etc.?

Blamscamp and scritch are both great programs for publishing previews of already-encoded on itch.io and other websites! However, their functionality is only to bundle prepared audio files into a web-based player, and they don't presently handle encoding or tagging, two things that are historically tedious and difficult to do well.

Bandcrash is a full end-to-end system for preparing an album for both sale and preview online in a variety of formats.

What about Faircamp?

Faircamp does handle the end-to-end encoding and processing and builds a quite beautiful static website! If you just want to build a site to host your music and handle your own payments, it's totally usable for that.

Bandcrash is for people who want to be able to host their downloads and web-based preview on existing marketplaces such as itch.io, gumroad, ko-fi, etc., or who want to be able to embed their preview on their website under their own terms, rather than being beholden to a specific static site template.

What player does Bandcrash use?

At present, it defaults to using Camptown, a player built specifically for Bandcrash. However, I do plan on eventually making it possible to choose from a variety of player engines, including Blamscamp and Scritch.

What happened to pyBlamscamp?

Back when this project started, it was named pyBlamscamp as the intention was to be basically a Python version of the blamscamp GUI which would also handle encoding steps for you, but it very quickly drifted away from that and became something else.

For a while, Bandcrash used a fork of the blamscamp player, but at this point that has been entirely removed.

Why make a local GUI instead instead of a web app?

You already have your large .wav files on your local hard drive. Your local drive is also a good place to keep your previous encoding results. Your local computer also has a lot more space available than a typical cloud server, doesn't have to juggle cloud storage credentials, doesn't have to worry about the security of the server running the encoder app, the cost of running servers or paying for cloud storage, and so on.

Basically, it's easier for everyone.

Sometimes local apps are just Better™.

That said, Bandcrash is also embeddable as a library, so someone could conceivably build a web-based system that uses it for encoding and tagging files.

Credits

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

bandcrash-0.7.13.tar.gz (34.9 kB view details)

Uploaded Source

Built Distribution

bandcrash-0.7.13-py3-none-any.whl (38.2 kB view details)

Uploaded Python 3

File details

Details for the file bandcrash-0.7.13.tar.gz.

File metadata

  • Download URL: bandcrash-0.7.13.tar.gz
  • Upload date:
  • Size: 34.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.11.6 Darwin/24.0.0

File hashes

Hashes for bandcrash-0.7.13.tar.gz
Algorithm Hash digest
SHA256 41bf1f469ecf22b330c0819202c118ed905d0d2f471d631f1bed6c2a1d00b986
MD5 9859c7296fb0c11a579a24a23db0b19d
BLAKE2b-256 20763c70ada5ff5de309564ed1f8144a24115b7a9e4f41c663f88e27b079a6d4

See more details on using hashes here.

File details

Details for the file bandcrash-0.7.13-py3-none-any.whl.

File metadata

  • Download URL: bandcrash-0.7.13-py3-none-any.whl
  • Upload date:
  • Size: 38.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.11.6 Darwin/24.0.0

File hashes

Hashes for bandcrash-0.7.13-py3-none-any.whl
Algorithm Hash digest
SHA256 8a242abdf2117b0739dfd52e41cd0f3588d9bd18e1e317cb2ab9f4f123c6b139
MD5 0fddc5d7a098dbc75d52ed4c64500a5f
BLAKE2b-256 2e8a7f7e3755e0fb20a3db03c67382a78c678e755bdfb484c9913db933d2e0bf

See more details on using hashes here.

Supported by

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