On this page
class ActionView::Digestor
Attributes
finder[R]
name[R]
options[R]
Public Class Methods
# File actionview/lib/action_view/digestor.rb, line 18
def digest(options)
options.assert_valid_keys(:name, :finder, :dependencies, :partial)
cache_key = ([ options[:name], options[:finder].details_key.hash ].compact + Array.wrap(options[:dependencies])).join('.')
# this is a correctly done double-checked locking idiom
# (ThreadSafe::Cache's lookups have volatile semantics)
@@cache[cache_key] || @@digest_monitor.synchronize do
@@cache.fetch(cache_key) do # re-check under lock
compute_and_store_digest(cache_key, options)
end
end
end
Supported options:
name
- Template namefinder
- An instance of ActionView::LookupContextdependencies
- An array of dependent viewspartial
- Specifies whether the template is a partial
# File actionview/lib/action_view/digestor.rb, line 56
def initialize(options)
@name, @finder = options.values_at(:name, :finder)
@options = options.except(:name, :finder)
end
Public Instance Methods
# File actionview/lib/action_view/digestor.rb, line 70
def dependencies
DependencyTracker.find_dependencies(name, template)
rescue ActionView::MissingTemplate
logger.try :error, " '#{name}' file doesn't exist, so no dependencies"
[]
end
# File actionview/lib/action_view/digestor.rb, line 61
def digest
Digest::MD5.hexdigest("#{source}-#{dependency_digest}").tap do |digest|
logger.try :debug, " Cache digest for #{template.inspect}: #{digest}"
end
rescue ActionView::MissingTemplate
logger.try :error, " Couldn't find template for digesting: #{name}"
''
end
# File actionview/lib/action_view/digestor.rb, line 77
def nested_dependencies
dependencies.collect do |dependency|
dependencies = PartialDigestor.new(name: dependency, finder: finder).nested_dependencies
dependencies.any? ? { dependency => dependencies } : dependency
end
end
© 2004–2018 David Heinemeier Hansson
Licensed under the MIT License.