Class: Hash
- Inherits:
-
Object
- Object
- Hash
- Defined in:
- lib/HDLRuby/hruby_high.rb,
lib/HDLRuby/std/sequencer_sync.rb
Overview
Extends the Hash class for declaring signals of structure types.
Direct Known Subclasses
Instance Method Summary collapse
-
#constant(hsh) ⇒ Object
Declares high-level untyped constant signals by name and value given by +hsh+ of the current type.
-
#inner(*names) ⇒ Object
Declares high-level untyped 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.
-
#output(*names) ⇒ Object
Declares high-level untyped output signals named +names+ of the current type.
-
#shared(*names) ⇒ Object
Create new shared signals from +args+.
-
#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
#constant(hsh) ⇒ Object
Declares high-level untyped constant signals by name and value given by +hsh+ of the current type.
Retuns the last declared constant.
5136 5137 5138 5139 5140 5141 5142 5143 5144 |
# File 'lib/HDLRuby/hruby_high.rb', line 5136 def constant(hsh) res = nil hsh.each do |name,value| res = HDLRuby::High.top_user. add_inner(SignalC.new(name, TypeStruct.new(:"",:little,self),:inner,value)) end return res end |
#inner(*names) ⇒ Object
Declares high-level untyped inner signals named +names+ of the current type.
Retuns the last declared inner.
5122 5123 5124 5125 5126 5127 5128 5129 5130 |
# File 'lib/HDLRuby/hruby_high.rb', line 5122 def inner(*names) res = nil names.each do |name| res = HDLRuby::High.top_user. add_inner(SignalI.new(name, TypeStruct.new(:"",:little,self),:inner)) end return res end |
#inout(*names) ⇒ Object
Declares high-level untyped inout signals named +names+ of the current type.
Retuns the last declared inout.
5108 5109 5110 5111 5112 5113 5114 5115 5116 |
# File 'lib/HDLRuby/hruby_high.rb', line 5108 def inout(*names) res = nil names.each do |name| res = HDLRuby::High.top_user. add_inout(SignalI.new(name, TypeStruct.new(:"",:little,self),:inout)) end return res end |
#input(*names) ⇒ Object
Declares high-level input signals named +names+ of the current type.
Retuns the last declared input.
5080 5081 5082 5083 5084 5085 5086 5087 5088 |
# File 'lib/HDLRuby/hruby_high.rb', line 5080 def input(*names) res = nil names.each do |name| res = HDLRuby::High.top_user. add_input(SignalI.new(name, TypeStruct.new(:"",:little,self),:input)) end return res end |
#output(*names) ⇒ Object
Declares high-level untyped output signals named +names+ of the current type.
Retuns the last declared output.
5094 5095 5096 5097 5098 5099 5100 5101 5102 |
# File 'lib/HDLRuby/hruby_high.rb', line 5094 def output(*names) res = nil names.each do |name| res = HDLRuby::High.top_user. add_output(SignalI.new(name, TypeStruct.new(:"",:little,self),:output)) end return res end |
#shared(*names) ⇒ Object
Create new shared signals from +args+.
392 393 394 |
# File 'lib/HDLRuby/std/sequencer_sync.rb', line 392 def shared(*names) return self.to_type.shared(*names) end |
#to_type ⇒ Object
Converts to a new type.
5068 5069 5070 |
# File 'lib/HDLRuby/hruby_high.rb', line 5068 def to_type return TypeStruct.new(:"",:little,self) end |
#typedef(name) ⇒ Object
Declares a new type definition with +name+ equivalent to current one.
5073 5074 5075 |
# File 'lib/HDLRuby/hruby_high.rb', line 5073 def typedef(name) return self.to_type.typedef(name) end |