A parse tree node representing a list literal. When resolved, this returns a {Sass::Tree::Value::List}.
Creates a new list literal.
@param elements [Array<Node>] See {#elements} @param separator [Symbol] See {#separator}
# File lib/sass/script/tree/list_literal.rb, line 20 def initialize(elements, separator) @elements = elements @separator = separator end
@see Node#children
# File lib/sass/script/tree/list_literal.rb, line 26 def children; elements; end
@see Node#deep_copy
# File lib/sass/script/tree/list_literal.rb, line 48 def deep_copy node = dup node.instance_variable_set('@elements', elements.map {|e| e.deep_copy}) node end
# File lib/sass/script/tree/list_literal.rb, line 54 def inspect "(#{elements.map {|e| e.inspect}.join(separator == :space ? ' ' : ', ')})" end
@see Value#to_sass
# File lib/sass/script/tree/list_literal.rb, line 29 def to_sass(opts = {}) return "()" if elements.empty? precedence = Sass::Script::Parser.precedence_of(separator) members = elements.map do |v| if v.is_a?(ListLiteral) && Sass::Script::Parser.precedence_of(v.separator) <= precedence || separator == :space && v.is_a?(UnaryOperation) && (v.operator == :minus || v.operator == :plus) "(#{v.to_sass(opts)})" else v.to_sass(opts) end end return "(#{members.first},)" if separator == :comma && members.length == 1 members.join(sep_str(nil)) end
Generated with the Darkfish Rdoc Generator 2.