Class: ClassHDL::BlocAssertIF

Inherits:
BlockIF
  • Object
show all
Defined in:
lib/tdl/class_hdl/hdl_initial.rb

Instance Attribute Summary

Attributes inherited from BlockIF

#cond, #opertor_chains, #slaver

Instance Method Summary collapse

Methods inherited from BlockIF

#initialize

Constructor Details

This class inherits a constructor from ClassHDL::BlockIF

Instance Method Details

#instance(as_type = :cond) ⇒ Object



41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
# File 'lib/tdl/class_hdl/hdl_initial.rb', line 41

def instance(as_type= :cond)
    if cond.is_a? ClassHDL::OpertorChain
        head_str = "assert(#{cond.instance(:cond)})else begin"
    else 
        head_str = "assert(#{cond.to_s})else begin"
    end

    sub_str = []
    opertor_chains.each do |oc|
        unless oc.is_a? BlockIF
            unless oc.slaver
                sub_str.push "    #{oc.instance(as_type)};"
            end
        else 
            sub_str.push( oc.instance(as_type).gsub(/^./){ |m| "    #{m}"} )
        end
    end

    return "#{head_str}\n#{sub_str.join("\n")}\nend"

end