Class: OrigenDocHelpers::DocInterface
- Inherits:
-
Object
- Object
- OrigenDocHelpers::DocInterface
- Includes:
- Origen::Tester::Doc::Generator
- Defined in:
- lib/origen_doc_helpers/doc_interface.rb
Instance Method Summary collapse
- #add_flow_entry(test, options) ⇒ Object
- #add_pattern(name, options = {}) ⇒ Object
- #add_test(name, options) ⇒ Object
- #func(name, options = {}) ⇒ Object
-
#initialize(_options = {}) ⇒ DocInterface
constructor
A new instance of DocInterface.
- #instance_name(name, options = {}) ⇒ Object
- #log(_msg) ⇒ Object
- #para(name, options = {}) ⇒ Object
- #pattern_name(name, _options = {}) ⇒ Object
- #vdd_loop(options) ⇒ Object
Constructor Details
#initialize(_options = {}) ⇒ DocInterface
Returns a new instance of DocInterface.
5 6 |
# File 'lib/origen_doc_helpers/doc_interface.rb', line 5 def initialize( = {}) end |
Instance Method Details
#add_flow_entry(test, options) ⇒ Object
66 67 68 69 70 71 72 |
# File 'lib/origen_doc_helpers/doc_interface.rb', line 66 def add_flow_entry(test, ) = { number: [:bin] * 1000, soft_bin: [:bin] }.merge() flow.test test, end |
#add_pattern(name, options = {}) ⇒ Object
51 52 53 54 |
# File 'lib/origen_doc_helpers/doc_interface.rb', line 51 def add_pattern(name, = {}) [:pattern] = pattern_name(name, ) end |
#add_test(name, options) ⇒ Object
56 57 58 59 60 61 62 63 64 |
# File 'lib/origen_doc_helpers/doc_interface.rb', line 56 def add_test(name, ) = { }.merge() # Delete any keys that we don't want to assign to the instance, this keeps # the attributes efficient, flow control keys will be screened by Origen [:bin, :tnum, :tname, :continue ].each { |k| .delete(k) } tests.add(instance_name(name, ), add_pattern(name, )) end |
#func(name, options = {}) ⇒ Object
29 30 31 32 33 34 35 36 37 38 |
# File 'lib/origen_doc_helpers/doc_interface.rb', line 29 def func(name, = {}) = { vdd: [:min, :max], type: :functional }.merge() vdd_loop() do || test = add_test name, add_flow_entry(test, ) end end |
#instance_name(name, options = {}) ⇒ Object
11 12 13 14 15 16 17 |
# File 'lib/origen_doc_helpers/doc_interface.rb', line 11 def instance_name(name, = {}) name = pattern_name(name) if [:vdd] || [:vdd] != :nom name += "_#{options[:vdd]}" end name end |
#log(_msg) ⇒ Object
8 9 |
# File 'lib/origen_doc_helpers/doc_interface.rb', line 8 def log(_msg) end |
#para(name, options = {}) ⇒ Object
40 41 42 43 44 45 46 47 48 49 |
# File 'lib/origen_doc_helpers/doc_interface.rb', line 40 def para(name, = {}) = { vdd: [:min, :max], type: :parametric }.merge() vdd_loop() do || test = add_test name, add_flow_entry(test, ) end end |
#pattern_name(name, _options = {}) ⇒ Object
19 20 21 |
# File 'lib/origen_doc_helpers/doc_interface.rb', line 19 def pattern_name(name, = {}) name.to_s end |
#vdd_loop(options) ⇒ Object
23 24 25 26 27 |
# File 'lib/origen_doc_helpers/doc_interface.rb', line 23 def vdd_loop() [[:vdd]].flatten.each do |vdd| yield .merge(vdd: vdd) end end |