Class: ActionView::PathSet
- Inherits:
-
Object
- Object
- ActionView::PathSet
- Includes:
- Enumerable
- Defined in:
- lib/action_view/path_set.rb
Overview
Action View PathSet
This class is used to store and access paths in Action View. A number of operations are defined so that you can search among the paths in this set and also perform operations on other PathSet
objects.
A LookupContext
will use a PathSet
to store the paths in its context.
Instance Attribute Summary collapse
-
#paths ⇒ Object
readonly
Returns the value of attribute paths.
Instance Method Summary collapse
- #+(array) ⇒ Object
- #compact ⇒ Object
- #exists?(path, prefixes, *args) ⇒ Boolean
- #find(*args) ⇒ Object (also: #find_file)
- #find_all(path, prefixes = [], *args) ⇒ Object
-
#find_all_with_query(query) ⇒ Object
:nodoc:.
-
#initialize(paths = []) ⇒ PathSet
constructor
A new instance of PathSet.
- #initialize_copy(other) ⇒ Object
- #to_ary ⇒ Object
Constructor Details
#initialize(paths = []) ⇒ PathSet
Returns a new instance of PathSet.
18 19 20 |
# File 'lib/action_view/path_set.rb', line 18 def initialize(paths = []) @paths = typecast paths end |
Instance Attribute Details
#paths ⇒ Object (readonly)
Returns the value of attribute paths.
14 15 16 |
# File 'lib/action_view/path_set.rb', line 14 def paths @paths end |
Instance Method Details
#+(array) ⇒ Object
35 36 37 |
# File 'lib/action_view/path_set.rb', line 35 def +(array) PathSet.new(paths + array) end |
#compact ⇒ Object
31 32 33 |
# File 'lib/action_view/path_set.rb', line 31 def compact PathSet.new paths.compact end |
#exists?(path, prefixes, *args) ⇒ Boolean
58 59 60 |
# File 'lib/action_view/path_set.rb', line 58 def exists?(path, prefixes, *args) find_all(path, prefixes, *args).any? end |
#find(*args) ⇒ Object Also known as: find_file
47 48 49 |
# File 'lib/action_view/path_set.rb', line 47 def find(*args) find_all(*args).first || raise(MissingTemplate.new(self, *args)) end |
#find_all(path, prefixes = [], *args) ⇒ Object
54 55 56 |
# File 'lib/action_view/path_set.rb', line 54 def find_all(path, prefixes = [], *args) _find_all path, prefixes, args end |
#find_all_with_query(query) ⇒ Object
:nodoc:
62 63 64 65 66 67 68 69 |
# File 'lib/action_view/path_set.rb', line 62 def find_all_with_query(query) # :nodoc: paths.each do |resolver| templates = resolver.find_all_with_query(query) return templates unless templates.empty? end [] end |
#initialize_copy(other) ⇒ Object
22 23 24 25 |
# File 'lib/action_view/path_set.rb', line 22 def initialize_copy(other) @paths = other.paths.dup self end |
#to_ary ⇒ Object
27 28 29 |
# File 'lib/action_view/path_set.rb', line 27 def to_ary paths.dup end |