ruby-vpi 7.2.0 → 7.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (214) hide show
  1. data/HEADER +4 -5
  2. data/HISTORY +18 -2
  3. data/MEMO +10 -6
  4. data/Rakefile +11 -14
  5. data/bin/generate_test.rb +7 -58
  6. data/bin/generate_test_tpl/bench.v +15 -19
  7. data/bin/generate_test_tpl/design.rb +8 -8
  8. data/bin/generate_test_tpl/spec.rb +2 -2
  9. data/bin/header_to_ruby.rb +2 -27
  10. data/doc/xhtml/background.organization.html +1 -1
  11. data/doc/xhtml/index.html +2 -2
  12. data/header.html +3 -6
  13. data/header.part.html +3 -6
  14. data/history.html +35 -8
  15. data/history.part.html +32 -2
  16. data/lib/ruby-vpi/verilog_parser.rb +136 -0
  17. data/lib/ruby-vpi/vpi_util.rb +10 -0
  18. data/memo.html +19 -17
  19. data/memo.part.html +16 -11
  20. data/readme.html +3 -6
  21. data/ref/c/annotated.html +1 -1
  22. data/ref/c/common_8h.html +1 -1
  23. data/ref/c/files.html +1 -1
  24. data/ref/c/functions.html +1 -1
  25. data/ref/c/functions_vars.html +1 -1
  26. data/ref/c/globals.html +1 -1
  27. data/ref/c/globals_0x63.html +1 -1
  28. data/ref/c/globals_0x65.html +1 -1
  29. data/ref/c/globals_0x66.html +1 -1
  30. data/ref/c/globals_0x70.html +1 -1
  31. data/ref/c/globals_0x72.html +1 -1
  32. data/ref/c/globals_0x73.html +1 -1
  33. data/ref/c/globals_0x74.html +1 -1
  34. data/ref/c/globals_0x76.html +1 -1
  35. data/ref/c/globals_0x78.html +1 -1
  36. data/ref/c/globals_defs.html +1 -1
  37. data/ref/c/globals_defs_0x65.html +1 -1
  38. data/ref/c/globals_defs_0x70.html +1 -1
  39. data/ref/c/globals_defs_0x76.html +1 -1
  40. data/ref/c/globals_defs_0x78.html +1 -1
  41. data/ref/c/globals_enum.html +1 -1
  42. data/ref/c/globals_eval.html +1 -1
  43. data/ref/c/globals_func.html +1 -1
  44. data/ref/c/globals_type.html +1 -1
  45. data/ref/c/globals_vars.html +1 -1
  46. data/ref/c/hierarchy.html +1 -1
  47. data/ref/c/index.html +1 -1
  48. data/ref/c/relay_8cin.html +1 -1
  49. data/ref/c/relay_8hin.html +1 -1
  50. data/ref/c/ruby-vpi_8c.html +1 -1
  51. data/ref/c/structrelay____RubyOptions____def.html +1 -1
  52. data/ref/c/structt__cb__data.html +1 -1
  53. data/ref/c/structt__vpi__delay.html +1 -1
  54. data/ref/c/structt__vpi__error__info.html +1 -1
  55. data/ref/c/structt__vpi__strengthval.html +1 -1
  56. data/ref/c/structt__vpi__systf__data.html +1 -1
  57. data/ref/c/structt__vpi__time.html +1 -1
  58. data/ref/c/structt__vpi__value.html +1 -1
  59. data/ref/c/structt__vpi__vecval.html +1 -1
  60. data/ref/c/structt__vpi__vlog__info.html +1 -1
  61. data/ref/c/swig_8cin.html +1 -1
  62. data/ref/c/swig_8hin.html +1 -1
  63. data/ref/c/verilog_8h.html +1 -1
  64. data/ref/c/vlog_8cin.html +1 -1
  65. data/ref/c/vlog_8hin.html +1 -1
  66. data/ref/c/vpi__user_8h.html +1 -1
  67. data/ref/ruby/classes/ERB.html +5 -5
  68. data/ref/ruby/classes/ERB.src/{M000011.html → M000018.html} +0 -0
  69. data/ref/ruby/classes/FileUtils.html +10 -10
  70. data/ref/ruby/classes/FileUtils.src/{M000065.html → M000073.html} +0 -0
  71. data/ref/ruby/classes/FileUtils.src/{M000066.html → M000074.html} +0 -0
  72. data/ref/ruby/classes/OutputInfo.html +5 -5
  73. data/ref/ruby/classes/OutputInfo.src/{M000007.html → M000014.html} +37 -37
  74. data/ref/ruby/classes/RDoc.html +5 -5
  75. data/ref/ruby/classes/RDoc.src/{M000069.html → M000077.html} +0 -0
  76. data/ref/ruby/classes/RubyVPI.html +10 -10
  77. data/ref/ruby/classes/RubyVPI.src/{M000067.html → M000075.html} +0 -0
  78. data/ref/ruby/classes/RubyVPI.src/{M000068.html → M000076.html} +0 -0
  79. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.html +72 -35
  80. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/M000065.html +18 -0
  81. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/M000066.html +18 -0
  82. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/{M000059.html → M000067.html} +8 -8
  83. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/{M000060.html → M000068.html} +29 -29
  84. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/{M000061.html → M000069.html} +63 -63
  85. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/{M000062.html → M000070.html} +106 -106
  86. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/{M000063.html → M000071.html} +12 -12
  87. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/{M000064.html → M000072.html} +4 -4
  88. data/ref/ruby/classes/String.html +27 -9
  89. data/ref/ruby/classes/String.src/M000016.html +41 -0
  90. data/ref/ruby/classes/String.src/M000017.html +18 -0
  91. data/ref/ruby/classes/Table.html +20 -20
  92. data/ref/ruby/classes/Table.src/{M000003.html → M000010.html} +0 -0
  93. data/ref/ruby/classes/Table.src/{M000004.html → M000011.html} +0 -0
  94. data/ref/ruby/classes/Table.src/{M000005.html → M000012.html} +0 -0
  95. data/ref/ruby/classes/Table.src/{M000006.html → M000013.html} +0 -0
  96. data/ref/ruby/classes/Template.html +5 -5
  97. data/ref/ruby/classes/Template.src/{M000010.html → M000015.html} +0 -0
  98. data/ref/ruby/classes/VerilogParser/Module/Parameter.html +160 -0
  99. data/ref/ruby/classes/VerilogParser/Module/Parameter.src/M000009.html +21 -0
  100. data/ref/ruby/classes/VerilogParser/Module/Port.html +207 -0
  101. data/ref/ruby/classes/VerilogParser/Module/Port.src/M000005.html +21 -0
  102. data/ref/ruby/classes/VerilogParser/Module/Port.src/M000006.html +18 -0
  103. data/ref/ruby/classes/VerilogParser/Module/Port.src/M000007.html +18 -0
  104. data/ref/ruby/classes/VerilogParser/Module/Port.src/M000008.html +18 -0
  105. data/ref/ruby/classes/VerilogParser/Module.html +172 -0
  106. data/ref/ruby/classes/VerilogParser/Module.src/M000004.html +29 -0
  107. data/ref/ruby/classes/{ModuleInfo.html → VerilogParser.html} +38 -50
  108. data/ref/ruby/classes/VerilogParser.src/M000003.html +34 -0
  109. data/ref/ruby/classes/XX/Document.html +45 -45
  110. data/ref/ruby/classes/XX/Document.src/M000056.html +9 -8
  111. data/ref/ruby/classes/XX/Document.src/M000057.html +7 -21
  112. data/ref/ruby/classes/XX/Document.src/M000058.html +7 -85
  113. data/ref/ruby/classes/XX/Document.src/{M000053.html → M000059.html} +0 -0
  114. data/ref/ruby/classes/XX/Document.src/{M000054.html → M000060.html} +0 -0
  115. data/ref/ruby/classes/XX/Document.src/{M000055.html → M000061.html} +0 -0
  116. data/ref/ruby/classes/XX/Document.src/M000062.html +21 -0
  117. data/ref/ruby/classes/XX/Document.src/M000063.html +34 -0
  118. data/ref/ruby/classes/XX/Document.src/M000064.html +98 -0
  119. data/ref/ruby/classes/XX/HTML4/Strict.html +5 -5
  120. data/ref/ruby/classes/XX/HTML4/Strict.src/{M000016.html → M000022.html} +0 -0
  121. data/ref/ruby/classes/XX/HTML4/Transitional.html +5 -5
  122. data/ref/ruby/classes/XX/HTML4/Transitional.src/{M000015.html → M000021.html} +0 -0
  123. data/ref/ruby/classes/XX/HTML4.html +5 -5
  124. data/ref/ruby/classes/XX/HTML4.src/{M000014.html → M000020.html} +0 -0
  125. data/ref/ruby/classes/XX/Markup/ClassMethods.html +40 -40
  126. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000028.html +9 -14
  127. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000029.html +7 -9
  128. data/ref/ruby/classes/XX/Markup/ClassMethods.src/{M000024.html → M000030.html} +0 -0
  129. data/ref/ruby/classes/XX/Markup/ClassMethods.src/{M000025.html → M000031.html} +0 -0
  130. data/ref/ruby/classes/XX/Markup/ClassMethods.src/{M000026.html → M000032.html} +0 -0
  131. data/ref/ruby/classes/XX/Markup/ClassMethods.src/{M000027.html → M000033.html} +0 -0
  132. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000034.html +27 -0
  133. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000035.html +22 -0
  134. data/ref/ruby/classes/XX/Markup/InstanceMethods.html +100 -100
  135. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000036.html +43 -19
  136. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000037.html +20 -19
  137. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000038.html +18 -15
  138. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000039.html +35 -10
  139. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000040.html +7 -13
  140. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000041.html +18 -7
  141. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000042.html +19 -7
  142. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000043.html +19 -7
  143. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000044.html +15 -7
  144. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000045.html +10 -7
  145. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000046.html +13 -8
  146. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000047.html +7 -7
  147. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000048.html +7 -7
  148. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000049.html +7 -7
  149. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000050.html +20 -0
  150. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000051.html +20 -0
  151. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000052.html +21 -0
  152. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000053.html +20 -0
  153. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000054.html +20 -0
  154. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000055.html +20 -0
  155. data/ref/ruby/classes/XX/Markup.html +5 -5
  156. data/ref/ruby/classes/XX/Markup.src/{M000021.html → M000027.html} +0 -0
  157. data/ref/ruby/classes/XX/XHTML/Strict.html +5 -5
  158. data/ref/ruby/classes/XX/XHTML/Strict.src/{M000020.html → M000026.html} +0 -0
  159. data/ref/ruby/classes/XX/XHTML/Transitional.html +5 -5
  160. data/ref/ruby/classes/XX/XHTML/Transitional.src/{M000019.html → M000025.html} +0 -0
  161. data/ref/ruby/classes/XX/XHTML.html +5 -5
  162. data/ref/ruby/classes/XX/XHTML.src/{M000018.html → M000024.html} +0 -0
  163. data/ref/ruby/classes/XX/XML.html +5 -5
  164. data/ref/ruby/classes/XX/XML.src/{M000013.html → M000019.html} +0 -0
  165. data/ref/ruby/classes/XX/XMLish.html +5 -5
  166. data/ref/ruby/classes/XX/XMLish.src/{M000017.html → M000023.html} +0 -0
  167. data/ref/ruby/created.rid +1 -1
  168. data/ref/ruby/files/bin/generate_test_rb.html +2 -1
  169. data/ref/ruby/files/bin/generate_test_rb.src/M000001.html +15 -15
  170. data/ref/ruby/files/bin/header_to_ruby_rb.html +2 -1
  171. data/ref/ruby/files/lib/ruby-vpi/erb_rb.html +1 -1
  172. data/ref/ruby/files/lib/ruby-vpi/rake_rb.html +1 -1
  173. data/ref/ruby/files/lib/ruby-vpi/rcov_rb.html +1 -1
  174. data/ref/ruby/files/lib/ruby-vpi/rdoc_rb.html +1 -1
  175. data/ref/ruby/files/lib/ruby-vpi/rspec_rb.html +1 -1
  176. data/ref/ruby/files/lib/ruby-vpi/runner_proxy_rb.html +1 -1
  177. data/ref/ruby/files/lib/ruby-vpi/runner_rb.html +1 -1
  178. data/ref/ruby/files/lib/ruby-vpi/verilog_parser_rb.html +107 -0
  179. data/ref/ruby/files/lib/ruby-vpi/vpi_util_rb.html +1 -1
  180. data/ref/ruby/files/lib/ruby-vpi/xx_rb.html +1 -1
  181. data/ref/ruby/files/lib/ruby-vpi_rb.html +1 -1
  182. data/ref/ruby/fr_class_index.html +4 -1
  183. data/ref/ruby/fr_file_index.html +1 -0
  184. data/ref/ruby/fr_method_index.html +75 -67
  185. data/samp/counter/counter_rspecTest_bench.v +4 -5
  186. data/samp/counter/counter_unitTest_bench.v +6 -5
  187. data/samp/pipelined_alu/Hw5UnitModel.rb +4 -4
  188. data/samp/pipelined_alu/hw5_unit.v +15 -23
  189. data/samp/pipelined_alu/hw5_unit_test_bench.rb +9 -0
  190. data/samp/pipelined_alu/hw5_unit_test_bench.v +39 -0
  191. data/samp/pipelined_alu/hw5_unit_test_design.rb +88 -0
  192. data/samp/pipelined_alu/hw5_unit_test_proto.rb +8 -0
  193. data/samp/pipelined_alu/hw5_unit_test_runner.rake +28 -0
  194. data/samp/pipelined_alu/hw5_unit_test_spec.rb +88 -0
  195. metadata +82 -63
  196. data/ref/ruby/classes/ModuleInfo.src/M000008.html +0 -44
  197. data/ref/ruby/classes/ModuleInfo.src/M000009.html +0 -26
  198. data/ref/ruby/classes/String.src/M000012.html +0 -37
  199. data/ref/ruby/classes/XX/Document.src/M000050.html +0 -22
  200. data/ref/ruby/classes/XX/Document.src/M000051.html +0 -20
  201. data/ref/ruby/classes/XX/Document.src/M000052.html +0 -20
  202. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000022.html +0 -22
  203. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000023.html +0 -20
  204. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000030.html +0 -56
  205. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000031.html +0 -33
  206. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000032.html +0 -31
  207. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000033.html +0 -48
  208. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000034.html +0 -20
  209. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000035.html +0 -31
  210. data/samp/pipelined_alu/hw5_unit_bench.rb +0 -8
  211. data/samp/pipelined_alu/hw5_unit_bench.v +0 -45
  212. data/samp/pipelined_alu/hw5_unit_design.rb +0 -18
  213. data/samp/pipelined_alu/hw5_unit_runner.rake +0 -10
  214. data/samp/pipelined_alu/hw5_unit_spec.rb +0 -123
