mirror of
https://github.com/haml/haml.git
synced 2022-11-09 12:33:31 -05:00

Conflicts: lib/sass.rb lib/sass/error.rb lib/sass/tree/comment_node.rb lib/sass/tree/debug_node.rb lib/sass/tree/directive_node.rb lib/sass/tree/file_node.rb lib/sass/tree/for_node.rb lib/sass/tree/if_node.rb lib/sass/tree/mixin_def_node.rb lib/sass/tree/mixin_node.rb lib/sass/tree/node.rb lib/sass/tree/while_node.rb
54 lines
1.5 KiB
Ruby
54 lines
1.5 KiB
Ruby
require 'sass/tree/node'
|
|
|
|
module Sass::Tree
|
|
# A dynamic node representing a Sass `@if` statement.
|
|
#
|
|
# {IfNode}s are a little odd, in that they also represent `@else` and `@else if`s.
|
|
# This is done as a linked list:
|
|
# each {IfNode} has a link (\{#else}) to the next {IfNode}.
|
|
#
|
|
# @see Sass::Tree
|
|
class IfNode < Node
|
|
# The next {IfNode} in the if-else list, or `nil`.
|
|
#
|
|
# @return [IfNode]
|
|
attr_accessor :else
|
|
|
|
# @param expr [Script::Expr] The conditional expression.
|
|
# If this is nil, this is an `@else` node, not an `@else if`
|
|
def initialize(expr)
|
|
@expr = expr
|
|
@last_else = self
|
|
super()
|
|
end
|
|
|
|
# Append an `@else` node to the end of the list.
|
|
#
|
|
# @param node [IfNode] The `@else` node to append
|
|
def add_else(node)
|
|
@last_else.else = node
|
|
@last_else = node
|
|
end
|
|
|
|
def options=(options)
|
|
super
|
|
self.else.options = options if self.else
|
|
end
|
|
|
|
protected
|
|
|
|
# Runs the child nodes if the conditional expression is true;
|
|
# otherwise, tries the \{#else} nodes.
|
|
#
|
|
# @param environment [Sass::Environment] The lexical environment containing
|
|
# variable and mixin values
|
|
# @return [Array<Tree::Node>] The resulting static nodes
|
|
# @see Sass::Tree
|
|
def _perform(environment)
|
|
environment = Sass::Environment.new(environment)
|
|
return perform_children(environment) if @expr.nil? || @expr.perform(environment).to_bool
|
|
return @else.perform(environment) if @else
|
|
[]
|
|
end
|
|
end
|
|
end
|