The abstract superclass for SassScript parse tree nodes.
Use {#perform} to evaluate a parse tree.
The line of the document on which this node appeared.
@return [Fixnum]
The options hash for this node.
@return [{Symbol => Object}]
Returns all child nodes of this node.
@return [Array<Node>]
# File lib/sass/script/node.rb, line 49 def children Sass::Util.abstract(self) end
Returns a deep clone of this node. The child nodes are cloned, but options are not.
@return [Node]
# File lib/sass/script/node.rb, line 64 def deep_copy Sass::Util.abstract(self) end
Sets the options hash for this node, as well as for all child nodes. See {file:SASS_REFERENCE.md#sass_options the Sass options documentation}.
@param options [{Symbol => Object}] The options
# File lib/sass/script/node.rb, line 21 def options=(options) @options = options children.each do |c| if c.is_a? Hash c.values.each {|v| v.options = options } else c.options = options end end end
Evaluates the node.
{#perform} shouldn't be overridden directly; instead, override {#_perform}.
@param environment [Sass::Environment] The environment in which to evaluate the SassScript @return [Literal] The SassScript object that is the value of the SassScript
# File lib/sass/script/node.rb, line 39 def perform(environment) _perform(environment) rescue Sass::SyntaxError => e e.modify_backtrace(:line => line) raise e end
Returns the text of this SassScript expression.
@return [String]
# File lib/sass/script/node.rb, line 56 def to_sass(opts = {}) Sass::Util.abstract(self) end
Evaluates this node. Note that all {Literal} objects created within this method should have their {#options} attribute set, probably via {#opts}.
@param environment [Sass::Environment] The environment in which to evaluate the SassScript @return [Literal] The SassScript object that is the value of the SassScript @see perform
# File lib/sass/script/node.rb, line 86 def _perform(environment) Sass::Util.abstract(self) end
Converts underscores to dashes if the :dasherize option is set.
# File lib/sass/script/node.rb, line 71 def dasherize(s, opts) if opts[:dasherize] s.gsub(%r_/,'-') else s end end
Sets the {#options} field on the given literal and returns it
@param literal [Literal] @return [Literal]
# File lib/sass/script/node.rb, line 94 def opts(literal) literal.options = options literal end