rubyx/lib/vool/statements/if_statement.rb

75 lines
1.9 KiB
Ruby
Raw Normal View History

require_relative "normalizer"
2017-04-01 20:28:57 +02:00
module Vool
class IfStatement < Statement
include Normalizer
attr_reader :condition , :if_true , :if_false
2017-04-02 18:12:42 +02:00
2017-08-30 16:21:13 +02:00
def initialize( cond , if_true , if_false = nil)
2017-04-02 18:12:42 +02:00
@condition = cond
@if_true = if_true
@if_false = if_false
simplify_condition
end
def normalize
cond , rest = *normalize_name(@condition)
fals = @if_false ? @if_false.normalize : nil
me = IfStatement.new(cond , @if_true.normalize, fals)
return me unless rest
rest << me
end
2017-08-30 16:21:13 +02:00
def to_mom( method )
if_true = @if_true.to_mom( method )
if_false = @if_false ? @if_false.to_mom( method ) : nil
condition , hoisted = hoist_condition( method )
2017-09-04 20:31:49 +02:00
cond = Mom::TruthCheck.new(condition.to_mom(method))
check = Mom::IfStatement.new( cond , if_true , if_false )
check.hoisted = hoisted.to_mom(method) if hoisted
check
2017-08-30 16:21:13 +02:00
end
def flatten(options = {})
true_label = Label.new( "true_label_#{object_id}")
false_label = Label.new( "false_label_#{object_id}")
merge_label = Label.new( "merge_label_#{object_id}")
first = condition.flatten( true_label: true_label , false_label: false_label)
if hoisted
head = hoisted.flatten
head.append first
else
head = first
end
head.append true_label
head.append if_true.flatten( merge_label: merge_label)
if( if_false)
head.append false_label
head.append if_false.flatten( merge_label: merge_label)
end
head.append merge_label
head
end
2017-08-30 16:21:13 +02:00
def each(&block)
block.call(condition)
@if_true.each(&block)
@if_false.each(&block) if @if_false
2017-04-08 11:10:42 +02:00
end
def simplify_condition
return unless @condition.is_a?(ScopeStatement)
@condition = @condition.first if @condition.single?
2017-04-02 18:12:42 +02:00
end
def has_false?
@if_false != nil
end
def has_true?
@if_true != nil
end
2017-08-30 17:23:54 +02:00
2017-04-01 20:28:57 +02:00
end
end