Skip to main content

A package for displaying Cmus current status in notifications

Project description

https://github.com/AntoineGagne/cmus-notify/actions/workflows/check.yaml/badge.svg?branch=master https://img.shields.io/pypi/v/cmus-notify.svg
Author:

Antoine Gagné

1 Requirements

To install this program, you must have the following:

  • python 3.9+

2 Installation

To install this program, you can simply run the following command:

python setup.py install

This program can also be found on Pypi which means you can install it by downloading the wheel or by using the following command:

pip install cmus-notify

You can check if it installed correctly by doing the following command:

cmus_notify -h

It should display a message.

3 Hooking To Cmus

To hook this program to cmus, you have to create a shell script that have the following lines in it:

#! /bin/sh

cmus_notify "$*" &

Then, you must make the file executable by using the following command (assuming your script’s name is cmus_notify.sh):

chmod +x cmus_notify.sh

Finally, once you are in cmus, you can add the hook by using the following command:

:set status_display_program=<path-to-the-shell-script>

4 Customization

If you want you can specify the formatting of the notification by specifying format strings. For example:

#! /bin/sh

cmus_notify --title "Now playing: {title} by {artist}" --body "$(printf "<b>Album:</b> {album}\n<b>Duration:</b> {duration}")" "$*"

You can also specify a configuration to read these values from. By default, the program will search for a configuration file named ~/.cmus-notify. It has the following format:

[notifications]
    application_name = Cmus
    custom_notification = /home/user/.cmus/custom_notification.py

[format]
    title = Now playing: {title} by {artist}
    body = <b>Album:</b> {album}
           <b>Duration:</b> {duration}

The options accepts the same values as their command-line options equivalent.

5 Options

To view the full options, you can run the following command:

cmus_notify --help

which will display the following prompt:

usage: cmus_notify [-h] [-a APPLICATION_NAME] [-b BODY_FORMAT_STRING]
                   [-t TITLE_FORMAT_STRING] [-f CONFIGURATION_FILE]
                   [-c CUSTOM_NOTIFICATION]
                   INFORMATION

Display a notification about Cmus's current status

positional arguments:
  INFORMATION           Parse the given information

optional arguments:
  -h, --help            show this help message and exit
  -a APPLICATION_NAME, --application_name APPLICATION_NAME
                        The name of the application
  -b BODY_FORMAT_STRING, --body BODY_FORMAT_STRING
                        A format string that can be specified to tell the
                        software how to format the body. The syntax is the
                        same as Python's. The available options are specified
                        at the end of this help message. (i.e. 'Artist:
                        {artist}')
  -t TITLE_FORMAT_STRING, --title TITLE_FORMAT_STRING
                        A format string that can be specified to tell the
                        software how to format the title. The syntax is the
                        same as Python's. The available options are specified
                        at the end of this help message. (i.e. 'Now playing:
                        {title}')
  -f CONFIGURATION_FILE, --configuration_file CONFIGURATION_FILE
                        The path to the configuration file. If it is not
                        specified, the program will use the default values of
                        the other options.
  -c CUSTOM_NOTIFICATION, --custom_notification CUSTOM_NOTIFICATION
                        The path to a custom implementation of the
                        notification class. If it is not specified, the
                        standard implementation will be used (the one using
                        notify2).

Format String Parameters
========================

The available arguments to the format strings are the following:

  - album: The song's album
  - albumartist: The song's album's artist
  - artist: The song's artist
  - date: The song's release date
  - discnumber: The song's disc's number
  - duration: The song's duration
  - file: The song's file's path
  - status: Cmus current status
  - title: The song's title
  - tracknumber: The song's track number

6 Documentation

The project’s documentation can be found here.

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

cmus_notify-1.4.2.tar.gz (26.8 kB view details)

Uploaded Source

Built Distribution

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

cmus_notify-1.4.2-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file cmus_notify-1.4.2.tar.gz.

File metadata

  • Download URL: cmus_notify-1.4.2.tar.gz
  • Upload date:
  • Size: 26.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for cmus_notify-1.4.2.tar.gz
Algorithm Hash digest
SHA256 800003dbdf2d9b1688883bec57e259a180c3095d2dc9fb79b7b764ccfdd8a199
MD5 99d4734f89b0c5a6c0912bdd519f9609
BLAKE2b-256 f9eb1c4f622811d0338f4c9bfed24c3dd0991ffd0496232a88ddd05bc8153e36

See more details on using hashes here.

File details

Details for the file cmus_notify-1.4.2-py3-none-any.whl.

File metadata

  • Download URL: cmus_notify-1.4.2-py3-none-any.whl
  • Upload date:
  • Size: 10.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for cmus_notify-1.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 4f8ea9942bada4389450e446f7f472f0bd30db81369334ff43d2512b7d2fb9a5
MD5 6eb3f273e247cdab85aeb92ad068907a
BLAKE2b-256 6d0528aefb6578295ae419b554448a81a8e5e8a533db9b57c9578470e528bde4

See more details on using hashes here.

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