X-Git-Url: https://git.nihav.org/?a=blobdiff_plain;f=src%2Fdemuxers%2Fmod.rs;fp=src%2Fdemuxers%2Fmod.rs;h=14aac9380761bff34c4ff1fdb6161fca95f3b373;hb=20ef4353905883ca289782858ccfcd7d2146fa42;hp=1eb6cd13874411b34d417ff180b7e52f17037e02;hpb=fba6f8e46fbe906f5c7b372becc14c4400533eeb;p=nihav.git diff --git a/src/demuxers/mod.rs b/src/demuxers/mod.rs index 1eb6cd1..14aac93 100644 --- a/src/demuxers/mod.rs +++ b/src/demuxers/mod.rs @@ -6,7 +6,7 @@ use frame::*; //use std::collections::HashMap; use io::byteio::*; -#[derive(Debug)] +#[derive(Debug,Clone,Copy)] #[allow(dead_code)] pub enum StreamType { Video, @@ -28,17 +28,21 @@ impl fmt::Display for StreamType { #[allow(dead_code)] +#[derive(Clone)] pub struct NAStream { media_type: StreamType, id: u32, + num: usize, info: Rc, } impl NAStream { pub fn new(mt: StreamType, id: u32, info: NACodecInfo) -> Self { - NAStream { media_type: mt, id: id, info: Rc::new(info) } + NAStream { media_type: mt, id: id, num: 0, info: Rc::new(info) } } pub fn get_id(&self) -> u32 { self.id } + pub fn get_num(&self) -> usize { self.num } + pub fn set_num(&mut self, num: usize) { self.num = num; } pub fn get_info(&self) -> Rc { self.info.clone() } } @@ -95,7 +99,7 @@ pub enum DemuxerError { type DemuxerResult = Result; -pub trait NADemuxer<'a> { +pub trait Demux<'a> { fn open(&mut self) -> DemuxerResult<()>; fn get_frame(&mut self) -> DemuxerResult; fn seek(&mut self, time: u64) -> DemuxerResult<()>; @@ -127,16 +131,43 @@ impl<'a> NAPacketReader for ByteReader<'a> { } } -pub struct NADemuxerBuilder { +pub struct Demuxer { + streams: Vec>, +} + +impl Demuxer { + pub fn new() -> Self { Demuxer { streams: Vec::new() } } + pub fn add_stream(&mut self, stream: NAStream) -> Option { + let stream_num = self.streams.len(); + let mut str = stream.clone(); + str.set_num(stream_num); + self.streams.push(Rc::new(str)); + Some(stream_num) + } + pub fn get_stream(&self, idx: usize) -> Option> { + if idx < self.streams.len() { + Some(self.streams[idx].clone()) + } else { + None + } + } + pub fn get_stream_by_id(&self, id: u32) -> Option> { + for i in 0..self.streams.len() { + if self.streams[i].get_id() == id { + return Some(self.streams[i].clone()); + } + } + None + } } impl From for DemuxerError { fn from(_: ByteIOError) -> Self { DemuxerError::IOError } } -impl NADemuxerBuilder { - #[allow(unused_variables)] - pub fn create_demuxer(name: &str, url: &str) -> DemuxerResult>> { - unimplemented!() - } -} +//impl NADemuxerBuilder { +// #[allow(unused_variables)] +// pub fn create_demuxer(name: &str, url: &str) -> DemuxerResult>> { +// unimplemented!() +// } +//}