Merge pull request #264 from zip-rs/fix/issue_252
fix: permissions are not copied
This commit is contained in:
commit
d6e0c7dc68
1 changed files with 6 additions and 2 deletions
|
@ -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 {
|
||||||
|
|
Loading…
Add table
Reference in a new issue