ruby-vpi 9.0.0 → 10.0.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 (250) hide show
  1. data/HISTORY +120 -56
  2. data/MEMO +8 -0
  3. data/README +1 -1
  4. data/Rakefile +2 -2
  5. data/bin/generate_test.rb +11 -12
  6. data/bin/generate_test_tpl/bench.rb +2 -2
  7. data/bin/generate_test_tpl/bench.v +1 -4
  8. data/bin/generate_test_tpl/design.rb +6 -20
  9. data/bin/generate_test_tpl/proto.rb +5 -3
  10. data/bin/generate_test_tpl/runner.rake +2 -1
  11. data/bin/generate_test_tpl/spec.rb +5 -12
  12. data/doc/background.organization.html +1 -1
  13. data/doc/background.running-tests.html +1 -1
  14. data/doc/index.html +2 -2
  15. data/doc/manual.txt +276 -223
  16. data/doc/problem.ivl.html +3 -3
  17. data/doc/problems.html +1 -1
  18. data/doc/problems.ruby.html +1 -1
  19. data/doc/problems.vsim.html +1 -1
  20. data/doc/setup.html +3 -0
  21. data/doc/setup.installation.html +9 -0
  22. data/doc/setup.maintenance.html +3 -0
  23. data/doc/setup.reqs.html +3 -0
  24. data/doc/src/manual.xml +232 -195
  25. data/doc/styles/manual.css +8 -0
  26. data/doc/usage.examples.html +1 -1
  27. data/doc/usage.html +1 -1
  28. data/doc/usage.tools.html +7 -1
  29. data/doc/usage.tutorial.html +50 -56
  30. data/history.html +195 -77
  31. data/history.part.html +195 -77
  32. data/lib/ruby-vpi/vpi.rb +13 -1
  33. data/lib/ruby-vpi.rb +18 -7
  34. data/memo.html +19 -0
  35. data/memo.part.html +19 -0
  36. data/readme.html +1 -1
  37. data/readme.part.html +1 -1
  38. data/samp/counter/counter_rspec_bench.rb +2 -2
  39. data/samp/counter/counter_rspec_bench.v +1 -4
  40. data/samp/counter/counter_rspec_design.rb +4 -18
  41. data/samp/counter/counter_rspec_proto.rb +7 -5
  42. data/samp/counter/counter_rspec_runner.rake +2 -1
  43. data/samp/counter/counter_rspec_spec.rb +8 -12
  44. data/samp/counter/counter_xunit_bench.rb +2 -2
  45. data/samp/counter/counter_xunit_bench.v +1 -4
  46. data/samp/counter/counter_xunit_design.rb +4 -18
  47. data/samp/counter/counter_xunit_proto.rb +7 -5
  48. data/samp/counter/counter_xunit_runner.rake +2 -1
  49. data/samp/counter/counter_xunit_spec.rb +8 -14
  50. data/samp/pipelined_alu/hw5_unit_test_bench.rb +3 -3
  51. data/samp/pipelined_alu/hw5_unit_test_bench.v +1 -4
  52. data/samp/pipelined_alu/hw5_unit_test_design.rb +49 -65
  53. data/samp/pipelined_alu/hw5_unit_test_proto.rb +9 -5
  54. data/samp/pipelined_alu/hw5_unit_test_runner.rake +2 -1
  55. data/samp/pipelined_alu/hw5_unit_test_spec.rb +18 -21
  56. metadata +8 -242
  57. data/doc/usage.installation.html +0 -9
  58. data/doc/usage.recommendations.html +0 -3
  59. data/doc/usage.requirements.html +0 -3
  60. data/ref/c/annotated.html +0 -35
  61. data/ref/c/common_8h.html +0 -146
  62. data/ref/c/doxygen.css +0 -358
  63. data/ref/c/doxygen.png +0 -0
  64. data/ref/c/files.html +0 -34
  65. data/ref/c/functions.html +0 -134
  66. data/ref/c/functions_vars.html +0 -134
  67. data/ref/c/globals.html +0 -55
  68. data/ref/c/globals_0x63.html +0 -86
  69. data/ref/c/globals_0x65.html +0 -55
  70. data/ref/c/globals_0x66.html +0 -55
  71. data/ref/c/globals_0x70.html +0 -71
  72. data/ref/c/globals_0x72.html +0 -62
  73. data/ref/c/globals_0x73.html +0 -65
  74. data/ref/c/globals_0x74.html +0 -55
  75. data/ref/c/globals_0x76.html +0 -472
  76. data/ref/c/globals_0x78.html +0 -55
  77. data/ref/c/globals_defs.html +0 -81
  78. data/ref/c/globals_defs_0x65.html +0 -50
  79. data/ref/c/globals_defs_0x70.html +0 -51
  80. data/ref/c/globals_defs_0x76.html +0 -463
  81. data/ref/c/globals_defs_0x78.html +0 -50
  82. data/ref/c/globals_enum.html +0 -39
  83. data/ref/c/globals_eval.html +0 -40
  84. data/ref/c/globals_func.html +0 -49
  85. data/ref/c/globals_type.html +0 -63
  86. data/ref/c/globals_vars.html +0 -42
  87. data/ref/c/index.html +0 -20
  88. data/ref/c/relay_8c.html +0 -214
  89. data/ref/c/relay_8h.html +0 -129
  90. data/ref/c/structrelay____RubyOptions____def.html +0 -67
  91. data/ref/c/structt__cb__data.html +0 -151
  92. data/ref/c/structt__vpi__delay.html +0 -134
  93. data/ref/c/structt__vpi__error__info.html +0 -151
  94. data/ref/c/structt__vpi__strengthval.html +0 -83
  95. data/ref/c/structt__vpi__systf__data.html +0 -151
  96. data/ref/c/structt__vpi__time.html +0 -100
  97. data/ref/c/structt__vpi__value.html +0 -204
  98. data/ref/c/structt__vpi__vecval.html +0 -66
  99. data/ref/c/structt__vpi__vlog__info.html +0 -100
  100. data/ref/c/swig_8c.html +0 -80
  101. data/ref/c/swig_8h.html +0 -83
  102. data/ref/c/tab_b.gif +0 -0
  103. data/ref/c/tab_l.gif +0 -0
  104. data/ref/c/tab_r.gif +0 -0
  105. data/ref/c/tabs.css +0 -102
  106. data/ref/c/verilog_8h.html +0 -117
  107. data/ref/c/vlog_8c.html +0 -168
  108. data/ref/c/vlog_8h.html +0 -128
  109. data/ref/c/vpi__user_8h.html +0 -8739
  110. data/ref/ruby/classes/ERB.html +0 -158
  111. data/ref/ruby/classes/ERB.src/M000034.html +0 -29
  112. data/ref/ruby/classes/FileUtils.html +0 -165
  113. data/ref/ruby/classes/FileUtils.src/M000089.html +0 -18
  114. data/ref/ruby/classes/FileUtils.src/M000090.html +0 -18
  115. data/ref/ruby/classes/Integer.html +0 -398
  116. data/ref/ruby/classes/Integer.src/M000012.html +0 -25
  117. data/ref/ruby/classes/Integer.src/M000013.html +0 -18
  118. data/ref/ruby/classes/Integer.src/M000014.html +0 -18
  119. data/ref/ruby/classes/Integer.src/M000015.html +0 -18
  120. data/ref/ruby/classes/Integer.src/M000016.html +0 -18
  121. data/ref/ruby/classes/Integer.src/M000017.html +0 -18
  122. data/ref/ruby/classes/Integer.src/M000020.html +0 -22
  123. data/ref/ruby/classes/Integer.src/M000021.html +0 -22
  124. data/ref/ruby/classes/Integer.src/M000022.html +0 -25
  125. data/ref/ruby/classes/Integer.src/M000023.html +0 -31
  126. data/ref/ruby/classes/Integer.src/M000024.html +0 -25
  127. data/ref/ruby/classes/Integer.src/M000025.html +0 -30
  128. data/ref/ruby/classes/OutputInfo.html +0 -299
  129. data/ref/ruby/classes/OutputInfo.src/M000030.html +0 -51
  130. data/ref/ruby/classes/RDoc.html +0 -135
  131. data/ref/ruby/classes/RDoc.src/M000093.html +0 -40
  132. data/ref/ruby/classes/RubyVpi/Config.html +0 -148
  133. data/ref/ruby/classes/RubyVpi.html +0 -186
  134. data/ref/ruby/classes/RubyVpi.src/M000091.html +0 -50
  135. data/ref/ruby/classes/RubyVpi.src/M000092.html +0 -20
  136. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.html +0 -407
  137. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/M000081.html +0 -18
  138. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/M000082.html +0 -18
  139. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/M000083.html +0 -22
  140. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/M000084.html +0 -44
  141. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/M000085.html +0 -82
  142. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/M000086.html +0 -127
  143. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/M000087.html +0 -26
  144. data/ref/ruby/classes/SWIG/TYPE_p_unsigned_int.src/M000088.html +0 -18
  145. data/ref/ruby/classes/SWIG.html +0 -111
  146. data/ref/ruby/classes/String.html +0 -158
  147. data/ref/ruby/classes/String.src/M000032.html +0 -41
  148. data/ref/ruby/classes/String.src/M000033.html +0 -18
  149. data/ref/ruby/classes/Table.html +0 -191
  150. data/ref/ruby/classes/Table.src/M000026.html +0 -38
  151. data/ref/ruby/classes/Table.src/M000027.html +0 -18
  152. data/ref/ruby/classes/Table.src/M000028.html +0 -18
  153. data/ref/ruby/classes/Table.src/M000029.html +0 -18
  154. data/ref/ruby/classes/Template.html +0 -158
  155. data/ref/ruby/classes/Template.src/M000031.html +0 -18
  156. data/ref/ruby/classes/VerilogParser/Module/Parameter.html +0 -160
  157. data/ref/ruby/classes/VerilogParser/Module/Parameter.src/M000011.html +0 -21
  158. data/ref/ruby/classes/VerilogParser/Module/Port.html +0 -207
  159. data/ref/ruby/classes/VerilogParser/Module/Port.src/M000007.html +0 -21
  160. data/ref/ruby/classes/VerilogParser/Module/Port.src/M000008.html +0 -18
  161. data/ref/ruby/classes/VerilogParser/Module/Port.src/M000009.html +0 -18
  162. data/ref/ruby/classes/VerilogParser/Module/Port.src/M000010.html +0 -18
  163. data/ref/ruby/classes/VerilogParser/Module.html +0 -172
  164. data/ref/ruby/classes/VerilogParser/Module.src/M000006.html +0 -29
  165. data/ref/ruby/classes/VerilogParser.html +0 -187
  166. data/ref/ruby/classes/VerilogParser.src/M000005.html +0 -34
  167. data/ref/ruby/classes/XX/Document.html +0 -295
  168. data/ref/ruby/classes/XX/Document.src/M000072.html +0 -22
  169. data/ref/ruby/classes/XX/Document.src/M000073.html +0 -20
  170. data/ref/ruby/classes/XX/Document.src/M000074.html +0 -20
  171. data/ref/ruby/classes/XX/Document.src/M000075.html +0 -20
  172. data/ref/ruby/classes/XX/Document.src/M000076.html +0 -22
  173. data/ref/ruby/classes/XX/Document.src/M000077.html +0 -21
  174. data/ref/ruby/classes/XX/Document.src/M000078.html +0 -21
  175. data/ref/ruby/classes/XX/Document.src/M000079.html +0 -34
  176. data/ref/ruby/classes/XX/Document.src/M000080.html +0 -98
  177. data/ref/ruby/classes/XX/HTML4/Strict.html +0 -138
  178. data/ref/ruby/classes/XX/HTML4/Strict.src/M000038.html +0 -20
  179. data/ref/ruby/classes/XX/HTML4/Transitional.html +0 -138
  180. data/ref/ruby/classes/XX/HTML4/Transitional.src/M000037.html +0 -20
  181. data/ref/ruby/classes/XX/HTML4.html +0 -145
  182. data/ref/ruby/classes/XX/HTML4.src/M000036.html +0 -20
  183. data/ref/ruby/classes/XX/Markup/ClassMethods.html +0 -236
  184. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000044.html +0 -22
  185. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000045.html +0 -20
  186. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000046.html +0 -25
  187. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000047.html +0 -20
  188. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000048.html +0 -27
  189. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000049.html +0 -20
  190. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000050.html +0 -27
  191. data/ref/ruby/classes/XX/Markup/ClassMethods.src/M000051.html +0 -22
  192. data/ref/ruby/classes/XX/Markup/Error.html +0 -111
  193. data/ref/ruby/classes/XX/Markup/InstanceMethods.html +0 -474
  194. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000052.html +0 -56
  195. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000053.html +0 -33
  196. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000054.html +0 -31
  197. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000055.html +0 -48
  198. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000056.html +0 -20
  199. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000057.html +0 -31
  200. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000058.html +0 -32
  201. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000059.html +0 -32
  202. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000060.html +0 -28
  203. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000061.html +0 -23
  204. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000062.html +0 -26
  205. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000063.html +0 -20
  206. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000064.html +0 -20
  207. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000065.html +0 -20
  208. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000066.html +0 -20
  209. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000067.html +0 -20
  210. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000068.html +0 -21
  211. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000069.html +0 -20
  212. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000070.html +0 -20
  213. data/ref/ruby/classes/XX/Markup/InstanceMethods.src/M000071.html +0 -20
  214. data/ref/ruby/classes/XX/Markup.html +0 -160
  215. data/ref/ruby/classes/XX/Markup.src/M000043.html +0 -28
  216. data/ref/ruby/classes/XX/XHTML/Strict.html +0 -138
  217. data/ref/ruby/classes/XX/XHTML/Strict.src/M000041.html +0 -20
  218. data/ref/ruby/classes/XX/XHTML/Transitional.html +0 -138
  219. data/ref/ruby/classes/XX/XHTML/Transitional.src/M000040.html +0 -20
  220. data/ref/ruby/classes/XX/XHTML.html +0 -145
  221. data/ref/ruby/classes/XX/XHTML.src/M000039.html +0 -36
  222. data/ref/ruby/classes/XX/XML.html +0 -138
  223. data/ref/ruby/classes/XX/XML.src/M000035.html +0 -20
  224. data/ref/ruby/classes/XX/XMLish.html +0 -138
  225. data/ref/ruby/classes/XX/XMLish.src/M000042.html +0 -18
  226. data/ref/ruby/classes/XX.html +0 -138
  227. data/ref/ruby/created.rid +0 -1
  228. data/ref/ruby/files/bin/generate_test_rb.html +0 -245
  229. data/ref/ruby/files/bin/generate_test_rb.src/M000001.html +0 -18
  230. data/ref/ruby/files/bin/generate_test_rb.src/M000002.html +0 -39
  231. data/ref/ruby/files/bin/header_to_ruby_rb.html +0 -125
  232. data/ref/ruby/files/lib/ruby-vpi/erb_rb.html +0 -108
  233. data/ref/ruby/files/lib/ruby-vpi/integer_rb.html +0 -101
  234. data/ref/ruby/files/lib/ruby-vpi/rake_rb.html +0 -108
  235. data/ref/ruby/files/lib/ruby-vpi/rcov_rb.html +0 -111
  236. data/ref/ruby/files/lib/ruby-vpi/rdoc_rb.html +0 -108
  237. data/ref/ruby/files/lib/ruby-vpi/rspec_rb.html +0 -115
  238. data/ref/ruby/files/lib/ruby-vpi/runner_proxy_rb.html +0 -108
  239. data/ref/ruby/files/lib/ruby-vpi/runner_rb.html +0 -208
  240. data/ref/ruby/files/lib/ruby-vpi/runner_rb.src/M000003.html +0 -24
  241. data/ref/ruby/files/lib/ruby-vpi/runner_rb.src/M000004.html +0 -26
  242. data/ref/ruby/files/lib/ruby-vpi/verilog_parser_rb.html +0 -107
  243. data/ref/ruby/files/lib/ruby-vpi/vpi_rb.html +0 -108
  244. data/ref/ruby/files/lib/ruby-vpi/xx_rb.html +0 -148
  245. data/ref/ruby/files/lib/ruby-vpi_rb.html +0 -109
  246. data/ref/ruby/fr_class_index.html +0 -56
  247. data/ref/ruby/fr_file_index.html +0 -40
  248. data/ref/ruby/fr_method_index.html +0 -119
  249. data/ref/ruby/index.html +0 -24
  250. data/ref/ruby/rdoc-style.css +0 -208
