diff options
Diffstat (limited to 'actionview')
-rw-r--r-- | actionview/lib/action_view/digestor.rb | 14 | ||||
-rw-r--r-- | actionview/test/template/digestor_test.rb | 4 |
2 files changed, 9 insertions, 9 deletions
diff --git a/actionview/lib/action_view/digestor.rb b/actionview/lib/action_view/digestor.rb index 518f0da16c..d0b86b4c03 100644 --- a/actionview/lib/action_view/digestor.rb +++ b/actionview/lib/action_view/digestor.rb @@ -28,7 +28,11 @@ module ActionView # (Concurrent::Map's lookups have volatile semantics) finder.digest_cache[cache_key] || @@digest_mutex.synchronize do finder.digest_cache.fetch(cache_key) do # re-check under lock - finder.digest_cache[cache_key] = tree(name, finder, dependencies).digest(finder) + root = tree(name, finder) + dependencies.each do |injected_dep| + root.children << Injected.new(injected_dep, nil, nil) + end + finder.digest_cache[cache_key] = root.digest(finder) end end end @@ -38,7 +42,7 @@ module ActionView end # Create a dependency tree for template named +name+. - def tree(name, finder, injected = [], partial = false, seen = {}) + def tree(name, finder, partial = false, seen = {}) logical_name = name.gsub(%r|/_|, "/") partial = partial || name.include?("/_") @@ -48,15 +52,11 @@ module ActionView if node = seen[template.identifier] # handle cycles in the tree node else - node = seen[template.identifier] = Node.create(name, logical_name, template, partial) deps = DependencyTracker.find_dependencies(name, template, finder.view_paths) deps.uniq { |n| n.gsub(%r|/_|, "/") }.each do |dep_file| - node.children << tree(dep_file, finder, [], true, seen) - end - injected.each do |injected_dep| - node.children << Injected.new(injected_dep, nil, nil) + node.children << tree(dep_file, finder, true, seen) end node end diff --git a/actionview/test/template/digestor_test.rb b/actionview/test/template/digestor_test.rb index 2f43ef4bfb..1bab615b29 100644 --- a/actionview/test/template/digestor_test.rb +++ b/actionview/test/template/digestor_test.rb @@ -321,12 +321,12 @@ class TemplateDigestorTest < ActionView::TestCase end def dependencies(template_name) - tree = ActionView::Digestor.tree(template_name, finder, []) + tree = ActionView::Digestor.tree(template_name, finder) tree.children.map(&:name) end def nested_dependencies(template_name) - tree = ActionView::Digestor.tree(template_name, finder, []) + tree = ActionView::Digestor.tree(template_name, finder) tree.children.map(&:to_dep_map) end |