Fix #138
This commit is contained in:
parent
d9f97b06d4
commit
2697c7ea4f
|
@ -538,9 +538,9 @@ module Zip
|
||||||
|
|
||||||
def write_to_zip_output_stream(zip_output_stream) #:nodoc:all
|
def write_to_zip_output_stream(zip_output_stream) #:nodoc:all
|
||||||
if @ftype == :directory
|
if @ftype == :directory
|
||||||
zip_output_stream.put_next_entry(self)
|
zip_output_stream.put_next_entry(self, nil, nil, ::Zip::Entry::STORED)
|
||||||
elsif @filepath
|
elsif @filepath
|
||||||
zip_output_stream.put_next_entry(self, nil, nil, nil)
|
zip_output_stream.put_next_entry(self, nil, nil, ::Zip::Entry::DEFLATED)
|
||||||
get_input_stream { |is| ::Zip::IOExtras.copy_stream(zip_output_stream, is) }
|
get_input_stream { |is| ::Zip::IOExtras.copy_stream(zip_output_stream, is) }
|
||||||
else
|
else
|
||||||
zip_output_stream.copy_raw_entry(self)
|
zip_output_stream.copy_raw_entry(self)
|
||||||
|
|
|
@ -90,6 +90,7 @@ end
|
||||||
|
|
||||||
require 'zip/extra_field/generic'
|
require 'zip/extra_field/generic'
|
||||||
require 'zip/extra_field/universal_time'
|
require 'zip/extra_field/universal_time'
|
||||||
|
require 'zip/extra_field/old_unix'
|
||||||
require 'zip/extra_field/unix'
|
require 'zip/extra_field/unix'
|
||||||
require 'zip/extra_field/zip64'
|
require 'zip/extra_field/zip64'
|
||||||
require 'zip/extra_field/zip64_placeholder'
|
require 'zip/extra_field/zip64_placeholder'
|
||||||
|
|
|
@ -0,0 +1,45 @@
|
||||||
|
module Zip
|
||||||
|
# Olf Info-ZIP Extra for UNIX uid/gid and file timestampes
|
||||||
|
class ExtraField::OldUnix < ExtraField::Generic
|
||||||
|
HEADER_ID = "UX"
|
||||||
|
register_map
|
||||||
|
|
||||||
|
def initialize(binstr = nil)
|
||||||
|
@uid = 0
|
||||||
|
@gid = 0
|
||||||
|
@atime = nil
|
||||||
|
@mtime = nil
|
||||||
|
binstr and merge(binstr)
|
||||||
|
end
|
||||||
|
|
||||||
|
attr_accessor :uid, :gid, :atime, :mtime
|
||||||
|
|
||||||
|
def merge(binstr)
|
||||||
|
return if binstr.empty?
|
||||||
|
size, content = initial_parse(binstr)
|
||||||
|
# size: 0 for central directory. 4 for local header
|
||||||
|
return if (!size || size == 0)
|
||||||
|
atime, mtime, uid, gid = content.unpack("VVvv")
|
||||||
|
@uid ||= uid
|
||||||
|
@gid ||= gid
|
||||||
|
@atime ||= atime
|
||||||
|
@mtime ||= mtime
|
||||||
|
end
|
||||||
|
|
||||||
|
def ==(other)
|
||||||
|
@uid == other.uid &&
|
||||||
|
@gid == other.gid &&
|
||||||
|
@atime == other.atime &&
|
||||||
|
@mtime == other.mtime
|
||||||
|
end
|
||||||
|
|
||||||
|
def pack_for_local
|
||||||
|
[@atime, @mtime, @uid, @gid].pack("VVvv")
|
||||||
|
end
|
||||||
|
|
||||||
|
def pack_for_c_dir
|
||||||
|
[@atime, @mtime].pack("VV")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
Loading…
Reference in New Issue