data/history.html CHANGED
@@ -113,6 +113,86 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
113
113
  <p id="fn1"><sup>1</sup> C. Gross, &#8220;Explaining Open Source Version Numbers&#8221;, [Online document], 2005 Nov 28, [cited 2006 Aug 27], Available <span class="caps">HTTP</span>: <a href="http://ablog.apress.com/?p=738">http://ablog.apress.com/?p=738</a></p>
114
114
 
115
115
 
116
+ <h1>Version 10.0.0 (2006-11-05)</h1>
117
+
118
+
119
+ <h2>Summary</h2>
120
+
121
+
122
+ <p>This release adds the ability to access a handle&#8217;s children and reduces the amount of code produced by the automated test generator.</p>
123
+
124
+
125
+ <h2>Acknowledgment</h2>
126
+
127
+
128
+ <p>Thanks to Matt Fischler for finding the problem of misdirected compilation errors in Verilog benches.</p>
129
+
130
+
131
+ <h2>Notice</h2>
132
+
133
+
134
+ <ul>
135
+ <li>The way in which Ruby-VPI and generated tests interact has changed: the design is now a <span class="caps">VPI</span> handle object and the <code>design.rb</code> and <code>proto.rb</code> files define <a href="http://wiki.rubygarden.org/Ruby/page/show/SingletonTutorial">singleton methods</a> for that object.
136
+ <ul>
137
+ <li>I suggest that you regenerate your existing tests (just run <strong>generate_test.rb</strong> again) whilst employing the service of a text merging tool (see the user manual).</li>
138
+ </ul></li>
139
+ </ul>
140
+
141
+
142
+ <ul>
143
+ <li>You can now access a handle&#8217;s children by simply calling methods on it. In the event that a child handle has the same name as a <span class="caps">VPI</span> property, the child is given priority. However, you can always access <span class="caps">VPI</span> properties explicitly via the <code>get_value</code> and <code>put_value</code> methods.</li>
144
+ </ul>
145
+
146
+
147
+ <ul>
148
+ <li><strong>generate_test.rb</strong> no longer accepts the <code>-s</code> and <code>-u</code> options. Use their longer counterparts <code>--rspec</code> and <code>--xunit</code> instead.</li>
149
+ </ul>
150
+
151
+
152
+ <h2>Detail</h2>
153
+
154
+
155
+ <h3>Automated test generator</h3>
156
+
157
+
158
+ <ul>
159
+ <li>Generated Verilog benches no longer divert compilation errors from Verilog design files. That is, if the Verilog simulator finds compilation errors in a Verilog design file, it will report that the Verilog design file is at fault (instead of reporting that the generated Verilog bench is at fault).</li>
160
+ </ul>
161
+
162
+
163
+ <ul>
164
+ <li>The user is now notified when a backup of an existing file is made.</li>
165
+ </ul>
166
+
167
+
168
+ <ul>
169
+ <li>Generated tests have been greatly simplified to reduce the amount of work for the user.
170
+ <ul>
171
+ <li>The design is now just a handle to the module in the Verilog bench.</li>
172
+ <li><code>include Vpi</code> and <code>@design</code> are no longer generated.</li>
173
+ <li>The tutorial and examples have been updated accordingly.</li>
174
+ </ul></li>
175
+ </ul>
176
+
177
+
178
+ <h3>User manual</h3>
179
+
180
+
181
+ <ul>
182
+ <li>Revised the stylesheet to make disjoint sections readily distinguishable from eachother, through generous spacing and minor coloring.</li>
183
+ </ul>
184
+
185
+
186
+ <ul>
187
+ <li>Added tips about <code>ruby-vpi/runner_proxy</code>, <code>rake -T</code>, and using <strong>kdiff3</strong> with <strong>generate_test.rb</strong>.</li>
188
+ </ul>
189
+
190
+
191
+ <ul>
192
+ <li>Moved installation information into a new &#8220;setup&#8221; chapter.</li>
193
+ </ul>
194
+
195
+
116
196
  <h1>Version 9.0.0 (2006-10-28)</h1>