@@ -90,8 +90,8 @@ Provides configuration information of the Ruby-VPI project.
90
90
  <h3 class="section-bar">Methods</h3>
91
91
 
92
92
  <div class="name-list">
93
- <a href="#M000067">init_bench</a>&nbsp;&nbsp;
94
- <a href="#M000068">with_coverage_analysis</a>&nbsp;&nbsp;
93
+ <a href="#M000075">init_bench</a>&nbsp;&nbsp;
94
+ <a href="#M000076">with_coverage_analysis</a>&nbsp;&nbsp;
95
95
  </div>
96
96
  </div>
97
97
 
@@ -131,12 +131,12 @@ Provides configuration information of the Ruby-VPI project.
131
131
  <div id="methods">
132
132
  <h3 class="section-bar">Public Class methods</h3>
133
133
 
134
- <div id="method-M000067" class="method-detail">
135
- <a name="M000067"></a>
134
+ <div id="method-M000075" class="method-detail">
135
+ <a name="M000075"></a>
136
136
 
137
137
  <div class="method-heading">
138
- <a href="RubyVPI.src/M000067.html" target="Code" class="method-signature"
139
- onclick="popupCode('RubyVPI.src/M000067.html');return false;">
138
+ <a href="RubyVPI.src/M000075.html" target="Code" class="method-signature"
139
+ onclick="popupCode('RubyVPI.src/M000075.html');return false;">
140
140
  <span class="method-name">init_bench</span><span class="method-args">(aTestPrefix, aProtoClassId)</span>
