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 name
-  finder- An instance of ActionView::LookupContext
-  dependencies- An array of dependent views
-  partial- 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.