mirror of
https://github.com/kemko/liquid.git
synced 2026-01-01 15:55:40 +03:00
Merge pull request #1380 from Shopify/pz-serialize-compat
Fixes for serialization
This commit is contained in:
@@ -21,7 +21,7 @@ module Liquid
|
|||||||
def parse(tokens)
|
def parse(tokens)
|
||||||
body = case_body = new_body
|
body = case_body = new_body
|
||||||
body = @blocks.last.attachment while parse_body(body, tokens)
|
body = @blocks.last.attachment while parse_body(body, tokens)
|
||||||
@blocks.each do |condition|
|
@blocks.reverse_each do |condition|
|
||||||
body = condition.attachment
|
body = condition.attachment
|
||||||
unless body.frozen?
|
unless body.frozen?
|
||||||
body.remove_blank_strings if blank?
|
body.remove_blank_strings if blank?
|
||||||
|
|||||||
@@ -63,11 +63,11 @@ module Liquid
|
|||||||
parse_body(@else_block, tokens)
|
parse_body(@else_block, tokens)
|
||||||
end
|
end
|
||||||
if blank?
|
if blank?
|
||||||
@for_block.remove_blank_strings
|
|
||||||
@else_block&.remove_blank_strings
|
@else_block&.remove_blank_strings
|
||||||
|
@for_block.remove_blank_strings
|
||||||
end
|
end
|
||||||
@for_block.freeze
|
|
||||||
@else_block&.freeze
|
@else_block&.freeze
|
||||||
|
@for_block.freeze
|
||||||
end
|
end
|
||||||
|
|
||||||
def nodelist
|
def nodelist
|
||||||
|
|||||||
@@ -31,7 +31,7 @@ module Liquid
|
|||||||
def parse(tokens)
|
def parse(tokens)
|
||||||
while parse_body(@blocks.last.attachment, tokens)
|
while parse_body(@blocks.last.attachment, tokens)
|
||||||
end
|
end
|
||||||
@blocks.each do |block|
|
@blocks.reverse_each do |block|
|
||||||
block.attachment.remove_blank_strings if blank?
|
block.attachment.remove_blank_strings if blank?
|
||||||
block.attachment.freeze
|
block.attachment.freeze
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -106,16 +106,8 @@ module Liquid
|
|||||||
# Parse source code.
|
# Parse source code.
|
||||||
# Returns self for easy chaining
|
# Returns self for easy chaining
|
||||||
def parse(source, options = {})
|
def parse(source, options = {})
|
||||||
if (profiling = options[:profile])
|
parse_context = configure_options(options)
|
||||||
raise "Profiler not loaded, require 'liquid/profiler' first" unless defined?(Liquid::Profiler)
|
|
||||||
end
|
|
||||||
|
|
||||||
@options = options
|
|
||||||
@profiling = profiling
|
|
||||||
@line_numbers = options[:line_numbers] || profiling
|
|
||||||
parse_context = options.is_a?(ParseContext) ? options : ParseContext.new(options)
|
|
||||||
@root = Document.parse(tokenize(source), parse_context)
|
@root = Document.parse(tokenize(source), parse_context)
|
||||||
@warnings = parse_context.warnings
|
|
||||||
self
|
self
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -218,6 +210,19 @@ module Liquid
|
|||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
|
def configure_options(options)
|
||||||
|
if (profiling = options[:profile])
|
||||||
|
raise "Profiler not loaded, require 'liquid/profiler' first" unless defined?(Liquid::Profiler)
|
||||||
|
end
|
||||||
|
|
||||||
|
@options = options
|
||||||
|
@profiling = profiling
|
||||||
|
@line_numbers = options[:line_numbers] || @profiling
|
||||||
|
parse_context = options.is_a?(ParseContext) ? options : ParseContext.new(options)
|
||||||
|
@warnings = parse_context.warnings
|
||||||
|
parse_context
|
||||||
|
end
|
||||||
|
|
||||||
def tokenize(source)
|
def tokenize(source)
|
||||||
Tokenizer.new(source, @line_numbers)
|
Tokenizer.new(source, @line_numbers)
|
||||||
end
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user