This commit is contained in:
Alexander Simonov 2014-03-09 20:38:14 +02:00
parent d9f97b06d4
commit 2697c7ea4f
3 changed files with 48 additions and 2 deletions

View File

@ -538,9 +538,9 @@ module Zip
def write_to_zip_output_stream(zip_output_stream) #:nodoc:all
if @ftype == :directory
zip_output_stream.put_next_entry(self)
zip_output_stream.put_next_entry(self, nil, nil, ::Zip::Entry::STORED)
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) }
else
zip_output_stream.copy_raw_entry(self)

View File

@ -90,6 +90,7 @@ end
require 'zip/extra_field/generic'
require 'zip/extra_field/universal_time'
require 'zip/extra_field/old_unix'
require 'zip/extra_field/unix'
require 'zip/extra_field/zip64'
require 'zip/extra_field/zip64_placeholder'

View File

@ -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