class Liquid::Variable
Public Instance Methods
render(context)
click to toggle source
Possibly render the variable with HTML escaping applied
If the auto-escaping context variable has been set by the {% autoescape %} tag or Liquid
auto-escaping is globally enabled, this will run the variable through the global exemption list to determine if it is exempt from auto-escaping. If it is not, its contents will be rendered as a string with all unsafe HTML characters escaped. In all other cases, the original, unescaped value of the variable will be rendered.
@param [Liquid::Context] context The variable's rendering context @return [String] The potentially escaped contents of the variable
# File lib/liquid/autoescape/liquid_ext/variable.rb, line 22 def render(context) is_global = Autoescape.configuration.global? is_local = context[Autoescape::ENABLED_FLAG] if !is_global && !is_local return non_escaping_render(context) end if is_global && is_local == false is_exempt = true else variable = Autoescape::TemplateVariable.from_liquid_variable(self) is_exempt = Autoescape.configuration.exemptions.apply?(variable) end @filters << [:escape, []] unless is_exempt output = non_escaping_render(context) @filters.pop unless is_exempt output end
Also aliased as: non_escaping_render