Class: Gem::Package::TarReader
Relationships & Source Files | |
Namespace Children | |
Classes:
| |
Exceptions:
| |
Super Chains via Extension / Inclusion / Inheritance | |
Instance Chain:
self,
Enumerable
|
|
Inherits: | Object |
Defined in: | lib/rubygems/package/tar_reader.rb |
Overview
TarReader
reads tar files and allows iteration over their items
Class Method Summary
-
.new(io) ⇒ TarReader
constructor
Creates a new
TarReader
onio
and yields it to the block, if given.
Instance Method Summary
-
#close
Close the tar file.
-
#each
(also: #each_entry)
Iterates over files in the tarball yielding each entry.
-
#each_entry
Alias for #each.
-
#initialize(io) ⇒ TarReader
constructor
Creates a new tar file reader on
io
which needs to respond to#pos
,#eof?
,#read
,#getc
and#pos=
- #rewind
-
#seek(name)
Seeks through the tar file until it finds the
entry
withname
and yields it.
Constructor Details
.new(io) ⇒ TarReader
Creates a new TarReader
on io
and yields it to the block, if given.
# File 'lib/rubygems/package/tar_reader.rb', line 22
def self.new(io) reader = super return reader unless block_given? begin yield reader ensure reader.close end nil end
#initialize(io) ⇒ TarReader
Creates a new tar file reader on io
which needs to respond to #pos
, #eof?
, #read
, #getc
and #pos=
# File 'lib/rubygems/package/tar_reader.rb', line 40
def initialize(io) @io = io @init_pos = io.pos end
Instance Method Details
#close
Close the tar file
# File 'lib/rubygems/package/tar_reader.rb', line 48
def close end
#each Also known as: #each_entry
Iterates over files in the tarball yielding each entry
#each_entry
Alias for #each.
# File 'lib/rubygems/package/tar_reader.rb', line 66
alias each_entry each
#rewind
NOTE: Do not call #rewind
during #each
# File 'lib/rubygems/package/tar_reader.rb', line 71
def rewind if @init_pos == 0 @io.rewind else @io.pos = @init_pos end end
#seek(name)
Seeks through the tar file until it finds the entry
with name
and yields it. Rewinds the tar file to the beginning when the block terminates.
# File 'lib/rubygems/package/tar_reader.rb', line 84
def seek(name) # :yields: entry found = find do |entry| entry.full_name == name end return unless found return yield found ensure rewind end