117
197
 
118
198
 
@@ -122,7 +202,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
122
202
  <p>This release improves the automated test generator and adds new content to the user manual.</p>
123
203
 
124
204
 
125
- <h2>Acknowledgments</h2>
205
+ <h2>Acknowledgment</h2>
126
206
 
127
207
 
128
208
  <p>Thanks to Matt Fischler for helping test and debug the installation of Ruby-VPI on Windows.</p>
@@ -136,7 +216,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
136
216
  </ul>
137
217
 
138
218
 
139
- <h2>Details</h2>
219
+ <h2>Detail</h2>
140
220
 
141
221
 
142
222
  <ul>
@@ -188,7 +268,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
188
268
  <p>This release simplifies configuration of generated tests.</p>
189
269
 
190
270
 
191
- <h2>Acknowledgments</h2>
271
+ <h2>Acknowledgment</h2>
192
272
 
193
273
 
194
274
  <p>Thanks to <a href="http://www.soe.ucsc.edu/classes/cmpe126/Fall06/">students in <span class="caps">CMPE</span>-126</a> for their constructive criticism.</p>
@@ -202,7 +282,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
202
282
  </ul>
203
283
 
204
284
 
205
- <h2>Details</h2>
285
+ <h2>Detail</h2>
206
286
 
207
287
 
