1
0
Fork 0
mirror of https://github.com/haml/haml.git synced 2022-11-09 12:33:31 -05:00
haml--haml/lib/sass/tree/root_node.rb
Nathan Weizenbaum 8ad55a6e26 Merge branch 'master' into extend
Conflicts:
	lib/sass/scss/css_parser.rb
	lib/sass/tree/mixin_node.rb
2010-04-20 03:26:31 -07:00

109 lines
3.1 KiB
Ruby

module Sass
module Tree
# A static node that is the root node of the Sass document.
class RootNode < Node
# The Sass template from which this node was created
#
# @param template [String]
attr_reader :template
# @param template [String] The Sass template from which this node was created
def initialize(template)
super()
@template = template
end
# @see Node#to_s
def to_s(*args)
super
rescue Sass::SyntaxError => e
e.sass_template = @template
raise e
end
# @see Node#perform
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
# @see Node#cssize
def cssize(*args)
super
rescue Sass::SyntaxError => e
e.sass_template = @template
raise e
end
# @see \{Node#perform!}
def perform!(environment)
environment.options = @options if environment.options.nil? || environment.options.empty?
super
end
# Converts a node to Sass code that will generate it.
#
# @param opts [{Symbol => Object}] An options hash (see {Sass::CSS#initialize})
# @return [String] The Sass code corresponding to the node
def to_sass(opts = {})
to_src(opts, :sass)
end
# Converts a node to SCSS code that will generate it.
#
# @param opts [{Symbol => Object}] An options hash (see {Sass::CSS#initialize})
# @return [String] The SCSS code corresponding to the node
def to_scss(opts = {})
to_src(opts, :scss)
end
protected
# @see Node#to_src
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)
""
else
"\n"
end
end.join.rstrip + "\n"
end
# Computes the CSS corresponding to this Sass tree.
#
# @param args [Array] ignored
# @return [String] The resulting CSS
# @see Sass::Tree
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
# Returns an error message if the given child node is invalid,
# and false otherwise.
#
# Only property nodes are invalid at root level.
#
# @see Node#invalid_child?
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
end
end
end