Skip to content

Commit

Permalink
don't cache string expressions to be more perfomant
Browse files Browse the repository at this point in the history
  • Loading branch information
ggmichaelgo committed Nov 14, 2024
1 parent e0d54cc commit 7419a44
Showing 1 changed file with 7 additions and 5 deletions.
12 changes: 7 additions & 5 deletions lib/liquid/expression.rb
Original file line number Diff line number Diff line change
Expand Up @@ -81,16 +81,18 @@ def parse(markup)

markup = markup.strip # markup can be a frozen string

if (markup.start_with?('"') && markup.end_with?('"')) ||
(markup.start_with?("'") && markup.end_with?("'"))
return markup[1..-2]
end

return CACHE[markup] if CACHE.key?(markup)

CACHE[markup] = inner_parse(markup)
end

def inner_parse(markup)
if (markup.start_with?('"') && markup.end_with?('"')) ||
(markup.start_with?("'") && markup.end_with?("'"))
return markup[1..-2]
elsif (markup.start_with?("(") && markup.end_with?(")")) && markup =~ RANGES_REGEX
if (markup.start_with?("(") && markup.end_with?(")")) && markup =~ RANGES_REGEX
return RangeLookup.parse(Regexp.last_match(1), Regexp.last_match(2))
end

Expand Down Expand Up @@ -149,5 +151,5 @@ def parse_number(markup)
end
end

Expression = StringScanner.instance_methods.include?(:scan_byte) ? Expression2 : Expression1
Expression = StringScanner.instance_methods.include?(:scan_byte) ? Expression2 : Expression11
end

0 comments on commit 7419a44

Please sign in to comment.