Merge pull request #264 from zip-rs/fix/issue_252

fix: permissions are not copied
This commit is contained in:
Alexander Zaitsev 2022-01-23 20:30:57 +03:00 committed by GitHub
commit d6e0c7dc68
Signed by: DevComp
GPG key ID: 4AEE18F83AFDEB23

View file

@ -133,6 +133,7 @@ impl FileOptions {
/// ///
/// The default is `CompressionMethod::Deflated`. If the deflate compression feature is /// The default is `CompressionMethod::Deflated`. If the deflate compression feature is
/// disabled, `CompressionMethod::Stored` becomes the default. /// disabled, `CompressionMethod::Stored` becomes the default.
#[must_use]
pub fn compression_method(mut self, method: CompressionMethod) -> FileOptions { pub fn compression_method(mut self, method: CompressionMethod) -> FileOptions {
self.compression_method = method; self.compression_method = method;
self self
@ -142,6 +143,7 @@ impl FileOptions {
/// ///
/// The default is the current timestamp if the 'time' feature is enabled, and 1980-01-01 /// The default is the current timestamp if the 'time' feature is enabled, and 1980-01-01
/// otherwise /// otherwise
#[must_use]
pub fn last_modified_time(mut self, mod_time: DateTime) -> FileOptions { pub fn last_modified_time(mut self, mod_time: DateTime) -> FileOptions {
self.last_modified_time = mod_time; self.last_modified_time = mod_time;
self self
@ -152,6 +154,7 @@ impl FileOptions {
/// The format is represented with unix-style permissions. /// The format is represented with unix-style permissions.
/// The default is `0o644`, which represents `rw-r--r--` for files, /// The default is `0o644`, which represents `rw-r--r--` for files,
/// and `0o755`, which represents `rwxr-xr-x` for directories /// and `0o755`, which represents `rwxr-xr-x` for directories
#[must_use]
pub fn unix_permissions(mut self, mode: u32) -> FileOptions { pub fn unix_permissions(mut self, mode: u32) -> FileOptions {
self.permissions = Some(mode & 0o777); self.permissions = Some(mode & 0o777);
self self
@ -162,6 +165,7 @@ impl FileOptions {
/// If set to `false` and the file exceeds the limit, an I/O error is thrown. If set to `true`, /// If set to `false` and the file exceeds the limit, an I/O error is thrown. If set to `true`,
/// readers will require ZIP64 support and if the file does not exceed the limit, 20 B are /// readers will require ZIP64 support and if the file does not exceed the limit, 20 B are
/// wasted. The default is `false`. /// wasted. The default is `false`.
#[must_use]
pub fn large_file(mut self, large: bool) -> FileOptions { pub fn large_file(mut self, large: bool) -> FileOptions {
self.large_file = large; self.large_file = large;
self self
@ -614,11 +618,11 @@ impl<W: Write + io::Seek> ZipWriter<W> {
where where
S: Into<String>, S: Into<String>,
{ {
let options = FileOptions::default() let mut options = FileOptions::default()
.last_modified_time(file.last_modified()) .last_modified_time(file.last_modified())
.compression_method(file.compression()); .compression_method(file.compression());
if let Some(perms) = file.unix_mode() { if let Some(perms) = file.unix_mode() {
options.unix_permissions(perms); options = options.unix_permissions(perms);
} }
let raw_values = ZipRawValues { let raw_values = ZipRawValues {