diff options
author | Richard Schneeman <richard.schneeman+no-recruiters@gmail.com> | 2018-09-07 22:05:23 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-09-07 22:05:23 -0400 |
commit | 273e73dbcdf82748237173f9cff3352bf74b4753 (patch) | |
tree | 9f6a20c4c720f3de9877cee7be8ec88ed7ff9f4d | |
parent | c03bba4f1f03bad7dc034af555b7f2b329cf76f5 (diff) | |
parent | 1bd578ffe6e89cbe828745c15d730be2ce850109 (diff) | |
download | rails-273e73dbcdf82748237173f9cff3352bf74b4753.tar.gz rails-273e73dbcdf82748237173f9cff3352bf74b4753.tar.bz2 rails-273e73dbcdf82748237173f9cff3352bf74b4753.zip |
Merge pull request #33817 from schneems/schneems/dig-simple
Don’t allocate array on no args
-rw-r--r-- | actionview/lib/action_view/digestor.rb | 11 | ||||
-rw-r--r-- | actionview/test/activerecord/relation_cache_test.rb | 2 | ||||
-rw-r--r-- | actionview/test/template/render_test.rb | 2 |
3 files changed, 9 insertions, 6 deletions
diff --git a/actionview/lib/action_view/digestor.rb b/actionview/lib/action_view/digestor.rb index 39cdecb9e4..6d2e471a44 100644 --- a/actionview/lib/action_view/digestor.rb +++ b/actionview/lib/action_view/digestor.rb @@ -18,9 +18,12 @@ module ActionView # * <tt>name</tt> - Template name # * <tt>finder</tt> - An instance of <tt>ActionView::LookupContext</tt> # * <tt>dependencies</tt> - An array of dependent views - def digest(name:, finder:, dependencies: []) - dependencies ||= [] - cache_key = [ name, finder.rendered_format, dependencies ].flatten.compact.join(".") + def digest(name:, finder:, dependencies: nil) + if dependencies.nil? || dependencies.empty? + cache_key = "#{name}.#{finder.rendered_format}" + else + cache_key = [ name, finder.rendered_format, dependencies ].flatten.compact.join(".") + end # this is a correctly done double-checked locking idiom # (Concurrent::Map's lookups have volatile semantics) @@ -30,7 +33,7 @@ module ActionView root = tree(name, finder, partial) dependencies.each do |injected_dep| root.children << Injected.new(injected_dep, nil, nil) - end + end if dependencies finder.digest_cache[cache_key] = root.digest(finder) end end diff --git a/actionview/test/activerecord/relation_cache_test.rb b/actionview/test/activerecord/relation_cache_test.rb index bd0cd10eaf..56e17e67a8 100644 --- a/actionview/test/activerecord/relation_cache_test.rb +++ b/actionview/test/activerecord/relation_cache_test.rb @@ -19,5 +19,5 @@ class RelationCacheTest < ActionView::TestCase assert_equal "Hello World", controller.cache_store.read("views/path/projects-#{Project.count}") end - def view_cache_dependencies; end + def view_cache_dependencies; []; end end diff --git a/actionview/test/template/render_test.rb b/actionview/test/template/render_test.rb index 8782eb4430..6ff7ddba0f 100644 --- a/actionview/test/template/render_test.rb +++ b/actionview/test/template/render_test.rb @@ -10,7 +10,7 @@ module RenderTestCases def setup_view(paths) @assigns = { secret: "in the sauce" } @view = Class.new(ActionView::Base) do - def view_cache_dependencies; end + def view_cache_dependencies; []; end def combined_fragment_cache_key(key) [ :views, key ] |