Class: Sass::Tree::Node

Inherits:
Object
  • Object
show all
Includes:
Enumerable
Defined in:
lib/sass/tree/node.rb

Overview

The abstract superclass of all parse-tree nodes.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeNode

Returns a new instance of Node.



91
92
93
# File 'lib/sass/tree/node.rb', line 91

def initialize
  @children = []
end

Instance Attribute Details

#childrenArray<Tree::Node>

The child nodes of this node.

Returns:



61
62
63
# File 'lib/sass/tree/node.rb', line 61

def children
  @children
end

#filenameString

The name of the document on which this node appeared.

Returns:

  • (String)


112
113
114
# File 'lib/sass/tree/node.rb', line 112

def filename
  @filename || (@options && @options[:filename])
end

#has_childrenBoolean

Whether or not this node has child nodes. This may be true even when #children is empty, in which case this node has an empty block (e.g. {}).

Returns:

  • (Boolean)


68
69
70
# File 'lib/sass/tree/node.rb', line 68

def has_children
  @has_children
end

#lineFixnum

The line of the document on which this node appeared.

Returns:

  • (Fixnum)


73
74
75
# File 'lib/sass/tree/node.rb', line 73

def line
  @line
end

#options{Symbol => Object}

The options hash for the node. See the Sass options documentation.

Returns:

  • ({Symbol => Object})


89
90
91
# File 'lib/sass/tree/node.rb', line 89

def options
  @options
end

#source_rangeSass::Source::Range

The source range in the document on which this node appeared.

Returns:



78
79
80
# File 'lib/sass/tree/node.rb', line 78

def source_range
  @source_range
end

Instance Method Details

#<<(child)

Appends a child to the node.

Parameters:

Raises:



120
121
122
123
124
125
126
127
128
# File 'lib/sass/tree/node.rb', line 120

def <<(child)
  return if child.nil?
  if child.is_a?(Array)
    child.each {|c| self << c}
  else
    self.has_children = true
    @children << child
  end
end

#==(other) ⇒ Boolean

Compares this node and another object (only other Sass::Tree::Nodes will be equal). This does a structural comparison; if the contents of the nodes and all the child nodes are equivalent, then the nodes are as well.

Only static nodes need to override this.

Parameters:

  • other (Object)

    The object to compare with

Returns:

  • (Boolean)

    Whether or not this node and the other object are the same

See Also:



141
142
143
# File 'lib/sass/tree/node.rb', line 141

def ==(other)
  self.class == other.class && other.children == children
end

#balance(*args) (protected)

Raises:

See Also:

  • Shared.balance


231
232
233
234
235
# File 'lib/sass/tree/node.rb', line 231

def balance(*args)
  res = Sass::Shared.balance(*args)
  return res if res
  raise Sass::SyntaxError.new("Unbalanced brackets.", :line => line)
end

#bubbles?Boolean

Whether or not this node bubbles up through RuleNodes.

Returns:

  • (Boolean)


223
224
225
# File 'lib/sass/tree/node.rb', line 223

def bubbles?
  false
end

#cssString

Computes the CSS corresponding to this static CSS tree.

Returns:

  • (String)

    The resulting CSS

See Also:



163
164
165
# File 'lib/sass/tree/node.rb', line 163

def css
  Sass::Tree::Visitors::ToCss.new.visit(self)
end

#css_with_sourcemap(String, Sass::Source::Map)

Computes the CSS corresponding to this static CSS tree, along with the respective source map.

Returns:

See Also:



172
173
174
175
176
# File 'lib/sass/tree/node.rb', line 172

def css_with_sourcemap
  visitor = Sass::Tree::Visitors::ToCss.new(:build_source_mapping)
  result = visitor.visit(self)
  return result, visitor.source_mapping
end

#deep_copyNode

Return a deep clone of this node. The child nodes are cloned, but options are not.

Returns:



216
217
218
# File 'lib/sass/tree/node.rb', line 216

def deep_copy
  Sass::Tree::Visitors::DeepCopy.visit(self)
end

#each {|node| ... }

Iterates through each node in the tree rooted at this node in a pre-order walk.

Yields:

  • node

Yield Parameters:

  • node (Node)

    a node in the tree



191
192
193
194
# File 'lib/sass/tree/node.rb', line 191

def each
  yield self
  children.each {|c| c.each {|n| yield n}}
end

#inspectString

Returns a representation of the node for debugging purposes.

Returns:

  • (String)


181
182
183
184
# File 'lib/sass/tree/node.rb', line 181

def inspect
  return self.class.to_s unless has_children
  "(#{self.class} #{children.map {|c| c.inspect}.join(' ')})"
end

#invisible?Boolean

True if #to_s will return nil; that is, if the node shouldn't be rendered. Should only be called in a static tree.

Returns:

  • (Boolean)


150
# File 'lib/sass/tree/node.rb', line 150

def invisible?; false; end

#styleSymbol

The output style. See the Sass options documentation.

Returns:

  • (Symbol)


155
156
157
# File 'lib/sass/tree/node.rb', line 155

def style
  @options[:style]
end

#to_sass(options = {}) ⇒ String

Converts a node to Sass code that will generate it.

Parameters:

  • options ({Symbol => Object}) (defaults to: {})

    An options hash (see CSS#initialize)

Returns:

  • (String)

    The Sass code corresponding to the node



200
201
202
# File 'lib/sass/tree/node.rb', line 200

def to_sass(options = {})
  Sass::Tree::Visitors::Convert.visit(self, options, :sass)
end

#to_scss(options = {}) ⇒ String

Converts a node to SCSS code that will generate it.

Parameters:

  • options ({Symbol => Object}) (defaults to: {})

    An options hash (see CSS#initialize)

Returns:

  • (String)

    The Sass code corresponding to the node



208
209
210
# File 'lib/sass/tree/node.rb', line 208

def to_scss(options = {})
  Sass::Tree::Visitors::Convert.visit(self, options, :scss)
end