Mopidy extension for ALSA volume control
Project description
mopidy-alsamixer
Mopidy extension for ALSA volume control.
Maintainer wanted
mopidy-alsamixer is currently kept on life support by the Mopidy core developers. It is in need of a more dedicated maintainer.
If you want to be the maintainer of mopidy-alsamixer, please:
-
Make 2-3 good pull requests improving any part of the project.
-
Read and get familiar with all of the project's open issues.
-
Send a pull request removing this section and adding yourself as the "Current maintainer" in the "Credits" section below. In the pull request description, please refer to the previous pull requests and state that you've familiarized yourself with the open issues.
As a maintainer, you'll be given push access to the repo and the authority to make releases to PyPI when you see fit.
Installation
Install by running:
python3 -m pip install mopidy-alsamixer
See https://mopidy.com/ext/alsamixer/ for alternative installation methods.
Configuration
To use mopidy-alsamixer the audio/mixer configuration value must be set to
alsamixer in the Mopidy configuration file:
[audio]
mixer = alsamixer
The default mopidy-alsaMixer configuration will probably work for most use cases. If not, the following configuration values are available:
-
alsamixer/device: Which soundcard should be used, specified by its string alias. Defaults todefault. -
alsamixer/card: Which soundcard should be used, specified by its index. Numbered from 0 and up. If specified,alsamixer/deviceis ignored. -
alsamixer/control: Which ALSA control should be used. Defaults toMaster. Other typical values includesPCM. Run the commandamixer scontrolsto list available controls on your system. -
alsamixer/min_volumeandalsamixer/max_volume: Map the Mopidy volume control range to a different range. Values are in the range 0-100. Use this if the default range (0-100) is too wide, resulting in a small usable range for Mopidy's volume control. For example trymin_volume = 30andmax_volume = 70to map Mopidy's volume control to the middle of ALSA's volume range. -
alsamixer/volume_scale: Eitherlinear,cubic, orlog. The cubic scale is the default as it is closer to how the human ear percieves volume, and matches the volume scale used in thealsamixerprogram.
Example alsamixer section from the Mopidy configuration file:
[alsamixer]
card = 1
control = PCM
min_volume = 0
max_volume = 100
volume_scale = cubic
Project resources
Development
Set up development environment
Clone the repo using, e.g. using gh:
gh repo clone mopidy/mopidy-alsamixer
Enter the directory, and install dependencies using uv:
cd mopidy-alsamixer/
uv sync
Running tests
To run all tests and linters in isolated environments, use tox:
tox
To only run tests, use pytest:
pytest
To format the code, use ruff:
ruff format .
To check for lints with ruff, run:
ruff check .
To check for type errors, use pyright:
pyright .
Making a release
To make a release to PyPI, go to the project's GitHub releases page and click the "Draft a new release" button.
In the "choose a tag" dropdown, select the tag you want to release or create a
new tag, e.g. v0.1.0. Add a title, e.g. v0.1.0, and a description of the changes.
Decide if the release is a pre-release (alpha, beta, or release candidate) or should be marked as the latest release, and click "Publish release".
Once the release is created, the release.yml GitHub Action will automatically
build and publish the release to
PyPI.
Credits
- Original author: Stein Magnus Jodal
- Current maintainer: None. Maintainer wanted, see section above.
- Contributors
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 mopidy_alsamixer-3.0.0.tar.gz.
File metadata
- Download URL: mopidy_alsamixer-3.0.0.tar.gz
- Upload date:
- Size: 15.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6ef0a0a5cbefb4b8a2f7258d9f844dd7cac0d9e825f0a86354f09b4f4b739e87
|
|
| MD5 |
a829db5994e083fe7624f6310769098b
|
|
| BLAKE2b-256 |
b506f2d2982aac394595e3d22c2635a4fd63b7934adfbb030177b38e9ada4308
|
Provenance
The following attestation bundles were made for mopidy_alsamixer-3.0.0.tar.gz:
Publisher:
release.yml on mopidy/mopidy-alsamixer
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mopidy_alsamixer-3.0.0.tar.gz -
Subject digest:
6ef0a0a5cbefb4b8a2f7258d9f844dd7cac0d9e825f0a86354f09b4f4b739e87 - Sigstore transparency entry: 1375897064
- Sigstore integration time:
-
Permalink:
mopidy/mopidy-alsamixer@9920b659167ec8844c4ae07cfb1bdf9047e5dcc3 -
Branch / Tag:
refs/tags/v3.0.0 - Owner: https://github.com/mopidy
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@9920b659167ec8844c4ae07cfb1bdf9047e5dcc3 -
Trigger Event:
release
-
Statement type:
File details
Details for the file mopidy_alsamixer-3.0.0-py3-none-any.whl.
File metadata
- Download URL: mopidy_alsamixer-3.0.0-py3-none-any.whl
- Upload date:
- Size: 10.9 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 |
02ea240dd69ab4086fe1016f4c3370ed4cfbef5b587159fbcb127bba636828dd
|
|
| MD5 |
ba369d4a21a3b20461e8b6271c09bc79
|
|
| BLAKE2b-256 |
d671b544e0c068be1a2589af96d08cf89e66712563522e3517b4f2c98ac8d850
|
Provenance
The following attestation bundles were made for mopidy_alsamixer-3.0.0-py3-none-any.whl:
Publisher:
release.yml on mopidy/mopidy-alsamixer
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mopidy_alsamixer-3.0.0-py3-none-any.whl -
Subject digest:
02ea240dd69ab4086fe1016f4c3370ed4cfbef5b587159fbcb127bba636828dd - Sigstore transparency entry: 1375897158
- Sigstore integration time:
-
Permalink:
mopidy/mopidy-alsamixer@9920b659167ec8844c4ae07cfb1bdf9047e5dcc3 -
Branch / Tag:
refs/tags/v3.0.0 - Owner: https://github.com/mopidy
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@9920b659167ec8844c4ae07cfb1bdf9047e5dcc3 -
Trigger Event:
release
-
Statement type: