Context as accessor

This commit is contained in:
Thierry Joyal
2020-01-16 14:40:51 -05:00
parent c0ffee4133
commit 13936a24f1
2 changed files with 14 additions and 18 deletions

View File

@@ -32,12 +32,6 @@ module Liquid
end
end
def initialize(context)
@context = context
end
private
attr_reader :context
attr_accessor :context
end
end

View File

@@ -23,25 +23,30 @@ module Liquid
raise(ArgumentError, "wrong argument type Proc (expected Liquid::Filter)")
end
instance = filter.new
filter.invokable_methods.each do |method|
filter_map[method] = filter
filter_instances[method] = instance
end
end
def fetch_filter(method)
filter_map.fetch(method)
def invokable?(method)
filter_instances.key?(method)
end
def invokable?(method)
filter_map.key?(method)
def invoke(method, context, *args)
instance = filter_instances.fetch(method)
instance.context = context
instance.public_send(method, *args)
end
private
def filter_map
@filter_map ||= {}
def filter_instances
@filter_instances ||= {}
end
# Caching here is most likely not required anymore since we cache instances and there is only one instance per filter class.
def convert_mod_to_filter(mod)
@filter_classes ||= {}
@filter_classes[mod] ||= begin
@@ -58,10 +63,7 @@ module Liquid
def invoke(method, *args)
if self.class.invokable?(method)
klass = self.class.fetch_filter(method)
instance = klass.new(@context)
instance.public_send(method, *args)
self.class.invoke(method, @context, *args)
elsif @context.strict_filters
raise(Liquid::UndefinedFilter, "undefined filter #{method}")
else