2023-02-03 20:36:20 +00:00
|
|
|
use clap::Parser;
|
|
|
|
|
|
|
|
const NOTIFICATION_TIMEOUT: &str = "5";
|
|
|
|
const NOTIFICATION_BODY: &str = "<b>Playing:</b> {title} from {album} \n\n <b>Artist:</b> {artist} - {year}";
|
|
|
|
const NOTIFICATION_SUMMARY: &str = "{artist} - {title}";
|
|
|
|
const NOTIFICATION_APP_NAME: &str = "C* Music Player";
|
|
|
|
const DEFAULT_MAX_DEPTH: &str = "3";
|
2023-02-03 17:00:03 +00:00
|
|
|
|
|
|
|
#[derive(Parser, Debug)]
|
|
|
|
#[command(author, about, version, long_about = None)]
|
|
|
|
pub struct Arguments {
|
|
|
|
/// The notification timeout, in seconds
|
2023-02-03 20:36:20 +00:00
|
|
|
#[arg(short, long, default_value = NOTIFICATION_TIMEOUT)]
|
2023-02-03 17:00:03 +00:00
|
|
|
pub timeout: u8,
|
|
|
|
/// Make the notification persistent, i.e. not disappear after a timeout (you can dismiss it manually)
|
|
|
|
#[arg(short, long)]
|
|
|
|
pub persistent: bool,
|
|
|
|
/// Show the track cover in the notification, if available
|
2023-02-03 17:25:11 +00:00
|
|
|
#[arg(short = 'c', long = "cover")]
|
2023-02-03 17:00:03 +00:00
|
|
|
pub show_track_cover: bool,
|
|
|
|
/// The static icon to use for the notification, it not effective if the track cover is shown,
|
|
|
|
/// but if the cover is not available or you disabled it, this icon will be used.
|
|
|
|
///
|
|
|
|
/// you can give it the full path to an image file or a name of an icon from the current icon theme
|
|
|
|
/// (e.g. "audio-x-generic" or "spotify-client")
|
2023-02-03 17:25:11 +00:00
|
|
|
#[arg(short = 'i', long = "icon", default_value = None)]
|
2023-02-03 17:00:03 +00:00
|
|
|
pub notification_static_icon: Option<String>,
|
|
|
|
/// The path to look for the cover image, if not given, the cover will be searched in the track's directory
|
|
|
|
/// for an image file with the name "cover".
|
|
|
|
///
|
2023-02-03 17:06:01 +00:00
|
|
|
/// You can use the placeholder "{artist}" and "{album}" and "{title}" and "{track_number}" and
|
|
|
|
/// "{disc_number}" and "{year}" and "{genre}" in the path, they will be replaced with the corresponding metadata.
|
|
|
|
/// but if the metadata is not available, the placeholder will be replaced with an empty string.
|
2023-02-03 17:00:03 +00:00
|
|
|
/// And you can use the simple glob pattern `*` to match any character.
|
|
|
|
/// e.g. "covers/{artist}/{album}/cover.*", "covers/{artist}/{album}/*",
|
|
|
|
///
|
|
|
|
/// If you not specify the full path, the cover will be started from the track's directory.
|
2023-02-03 17:25:11 +00:00
|
|
|
#[arg(short = 'w', long = "cover-path", default_value = None)]
|
2023-02-03 17:00:03 +00:00
|
|
|
pub cover_path: Option<String>,
|
|
|
|
#[cfg(feature = "lyrics")]
|
|
|
|
/// The lyrics file path, if not given, the lyrics will be searched in the track's directory
|
|
|
|
/// for a text file with the name "lyrics", or with the same name as the track.
|
|
|
|
///
|
2023-02-03 17:06:01 +00:00
|
|
|
/// You can use the placeholder "{artist}" and "{album}" and "{title}" and "{track_number}" and
|
|
|
|
/// "{disc_number}" and "{year}" and "{genre}" in the path, they will be replaced with the corresponding metadata.
|
|
|
|
/// but if the metadata is not available, the placeholder will be replaced with an empty string.
|
2023-02-03 17:00:03 +00:00
|
|
|
/// And you can use the simple glob pattern `*` to match any character.
|
|
|
|
/// e.g. "lyrics/{artist}/{album}/{title}.lrc", "lyrics/{artist}/{album}/*",
|
|
|
|
///
|
|
|
|
/// If you not specify the full path, the lyrics will be started from the track's directory.
|
|
|
|
#[arg(short, long, default_value = None)]
|
|
|
|
pub lyrics_path: Option<String>,
|
|
|
|
/// The maximum path depth to search for the cover and lyrics files,
|
|
|
|
/// if the files are not found in the track's directory, or the directory specified by the `--cover-path`
|
|
|
|
/// or `--lyrics-path`* options, the program will search in the parent directory,
|
|
|
|
/// and so on, until the maximum depth is reached.
|
2023-02-03 20:36:20 +00:00
|
|
|
#[arg(short, long, default_value = DEFAULT_MAX_DEPTH)]
|
2023-02-03 17:00:03 +00:00
|
|
|
pub depth: u8,
|
2023-02-03 19:16:12 +00:00
|
|
|
/// The name of the app to use for the notification.
|
2023-02-03 20:36:20 +00:00
|
|
|
#[arg(short, long, default_value = NOTIFICATION_APP_NAME)]
|
2023-02-03 19:16:12 +00:00
|
|
|
pub app_name: String,
|
|
|
|
/// The summary of the notification.
|
|
|
|
///
|
|
|
|
/// you can use the placeholder "{artist}" and "{album}" and "{title}" and "{track_number}" and
|
|
|
|
/// "{disc_number}" and "{year}" and "{genre}" in the summary, they will be replaced with the corresponding metadata.
|
|
|
|
/// but if the metadata is not available, the placeholder will be replaced with an empty string.
|
|
|
|
/// e.g. "{artist} - {title}"
|
2023-02-03 20:36:20 +00:00
|
|
|
#[arg(short, long, default_value = NOTIFICATION_SUMMARY)]
|
2023-02-03 19:16:12 +00:00
|
|
|
pub summary: String,
|
|
|
|
#[cfg(feature = "lyrics")]
|
|
|
|
/// The body of the notification.
|
|
|
|
/// you can use the placeholder "{artist}" and "{album}" and "{title}" and "{track_number}" and
|
|
|
|
/// "{disc_number}" and "{year}" and "{genre}" in the body, they will be replaced with the corresponding metadata.
|
|
|
|
/// but if the metadata is not available, the placeholder will be replaced with an empty string.
|
|
|
|
///
|
|
|
|
/// And you can use the placeholder "{lyrics}" to show the lyrics of the track, if available.
|
|
|
|
/// But if you use this placeholder, the notification will be persistent, and you need to dismiss it manually tow times.
|
|
|
|
///
|
|
|
|
/// Also you can use the placeholder "{progress}" to show the progress of the track, in the format "00:00 / 00:00".
|
|
|
|
///
|
|
|
|
/// Also you can use the placeholder "{progress_bar}" to show the progress bar of the track.
|
|
|
|
///
|
|
|
|
/// Like the "{lyrics}" placeholder, if you use the "{progress}" or "{progress_bar}" placeholder,
|
|
|
|
/// the notification will be persistent, and you need to dismiss it manually tow times.
|
|
|
|
///
|
|
|
|
/// Also you can use the simple html markup, if your notification server supports it.
|
2023-02-03 20:36:20 +00:00
|
|
|
#[arg(default_value = NOTIFICATION_BODY)]
|
2023-02-03 19:16:12 +00:00
|
|
|
pub body: String,
|
|
|
|
#[cfg(not(feature = "lyrics"))]
|
|
|
|
/// The body of the notification.
|
|
|
|
/// you can use the placeholder "{artist}" and "{album}" and "{title}" and "{track_number}" and
|
|
|
|
/// "{disc_number}" and "{year}" and "{genre}" in the body, they will be replaced with the corresponding metadata.
|
|
|
|
/// but if the metadata is not available, the placeholder will be replaced with an empty string.
|
|
|
|
///
|
|
|
|
/// And you can use the placeholder "{progress}" to show the progress of the track, in the format "00:00 / 00:00".
|
|
|
|
/// Also you can use the placeholder "{progress_bar}" to show the progress bar of the track.
|
|
|
|
///
|
|
|
|
/// But if you use the "{progress}" or "{progress_bar}" placeholder,
|
|
|
|
/// the notification will be persistent, and you need to dismiss it manually tow times.
|
|
|
|
///
|
|
|
|
/// Also you can use the simple html markup, if your notification server supports it.
|
2023-02-03 20:36:20 +00:00
|
|
|
#[arg(default_value = NOTIFICATION_BODY)]
|
2023-02-03 19:16:12 +00:00
|
|
|
pub body: String,
|
2023-02-03 17:00:03 +00:00
|
|
|
}
|