aboutsummaryrefslogtreecommitdiffstats
path: root/src/demux.rs
diff options
context:
space:
mode:
authorKostya Shishkov <kostya.shishkov@gmail.com>2022-12-17 11:45:54 +0100
committerKostya Shishkov <kostya.shishkov@gmail.com>2022-12-17 11:45:54 +0100
commit081797c71bd8cd4342d58a2124cbd7f72d02b7d2 (patch)
tree0d4e45839212c9d1fe7b4bee6fd36517ef8e5e45 /src/demux.rs
parent8a8f6e5c8847945e274c5d7e2c6a51c027c19c35 (diff)
downloadnihav-tool-master.tar.gz
add option for printing MOV chunks hierarchyHEADmaster
Diffstat (limited to 'src/demux.rs')
-rw-r--r--src/demux.rs10
1 files changed, 5 insertions, 5 deletions
diff --git a/src/demux.rs b/src/demux.rs
index 56659c7..9c65b85 100644
--- a/src/demux.rs
+++ b/src/demux.rs
@@ -98,14 +98,14 @@ pub enum DemuxerObject<'a> {
}
impl<'a> DemuxerObject<'a> {
- pub fn create(br: &'a mut ByteReader<'a>, reg: &FullRegister, name: &str, force_dmx: Option<&str>, is_raw: bool) -> DemuxerObject<'a> {
+ pub fn create(br: &'a mut ByteReader<'a>, reg: &FullRegister, name: &str, force_dmx: Option<&str>, is_raw: bool, opts: &[NAOption]) -> DemuxerObject<'a> {
if !is_raw {
let res = detect::detect_format(name, br);
if let Some(dmx_name) = force_dmx {
println!("forcing demuxer {} on {}", dmx_name, name);
if let Some(dmx_fact) = reg.dmx_reg.find_demuxer(dmx_name) {
br.seek(SeekFrom::Start(0)).unwrap();
- let dmx = create_demuxer(dmx_fact, br).unwrap();
+ let dmx = create_demuxer_with_options(dmx_fact, br, opts).unwrap();
return DemuxerObject::Normal(dmx);
} else {
return DemuxerObject::None
@@ -116,7 +116,7 @@ impl<'a> DemuxerObject<'a> {
println!("trying demuxer {} on {}", dmx_name, name);
if let Some(dmx_fact) = reg.dmx_reg.find_demuxer(dmx_name) {
br.seek(SeekFrom::Start(0)).unwrap();
- let dmx = create_demuxer(dmx_fact, br).unwrap();
+ let dmx = create_demuxer_with_options(dmx_fact, br, opts).unwrap();
return DemuxerObject::Normal(dmx);
}
}
@@ -124,7 +124,7 @@ impl<'a> DemuxerObject<'a> {
println!("trying raw demuxer {} on {}", dmx_name, name);
if let Some(rdmx_fact) = reg.rdmx_reg.find_demuxer(dmx_name) {
br.seek(SeekFrom::Start(0)).unwrap();
- let dmx = create_raw_demuxer(rdmx_fact, br).unwrap();
+ let dmx = create_raw_demuxer_with_options(rdmx_fact, br, opts).unwrap();
let mut pkts = Vec::new();
for stream in dmx.get_streams() {
if let Some(pcreate) = reg.pkt_reg.find_packetiser(stream.get_info().get_name()) {
@@ -141,7 +141,7 @@ impl<'a> DemuxerObject<'a> {
if rdmx.check_format(br) {
println!("detected {} as {}", name, rdmx.get_name());
br.seek(SeekFrom::Start(0)).unwrap();
- let dmx = create_raw_demuxer(*rdmx, br).unwrap();
+ let dmx = create_raw_demuxer_with_options(*rdmx, br, opts).unwrap();
let mut pkts = Vec::new();
for stream in dmx.get_streams() {
if let Some(pcreate) = reg.pkt_reg.find_packetiser(stream.get_info().get_name()) {