fix: version_needed was wrong when e.g. cfg(bzip2) but current file wasn't bzip2 (#100)
This commit is contained in:
parent
e1ef3fc65c
commit
c2fe20741c
1 changed files with 30 additions and 5 deletions
35
src/types.rs
35
src/types.rs
|
@ -50,6 +50,8 @@ use crate::extra_fields::ExtraField;
|
||||||
use crate::result::DateTimeRangeError;
|
use crate::result::DateTimeRangeError;
|
||||||
#[cfg(feature = "time")]
|
#[cfg(feature = "time")]
|
||||||
use time::{error::ComponentRange, Date, Month, OffsetDateTime, PrimitiveDateTime, Time};
|
use time::{error::ComponentRange, Date, Month, OffsetDateTime, PrimitiveDateTime, Time};
|
||||||
|
use crate::CompressionMethod;
|
||||||
|
use crate::types::ffi::S_IFDIR;
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug, PartialEq, Eq, FromPrimitive, IntoPrimitive)]
|
#[derive(Clone, Copy, Debug, PartialEq, Eq, FromPrimitive, IntoPrimitive)]
|
||||||
#[repr(u8)]
|
#[repr(u8)]
|
||||||
|
@ -369,6 +371,7 @@ pub struct ZipFileData {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ZipFileData {
|
impl ZipFileData {
|
||||||
|
|
||||||
pub fn file_name_sanitized(&self) -> PathBuf {
|
pub fn file_name_sanitized(&self) -> PathBuf {
|
||||||
let no_null_filename = match self.file_name.find('\0') {
|
let no_null_filename = match self.file_name.find('\0') {
|
||||||
Some(index) => &self.file_name[0..index],
|
Some(index) => &self.file_name[0..index],
|
||||||
|
@ -446,12 +449,34 @@ impl ZipFileData {
|
||||||
|
|
||||||
pub const fn version_needed(&self) -> u16 {
|
pub const fn version_needed(&self) -> u16 {
|
||||||
// higher versions matched first
|
// higher versions matched first
|
||||||
match (self.zip64_extension(), self.compression_method) {
|
let compression_version: u16 = match self.compression_method {
|
||||||
|
CompressionMethod::Stored => 10,
|
||||||
|
#[cfg(feature = "_deflate-any")]
|
||||||
|
CompressionMethod::Deflated => 20,
|
||||||
#[cfg(feature = "bzip2")]
|
#[cfg(feature = "bzip2")]
|
||||||
(_, crate::compression::CompressionMethod::Bzip2) => 46,
|
CompressionMethod::Bzip2 => 46,
|
||||||
(true, _) => 45,
|
#[cfg(feature = "deflate64")]
|
||||||
_ => 20,
|
CompressionMethod::Deflate64 => 21,
|
||||||
}
|
#[cfg(feature = "lzma")]
|
||||||
|
CompressionMethod::Lzma => 63,
|
||||||
|
_ => DEFAULT_VERSION as u16
|
||||||
|
};
|
||||||
|
let crypto_version: u16 = if self.aes_mode.is_some() {
|
||||||
|
51
|
||||||
|
} else if self.encrypted {
|
||||||
|
20
|
||||||
|
} else {
|
||||||
|
10
|
||||||
|
};
|
||||||
|
let misc_feature_version: u16 = if self.large_file {
|
||||||
|
45
|
||||||
|
} else if self.unix_mode().is_some_and(|mode| mode & S_IFDIR == S_IFDIR) {
|
||||||
|
// file is directory
|
||||||
|
20
|
||||||
|
} else {
|
||||||
|
10
|
||||||
|
};
|
||||||
|
compression_version.max(crypto_version).max(misc_feature_version)
|
||||||
}
|
}
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
pub(crate) fn extra_field_len(&self) -> usize {
|
pub(crate) fn extra_field_len(&self) -> usize {
|
||||||
|
|
Loading…
Add table
Reference in a new issue