add feature for toggling replaygain support

This commit is contained in:
chaos 2023-10-20 15:36:37 +01:00
parent 96117c2faf
commit 9a83845831
No known key found for this signature in database
3 changed files with 12 additions and 2 deletions

View file

@ -52,6 +52,7 @@ notify = "6"
[features] [features]
default = [ default = [
"replaygain",
"mp3_extractor", "mp3_extractor",
"flac_extractor", "flac_extractor",
"taglib_extractor", "taglib_extractor",
@ -66,3 +67,5 @@ mp3_extractor = ["dep:id3"]
ffprobe_extractor = [] # If to allow using ffmpeg/ffprobe as a fallback tag extractor ffprobe_extractor = [] # If to allow using ffmpeg/ffprobe as a fallback tag extractor
command_genhtml = ["dep:html-escape", "dep:urlencoding"] command_genhtml = ["dep:html-escape", "dep:urlencoding"]
replaygain = []

View file

@ -7,6 +7,7 @@ use crate::types::AudioFileInfo;
use crate::types::File; use crate::types::File;
use crate::utils::ascii_reduce::reduce_to_ascii; use crate::utils::ascii_reduce::reduce_to_ascii;
use crate::utils::formats::get_format_handler; use crate::utils::formats::get_format_handler;
#[cfg(feature = "replaygain")]
use crate::utils::replaygain::analyze_replaygain; use crate::utils::replaygain::analyze_replaygain;
use crate::utils::scan_for_music; use crate::utils::scan_for_music;
@ -15,10 +16,13 @@ pub struct ProcessCommandArgs {
pub source: String, pub source: String,
#[clap(long)] #[clap(long)]
pub dry_run: bool, pub dry_run: bool,
#[cfg(feature = "replaygain")]
#[clap(long)] #[clap(long)]
pub skip_replaygain: bool, pub skip_replaygain: bool,
#[cfg(feature = "replaygain")]
#[clap(long)] #[clap(long)]
pub force_replaygain: bool, pub force_replaygain: bool,
#[cfg(feature = "replaygain")]
#[clap(long)] #[clap(long)]
pub replaygain_threads: Option<u32>, pub replaygain_threads: Option<u32>,
#[clap(long)] #[clap(long)]
@ -112,6 +116,7 @@ fn rename_file(process_args: &ProcessCommandArgs, file: &mut File) {
} }
} }
#[cfg(feature = "replaygain")]
pub fn add_replaygain_tags(file: &File, force: bool) -> Result<(), Box<dyn std::error::Error>> { pub fn add_replaygain_tags(file: &File, force: bool) -> Result<(), Box<dyn std::error::Error>> {
if !file.info.supports_replaygain { if !file.info.supports_replaygain {
println!( println!(
@ -211,6 +216,7 @@ pub fn process_command(
rename_file(process_args, file); rename_file(process_args, file);
} }
#[cfg(feature = "replaygain")]
if !process_args.skip_replaygain && !process_args.dry_run { if !process_args.skip_replaygain && !process_args.dry_run {
println!("Adding ReplayGain Tags to Files"); println!("Adding ReplayGain Tags to Files");

View file

@ -1,6 +1,7 @@
pub mod ascii_reduce; pub mod ascii_reduce;
pub mod ffprobe; pub mod ffprobe;
pub mod format_detection; pub mod format_detection;
#[cfg(feature = "replaygain")]
pub mod replaygain; pub mod replaygain;
pub mod transcoder; pub mod transcoder;