Class: ActiveFedora::FilesHash
- Inherits:
-
Object
- Object
- ActiveFedora::FilesHash
- Extended by:
- Forwardable
- Defined in:
- lib/active_fedora/files_hash.rb
Instance Method Summary collapse
- #[](name) ⇒ Object
- #[]=(name, object) ⇒ Object
- #association(name) ⇒ Object
- #each ⇒ Object
- #each_value ⇒ Object
- #empty? ⇒ Boolean
- #freeze ⇒ Object
- #has_key?(key) ⇒ Boolean
-
#initialize(model) ⇒ FilesHash
constructor
A new instance of FilesHash.
-
#key?(key) ⇒ Boolean
Check that the key exists with indifferent access (symbol or string) in a manner that avoids generating extra symbols.
- #keys ⇒ Object
- #reflections ⇒ Object
- #select ⇒ Object
- #size ⇒ Object
- #values ⇒ Object
Constructor Details
#initialize(model) ⇒ FilesHash
Returns a new instance of FilesHash.
7 8 9 |
# File 'lib/active_fedora/files_hash.rb', line 7 def initialize (model) @base = model end |
Instance Method Details
#[](name) ⇒ Object
11 12 13 |
# File 'lib/active_fedora/files_hash.rb', line 11 def [] (name) association(name).reader if association(name) end |
#[]=(name, object) ⇒ Object
15 16 17 |
# File 'lib/active_fedora/files_hash.rb', line 15 def []= (name, object) association(name).writer(object) if association(name) end |
#association(name) ⇒ Object
19 20 21 22 23 |
# File 'lib/active_fedora/files_hash.rb', line 19 def association(name) # Check to see if the key exists before casting to a symbol, because symbols # are not garbage collected in earlier versions of Ruby @base.association(name.to_sym) if key?(name) end |
#each ⇒ Object
29 30 31 32 33 |
# File 'lib/active_fedora/files_hash.rb', line 29 def each keys.each do |k| yield k, self[k] end end |
#each_value ⇒ Object
62 63 64 65 66 |
# File 'lib/active_fedora/files_hash.rb', line 62 def each_value keys.each do |k| yield self[k] end end |
#empty? ⇒ Boolean
58 59 60 |
# File 'lib/active_fedora/files_hash.rb', line 58 def empty? reflections.empty? end |
#freeze ⇒ Object
75 76 77 78 79 80 |
# File 'lib/active_fedora/files_hash.rb', line 75 def freeze keys.each do |name| association(name).reader.freeze if association(name).loaded? end super end |
#has_key?(key) ⇒ Boolean
50 51 52 |
# File 'lib/active_fedora/files_hash.rb', line 50 def has_key?(key) keys.include?(key) end |
#key?(key) ⇒ Boolean
Check that the key exists with indifferent access (symbol or string) in a manner that avoids generating extra symbols. Symbols are not garbage collected in earlier versions of ruby.
42 43 44 |
# File 'lib/active_fedora/files_hash.rb', line 42 def key?(key) keys.include?(key) || keys.map(&:to_s).include?(key) end |
#keys ⇒ Object
35 36 37 |
# File 'lib/active_fedora/files_hash.rb', line 35 def keys reflections.keys + @base.undeclared_files end |
#reflections ⇒ Object
25 26 27 |
# File 'lib/active_fedora/files_hash.rb', line 25 def reflections @base.class.child_resource_reflections end |
#select ⇒ Object
68 69 70 71 72 73 |
# File 'lib/active_fedora/files_hash.rb', line 68 def select keys.each_with_object({}) do |k, h| val = self[k] h[k] = val if yield k, val end end |
#size ⇒ Object
54 55 56 |
# File 'lib/active_fedora/files_hash.rb', line 54 def size keys.size end |
#values ⇒ Object
46 47 48 |
# File 'lib/active_fedora/files_hash.rb', line 46 def values keys.map { |k| self[k] } end |