summaryrefslogtreecommitdiffstats
path: root/nihav-rad/src
diff options
context:
space:
mode:
authorKostya Shishkov <[email protected]>2020-02-25 18:47:05 +0100
committerKostya Shishkov <[email protected]>2020-02-25 18:47:05 +0100
commit70e792a8d49bc44d2137752bfc35aceb7023f7fa (patch)
treec9b1b3132ff857038c12b2e7b4246819b8aeb1a1 /nihav-rad/src
parentbb07b6858762ea5ce0beab02d2b871726b3ba6a4 (diff)
smacker-audio: use interleaved output format as it is stored that way too
Diffstat (limited to 'nihav-rad/src')
-rw-r--r--nihav-rad/src/codecs/smacker.rs7
1 files changed, 3 insertions, 4 deletions
diff --git a/nihav-rad/src/codecs/smacker.rs b/nihav-rad/src/codecs/smacker.rs
index 650fddd..3d32c21 100644
--- a/nihav-rad/src/codecs/smacker.rs
+++ b/nihav-rad/src/codecs/smacker.rs
@@ -495,7 +495,7 @@ impl NADecoder for SmackerAudioDecoder {
fn init(&mut self, _supp: &mut NADecoderSupport, info: NACodecInfoRef) -> DecoderResult<()> {
if let NACodecTypeInfo::Audio(ainfo) = info.get_properties() {
self.bits = ainfo.get_format().get_bits();
- let fmt = if self.bits == 8 { SND_U8_FORMAT } else { SND_S16P_FORMAT };
+ let fmt = if self.bits == 8 { SND_U8_FORMAT } else { SND_S16_FORMAT };
self.chans = ainfo.get_channels() as usize;
self.ainfo = NAAudioInfo::new(ainfo.get_sample_rate(), ainfo.get_channels(), fmt, 0);
self.chmap = NAChannelMap::from_str(if ainfo.get_channels() == 2 {"L,R"} else {"C"}).unwrap();
@@ -540,10 +540,9 @@ impl NADecoder for SmackerAudioDecoder {
abuf = alloc_audio_buffer(self.ainfo, samples, self.chmap.clone())?;
let mut adata = abuf.get_abuf_i16().unwrap();
- let offs: [usize; 2] = [0, adata.get_offset(1)];
let dst = adata.get_data_mut().unwrap();
for ch in 0..nch {
- dst[offs[ch]] = pred[ch];
+ dst[ch] = pred[ch];
}
for i in nch..(unp_size >> 1) {
let idx = i & mask;
@@ -551,7 +550,7 @@ impl NADecoder for SmackerAudioDecoder {
let hi = br.read_tree8(&trees[idx * 2 + 1])? as u16;
let diff = (lo | (hi << 8)) as i16;
pred[idx] = pred[idx].wrapping_add(diff);
- dst[offs[idx] + (i >> 1)] = pred[idx];
+ dst[i] = pred[idx];
}
} else {
samples = unp_size / nch;