const WV_FLAG_FALSE_STEREO: u32 = 1 << 30;
//const WV_FLAG_DSD_AUDIO: u32 = 1 << 31;
-const WV_STREAM_FLAGS: u32 = 0x8000018B;
+const WV_STREAM_FLAGS: u32 = 0x8000008B;
#[derive(Clone,Copy,Default)]
struct WVHeader {
const WV_HEADER_SIZE: usize = 32;
impl WVHeader {
+ #[allow(clippy::field_reassign_with_default)]
fn parse(src: &[u8]) -> DemuxerResult<Self> {
let mut mr = MemoryReader::new_read(src);
let mut br = ByteReader::new(&mut mr);
std::mem::swap(&mut fb, &mut self.first_blocks);
let (refhdr, buf) = fb.unwrap();
let stream = strmgr.get_stream(0).unwrap();
- let (tb_num, tb_den) = stream.get_timebase();
- let ts = NATimeInfo::new(Some(self.samplepos), None, None, tb_num, tb_den);
+ let ts = stream.make_ts(Some(self.samplepos), None, None);
let pkt = NAPacket::new(stream, ts, true, buf);
self.samplepos += u64::from(refhdr.block_samples);
let (refhdr, buf) = self.read_blocks()?;
let stream = strmgr.get_stream(0).unwrap();
- let (tb_num, tb_den) = stream.get_timebase();
- let ts = NATimeInfo::new(Some(self.samplepos), None, None, tb_num, tb_den);
+ let ts = stream.make_ts(Some(self.samplepos), None, None);
let pkt = NAPacket::new(stream, ts, true, buf);
self.samplepos += u64::from(refhdr.block_samples);
#[test]
fn test_wavpack_demux() {
+ // sample from the official WavPack test samples set
let mut file = File::open("assets/LLaudio/wv/false_stereo.wv").unwrap();
let mut fr = FileReader::new_read(&mut file);
let mut br = ByteReader::new(&mut fr);