X-Git-Url: https://git.nihav.org/?a=blobdiff_plain;f=nihav-core%2Fsrc%2Fdetect.rs;h=0285e64a84ac6034a5c54326d8665d5c77d53557;hb=1b8522d6275f5a8e252b7c7283ed4d80a594db93;hp=b2d4295ff9ac1a24938ea5b34ce3c2e28ce53d52;hpb=128253cc176c24aa8934a1a2b1c644da56df2764;p=nihav.git diff --git a/nihav-core/src/detect.rs b/nihav-core/src/detect.rs index b2d4295..0285e64 100644 --- a/nihav-core/src/detect.rs +++ b/nihav-core/src/detect.rs @@ -134,7 +134,7 @@ impl<'a> CC<'a> { match *self { CC::Or (ref a, ref b) => { a.eval(src) || b.eval(src) }, CC::Eq(ref arg) => { arg.eq(src) }, - CC::In(ref a, ref b) => { a.le(src) && b.ge(src) }, + CC::In(ref a, ref b) => { a.ge(src) && b.le(src) }, CC::Lt(ref arg) => { arg.lt(src) }, CC::Le(ref arg) => { arg.le(src) }, CC::Gt(ref arg) => { arg.gt(src) }, @@ -193,6 +193,14 @@ const DETECTORS: &[DetectConditions] = &[ extensions: ".ivr", conditions: &[CheckItem{offs: 0, cond: &CC::Or(&CC::Str(b".R1M"), &CC::Str(b".REC"))}], }, + DetectConditions { + demux_name: "bink", + extensions: ".bik,.bk2", + conditions: &[CheckItem{offs: 0, cond: &CC::Or(&CC::In(Arg::U32BE(0x32494B62), // BIKb + Arg::U32BE(0x32494B7B)), // BIKz + &CC::In(Arg::U32BE(0x4B423261), // KB2a + Arg::U32BE(0x4B42327B)))}], // KB2z + }, DetectConditions { demux_name: "smacker", extensions: ".smk", @@ -236,9 +244,9 @@ pub fn detect_format(name: &str, src: &mut ByteReader) -> Option<(&'static str, if score == DetectionScore::MagicMatches { return Some((detector.demux_name, score)); } - if let None = result { + if result.is_none() && score != DetectionScore::No { result = Some((detector.demux_name, score)); - } else { + } else if result.is_some() { let (_, oldsc) = result.unwrap(); if oldsc.less(score) { result = Some((detector.demux_name, score));