208
288
  <ul>
@@ -229,7 +309,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
229
309
  </ul>
230
310
 
231
311
 
232
- <h2>Details</h2>
312
+ <h2>Detail</h2>
233
313
 
234
314
 
235
315
  <ul>
@@ -262,7 +342,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
262
342
  </ul>
263
343
 
264
344
 
265
- <h2>Details</h2>
345
+ <h2>Detail</h2>
266
346
 
267
347
 
268
348
  <ul>
@@ -308,13 +388,13 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
308
388
  <ul>
309
389
  <li>Handles now have two new methods:
310
390
  <ul>
311
- <li><code>handle.x?</code>&#8212;checks if the logic value is &#8220;don&#8217;t care&#8221; </li>
312
- <li><code>handle.z?</code>&#8212;checks if the logic value is high impedance</li>
391
+ <li><code>handle.x?</code> checks if the logic value is &#8220;don&#8217;t care&#8221; </li>
392
+ <li><code>handle.z?</code> checks if the logic value is high impedance</li>
313
393
  </ul></li>
314
394
  </ul>
315
395
 
316
396
 
317
- <h2>Details</h2>
397
+ <h2>Detail</h2>
318
398
 
319
399
 
320
400
  <ul>
@@ -344,13 +424,13 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
344
424
  <p>This release adds initial<sup><a href="#fn1">1</a></sup> support for code coverage analysis via the <a href="http://eigenclass.org/hiki.rb?rcov">rcov library</a>.</p>
