Class: Sass::Tree::RootNode

Inherits:
Node
  • Object
show all
Defined in:
lib/sass/tree/root_node.rb

Overview

A static node that is the root node of the Sass document.

Direct Known Subclasses

ImportNode

Constant Summary

Constants inherited from Node

Node::SAVED_OPTIONS

Instance Attribute Summary collapse

Attributes inherited from Node

#children, #filename, #has_children, #line, #options

Instance Method Summary collapse

Methods inherited from Node

#<<, #==, #_around_dump, #_cssize, #_perform, #balance, #check_child!, #children_to_src, #cssize!, #dasherize, #do_extend, #each, #invisible?, #perform_children, #run_interp, #selector_to_sass, #selector_to_scss, #selector_to_src, #semi, #style

Constructor Details

#initialize(template) ⇒ RootNode

Returns a new instance of RootNode.

Parameters:

  • template (String)

    The Sass template from which this node was created



11
12
13
14
# File 'lib/sass/tree/root_node.rb', line 11

def initialize(template)
  super()
  @template = template
end

Instance Attribute Details

#template (readonly)

The Sass template from which this node was created

Parameters:

  • template (String)


8
9
10
# File 'lib/sass/tree/root_node.rb', line 8

def template
  @template
end

Instance Method Details

#_to_s(*args) ⇒ String (protected)

Computes the CSS corresponding to this Sass tree.

Parameters:

  • args (Array)

    ignored

Returns:

  • (String)

    The resulting CSS

See Also:



100
101
102
103
104
105
106
107
108
109
110
# File 'lib/sass/tree/root_node.rb', line 100

def _to_s(*args)
  result = String.new
  children.each do |child|
    next if child.invisible?
    child_str = child.to_s(1)
    result << child_str + (style == :compressed ? '' : "\n")
  end
  result.rstrip!
  return "" if result.empty?
  return result + "\n"
end

#cssize(extends = Haml::Util::SubsetMap.new, parent = nil) ⇒ (Tree::Node, Haml::Util::SubsetMap)

Like Node#cssize, except that this method will create its own extends map if necessary, and it returns that map along with the cssized tree.

Returns:



49
50
51
52
53
54
# File 'lib/sass/tree/root_node.rb', line 49

def cssize(extends = Haml::Util::SubsetMap.new, parent = nil)
  return super(extends), extends
rescue Sass::SyntaxError => e
  e.sass_template = @template
  raise e
end

#invalid_child?(child) ⇒ Boolean (protected)

Returns an error message if the given child node is invalid, and false otherwise.

Only property nodes are invalid at root level.

Returns:

  • (Boolean)

See Also:



118
119
120
121
122
# File 'lib/sass/tree/root_node.rb', line 118

def invalid_child?(child)
  return unless child.is_a?(Tree::PropNode)
  "Properties aren't allowed at the root of a document." +
    child.pseudo_class_selector_message
end

#perform(environment)

See Also:



35
36
37
38
39
40
41
# File 'lib/sass/tree/root_node.rb', line 35

def perform(environment)
  environment.options = @options if environment.options.nil? || environment.options.empty?
  super
rescue Sass::SyntaxError => e
  e.sass_template = @template
  raise e
end

#perform!(environment)

See Also:

  • Sass::Tree::RootNode.\{Node\{Node#perform!}


57
58
59
60
# File 'lib/sass/tree/root_node.rb', line 57

def perform!(environment)
  environment.options = @options if environment.options.nil? || environment.options.empty?
  super
end

#render

Runs the dynamic Sass code and computes the CSS for the tree.

See Also:



28
29
30
31
32
# File 'lib/sass/tree/root_node.rb', line 28

def render
  result, extends = perform(Environment.new).cssize
  result = result.do_extend(extends) unless extends.empty?
  result.to_s
end

#to_s(*args)

See Also:



17
18
19
20
21
22
# File 'lib/sass/tree/root_node.rb', line 17

def to_s(*args)
  super
rescue Sass::SyntaxError => e
  e.sass_template = @template
  raise e
end

#to_sass(opts = {}) ⇒ String

Converts a node to Sass code that will generate it.

Parameters:

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

    An options hash (see CSS#initialize)

Returns:

  • (String)

    The Sass code corresponding to the node



66
67
68
# File 'lib/sass/tree/root_node.rb', line 66

def to_sass(opts = {})
  to_src(opts, :sass)
end

#to_scss(opts = {}) ⇒ String

Converts a node to SCSS code that will generate it.

Parameters:

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

    An options hash (see CSS#initialize)

Returns:

  • (String)

    The SCSS code corresponding to the node



74
75
76
# File 'lib/sass/tree/root_node.rb', line 74

def to_scss(opts = {})
  to_src(opts, :scss)
end

#to_src(opts, fmt) (protected)

See Also:



81
82
83
84
85
86
87
88
89
90
91
92
93
# File 'lib/sass/tree/root_node.rb', line 81

def to_src(opts, fmt)
  Haml::Util.enum_cons(children + [nil], 2).map do |child, nxt|
    child.send("to_#{fmt}", 0, opts) +
      if nxt &&
          (child.is_a?(CommentNode) && child.line + child.value.count("\n") + 1 == nxt.line) ||
          (child.is_a?(ImportNode) && nxt.is_a?(ImportNode) && child.line + 1 == nxt.line) ||
          (child.is_a?(VariableNode) && nxt.is_a?(VariableNode) && child.line + 1 == nxt.line)
        ""
      else
        "\n"
      end
  end.join.rstrip + "\n"
end