simplify names in register
[nihav.git] / src / demuxers / mod.rs
CommitLineData
5869fd63 1pub mod gdv;
ca41f125 2pub mod avi;
5869fd63
KS
3
4use std::fmt;
5use std::rc::Rc;
6use frame::*;
7//use std::collections::HashMap;
8use io::byteio::*;
9
20ef4353 10#[derive(Debug,Clone,Copy)]
5869fd63
KS
11#[allow(dead_code)]
12pub enum StreamType {
13 Video,
14 Audio,
15 Subtitles,
16 Data,
83e603fa 17 None,
5869fd63
KS
18}
19
20impl fmt::Display for StreamType {
21 fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
22 match *self {
23 StreamType::Video => write!(f, "Video"),
24 StreamType::Audio => write!(f, "Audio"),
25 StreamType::Subtitles => write!(f, "Subtitles"),
26 StreamType::Data => write!(f, "Data"),
83e603fa 27 StreamType::None => write!(f, "-"),
5869fd63
KS
28 }
29 }
30}
31
32
33#[allow(dead_code)]
20ef4353 34#[derive(Clone)]
8869d452 35pub struct NAStream {
5869fd63
KS
36 media_type: StreamType,
37 id: u32,
20ef4353 38 num: usize,
8869d452 39 info: Rc<NACodecInfo>,
5869fd63
KS
40}
41
8869d452
KS
42impl NAStream {
43 pub fn new(mt: StreamType, id: u32, info: NACodecInfo) -> Self {
20ef4353 44 NAStream { media_type: mt, id: id, num: 0, info: Rc::new(info) }
5869fd63
KS
45 }
46 pub fn get_id(&self) -> u32 { self.id }
20ef4353
KS
47 pub fn get_num(&self) -> usize { self.num }
48 pub fn set_num(&mut self, num: usize) { self.num = num; }
8869d452 49 pub fn get_info(&self) -> Rc<NACodecInfo> { self.info.clone() }
5869fd63
KS
50}
51
8869d452 52impl fmt::Display for NAStream {
5869fd63 53 fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
83e603fa 54 write!(f, "({}#{} - {})", self.media_type, self.id, self.info.get_properties())
5869fd63
KS
55 }
56}
57
58#[allow(dead_code)]
8869d452
KS
59pub struct NAPacket {
60 stream: Rc<NAStream>,
5869fd63
KS
61 pts: Option<u64>,
62 dts: Option<u64>,
63 duration: Option<u64>,
64 buffer: Rc<Vec<u8>>,
65 keyframe: bool,
66// options: HashMap<String, NAValue<'a>>,
67}
68
8869d452
KS
69impl NAPacket {
70 pub fn new(str: Rc<NAStream>, pts: Option<u64>, dts: Option<u64>, dur: Option<u64>, kf: bool, vec: Vec<u8>) -> Self {
5869fd63
KS
71// let mut vec: Vec<u8> = Vec::new();
72// vec.resize(size, 0);
73 NAPacket { stream: str, pts: pts, dts: dts, duration: dur, keyframe: kf, buffer: Rc::new(vec) }
74 }
8869d452 75 pub fn get_stream(&self) -> Rc<NAStream> { self.stream.clone() }
5869fd63
KS
76 pub fn get_pts(&self) -> Option<u64> { self.pts }
77 pub fn get_buffer(&self) -> Rc<Vec<u8>> { self.buffer.clone() }
78}
79
8869d452 80impl fmt::Display for NAPacket {
5869fd63
KS
81 fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
82 let mut foo = format!("[pkt for {} size {}", self.stream, self.buffer.len());
83 if let Some(pts) = self.pts { foo = format!("{} pts {}", foo, pts); }
84 if let Some(dts) = self.dts { foo = format!("{} dts {}", foo, dts); }
85 if let Some(dur) = self.duration { foo = format!("{} duration {}", foo, dur); }
86 if self.keyframe { foo = format!("{} kf", foo); }
87 foo = foo + "]";
88 write!(f, "{}", foo)
89 }
90}
91
92#[derive(Debug)]
93#[allow(dead_code)]
94pub enum DemuxerError {
95 EOF,
96 NoSuchInput,
97 InvalidData,
98 IOError,
99 NotImplemented,
100 MemoryError,
101}
102
103type DemuxerResult<T> = Result<T, DemuxerError>;
104
20ef4353 105pub trait Demux<'a> {
5869fd63
KS
106 fn open(&mut self) -> DemuxerResult<()>;
107 fn get_frame(&mut self) -> DemuxerResult<NAPacket>;
108 fn seek(&mut self, time: u64) -> DemuxerResult<()>;
109}
110
8869d452
KS
111pub trait NAPacketReader {
112 fn read_packet(&mut self, str: Rc<NAStream>, pts: Option<u64>, dts: Option<u64>, dur: Option<u64>, keyframe: bool, size: usize) -> DemuxerResult<NAPacket>;
5869fd63
KS
113 fn fill_packet(&mut self, pkt: &mut NAPacket) -> DemuxerResult<()>;
114}
115
8869d452
KS
116impl<'a> NAPacketReader for ByteReader<'a> {
117 fn read_packet(&mut self, str: Rc<NAStream>, pts: Option<u64>, dts: Option<u64>, dur: Option<u64>, kf: bool, size: usize) -> DemuxerResult<NAPacket> {
5869fd63
KS
118 let mut buf: Vec<u8> = Vec::with_capacity(size);
119 if buf.capacity() < size { return Err(DemuxerError::MemoryError); }
120 buf.resize(size, 0);
121 let res = self.read_buf(buf.as_mut_slice());
122 if let Err(_) = res { return Err(DemuxerError::IOError); }
5869fd63
KS
123 let pkt = NAPacket::new(str, pts, dts, dur, kf, buf);
124 Ok(pkt)
125 }
126 fn fill_packet(&mut self, pkt: &mut NAPacket) -> DemuxerResult<()> {
127 let mut refbuf = pkt.get_buffer();
128 let mut buf = Rc::make_mut(&mut refbuf);
129 let res = self.read_buf(buf.as_mut_slice());
130 if let Err(_) = res { return Err(DemuxerError::IOError); }
5869fd63
KS
131 Ok(())
132 }
133}
134
20ef4353
KS
135pub struct Demuxer {
136 streams: Vec<Rc<NAStream>>,
137}
138
139impl Demuxer {
140 pub fn new() -> Self { Demuxer { streams: Vec::new() } }
141 pub fn add_stream(&mut self, stream: NAStream) -> Option<usize> {
142 let stream_num = self.streams.len();
143 let mut str = stream.clone();
144 str.set_num(stream_num);
145 self.streams.push(Rc::new(str));
146 Some(stream_num)
147 }
148 pub fn get_stream(&self, idx: usize) -> Option<Rc<NAStream>> {
149 if idx < self.streams.len() {
150 Some(self.streams[idx].clone())
151 } else {
152 None
153 }
154 }
155 pub fn get_stream_by_id(&self, id: u32) -> Option<Rc<NAStream>> {
156 for i in 0..self.streams.len() {
157 if self.streams[i].get_id() == id {
158 return Some(self.streams[i].clone());
159 }
160 }
161 None
162 }
5869fd63
KS
163}
164
165impl From<ByteIOError> for DemuxerError {
166 fn from(_: ByteIOError) -> Self { DemuxerError::IOError }
167}
168
20ef4353
KS
169//impl NADemuxerBuilder {
170// #[allow(unused_variables)]
171// pub fn create_demuxer(name: &str, url: &str) -> DemuxerResult<Box<NADemuxer<'static>>> {
172// unimplemented!()
173// }
174//}