345
425
 
346
426
 
347
- <h2>Acknowledgments</h2>
427
+ <h2>Acknowledgment</h2>
348
428
 
349
429
 
350
430
  <p>Thanks to Mauricio Fernandez for helping me use rcov without its runner.</p>
351
431
 
352
432
 
353
- <h2>Details</h2>
433
+ <h2>Detail</h2>
354
434
 
355
435
 
356
436
  <ul>
@@ -378,7 +458,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
378
458
  <p>This release simplifies running of multiple tests, restores compatibility with Synopsys <span class="caps">VCS</span>, and better integrates with RubyGems.</p>
379
459
 
380
460
 
381
- <h2>Details</h2>
461
+ <h2>Detail</h2>
382
462
 
383
463
 
384
464
  <ul>
@@ -415,7 +495,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
415
495
  <p>This release distributes Ruby-VPI as a gem, improves portability of generated tests, and fixes a bug.</p>
416
496
 
417
497
 
418
- <h2>Details</h2>
498
+ <h2>Notice</h2>
419
499
 
420
500
 
421
501
  <ul>
@@ -423,11 +503,6 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
423
503
  </ul>
424
504
 
425
505
 
426
- <ul>
427
- <li>Ruby-VPI is now distributed only as a <a href="http://www.rubygems.org">source gem</a>. You can decompress the gem without installing it onto your system by running the command <code>gem install -i output_directory ruby-vpi-7.0.0.gem</code>. In addition, you can still obtain the source code directly from the Subversion repository.</li>
428
- </ul>
429
-
430
-
431
506
  <ul>
432
507
  <li>The test generator&#8217;s templates and the examples have been updated as follows:
433
508
  <ul>
@@ -447,6 +522,14 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
447
522
  </ul>
448
523
 
449
524
 
525
+ <h2>Detail</h2>
526
+
527
+
528
+ <ul>
529
+ <li>Ruby-VPI is now distributed only as a <a href="http://www.rubygems.org">source gem</a>. You can decompress the gem without installing it onto your system by running the command <code>gem install -i output_directory ruby-vpi-7.0.0.gem</code>. In addition, you can still obtain the source code directly from the Subversion repository.</li>
530
+ </ul>
531
+
532
+
450
533
  <ul>
451
534
  <li>The tools in <code>bin/</code> become available in your system&#8217;s <code>bin/</code> directory when the gem is installed.
452
535
  <ul>
