Releases: hastinbe/i3-volume
v3.9.0
i3-volume v3.9.0
🎉 New Features
- Added support for configuration file loading from
XDG_CONFIG_HOME
- Users can now store their configuration in
~/.config/i3-volume/config
- Maintains backward compatibility with existing setups
- Users can now store their configuration in
- Added port aliases support for PulseAudio sinks
- Allows custom naming of audio ports
- Improves readability in notifications
🔧 Improvements
- Improved AWK pattern matching for better cross-platform compatibility
- Simplified PulseAudio sink and port handling functions
- Reduced code complexity
- Better performance in sink detection
- Better caching of PulseAudio sink information
- Reduces unnecessary system calls
- Improves overall script performance
🐛 Bug Fixes
- Fixed unbound variables in various functions
- Fixed
pa_list_sinks
not working properly in listen mode - Fixed sink port handling to prevent word splitting
- Fixed unnecessary
${}
usage in arithmetic operations - Fixed double declaration of
SINK_PORTS
array
🏗️ Infrastructure
- Replaced Travis CI with GitHub Actions
- Faster CI/CD pipeline
- Better integration with GitHub
- Updated shellcheck configuration
- Stricter code quality checks
- Better compliance with shell scripting best practices
📝 Documentation
- Updated README with new configuration options
- Added examples for port aliases configuration
🔍 Installation
git clone https://github.com/hastinbe/i3-volume.git
cd i3-volume
./volume --help
🙏 Thanks
Special thanks to all contributors who helped make this release possible!
v3.6.1
v3.6.0
v3.5.0
v3.4.0
Added
Auto-detect notification method (requires DBus)
Ability to play an event sound when volume changed
Support for libcanberra for playing event sounds
Repects server capabilities of your notification server
Auto-detect notification method
i3-volume use to default to libnotify when a notification method was not
specified. When using a libnotify compatible notification daemon like
notify-osd or dunst, this is a non-issue. Now if DBus
is available this is no longer the case. When available, i3-volume will ask what your notification server is, if supported it will send notifications to that server, if not supported it will fallback to libnotify and try anyway.
Customize notification sound
The sound played during volume change events can be set by the
SOUND_VOLUME_CHANGED
environment variable. It currently defaults to the
freedesktop sound theme (sound-theme-freedesktop
package). If you wish
to use a custom sound, you can specify it like so:
env SOUND_VOLUME_CHANGED=/path/to/soundfile.oga ~/i3-volume/volume -P up 5
Currently i3-volume does not support XDG sound theming spec and requires path
to the full sound file. The exception of this is when using libcanberra
(-C
) which does support XDG. However, by default i3-volume tells
libcanberra to play the sound file instead of a sound event id. To get
libcanberra to use the sound event id instead, we need to set
SOUND_VOLUME_CHANGED to a non-existent file like so:
env SOUND_VOLUME_CHANGED= ~/i3-volume/volume -CP up 5
Capabilities
When discoverable the capabilities of the notification server is
requested. Currently this is limited to libnotify compatible servers. If
icons are supported, i3-volume will display a volume icon. If the
notification server can handle sound, i3-volume will play volume change
sound events if enabled (-P) through the notification server instead of
externally.
v3.0.0
Features & Changes
- Colored usage/help if the terminal supports 8 colors.
- Error feedback for missing required function arguments.
- PA and amixer functions are only defined when enabled.
- Removed all global variables.
- PA functions renamed with a pa_ prefix, likewise amixer_ for amixer.
- Immutable and/or integer variables are now declared as such.
- Cache
pacmd list-sinks
during the script's execution, except forlisten
. - Support for volnoti notifications
Commands
Commands are used to perform an operation, such as muting or changing the volume. In versions prior to 3.x they were command-line options. This change frees up and slims down the amount of options, and makes the script straight-forward to use.
Commands include: up
, down
, set
, mute
, listen
, output
, outputs
, notifications
, help
Options
Removed options
-d
is now thedown
command-i
is now theup
command-m
is now themute
command-o
is now theoutput
command-v
is now theset
command
Renamed options
-M
is now-m
Fixes
- Custom output format not working with more than 1 argument.
- A few cases where word splitting was not desired.
v2.7.0
Added
Listen mode for PulseAudio (-L)
- Subscribes to and listens for changes on the provided, or default, PulseAudio sink.
- When notifications (-n) are enabled, they will be triggered for these events.
- When the status bar (-t) and signal (-s) are set, the status bar will be signaled to update.