use std::path::PathBuf;
use audio_analysis_transcription::AlignmentInterpolationMethod;
use serde::{Deserialize, Serialize};
use super::defaults::default_alignment_model_id;
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct AlignmentConfig {
#[serde(default)]
pub enabled: bool,
#[serde(default = "default_alignment_model_id")]
pub model_id: String,
#[serde(default)]
pub model_bundle: Option<PathBuf>,
#[serde(default)]
pub model_dir: Option<PathBuf>,
#[serde(default)]
pub model_cache_only: bool,
#[serde(default)]
pub interpolate_method: AlignmentInterpolationMethod,
#[serde(default)]
pub return_char_alignments: bool,
}
impl Default for AlignmentConfig {
fn default() -> Self {
Self {
enabled: true,
model_id: default_alignment_model_id(),
model_bundle: None,
model_dir: None,
model_cache_only: false,
interpolate_method: AlignmentInterpolationMethod::Nearest,
return_char_alignments: false,
}
}
}