141
141
  </a>
142
142
  </div>
@@ -148,12 +148,12 @@ Initializes the current bench using the given parameters.
148
148
  </div>
149
149
  </div>
150
150
 
151
- <div id="method-M000068" class="method-detail">
152
- <a name="M000068"></a>
151
+ <div id="method-M000076" class="method-detail">
152
+ <a name="M000076"></a>
153
153
 
154
154
  <div class="method-heading">
155
- <a href="RubyVPI.src/M000068.html" target="Code" class="method-signature"
156
- onclick="popupCode('RubyVPI.src/M000068.html');return false;">
155
+ <a href="RubyVPI.src/M000076.html" target="Code" class="method-signature"
156
+ onclick="popupCode('RubyVPI.src/M000076.html');return false;">
157
157
  <span class="method-name">with_coverage_analysis</span><span class="method-args">( {|Rcov::CodeCoverageAnalyzer| ...}</span>
158
158
  </a>
159
159
  </div>
@@ -95,7 +95,7 @@ You can read and write values using <tt>S_vpi_value</tt> objects through
95
95
  the following methods.
96
96
  </p>
97
97
  <ul>
98
- <li><a href="TYPE_p_unsigned_int.html#M000059">get_value_wrapper</a>
98
+ <li><a href="TYPE_p_unsigned_int.html#M000067">get_value_wrapper</a>
99
99
 
100
100
  </li>
101
101
  <li>Vpi::vpi_get_value
@@ -112,10 +112,10 @@ following methods.
112
112
  </p>
113
113
  <ul>
114
114
  <li>value = handle.<a
115
- href="TYPE_p_unsigned_int.html#M000060">get_value</a>(format)
115
+ href="TYPE_p_unsigned_int.html#M000068">get_value</a>(format)
116
116
 
117
117
  </li>
118
- <li>handle.<a href="TYPE_p_unsigned_int.html#M000061">put_value</a>(value,
118
+ <li>handle.<a href="TYPE_p_unsigned_int.html#M000069">put_value</a>(value,
119
119
  format)
120
120
 
121
121
  </li>
@@ -156,7 +156,7 @@ The methods shown above can be used like so:
156
156
  To read a handle&#8217;s value as an integer:
157
157
  </p>
158
158
  <ul>
159
- <li>handle.<a href="TYPE_p_unsigned_int.html#M000060">get_value</a>(VpiIntVal)
159
+ <li>handle.<a href="TYPE_p_unsigned_int.html#M000068">get_value</a>(VpiIntVal)
160
160
 
161
161
  </li>
162
162
  <li>handle.intVal
@@ -167,7 +167,7 @@ To read a handle&#8217;s value as an integer:
167
167
  To write a handle&#8217;s value as an integer:
168
168
  </p>
169
169
  <ul>
170
- <li>handle.<a href="TYPE_p_unsigned_int.html#M000061">put_value</a>(15,
170
+ <li>handle.<a href="TYPE_p_unsigned_int.html#M000069">put_value</a>(15,
171
171
  VpiIntVal)
172
172
 
173
173
  </li>
@@ -185,12 +185,14 @@ VpiIntVal)
185
185
  <h3 class="section-bar">Methods</h3>
186
186
 
187
187
  <div class="name-list">
188
- <a href="#M000063">[]</a>&nbsp;&nbsp;
189
- <a href="#M000064">each</a>&nbsp;&nbsp;
190
- <a href="#M000060">get_value</a>&nbsp;&nbsp;
191
- <a href="#M000059">get_value_wrapper</a>&nbsp;&nbsp;
192
- <a href="#M000062">method_missing</a>&nbsp;&nbsp;
193
- <a href="#M000061">put_value</a>&nbsp;&nbsp;
188
+ <a href="#M000071">[]</a>&nbsp;&nbsp;
189
+ <a href="#M000072">each</a>&nbsp;&nbsp;
190
+ <a href="#M000068">get_value</a>&nbsp;&nbsp;
191
+ <a href="#M000067">get_value_wrapper</a>&nbsp;&nbsp;
192
+ <a href="#M000070">method_missing</a>&nbsp;&nbsp;
193
+ <a href="#M000069">put_value</a>&nbsp;&nbsp;
194
+ <a href="#M000065">x?</a>&nbsp;&nbsp;
195
+ <a href="#M000066">z?</a>&nbsp;&nbsp;
194
196
  </div>
195
197
  </div>
196
198
 
@@ -247,12 +249,12 @@ VpiIntVal)
247
249
  <div id="methods">
248
250
  <h3 class="section-bar">Public Instance methods</h3>
249
251
 
250
- <div id="method-M000063" class="method-detail">
251
- <a name="M000063"></a>
252
+ <div id="method-M000071" class="method-detail">
253
+ <a name="M000071"></a>
252
254
 
253
255
  <div class="method-heading">
254
- <a href="TYPE_p_unsigned_int.src/M000063.html" target="Code" class="method-signature"
255
- onclick="popupCode('TYPE_p_unsigned_int.src/M000063.html');return false;">
256
+ <a href="TYPE_p_unsigned_int.src/M000071.html" target="Code" class="method-signature"
257
+ onclick="popupCode('TYPE_p_unsigned_int.src/M000071.html');return false;">
256
258
  <span class="method-name">[]</span><span class="method-args">(aType)</span>
257
259
  </a>
258
260
  </div>
@@ -264,12 +266,12 @@ Returns an array of handles of the given type.
264
266
  </div>
265
267
  </div>
266
268
 
267
- <div id="method-M000064" class="method-detail">
268
- <a name="M000064"></a>
269
+ <div id="method-M000072" class="method-detail">
270
+ <a name="M000072"></a>
269
271
 
270
272
  <div class="method-heading">
271
- <a href="TYPE_p_unsigned_int.src/M000064.html" target="Code" class="method-signature"
272
- onclick="popupCode('TYPE_p_unsigned_int.src/M000064.html');return false;">
273
+ <a href="TYPE_p_unsigned_int.src/M000072.html" target="Code" class="method-signature"
274
+ onclick="popupCode('TYPE_p_unsigned_int.src/M000072.html');return false;">
273
275
  <span class="method-name">each</span><span class="method-args">(aType {|handle| ...}</span>
274
276
  </a>
275
277
  </div>
@@ -282,12 +284,12 @@ once for each handle.
282
284
  </div>
283
285
  </div>
284
286
 
285
- <div id="method-M000060" class="method-detail">
286
- <a name="M000060"></a>
287
+ <div id="method-M000068" class="method-detail">
288
+ <a name="M000068"></a>
287
289
 
288
290
  <div class="method-heading">
289
- <a href="TYPE_p_unsigned_int.src/M000060.html" target="Code" class="method-signature"
290
- onclick="popupCode('TYPE_p_unsigned_int.src/M000060.html');return false;">
291
+ <a href="TYPE_p_unsigned_int.src/M000068.html" target="Code" class="method-signature"
292
+ onclick="popupCode('TYPE_p_unsigned_int.src/M000068.html');return false;">
291
293
  <span class="method-name">get_value</span><span class="method-args">(aFormat = VpiObjTypeVal)</span>
292
294
  </a>
293
295
  </div>
@@ -301,12 +303,12 @@ format.
301
303
  </div>
302
304
  </div>
303
305
 
304
- <div id="method-M000059" class="method-detail">
305
- <a name="M000059"></a>
306
+ <div id="method-M000067" class="method-detail">
307
+ <a name="M000067"></a>
306
308
 
307
309
  <div class="method-heading">
308
- <a href="TYPE_p_unsigned_int.src/M000059.html" target="Code" class="method-signature"
309
- onclick="popupCode('TYPE_p_unsigned_int.src/M000059.html');return false;">
310
+ <a href="TYPE_p_unsigned_int.src/M000067.html" target="Code" class="method-signature"
311
+ onclick="popupCode('TYPE_p_unsigned_int.src/M000067.html');return false;">
310
312
  <span class="method-name">get_value_wrapper</span><span class="method-args">(aFormat)</span>
311
313
  </a>
312
314
  </div>
@@ -319,12 +321,12 @@ object.
319
321
  </div>
320
322
  </div>
321
323
 
322
- <div id="method-M000062" class="method-detail">
323
- <a name="M000062"></a>
324
+ <div id="method-M000070" class="method-detail">
325
+ <a name="M000070"></a>
324
326
 
325
327
  <div class="method-heading">
326
- <a href="TYPE_p_unsigned_int.src/M000062.html" target="Code" class="method-signature"
327
- onclick="popupCode('TYPE_p_unsigned_int.src/M000062.html');return false;">
328
+ <a href="TYPE_p_unsigned_int.src/M000070.html" target="Code" class="method-signature"
329
+ onclick="popupCode('TYPE_p_unsigned_int.src/M000070.html');return false;">
328
330
  <span class="method-name">method_missing</span><span class="method-args">(aMsg, *aArgs, &amp;aBlockArg)</span>
329
331
  </a>
330
332
  </div>
@@ -336,12 +338,12 @@ Enables read and write access to VPI properties of this handle.
336
338
  </div>
337
339
  </div>
338
340
 
339
- <div id="method-M000061" class="method-detail">
340
- <a name="M000061"></a>
341
+ <div id="method-M000069" class="method-detail">
342
+ <a name="M000069"></a>
341
343
 
342
344
  <div class="method-heading">
343
- <a href="TYPE_p_unsigned_int.src/M000061.html" target="Code" class="method-signature"
344
- onclick="popupCode('TYPE_p_unsigned_int.src/M000061.html');return false;">
345
+ <a href="TYPE_p_unsigned_int.src/M000069.html" target="Code" class="method-signature"
346
+ onclick="popupCode('TYPE_p_unsigned_int.src/M000069.html');return false;">
345
347
  <span class="method-name">put_value</span><span class="method-args">(aValue, aFormat = nil, aTime = nil, aDelay = VpiNoDelay)</span>
346
348
  </a>
347
349
  </div>
@@ -355,6 +357,41 @@ simulator will attempt to determine the correct format.
355
357
  </div>
356
358
  </div>
357
359
 
360
+ <div id="method-M000065" class="method-detail">
361
+ <a name="M000065"></a>
362
+
363
+ <div class="method-heading">
364
+ <a href="TYPE_p_unsigned_int.src/M000065.html" target="Code" class="method-signature"
365
+ onclick="popupCode('TYPE_p_unsigned_int.src/M000065.html');return false;">
366
+ <span class="method-name">x?</span><span class="method-args">()</span>
367
+ </a>
368
+ </div>
369
+
370
+ <div class="method-description">
371
+ <p>
372
+ Tests if the logic value of this handle is &quot;don&#8217;t care&quot;
373
+ (x).
374
+ </p>
375
+ </div>
376
+ </div>
377
+
378
+ <div id="method-M000066" class="method-detail">
379
+ <a name="M000066"></a>
380
+
381
+ <div class="method-heading">
382
+ <a href="TYPE_p_unsigned_int.src/M000066.html" target="Code" class="method-signature"
383
+ onclick="popupCode('TYPE_p_unsigned_int.src/M000066.html');return false;">
384
+ <span class="method-name">z?</span><span class="method-args">()</span>
385
+ </a>
386
+ </div>
387
+
388
+ <div class="method-description">
389
+ <p>
390
+ Tests if the logic value of this handle is high impedance (z).
391
+ </p>
392
+ </div>
393
+ </div>
394
+
358
395
 
359
396
  </div>
360
397
 
@@ -0,0 +1,18 @@
1
+ <?xml version="1.0" encoding="utf-8"?>
2
+ <!DOCTYPE html
3
+ PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
+
6
+ <html>
7
+ <head>
8
+ <title>x? (SWIG::TYPE_p_unsigned_int)</title>
9
+ <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
10
+ <link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
11
+ </head>
12
+ <body class="standalone-code">
13
+ <pre> <span class="ruby-comment cmt"># File lib/ruby-vpi/vpi_util.rb, line 65</span>
14
+ 65: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">x?</span>
15
+ 66: <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">hexStrVal</span> <span class="ruby-operator">=~</span> <span class="ruby-regexp re">/x/i</span>
16
+ 67: <span class="ruby-keyword kw">end</span></pre>
17
+ </body>
18
+ </html>
@@ -0,0 +1,18 @@
1
+ <?xml version="1.0" encoding="utf-8"?>
2
+ <!DOCTYPE html
3
+ PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
+
6
+ <html>
7
+ <head>
8
+ <title>z? (SWIG::TYPE_p_unsigned_int)</title>
9
+ <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
10
+ <link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
11
+ </head>
12
+ <body class="standalone-code">
13
+ <pre> <span class="ruby-comment cmt"># File lib/ruby-vpi/vpi_util.rb, line 70</span>
14
+ 70: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">z?</span>
15
+ 71: <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">hexStrVal</span> <span class="ruby-operator">=~</span> <span class="ruby-regexp re">/z/i</span>
16
+ 72: <span class="ruby-keyword kw">end</span></pre>
17
+ </body>
18
+ </html>
@@ -10,13 +10,13 @@
10
10
  <link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
11
11
  </head>
12
12
  <body class="standalone-code">
13
- <pre> <span class="ruby-comment cmt"># File lib/ruby-vpi/vpi_util.rb, line 65</span>
14
- 65: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">get_value_wrapper</span> <span class="ruby-identifier">aFormat</span>
15
- 66: <span class="ruby-identifier">val</span> = <span class="ruby-constant">S_vpi_value</span>.<span class="ruby-identifier">new</span>
16
- 67: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">format</span> = <span class="ruby-identifier">aFormat</span>
17
- 68:
18
- 69: <span class="ruby-identifier">vpi_get_value</span> <span class="ruby-keyword kw">self</span>, <span class="ruby-identifier">val</span>
19
- 70: <span class="ruby-identifier">val</span>
20
- 71: <span class="ruby-keyword kw">end</span></pre>
13
+ <pre> <span class="ruby-comment cmt"># File lib/ruby-vpi/vpi_util.rb, line 75</span>
14
+ 75: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">get_value_wrapper</span> <span class="ruby-identifier">aFormat</span>
15
+ 76: <span class="ruby-identifier">val</span> = <span class="ruby-constant">S_vpi_value</span>.<span class="ruby-identifier">new</span>
16
+ 77: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">format</span> = <span class="ruby-identifier">aFormat</span>
17
+ 78:
18
+ 79: <span class="ruby-identifier">vpi_get_value</span> <span class="ruby-keyword kw">self</span>, <span class="ruby-identifier">val</span>
19
+ 80: <span class="ruby-identifier">val</span>
20
+ 81: <span class="ruby-keyword kw">end</span></pre>
21
21
  </body>
22
22
  </html>
@@ -10,35 +10,35 @@
10
10
  <link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
11
11
  </head>
12
12
  <body class="standalone-code">
13
- <pre> <span class="ruby-comment cmt"># File lib/ruby-vpi/vpi_util.rb, line 74</span>
14
- 74: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">get_value</span> <span class="ruby-identifier">aFormat</span> = <span class="ruby-constant">VpiObjTypeVal</span>
15
- 75: <span class="ruby-identifier">val</span> = <span class="ruby-identifier">get_value_wrapper</span>(<span class="ruby-identifier">aFormat</span>)
16
- 76:
17
- 77: <span class="ruby-keyword kw">case</span> <span class="ruby-identifier">val</span>.<span class="ruby-identifier">format</span>
18
- 78: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiBinStrVal</span>, <span class="ruby-constant">VpiOctStrVal</span>, <span class="ruby-constant">VpiDecStrVal</span>, <span class="ruby-constant">VpiHexStrVal</span>, <span class="ruby-constant">VpiStringVal</span>
19
- 79: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">str</span>
20
- 80:
21
- 81: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiScalarVal</span>
22
- 82: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">scalar</span>
23
- 83:
24
- 84: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiIntVal</span>
25
- 85: <span class="ruby-identifier">get_value_wrapper</span>(<span class="ruby-constant">VpiHexStrVal</span>).<span class="ruby-identifier">value</span>.<span class="ruby-identifier">str</span>.<span class="ruby-identifier">to_i</span>(<span class="ruby-value">16</span>)
13
+ <pre> <span class="ruby-comment cmt"># File lib/ruby-vpi/vpi_util.rb, line 84</span>
14
+ 84: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">get_value</span> <span class="ruby-identifier">aFormat</span> = <span class="ruby-constant">VpiObjTypeVal</span>
15
+ 85: <span class="ruby-identifier">val</span> = <span class="ruby-identifier">get_value_wrapper</span>(<span class="ruby-identifier">aFormat</span>)
26
16
  86:
27
- 87: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiRealVal</span>
28
- 88: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">real</span>
29
- 89:
30
- 90: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiTimeVal</span>
31
- 91: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">time</span>
32
- 92:
33
- 93: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiVectorVal</span>
34
- 94: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">vector</span>
35
- 95:
36
- 96: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiStrengthVal</span>
37
- 97: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">strength</span>
38
- 98:
39
- 99: <span class="ruby-keyword kw">else</span>
40
- 100: <span class="ruby-identifier">raise</span> <span class="ruby-node">&quot;unknown S_vpi_value.format: #{val.format}&quot;</span>
41
- 101: <span class="ruby-keyword kw">end</span>
42
- 102: <span class="ruby-keyword kw">end</span></pre>
17
+ 87: <span class="ruby-keyword kw">case</span> <span class="ruby-identifier">val</span>.<span class="ruby-identifier">format</span>
18
+ 88: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiBinStrVal</span>, <span class="ruby-constant">VpiOctStrVal</span>, <span class="ruby-constant">VpiDecStrVal</span>, <span class="ruby-constant">VpiHexStrVal</span>, <span class="ruby-constant">VpiStringVal</span>
19
+ 89: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">str</span>
20
+ 90:
21
+ 91: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiScalarVal</span>
22
+ 92: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">scalar</span>
23
+ 93:
24
+ 94: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiIntVal</span>
25
+ 95: <span class="ruby-identifier">get_value_wrapper</span>(<span class="ruby-constant">VpiHexStrVal</span>).<span class="ruby-identifier">value</span>.<span class="ruby-identifier">str</span>.<span class="ruby-identifier">to_i</span>(<span class="ruby-value">16</span>)
26
+ 96:
27
+ 97: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiRealVal</span>
28
+ 98: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">real</span>
29
+ 99:
30
+ 100: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiTimeVal</span>
31
+ 101: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">time</span>
32
+ 102:
33
+ 103: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiVectorVal</span>
34
+ 104: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">vector</span>
35
+ 105:
36
+ 106: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiStrengthVal</span>
37
+ 107: <span class="ruby-identifier">val</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">strength</span>
38
+ 108:
39
+ 109: <span class="ruby-keyword kw">else</span>
40
+ 110: <span class="ruby-identifier">raise</span> <span class="ruby-node">&quot;unknown S_vpi_value.format: #{val.format}&quot;</span>
41
+ 111: <span class="ruby-keyword kw">end</span>
42
+ 112: <span class="ruby-keyword kw">end</span></pre>
43
43
  </body>
44
44
  </html>
@@ -10,73 +10,73 @@
10
10
  <link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
11
11
  </head>
12
12
  <body class="standalone-code">
13
- <pre> <span class="ruby-comment cmt"># File lib/ruby-vpi/vpi_util.rb, line 105</span>
14
- 105: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">put_value</span> <span class="ruby-identifier">aValue</span>, <span class="ruby-identifier">aFormat</span> = <span class="ruby-keyword kw">nil</span>, <span class="ruby-identifier">aTime</span> = <span class="ruby-keyword kw">nil</span>, <span class="ruby-identifier">aDelay</span> = <span class="ruby-constant">VpiNoDelay</span>
15
- 106: <span class="ruby-identifier">aFormat</span> <span class="ruby-operator">||=</span> <span class="ruby-identifier">get_value_wrapper</span>(<span class="ruby-constant">VpiObjTypeVal</span>).<span class="ruby-identifier">format</span>
16
- 107:
17
- 108: <span class="ruby-identifier">newVal</span> = <span class="ruby-constant">S_vpi_value</span>.<span class="ruby-identifier">new</span>
18
- 109: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">format</span> = <span class="ruby-identifier">aFormat</span>
19
- 110:
20
- 111: <span class="ruby-keyword kw">case</span> <span class="ruby-identifier">aFormat</span>
21
- 112: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiBinStrVal</span>, <span class="ruby-constant">VpiOctStrVal</span>, <span class="ruby-constant">VpiDecStrVal</span>, <span class="ruby-constant">VpiHexStrVal</span>, <span class="ruby-constant">VpiStringVal</span>
22
- 113: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">str</span> = <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_s</span>
23
- 114:
24
- 115: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiScalarVal</span>
25
- 116: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">scalar</span> = <span class="ruby-identifier">aValue</span>
13
+ <pre> <span class="ruby-comment cmt"># File lib/ruby-vpi/vpi_util.rb, line 115</span>
14
+ 115: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">put_value</span> <span class="ruby-identifier">aValue</span>, <span class="ruby-identifier">aFormat</span> = <span class="ruby-keyword kw">nil</span>, <span class="ruby-identifier">aTime</span> = <span class="ruby-keyword kw">nil</span>, <span class="ruby-identifier">aDelay</span> = <span class="ruby-constant">VpiNoDelay</span>
15
+ 116: <span class="ruby-identifier">aFormat</span> <span class="ruby-operator">||=</span> <span class="ruby-identifier">get_value_wrapper</span>(<span class="ruby-constant">VpiObjTypeVal</span>).<span class="ruby-identifier">format</span>
26
16
  117:
27
- 118: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiIntVal</span>
28
- 119: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">format</span> = <span class="ruby-constant">VpiHexStrVal</span>
29
- 120: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">str</span> = <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_i</span>.<span class="ruby-identifier">to_s</span>(<span class="ruby-value">16</span>)
30
- 121:
31
- 122: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiRealVal</span>
32
- 123: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">real</span> = <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_f</span>
17
+ 118: <span class="ruby-identifier">newVal</span> = <span class="ruby-constant">S_vpi_value</span>.<span class="ruby-identifier">new</span>
18
+ 119: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">format</span> = <span class="ruby-identifier">aFormat</span>
19
+ 120:
20
+ 121: <span class="ruby-keyword kw">case</span> <span class="ruby-identifier">aFormat</span>
21
+ 122: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiBinStrVal</span>, <span class="ruby-constant">VpiOctStrVal</span>, <span class="ruby-constant">VpiDecStrVal</span>, <span class="ruby-constant">VpiHexStrVal</span>, <span class="ruby-constant">VpiStringVal</span>
22
+ 123: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">str</span> = <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_s</span>
33
23
  124:
34
- 125: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiTimeVal</span>
35
- 126: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">time</span> = <span class="ruby-identifier">aValue</span>
24
+ 125: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiScalarVal</span>
25
+ 126: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">scalar</span> = <span class="ruby-identifier">aValue</span>
36
26
  127:
37
- 128: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiVectorVal</span>
38
- 129: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">vector</span> = <span class="ruby-identifier">aValue</span>
39
- 130:
40
- 131: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiStrengthVal</span>
41
- 132: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">strength</span> = <span class="ruby-identifier">aValue</span>
42
- 133:
43
- 134: <span class="ruby-keyword kw">else</span>
44
- 135: <span class="ruby-identifier">raise</span> <span class="ruby-node">&quot;unknown S_vpi_value.format: #{newVal.format}&quot;</span>
45
- 136: <span class="ruby-keyword kw">end</span>
27
+ 128: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiIntVal</span>
28
+ 129: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">format</span> = <span class="ruby-constant">VpiHexStrVal</span>
29
+ 130: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">str</span> = <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_i</span>.<span class="ruby-identifier">to_s</span>(<span class="ruby-value">16</span>)
30
+ 131:
31
+ 132: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiRealVal</span>
32
+ 133: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">real</span> = <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_f</span>
33
+ 134:
34
+ 135: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiTimeVal</span>
35
+ 136: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">time</span> = <span class="ruby-identifier">aValue</span>
46
36
  137:
47
- 138: <span class="ruby-identifier">vpi_put_value</span> <span class="ruby-keyword kw">self</span>, <span class="ruby-identifier">newVal</span>, <span class="ruby-identifier">aTime</span>, <span class="ruby-identifier">aDelay</span>
48
- 139:
49
- 140: <span class="ruby-comment cmt"># ensure that value was written correctly</span>
50
- 141: <span class="ruby-identifier">readenVal</span> = <span class="ruby-identifier">get_value</span>(<span class="ruby-identifier">aFormat</span>)
51
- 142:
52
- 143: <span class="ruby-identifier">writtenCorrectly</span> =
53
- 144: <span class="ruby-keyword kw">case</span> <span class="ruby-identifier">aFormat</span>
54
- 145: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiBinStrVal</span>, <span class="ruby-constant">VpiOctStrVal</span>, <span class="ruby-constant">VpiDecStrVal</span>, <span class="ruby-constant">VpiHexStrVal</span>
55
- 146: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">aValue</span> <span class="ruby-operator">=~</span> <span class="ruby-regexp re">/[xz]/i</span> <span class="ruby-comment cmt"># TODO: verify 'z' behavior</span>
56
- 147: <span class="ruby-identifier">readenVal</span> <span class="ruby-operator">=~</span> <span class="ruby-regexp re">/[xz]/i</span>
57
- 148: <span class="ruby-keyword kw">else</span>
58
- 149: <span class="ruby-identifier">readenVal</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_s</span>
59
- 150: <span class="ruby-keyword kw">end</span>
60
- 151:
61
- 152: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiStringVal</span>
62
- 153: <span class="ruby-identifier">readenVal</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_s</span>
63
- 154:
64
- 155: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiIntVal</span>
65
- 156: <span class="ruby-comment cmt"># allow for register overflow when limit reached</span>
66
- 157: <span class="ruby-identifier">readenVal</span> <span class="ruby-operator">==</span> (<span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_i</span> <span class="ruby-operator">%</span> (<span class="ruby-value">2</span> <span class="ruby-operator">**</span> <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">vpiSize</span>))
67
- 158:
68
- 159: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiRealVal</span>
69
- 160: <span class="ruby-identifier">readenVal</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_f</span>
37
+ 138: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiVectorVal</span>
38
+ 139: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">vector</span> = <span class="ruby-identifier">aValue</span>
39
+ 140:
40
+ 141: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiStrengthVal</span>
41
+ 142: <span class="ruby-identifier">newVal</span>.<span class="ruby-identifier">value</span>.<span class="ruby-identifier">strength</span> = <span class="ruby-identifier">aValue</span>
42
+ 143:
43
+ 144: <span class="ruby-keyword kw">else</span>
44
+ 145: <span class="ruby-identifier">raise</span> <span class="ruby-node">&quot;unknown S_vpi_value.format: #{newVal.format}&quot;</span>
45
+ 146: <span class="ruby-keyword kw">end</span>
46
+ 147:
47
+ 148: <span class="ruby-identifier">vpi_put_value</span> <span class="ruby-keyword kw">self</span>, <span class="ruby-identifier">newVal</span>, <span class="ruby-identifier">aTime</span>, <span class="ruby-identifier">aDelay</span>
48
+ 149:
49
+ 150: <span class="ruby-comment cmt"># ensure that value was written correctly</span>
50
+ 151: <span class="ruby-identifier">readenVal</span> = <span class="ruby-identifier">get_value</span>(<span class="ruby-identifier">aFormat</span>)
51
+ 152:
52
+ 153: <span class="ruby-identifier">writtenCorrectly</span> =
53
+ 154: <span class="ruby-keyword kw">case</span> <span class="ruby-identifier">aFormat</span>
54
+ 155: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiBinStrVal</span>, <span class="ruby-constant">VpiOctStrVal</span>, <span class="ruby-constant">VpiDecStrVal</span>, <span class="ruby-constant">VpiHexStrVal</span>
55
+ 156: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">aValue</span> <span class="ruby-operator">=~</span> <span class="ruby-regexp re">/[xz]/i</span> <span class="ruby-comment cmt"># TODO: verify 'z' behavior</span>
56
+ 157: <span class="ruby-identifier">readenVal</span> <span class="ruby-operator">=~</span> <span class="ruby-regexp re">/[xz]/i</span>
57
+ 158: <span class="ruby-keyword kw">else</span>
58
+ 159: <span class="ruby-identifier">readenVal</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_s</span>
59
+ 160: <span class="ruby-keyword kw">end</span>
70
60
  161:
71
- 162: <span class="ruby-keyword kw">else</span>
72
- 163: <span class="ruby-keyword kw">true</span>
73
- 164: <span class="ruby-keyword kw">end</span>
74
- 165:
75
- 166: <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">writtenCorrectly</span>
76
- 167: <span class="ruby-identifier">raise</span> <span class="ruby-node">&quot;value written (#{aValue.inspect}) does not match value read (#{readenVal.inspect}) from handle #{self}&quot;</span>
77
- 168: <span class="ruby-keyword kw">end</span>
78
- 169:
79
- 170: <span class="ruby-identifier">aValue</span>
80
- 171: <span class="ruby-keyword kw">end</span></pre>
61
+ 162: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiStringVal</span>
62
+ 163: <span class="ruby-identifier">readenVal</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_s</span>
63
+ 164:
64
+ 165: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiIntVal</span>
65
+ 166: <span class="ruby-comment cmt"># allow for register overflow when limit reached</span>
66
+ 167: <span class="ruby-identifier">readenVal</span> <span class="ruby-operator">==</span> (<span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_i</span> <span class="ruby-operator">%</span> (<span class="ruby-value">2</span> <span class="ruby-operator">**</span> <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">vpiSize</span>))
67
+ 168:
68
+ 169: <span class="ruby-keyword kw">when</span> <span class="ruby-constant">VpiRealVal</span>
69
+ 170: <span class="ruby-identifier">readenVal</span> <span class="ruby-operator">==</span> <span class="ruby-identifier">aValue</span>.<span class="ruby-identifier">to_f</span>
70
+ 171:
71
+ 172: <span class="ruby-keyword kw">else</span>
72
+ 173: <span class="ruby-keyword kw">true</span>
73
+ 174: <span class="ruby-keyword kw">end</span>
74
+ 175:
75
+ 176: <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">writtenCorrectly</span>
76
+ 177: <span class="ruby-identifier">raise</span> <span class="ruby-node">&quot;value written (#{aValue.inspect}) does not match value read (#{readenVal.inspect}) from handle #{self}&quot;</span>
77
+ 178: <span class="ruby-keyword kw">end</span>
78
+ 179:
79
+ 180: <span class="ruby-identifier">aValue</span>
80
+ 181: <span class="ruby-keyword kw">end</span></pre>
81
81
  </body>
82
82
  </html>