@@ -479,20 +562,27 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
479
562
  <p>This release adds support for the <span class="caps">GPL</span> Cver simulator, provides both binary and source packages, and explicitly defines the version numbering system.</p>
480
563
 
481
564
 
482
- <h2>Details</h2>
565
+ <h2>Notice</h2>
483
566
 
484
567
 
485
568
  <ul>
486
- <li>The <span class="caps">GPL</span> Cver simulator is now supported.</li>
569
+ <li>Ruby-VPI now only needs to be built once.
570
+ <ul>
571
+ <li>You can run tests with different Verilog simulators without having to re-compile Ruby-VPI.</li>
572
+ </ul></li>
487
573
  </ul>
488
574
 
489
575
 
576
+ <h2>Detail</h2>
577
+
578
+
490
579
  <ul>
491
- <li>Ruby-VPI now only needs to be built once.
580
+ <li>The <span class="caps">GPL</span> Cver simulator is now supported.</li>
581
+ </ul>
582
+
583
+
492
584
  <ul>
493
- <li>You can run tests with different Verilog simulators without having to re-compile Ruby-VPI.</li>
494
- <li>Release packages are now available in both source and binary form.</li>
495
- </ul></li>
585
+ <li>Release packages are now available in both source and binary form.</li>
496
586
  </ul>
497
587
 
498
588
 
@@ -587,31 +677,34 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
587
677
  <p>This release beautifies generated tests, adds checks to find signal width bugs, and includes a new tool.</p>
588
678
 
589
679
 
590
- <h2>Details</h2>
680
+ <h2>Notice</h2>
591
681
 
592
682
 
593
683
  <ul>
594
- <li>The test generator now uses <span class="caps">ERB</span> templates which ensures nice indentation of generated output.</li>
684
+ <li><code>put_value()</code> now returns the value it puts. Therefore, it is easier to chain together a series of assignments: <code>foo.intVal = bar.intVal = baz.intVal = 10</code></li>
595
685
  </ul>
596
686
 
597
687
 
598
688
  <ul>
599
- <li>The test generator now decouples Ruby-VPI paths from Verilog benches via the <span class="caps">RUBYLIB</span> environment variable.</li>
689
+ <li><code>put_value()</code> now verifies that the value it puts was written correctly. This helps to find bugs regarding invalid assumptions about the number of bits supported by a signal.</li>
600
690
  </ul>
601
691
 
602
692
 
693
+ <h2>Detail</h2>
694
+
695
+
603
696
  <ul>
604
- <li>A tool which converts Verilog headers into Ruby has been added.</li>
697
+ <li>The test generator now uses <span class="caps">ERB</span> templates which ensures nice indentation of generated output.</li>
605
698
  </ul>
606
699
 
607
700
 
608
701
  <ul>
609
- <li><code>put_value()</code> now returns the value it puts. Therefore, it is easier to chain together a series of assignments: <code>foo.intVal = bar.intVal = baz.intVal = 10</code></li>
702
+ <li>The test generator now decouples Ruby-VPI paths from Verilog benches via the <span class="caps">RUBYLIB</span> environment variable.</li>
610
703
  </ul>
611
704
 
612
705
 
613
706
  <ul>
614
- <li><code>put_value()</code> now verifies that the value it puts was written correctly. This helps to find bugs regarding invalid assumptions about the number of bits supported by a signal.</li>
707
+ <li>A tool which converts Verilog headers into Ruby has been added.</li>
615
708
  </ul>
616
709
 
617
710
 
@@ -629,7 +722,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
629
722
  <p>This release simplifies generated tests and fixes a bug.</p>
630
723
 
631
724
 
632
- <h2>Details</h2>
725
+ <h2>Detail</h2>
633
726
 
634
727
 
635
728
  <ul>
@@ -655,19 +748,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
655
748
  <p>This release adds support and documentation for rapid prototyping of Verilog designs in Ruby.</p>
656
749
 
657
750
 
658
- <h2>Details</h2>
659
-
660
-
661
- <ul>
662
- <li>Support for prototyping designs in Ruby, before they are implemented in Verilog, has been added.
663
- <ul>
664
- <li>The <em>same</em> specification can be used to verify both prototype <em>and</em> design! :-)</li>
665
- <li>The tutorial in the user manual has been updated to discuss prototyping.
666
- <ul>
667
- <li>Prototypes have been added to the counter example.</li>
668
- </ul></li>
669
- </ul></li>
670
- </ul>
751
+ <h2>Notice</h2>
671
752
 
672
753
 
673
754
  <ul>
@@ -685,6 +766,21 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
685
766
  </ul>
686
767
 
687
768
 
769
+ <h2>Detail</h2>
770
+
771
+
772
+ <ul>
773
+ <li>Support for prototyping designs in Ruby, before they are implemented in Verilog, has been added.
774
+ <ul>
775
+ <li>The <em>same</em> specification can be used to verify both prototype <em>and</em> design! :-)</li>
776
+ <li>The tutorial in the user manual has been updated to discuss prototyping.
777
+ <ul>
778
+ <li>Prototypes have been added to the counter example.</li>
779
+ </ul></li>
780
+ </ul></li>
781
+ </ul>
782
+
783
+
688
784
  <ul>
689
785
  <li>The user manual has been revised for consistency.</li>
