Class: Array
Overview
Extends the Array class for conversion to a high-level expression.
Direct Known Subclasses
Instance Method Summary collapse
-
#call(obj = nil, &ruby_block) ⇒ Object
Create an array whose number of elements is given by the content of the current array, filled by +obj+ objects.
-
#constant(hsh) ⇒ Object
Declares high-level inner constants named from +hsh+ with names and corresponding values.
-
#hcase(value, &ruby_block) ⇒ Object
Creates a hcase statement executing +ruby_block+ on the element of the array selected by +value+.
-
#inner(*names) ⇒ Object
Declares high-level inner signals named +names+ of the current type.
-
#inout(*names) ⇒ Object
Declares high-level untyped inout signals named +names+ of the current type.
-
#input(*names) ⇒ Object
Declares high-level input signals named +names+ of the current type.
-
#make(name, *args) ⇒ Object
Create an array of instances of system +name+, using +args+ as arguments.
-
#output(*names) ⇒ Object
Declares high-level untyped output signals named +names+ of the current type.
-
#to_expr ⇒ Object
Converts to a new high-level expression.
-
#to_ref ⇒ Object
Converts to a new high-level reference.
-
#to_type ⇒ Object
Converts to a new type.
-
#typedef(name) ⇒ Object
Declares a new type definition with +name+ equivalent to current one.
Instance Method Details
#call(obj = nil, &ruby_block) ⇒ Object
Create an array whose number of elements is given by the content of the current array, filled by +obj+ objects. If +obj+ is nil, +ruby_block+ is used instead for filling the array.
4110 4111 4112 4113 4114 4115 4116 4117 4118 4119 4120 |
# File 'lib/HDLRuby/hruby_high.rb', line 4110 def call(obj = nil, &ruby_block) unless self.size == 1 then raise AnyError, "Invalid array for call opertor." end number = self[0].to_i if obj then return Array.new(number,obj) else return Array.new(number,&ruby_block) end end |
#constant(hsh) ⇒ Object
Declares high-level inner constants named from +hsh+ with names and corresponding values.
4092 4093 4094 |
# File 'lib/HDLRuby/hruby_high.rb', line 4092 def constant(hsh) High.top_user.make_constants(self.to_type,hsh) end |
#hcase(value, &ruby_block) ⇒ Object
Creates a hcase statement executing +ruby_block+ on the element of the array selected by +value+
4098 4099 4100 4101 4102 4103 |
# File 'lib/HDLRuby/hruby_high.rb', line 4098 def hcase(value,&ruby_block) High.cur_block.hcase(value) self.each.with_index do |elem,i| High.cur_block.hwhen(i) { ruby_block.call(elem) } end end |
#inner(*names) ⇒ Object
Declares high-level inner signals named +names+ of the current type.
4086 4087 4088 |
# File 'lib/HDLRuby/hruby_high.rb', line 4086 def inner(*names) High.top_user.make_inners(self.to_type,*names) end |
#inout(*names) ⇒ Object
Declares high-level untyped inout signals named +names+ of the current type.
4080 4081 4082 |
# File 'lib/HDLRuby/hruby_high.rb', line 4080 def inout(*names) High.top_user.make_inouts(self.to_type,*names) end |
#input(*names) ⇒ Object
Declares high-level input signals named +names+ of the current type.
4068 4069 4070 |
# File 'lib/HDLRuby/hruby_high.rb', line 4068 def input(*names) High.top_user.make_inputs(self.to_type,*names) end |
#make(name, *args) ⇒ Object
Create an array of instances of system +name+, using +args+ as arguments.
NOTE: the array must have a single element that is an integer.
4126 4127 4128 4129 4130 4131 4132 4133 4134 4135 4136 4137 4138 4139 4140 4141 4142 4143 4144 4145 4146 4147 |
# File 'lib/HDLRuby/hruby_high.rb', line 4126 def make(name,*args) # Check the array and get the number of elements. size = self[0] unless self.size == 1 and size.is_a?(::Integer) raise AnyError, "Invalid array for declaring a list of instances." end # Get the system to instantiate. systemT = High.space_call(name) # Get the name of the instance from the arguments. nameI = args.shift.to_s # Create the instances. instances = size.times.map do |i| systemT.instantiate((nameI + "[#{i}]").to_sym,*args) end nameI = nameI.to_sym # Add them to the top system High.space_top.user.add_groupI(nameI,*instances) # Register and return the result. High.space_reg(nameI) { High.space_top.user.get_groupI(nameI) } return High.space_top.user.get_groupI(nameI) end |
#output(*names) ⇒ Object
Declares high-level untyped output signals named +names+ of the current type.
4074 4075 4076 |
# File 'lib/HDLRuby/hruby_high.rb', line 4074 def output(*names) High.top_user.make_outputs(self.to_type,*names) end |
#to_expr ⇒ Object
Converts to a new high-level expression.
4029 4030 4031 4032 4033 4034 4035 4036 |
# File 'lib/HDLRuby/hruby_high.rb', line 4029 def to_expr # expr = Concat.new expr = Concat.new(TypeTuple.new(:"",:little,*self.map do |elem| elem.to_expr.type end)) self.each {|elem| expr.add_expression(elem.to_expr) } expr end |
#to_ref ⇒ Object
Converts to a new high-level reference.
4039 4040 4041 4042 4043 4044 4045 4046 |
# File 'lib/HDLRuby/hruby_high.rb', line 4039 def to_ref # expr = RefConcat.new expr = RefConcat.new(TypeTuple.new(:"",:little,*self.map do |elem| elem.to_ref.type end)) self.each {|elem| expr.add_ref(elem.to_ref) } expr end |
#to_type ⇒ Object
Converts to a new type.
4049 4050 4051 4052 4053 4054 4055 4056 4057 4058 |
# File 'lib/HDLRuby/hruby_high.rb', line 4049 def to_type if self.size == 1 and ( self[0].is_a?(Range) or self[0].respond_to?(:to_i) ) then # Vector type case return bit[*self] else # Tuple type case. return TypeTuple.new(:"",:little,*self) end end |
#typedef(name) ⇒ Object
Declares a new type definition with +name+ equivalent to current one.
4061 4062 4063 |
# File 'lib/HDLRuby/hruby_high.rb', line 4061 def typedef(name) return self.to_type.typedef(name) end |