123456789_123456789_123456789_123456789_123456789_

Class: ActionView::UnboundTemplate

Relationships & Source Files
Inherits: Object
Defined in: actionview/lib/action_view/unbound_template.rb

Class Method Summary

Instance Attribute Summary

Instance Method Summary

Constructor Details

.new(source, identifier, details:, virtual_path:) ⇒ UnboundTemplate

[ GitHub ]

  
# File 'actionview/lib/action_view/unbound_template.rb', line 10

def initialize(source, identifier, details:, virtual_path:)
  @source = source
  @identifier = identifier
  @details = details
  @virtual_path = virtual_path

  @templates = Concurrent::Map.new(initial_capacity: 2)
  @write_lock = Mutex.new
end

Instance Attribute Details

#details (readonly)

[ GitHub ]

  
# File 'actionview/lib/action_view/unbound_template.rb', line 7

attr_reader :virtual_path, :details

#format (readonly)

[ GitHub ]

  
# File 'actionview/lib/action_view/unbound_template.rb', line 8

delegate :locale, :format, :variant, :handler, to: :@details

#handler (readonly)

[ GitHub ]

  
# File 'actionview/lib/action_view/unbound_template.rb', line 8

delegate :locale, :format, :variant, :handler, to: :@details

#locale (readonly)

[ GitHub ]

  
# File 'actionview/lib/action_view/unbound_template.rb', line 8

delegate :locale, :format, :variant, :handler, to: :@details

#variant (readonly)

[ GitHub ]

  
# File 'actionview/lib/action_view/unbound_template.rb', line 8

delegate :locale, :format, :variant, :handler, to: :@details

#virtual_path (readonly)

[ GitHub ]

  
# File 'actionview/lib/action_view/unbound_template.rb', line 7

attr_reader :virtual_path, :details

Instance Method Details

#bind_locals(locals)

[ GitHub ]

  
# File 'actionview/lib/action_view/unbound_template.rb', line 20

def bind_locals(locals)
  unless template = @templates[locals]
    @write_lock.synchronize do
      normalized_locals = normalize_locals(locals)

      # We need ||=, both to dedup on the normalized locals and to check
      # while holding the lock.
      template = (@templates[normalized_locals] ||= build_template(normalized_locals))

      if template.strict_locals?
        # Under strict locals, we only need one template.
        # This replaces the @templates Concurrent::Map with a hash which
        # returns this template for every key.
        @templates = Hash.new(template).freeze
      else
        # This may have already been assigned, but we've already de-dup'd so
        # reassignment is fine.
        @templates[locals.dup] = template
      end
    end
  end
  template
end