690
786
  </ul>
@@ -699,7 +795,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
699
795
  <p>This release fixes unreadable syntax coloring in the user manual.</p>
700
796
 
701
797
 
702
- <h2>Acknowledgments</h2>
798
+ <h2>Acknowledgment</h2>
703
799
 
704
800
 
705
801
  <ul>
@@ -707,7 +803,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
707
803
  </ul>
708
804
 
709
805
 
710
- <h2>Details</h2>
806
+ <h2>Detail</h2>
711
807
 
712
808
 
713
809
  <ul>
@@ -729,7 +825,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
729
825
  <p>This release adds a tutorial to the user manual, and improves the tools and examples.</p>
730
826
 
731
827
 
732
- <h2>Acknowledgments</h2>
828
+ <h2>Acknowledgment</h2>
733
829
 
734
830
 
735
831
  <ul>
@@ -737,7 +833,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
737
833
  </ul>
738
834
 
739
835
 
740
- <h2>Details</h2>
836
+ <h2>Detail</h2>
741
837
 
742
838
 
743
839
  <h3>User manual</h3>
@@ -798,7 +894,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
798
894
  <p>This release enhances the <span class="caps">VPI</span> utility layer and adds new content to the user manual.</p>
799
895
 
800
896
 
801
- <h2>Acknowledgments</h2>
897
+ <h2>Acknowledgment</h2>
802
898
 
803
899
 
804
900
  <ul>
@@ -806,7 +902,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
806
902
  </ul>
807
903
 
808
904
 
809
- <h2>Details</h2>
905
+ <h2>Notice</h2>
810
906
 
811
907
 
812
908
  <ul>
@@ -815,17 +911,20 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
815
911
 
816
912
 
817
913
  <ul>
818
- <li>The <span class="caps">VPI</span> utility layer provides access to <span class="caps">VPI</span> properties of handles in a <a href="http://ruby-vpi.rubyforge.org/doc/background.organization.html#organization.vpi">simpler, more powerful way</a>.</li>
914
+ <li>The <code>handle.value</code> and <code>handle.value=</code> methods have been removed.</li>
819
915
  </ul>
820
916
 
821
917
 
918
+ <h2>Detail</h2>
919
+
920
+
822
921
  <ul>
823
- <li>All <span class="caps">VPI</span> properties, except delay values, are now accessible from a handle.</li>
922
+ <li>The <span class="caps">VPI</span> utility layer provides access to <span class="caps">VPI</span> properties of handles in a <a href="http://ruby-vpi.rubyforge.org/doc/background.organization.html#organization.vpi">simpler, more powerful way</a>.</li>
824
923
  </ul>
825
924
 
826
925
 
827
926
  <ul>
828
- <li>The <code>handle.value</code> and <code>handle.value=</code> methods have been removed.</li>
927
+ <li>All <span class="caps">VPI</span> properties, except delay values, are now accessible from a handle.</li>
829
928
  </ul>
830
929
 
831
930
 
@@ -852,7 +951,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
852
951
  <p>This release adds a comprehensive user manual, upgrades from make to <a href="http://rake.rubyforge.org">Rake</a>, and improves the test generation tool.</p>
853
952
 
854
953
 
855
- <h2>Acknowledgments</h2>
954
+ <h2>Acknowledgment</h2>
856
955
 
857
956
 
858
957
  <ul>
@@ -860,21 +959,24 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
860
959
  </ul>
861
960
 
862
961
 
863
- <h2>Details</h2>
962
+ <h2>Notice</h2>
864
963
 
865
964
 
866
965
  <ul>
867
- <li>A comprehensive user manual, written in DocBook-XML, has been added.</li>
966
+ <li>Rake has replaced the role of <strong>make</strong>. All makefiles have been converted accordingly.</li>
868
967
  </ul>
869
968
 
870
969
 
871
970
  <ul>
872
- <li>Rake has replaced the role of <strong>make</strong>. All makefiles have been converted accordingly.</li>
971
+ <li>The test generation tool now generates multiple files (runner, bench, design, spec) and makes backups of existing files. See its help information for details.</li>
873
972
  </ul>
874
973
 
875
974
 
975
+ <h2>Detail</h2>
976
+
977
+
876
978
  <ul>
877
- <li>The test generation tool now generates multiple files (runner, bench, design, spec) and makes backups of existing files. See its help information for details.</li>
979
+ <li>A comprehensive user manual, written in DocBook-XML, has been added.</li>
878
980
  </ul>
879
981
 
880
982
 
@@ -904,7 +1006,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
904
1006
  <p>This release adds a tool which generates test benches, and adds support for <a href="http://behaviour-driven.org">Behavior Driven Development</a> via the <a href="http://rspec.rubyforge.org">RSpec</a> library.</p>
905
1007
 
906
1008
 
907
- <h2>Acknowledgments</h2>
1009
+ <h2>Acknowledgment</h2>
908
1010
 
909
1011
 
910
1012
  <ul>
@@ -912,7 +1014,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
912
1014
  </ul>
913
1015
 
914
1016
 
915
- <h2>Details</h2>
1017
+ <h2>Detail</h2>
916
1018
 
917
1019
 
918
1020
  <ul>
