moosicbox_audio_output 0.2.0

MoosicBox audio outputs package
//! Audio encoders for compressing decoded audio into various formats.
//!
//! This module provides the [`crate::encoder::AudioEncoder`] trait and implementations for encoding
//! decoded audio samples into compressed formats like AAC, FLAC, MP3, and Opus.
//! Each encoder is available through its corresponding feature flag.

#![allow(clippy::module_name_repetitions)]

use bytes::Bytes;
use symphonia::core::audio::{AudioBuffer, SignalSpec};

use crate::AudioOutputError;

#[cfg(feature = "aac")]
/// AAC audio encoder implementation.
pub mod aac;
#[cfg(feature = "flac")]
/// FLAC audio encoder implementation.
pub mod flac;
#[cfg(feature = "mp3")]
/// MP3 audio encoder implementation.
pub mod mp3;
#[cfg(feature = "opus")]
/// Opus audio encoder implementation.
pub mod opus;

/// Trait for encoding decoded audio into compressed formats.
///
/// Implementors of this trait handle encoding audio samples into various
/// compressed formats like AAC, FLAC, MP3, or Opus.
pub trait AudioEncoder: Send + Sync {
    /// Encodes decoded audio samples into a compressed format.
    ///
    /// # Errors
    ///
    /// * If the audio fails to encode
    fn encode(&mut self, decoded: AudioBuffer<f32>) -> Result<Bytes, AudioOutputError>;

    /// Returns the audio signal specification for this encoder.
    ///
    /// The returned `SignalSpec` describes the output format of encoded audio.
    #[must_use]
    fn spec(&self) -> SignalSpec;
}