diff options
Diffstat (limited to 'stream')
-rw-r--r-- | stream/stream_libarchive.c | 24 |
1 files changed, 14 insertions, 10 deletions
diff --git a/stream/stream_libarchive.c b/stream/stream_libarchive.c index d5d8dca3ff..0b48233f8c 100644 --- a/stream/stream_libarchive.c +++ b/stream/stream_libarchive.c @@ -42,6 +42,19 @@ static bool probe_rar(struct stream *s) return memcmp(buf, rar_sig, 6) == 0; } +static bool probe_multi_rar(struct stream *s) +{ + uint8_t hdr[14]; + if (stream_read_peek(s, hdr, sizeof(hdr)) == sizeof(hdr)) { + // Look for rar mark head & main head (assume they're in order). + if (hdr[6] == 0x00 && hdr[7 + 2] == 0x73) { + int rflags = hdr[7 + 3] | (hdr[7 + 4] << 8); + return rflags & 0x100; + } + } + return false; +} + static bool probe_zip(struct stream *s) { uint8_t p[4]; @@ -300,16 +313,7 @@ struct mp_archive *mp_archive_new(struct mp_log *log, struct stream *src, bool maybe_rar = probe_rar(src); bool maybe_zip = probe_zip(src); bool probe_all = flags & MP_ARCHIVE_FLAG_UNSAFE; - bool maybe_rar2_multivol = false; - - uint8_t hdr[14]; - if (maybe_rar && stream_read_peek(src, hdr, sizeof(hdr)) == sizeof(hdr)) { - // Look for rar mark head & main head (assume they're in order). - if (hdr[6] == 0x00 && hdr[7 + 2] == 0x73) { - int rflags = hdr[7 + 3] | (hdr[7 + 4] << 8); - maybe_rar2_multivol = rflags & 0x100; - } - } + bool maybe_rar2_multivol = maybe_rar && probe_multi_rar(src); bool is_multivolume = false; if (!(flags & MP_ARCHIVE_FLAG_NO_RAR_VOLUMES)) { |