@@ -948,7 +1050,15 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
948
1050
  <p>This release adds simple ways of reading and writing values to <span class="caps">VPI</span> handles, adds documentation for the <span class="caps">VPI</span> utility layer, and fixes the pipelined <span class="caps">ALU</span> example.</p>
949
1051
 
950
1052
 
951
- <h2>Details</h2>
1053
+ <h2>Notice</h2>
1054
+
1055
+
1056
+ <ul>
1057
+ <li>The <strong>msim</strong> Makefile target for Mentor Modelsim has been renamed back to <strong>vsim</strong>.</li>
1058
+ </ul>
1059
+
1060
+
1061
+ <h2>Detail</h2>
952
1062
 
953
1063
 
954
1064
  <ul>
@@ -994,7 +1104,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
994
1104
  <p>This release adds support for the <em>entire</em> <a href="http://ieeexplore.ieee.org/xpl/standardstoc.jsp?isnumber=33945"><span class="caps">IEEE</span> Std. 1364-2005</a> VPI interface, and updates the examples into unit tests.</p>
995
1105
 
996
1106
 
997
- <h2>Acknowledgments</h2>
1107
+ <h2>Acknowledgment</h2>
998
1108
 
999
1109
 
1000
1110
  <ul>
@@ -1002,7 +1112,15 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
1002
1112
  </ul>
1003
1113
 
1004
1114
 
1005
- <h2>Details</h2>
1115
+ <h2>Notice</h2>
1116
+
1117
+
1118
+ <ul>
1119
+ <li>The <strong>vsim</strong> Makefile target for Mentor Modelsim has been renamed to <strong>msim</strong>.</li>
1120
+ </ul>
1121
+
1122
+
1123
+ <h2>Detail</h2>
1006
1124
 
1007
1125
 
1008
1126
  <ul>
@@ -1031,10 +1149,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
1031
1149
 
1032
1150
 
1033
1151
  <ul>
1034
- <li>The makefiles for the examples have been simplified through the use of a common template.
1035
- <ul>
1036
- <li>The <strong>vsim</strong> target for Mentor Modelsim has been renamed to <strong>msim</strong>.</li>
1037
- </ul></li>
1152
+ <li>The makefiles for the examples have been simplified through the use of a common template.</li>
1038
1153
  </ul>
1039
1154
 
1040
1155
 
@@ -1056,7 +1171,7 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
1056
1171
  <p>This release fixes major bugs, adds support for Mentor Modelsim, and removes the <code>$ruby_task</code> callback.</p>
1057
1172
 
1058
1173
 
1059
- <h2>Acknowledgments</h2>
1174
+ <h2>Acknowledgment</h2>
1060
1175
 
1061
1176
 
1062
1177
  <ul>
@@ -1064,7 +1179,15 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
1064
1179
  </ul>
1065
1180
 
1066
1181
 
1067
- <h2>Details</h2>
1182
+ <h2>Notice</h2>
1183
+
1184
+
1185
+ <ul>
1186
+ <li>Removed <code>$ruby_task</code> callback and ability to dynamically register system tasks from Ruby because inter-process communication is complicated at present.</li>
1187
+ </ul>
1188
+
1189
+
1190
+ <h2>Detail</h2>
1068
1191
 
1069
1192
 
1070
1193
  <ul>
@@ -1077,11 +1200,6 @@ We <em>strictly</em> follow the RubyGems project&#8217;s <a href="http://www.rub
1077
1200
  </ul>
1078
1201
 
1079
1202
 
1080
- <ul>
1081
- <li>Removed <code>$ruby_task</code> callback and ability to dynamically register system tasks from Ruby because inter-process communication is complicated at present.</li>
1082
- </ul>
1083
-
1084
-
1085
1203
  <ul>
1086
1204
  <li>Added piplelined <span class="caps">ALU</span> example.</li>
1087
1205
  </ul>
@@ -1111,7 +1229,7 @@ This release adds enough Verilog <span class="caps">VPI</span> functionality to
1111
1229
  </ul>
1112
1230
 
1113
1231
 
1114
- <h2>Acknowledgments</h2>
1232
+ <h2>Acknowledgment</h2>
1115
1233
 
1116
1234
 
1117
1235
  <ul>
@@ -1124,7 +1242,7 @@ This release adds enough Verilog <span class="caps">VPI</span> functionality to
1124
1242
  </ul>
1125
1243
 
1126
1244
 
1127
- <h2>Details</h2>
1245
+ <h2>Detail</h2>
1128
1246
 
1129
1247
 
1130
1248
  <ul>
@@ -1184,7 +1302,7 @@ This release adds enough Verilog <span class="caps">VPI</span> functionality to
1184
1302
  <p>This is Kazuhiro <span class="caps">HIWADA</span>&#8217;s initial testing release of Ruby-VPI. See its <a href="http://www.ruby-talk.org/cgi-bin/scat.rb/ruby/ruby-list/18193">original announcement</a> and <a href="http://easter.kuee.kyoto-u.ac.jp/~hiwada/ruby/memo/src/ruby-vpi-test.tgz">source code</a>.</p>
1185
1303
 
1186
1304
 
1187
- <h2>Details</h2>
1305
+ <h2>Detail</h2>
1188
1306
 
1189
1307
 
1190
1308
  <ul>