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/directive_node.rb
2007-09-07 09:00:58 +00:00

51 lines
1.5 KiB
Ruby

require 'sass/tree/node'
require 'sass/tree/value_node'
module Sass::Tree
class DirectiveNode < ValueNode
def to_s(tabs)
if children.empty?
value + ";"
else
result = if @style == :compressed
"#{value}{"
else
"#{' ' * (tabs - 1)}#{value} {" + (@style == :compact ? ' ' : "\n")
end
was_attr = false
first = true
children.each do |child|
if child.is_a?(RuleNode) && child.continued?
check_multiline_rule(child)
continued_rule = true
end
if @style == :compact
if child.is_a?(AttrNode)
result << "#{child.to_s(first || was_attr ? 1 : tabs + 1)} "
else
if was_attr
result[-1] = "\n"
end
rendered = child.to_s(tabs + 1)
rendered.lstrip! if first
result << rendered
end
was_attr = child.is_a?(AttrNode)
first = continued_rule
elsif @style == :compressed
result << (was_attr ? ";#{child.to_s(1)}" : child.to_s(1))
was_attr = child.is_a?(AttrNode)
else
result << child.to_s(tabs + 1) + (continued_rule ? '' : "\n")
end
end
result.rstrip + if @style == :compressed
"}"
else
(@style == :expanded ? "\n" : " ") + "}\n"
end
end
end
end
end