rubyzip/lib/zip/entry_set.rb

87 lines
1.8 KiB
Ruby
Raw Normal View History

module Zip
class EntrySet #:nodoc:all
include Enumerable
2013-06-03 02:33:03 +08:00
attr_accessor :entry_set, :entry_order
def initialize(an_enumerable = [])
super()
2013-06-03 02:33:03 +08:00
@entry_set = {}
@entry_order = []
an_enumerable.each { |o| push(o) }
end
def include?(entry)
2013-06-03 02:33:03 +08:00
@entry_set.include?(to_key(entry))
end
def find_entry(entry)
2013-06-03 02:33:03 +08:00
@entry_set[to_key(entry)]
end
def <<(entry)
2013-06-03 02:33:03 +08:00
@entry_order.delete(to_key(entry))
@entry_order << to_key(entry)
@entry_set[to_key(entry)] = entry
end
2013-06-03 02:33:03 +08:00
alias :push :<<
def size
2013-06-03 02:33:03 +08:00
@entry_set.size
end
2013-06-03 02:33:03 +08:00
alias :length :size
def delete(entry)
2013-06-03 02:33:03 +08:00
if @entry_order.delete(to_key(entry)) && @entry_set.delete(to_key(entry))
entry
else
nil
2013-06-03 02:33:03 +08:00
end
end
2013-06-03 02:33:03 +08:00
def each(&block)
@entry_order.each do |key|
block.call @entry_set[key]
end
end
def entries
2013-06-03 02:33:03 +08:00
@entry_order.map { |key| @entry_set[key] }
end
# deep clone
def dup
EntrySet.new(@entry_order.map { |key| @entry_set[key].dup })
end
2012-02-01 03:46:42 +08:00
def ==(other)
return false unless other.kind_of?(EntrySet)
2013-06-03 02:33:03 +08:00
@entry_set == other.entry_set && @entry_order == other.entry_order
end
def parent(entry)
2013-06-03 02:33:03 +08:00
@entry_set[to_key(entry.parent_as_string)]
end
2012-02-01 03:46:42 +08:00
def glob(pattern, flags = ::File::FNM_PATHNAME|::File::FNM_DOTMATCH)
entries.map do |entry|
next nil unless ::File.fnmatch(pattern, entry.name.chomp('/'), flags)
yield(entry) if block_given?
entry
end.compact
2013-06-03 02:33:03 +08:00
end
protected
private
def to_key(entry)
2013-06-03 02:33:03 +08:00
entry.to_s.sub(/\/$/, '')
end
end
end
# Copyright (C) 2002, 2003 Thomas Sondergaard
# rubyzip is free software; you can redistribute it and/or
# modify it under the terms of the ruby license.