From 42fa9a844c4b8e46189ffaf9e5f803b3c03e7042 Mon Sep 17 00:00:00 2001 From: Kostya Shishkov Date: Wed, 7 Oct 2020 14:09:03 +0200 Subject: [PATCH] ape: report sample-based duration --- nihav-llaudio/src/demuxers/ape.rs | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/nihav-llaudio/src/demuxers/ape.rs b/nihav-llaudio/src/demuxers/ape.rs index 10ebc07..bae9416 100644 --- a/nihav-llaudio/src/demuxers/ape.rs +++ b/nihav-llaudio/src/demuxers/ape.rs @@ -15,6 +15,7 @@ struct APEDemuxer<'a> { normal_blocks: u32, last_blocks: u32, truncated: bool, + duration: u64, } impl<'a> APEDemuxer<'a> { @@ -26,6 +27,7 @@ impl<'a> APEDemuxer<'a> { normal_blocks: 0, last_blocks: 0, truncated: false, + duration: 0, } } } @@ -119,6 +121,7 @@ impl<'a> DemuxCore<'a> for APEDemuxer<'a> { self.frames = Vec::with_capacity(nframes); self.normal_blocks = blocksperframe; self.last_blocks = finalblocks; + self.duration = (((nframes - 1) as u64) * u64::from(blocksperframe) + u64::from(finalblocks)) * 1000 / u64::from(srate); seek_index.mode = SeekIndexMode::Present; let first_off = src.peek_u32le()?; @@ -223,7 +226,7 @@ impl<'a> DemuxCore<'a> for APEDemuxer<'a> { Ok(()) } - fn get_duration(&self) -> u64 { 0 } + fn get_duration(&self) -> u64 { self.duration } } impl<'a> NAOptionHandler for APEDemuxer<'a> { -- 2.30.2