ruby-vpi 19.0.0 → 20.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (776) hide show
  1. data/LICENSE +12 -13
  2. data/README +1 -1
  3. data/Rakefile +104 -118
  4. data/TODO +77 -0
  5. data/bin/convert.rb +1 -1
  6. data/bin/generate/design.rb +3 -2
  7. data/bin/generate/loader.rb +1 -0
  8. data/bin/generate/proto.rb +16 -14
  9. data/bin/generate/runner.rake +8 -3
  10. data/bin/generate/spec.rb +11 -13
  11. data/bin/generate.rb +23 -18
  12. data/bin/ruby-vpi +36 -27
  13. data/doc/api/c/annotated.html +36 -0
  14. data/{ref → doc/api}/c/common_8h.html +9 -13
  15. data/{ref → doc/api}/c/doxygen.css +0 -0
  16. data/{ref → doc/api}/c/doxygen.png +0 -0
  17. data/{ref → doc/api}/c/files.html +10 -8
  18. data/doc/api/c/functions.html +184 -0
  19. data/doc/api/c/functions_vars.html +184 -0
  20. data/{ref → doc/api}/c/globals.html +12 -11
  21. data/{ref → doc/api}/c/globals_0x63.html +12 -11
  22. data/{ref → doc/api}/c/globals_0x65.html +12 -11
  23. data/{ref → doc/api}/c/globals_0x66.html +12 -11
  24. data/{ref → doc/api}/c/globals_0x6d.html +14 -13
  25. data/{ref → doc/api}/c/globals_0x70.html +21 -20
  26. data/{ref → doc/api}/c/globals_0x72.html +14 -13
  27. data/{ref → doc/api}/c/globals_0x74.html +12 -11
  28. data/{ref → doc/api}/c/globals_0x76.html +17 -16
  29. data/{ref → doc/api}/c/globals_0x78.html +12 -11
  30. data/{ref → doc/api}/c/globals_defs.html +12 -10
  31. data/{ref → doc/api}/c/globals_defs_0x65.html +12 -10
  32. data/{ref → doc/api}/c/globals_defs_0x70.html +12 -10
  33. data/{ref → doc/api}/c/globals_defs_0x76.html +14 -12
  34. data/{ref → doc/api}/c/globals_defs_0x78.html +12 -10
  35. data/{ref → doc/api}/c/globals_enum.html +11 -9
  36. data/{ref → doc/api}/c/globals_eval.html +11 -9
  37. data/{ref → doc/api}/c/globals_func.html +17 -15
  38. data/doc/api/c/globals_type.html +72 -0
  39. data/{ref → doc/api}/c/globals_vars.html +13 -11
  40. data/{ref → doc/api}/c/index.html +7 -6
  41. data/{ref → doc/api}/c/main_8c.html +7 -11
  42. data/{ref → doc/api}/c/main_8h.html +7 -11
  43. data/{ref → doc/api}/c/relay_8c.html +7 -11
  44. data/{ref → doc/api}/c/relay_8h.html +7 -11
  45. data/{ref/c/structt__cb__data.html → doc/api/c/structs__cb__data.html} +32 -30
  46. data/{ref/c/structt__vpi__delay.html → doc/api/c/structs__vpi__delay.html} +29 -27
  47. data/{ref/c/structt__vpi__error__info.html → doc/api/c/structs__vpi__error__info.html} +32 -30
  48. data/{ref/c/structt__vpi__strengthval.html → doc/api/c/structs__vpi__strengthval.html} +20 -18
  49. data/{ref/c/structt__vpi__systf__data.html → doc/api/c/structs__vpi__systf__data.html} +32 -30
  50. data/{ref/c/structt__vpi__time.html → doc/api/c/structs__vpi__time.html} +23 -21
  51. data/doc/api/c/structs__vpi__value.html +207 -0
  52. data/{ref/c/structt__vpi__vecval.html → doc/api/c/structs__vpi__vecval.html} +17 -15
  53. data/{ref/c/structt__vpi__vlog__info.html → doc/api/c/structs__vpi__vlog__info.html} +23 -21
  54. data/{ref → doc/api}/c/tab_b.gif +0 -0
  55. data/{ref → doc/api}/c/tab_l.gif +0 -0
  56. data/{ref → doc/api}/c/tab_r.gif +0 -0
  57. data/{ref → doc/api}/c/tabs.css +2 -2
  58. data/{ref → doc/api}/c/verilog_8h.html +11 -15
  59. data/{ref → doc/api}/c/vlog_8c.html +14 -18
  60. data/{ref → doc/api}/c/vlog_8h.html +9 -13
  61. data/{ref → doc/api}/c/vpi__user_8h.html +120 -239
  62. data/{ref → doc/api}/ruby/classes/ERB.html +7 -7
  63. data/doc/api/ruby/classes/ERB.src/M000025.html +29 -0
  64. data/{ref → doc/api}/ruby/classes/FileUtils.html +6 -23
  65. data/doc/api/ruby/classes/FileUtils.src/M000026.html +20 -0
  66. data/{ref → doc/api}/ruby/classes/Float.html +8 -8
  67. data/doc/api/ruby/classes/Float.src/M000020.html +19 -0
  68. data/{ref → doc/api}/ruby/classes/Integer.html +67 -67
  69. data/doc/api/ruby/classes/Integer.src/M000008.html +25 -0
  70. data/doc/api/ruby/classes/Integer.src/M000009.html +18 -0
  71. data/doc/api/ruby/classes/Integer.src/M000010.html +18 -0
  72. data/doc/api/ruby/classes/Integer.src/M000011.html +18 -0
  73. data/doc/api/ruby/classes/Integer.src/M000012.html +18 -0
  74. data/doc/api/ruby/classes/Integer.src/M000013.html +18 -0
  75. data/doc/api/ruby/classes/Integer.src/M000016.html +25 -0
  76. data/doc/api/ruby/classes/Integer.src/M000017.html +31 -0
  77. data/doc/api/ruby/classes/Integer.src/M000018.html +25 -0
  78. data/doc/api/ruby/classes/Integer.src/M000019.html +30 -0
  79. data/{ref → doc/api}/ruby/classes/Object.html +3 -3
  80. data/{ref → doc/api}/ruby/classes/RDoc.html +7 -7
  81. data/doc/api/ruby/classes/RDoc.src/M000541.html +40 -0
  82. data/doc/api/ruby/classes/RubyVPI/SIMULATORS.html +130 -0
  83. data/doc/api/ruby/classes/RubyVPI/SIMULATORS.src/M000028.html +19 -0
  84. data/{ref → doc/api}/ruby/classes/RubyVPI.html +96 -55
  85. data/doc/api/ruby/classes/RubyVPI.src/M000027.html +34 -0
  86. data/{ref → doc/api}/ruby/classes/String.html +16 -16
  87. data/doc/api/ruby/classes/String.src/M000021.html +36 -0
  88. data/doc/api/ruby/classes/String.src/M000022.html +18 -0
  89. data/doc/api/ruby/classes/String.src/M000023.html +18 -0
  90. data/doc/api/ruby/classes/String.src/M000024.html +41 -0
  91. data/doc/api/ruby/classes/VPI/Handle.html +2098 -0
  92. data/doc/api/ruby/classes/VPI/Handle.src/M000434.html +31 -0
  93. data/doc/api/ruby/classes/VPI/Handle.src/M000435.html +18 -0
  94. data/doc/api/ruby/classes/VPI/Handle.src/M000436.html +18 -0
  95. data/doc/api/ruby/classes/VPI/Handle.src/M000439.html +18 -0
  96. data/doc/api/ruby/classes/VPI/Handle.src/M000440.html +18 -0
  97. data/doc/api/ruby/classes/VPI/Handle.src/M000443.html +18 -0
  98. data/doc/api/ruby/classes/VPI/Handle.src/M000444.html +18 -0
  99. data/doc/api/ruby/classes/VPI/Handle.src/M000447.html +18 -0
  100. data/doc/api/ruby/classes/VPI/Handle.src/M000448.html +18 -0
  101. data/doc/api/ruby/classes/VPI/Handle.src/M000451.html +18 -0
  102. data/doc/api/ruby/classes/VPI/Handle.src/M000452.html +18 -0
  103. data/doc/api/ruby/classes/VPI/Handle.src/M000455.html +18 -0
  104. data/doc/api/ruby/classes/VPI/Handle.src/M000456.html +18 -0
  105. data/doc/api/ruby/classes/VPI/Handle.src/M000459.html +24 -0
  106. data/doc/api/ruby/classes/VPI/Handle.src/M000461.html +21 -0
  107. data/doc/api/ruby/classes/VPI/Handle.src/M000462.html +28 -0
  108. data/doc/api/ruby/classes/VPI/Handle.src/M000463.html +50 -0
  109. data/doc/api/ruby/classes/VPI/Handle.src/M000464.html +19 -0
  110. data/doc/api/ruby/classes/VPI/Handle.src/M000465.html +19 -0
  111. data/doc/api/ruby/classes/VPI/Handle.src/M000466.html +18 -0
  112. data/doc/api/ruby/classes/VPI/Handle.src/M000467.html +18 -0
  113. data/doc/api/ruby/classes/VPI/Handle.src/M000468.html +30 -0
  114. data/doc/api/ruby/classes/VPI/Handle.src/M000469.html +18 -0
  115. data/doc/api/ruby/classes/VPI/Handle.src/M000470.html +18 -0
  116. data/doc/api/ruby/classes/VPI/Handle.src/M000471.html +40 -0
  117. data/doc/api/ruby/classes/VPI/Handle.src/M000472.html +18 -0
  118. data/doc/api/ruby/classes/VPI/Handle.src/M000473.html +21 -0
  119. data/doc/api/ruby/classes/VPI/Handle.src/M000474.html +16 -0
  120. data/doc/api/ruby/classes/VPI/Handle.src/M000475.html +16 -0
  121. data/doc/api/ruby/classes/VPI/Handle.src/M000476.html +16 -0
  122. data/doc/api/ruby/classes/VPI/Handle.src/M000477.html +16 -0
  123. data/doc/api/ruby/classes/VPI/Handle.src/M000478.html +16 -0
  124. data/doc/api/ruby/classes/VPI/Handle.src/M000479.html +16 -0
  125. data/doc/api/ruby/classes/VPI/Handle.src/M000480.html +16 -0
  126. data/doc/api/ruby/classes/VPI/Handle.src/M000481.html +16 -0
  127. data/doc/api/ruby/classes/VPI/Handle.src/M000482.html +16 -0
  128. data/doc/api/ruby/classes/VPI/Handle.src/M000483.html +16 -0
  129. data/doc/api/ruby/classes/VPI/Handle.src/M000484.html +16 -0
  130. data/doc/api/ruby/classes/VPI/Handle.src/M000485.html +16 -0
  131. data/doc/api/ruby/classes/VPI/Handle.src/M000486.html +16 -0
  132. data/doc/api/ruby/classes/VPI/Handle.src/M000487.html +16 -0
  133. data/doc/api/ruby/classes/VPI/Handle.src/M000488.html +16 -0
  134. data/doc/api/ruby/classes/VPI/Handle.src/M000489.html +16 -0
  135. data/doc/api/ruby/classes/VPI/Handle.src/M000490.html +16 -0
  136. data/doc/api/ruby/classes/VPI/Handle.src/M000491.html +16 -0
  137. data/doc/api/ruby/classes/VPI/Handle.src/M000492.html +16 -0
  138. data/doc/api/ruby/classes/VPI/Handle.src/M000493.html +16 -0
  139. data/doc/api/ruby/classes/VPI/Handle.src/M000494.html +16 -0
  140. data/doc/api/ruby/classes/VPI/Handle.src/M000495.html +16 -0
  141. data/doc/api/ruby/classes/VPI/Handle.src/M000496.html +16 -0
  142. data/doc/api/ruby/classes/VPI/Handle.src/M000497.html +16 -0
  143. data/doc/api/ruby/classes/VPI/Handle.src/M000498.html +16 -0
  144. data/doc/api/ruby/classes/VPI/Handle.src/M000499.html +16 -0
  145. data/doc/api/ruby/classes/VPI/Handle.src/M000500.html +16 -0
  146. data/doc/api/ruby/classes/VPI/Handle.src/M000501.html +16 -0
  147. data/doc/api/ruby/classes/VPI/Handle.src/M000502.html +16 -0
  148. data/doc/api/ruby/classes/VPI/Handle.src/M000503.html +16 -0
  149. data/doc/api/ruby/classes/VPI/Handle.src/M000504.html +16 -0
  150. data/doc/api/ruby/classes/VPI/Handle.src/M000505.html +16 -0
  151. data/doc/api/ruby/classes/VPI/Handle.src/M000506.html +16 -0
  152. data/doc/api/ruby/classes/VPI/Handle.src/M000507.html +16 -0
  153. data/doc/api/ruby/classes/VPI/Handle.src/M000508.html +16 -0
  154. data/doc/api/ruby/classes/VPI/Handle.src/M000509.html +16 -0
  155. data/doc/api/ruby/classes/VPI/Handle.src/M000510.html +16 -0
  156. data/doc/api/ruby/classes/VPI/Handle.src/M000511.html +16 -0
  157. data/doc/api/ruby/classes/VPI/Handle.src/M000512.html +16 -0
  158. data/doc/api/ruby/classes/VPI/Handle.src/M000513.html +16 -0
  159. data/doc/api/ruby/classes/VPI/Handle.src/M000514.html +16 -0
  160. data/doc/api/ruby/classes/VPI/Handle.src/M000515.html +16 -0
  161. data/doc/api/ruby/classes/VPI/Handle.src/M000516.html +16 -0
  162. data/doc/api/ruby/classes/VPI/Handle.src/M000517.html +16 -0
  163. data/doc/api/ruby/classes/VPI/Handle.src/M000518.html +16 -0
  164. data/doc/api/ruby/classes/VPI/Handle.src/M000519.html +16 -0
  165. data/doc/api/ruby/classes/VPI/Handle.src/M000520.html +16 -0
  166. data/doc/api/ruby/classes/VPI/Handle.src/M000521.html +16 -0
  167. data/doc/api/ruby/classes/VPI/Handle.src/M000522.html +16 -0
  168. data/doc/api/ruby/classes/VPI/Handle.src/M000523.html +16 -0
  169. data/doc/api/ruby/classes/VPI/Handle.src/M000524.html +16 -0
  170. data/doc/api/ruby/classes/VPI/Handle.src/M000525.html +16 -0
  171. data/doc/api/ruby/classes/VPI/Handle.src/M000526.html +16 -0
  172. data/doc/api/ruby/classes/VPI/Handle.src/M000527.html +16 -0
  173. data/doc/api/ruby/classes/VPI/Handle.src/M000528.html +16 -0
  174. data/doc/api/ruby/classes/VPI/Handle.src/M000529.html +16 -0
  175. data/doc/api/ruby/classes/VPI/Handle.src/M000530.html +16 -0
  176. data/doc/api/ruby/classes/VPI/Handle.src/M000531.html +16 -0
  177. data/doc/api/ruby/classes/VPI/Handle.src/M000532.html +16 -0
  178. data/doc/api/ruby/classes/VPI/Handle.src/M000533.html +16 -0
  179. data/doc/api/ruby/classes/VPI/Handle.src/M000534.html +16 -0
  180. data/doc/api/ruby/classes/VPI/Handle.src/M000535.html +16 -0
  181. data/doc/api/ruby/classes/VPI/Handle.src/M000536.html +16 -0
  182. data/doc/api/ruby/classes/VPI/Handle.src/M000537.html +16 -0
  183. data/{ref → doc/api}/ruby/classes/VPI/S_vpi_time.html +18 -18
  184. data/doc/api/ruby/classes/VPI/S_vpi_time.src/M000538.html +18 -0
  185. data/doc/api/ruby/classes/VPI/S_vpi_time.src/M000539.html +19 -0
  186. data/{ref → doc/api}/ruby/classes/VPI/S_vpi_value.html +17 -17
  187. data/doc/api/ruby/classes/VPI/S_vpi_value.src/M000431.html +35 -0
  188. data/doc/api/ruby/classes/VPI/S_vpi_value.src/M000432.html +42 -0
  189. data/doc/api/ruby/classes/VPI/S_vpi_value.src/M000433.html +42 -0
  190. data/doc/api/ruby/classes/VPI.html +11152 -0
  191. data/doc/api/ruby/classes/VPI.src/M000029.html +19 -0
  192. data/doc/api/ruby/classes/VPI.src/M000030.html +18 -0
  193. data/doc/api/ruby/classes/VPI.src/M000031.html +19 -0
  194. data/doc/api/ruby/classes/VPI.src/M000033.html +25 -0
  195. data/doc/api/ruby/classes/VPI.src/M000034.html +26 -0
  196. data/doc/api/ruby/classes/VPI.src/M000036.html +16 -0
  197. data/doc/api/ruby/classes/VPI.src/M000037.html +16 -0
  198. data/doc/api/ruby/classes/VPI.src/M000038.html +16 -0
  199. data/doc/api/ruby/classes/VPI.src/M000039.html +16 -0
  200. data/doc/api/ruby/classes/VPI.src/M000040.html +16 -0
  201. data/doc/api/ruby/classes/VPI.src/M000041.html +16 -0
  202. data/doc/api/ruby/classes/VPI.src/M000042.html +16 -0
  203. data/doc/api/ruby/classes/VPI.src/M000043.html +16 -0
  204. data/doc/api/ruby/classes/VPI.src/M000044.html +16 -0
  205. data/doc/api/ruby/classes/VPI.src/M000045.html +16 -0
  206. data/doc/api/ruby/classes/VPI.src/M000046.html +16 -0
  207. data/doc/api/ruby/classes/VPI.src/M000047.html +16 -0
  208. data/doc/api/ruby/classes/VPI.src/M000048.html +16 -0
  209. data/doc/api/ruby/classes/VPI.src/M000049.html +16 -0
  210. data/doc/api/ruby/classes/VPI.src/M000050.html +16 -0
  211. data/doc/api/ruby/classes/VPI.src/M000051.html +16 -0
  212. data/doc/api/ruby/classes/VPI.src/M000052.html +16 -0
  213. data/doc/api/ruby/classes/VPI.src/M000053.html +16 -0
  214. data/doc/api/ruby/classes/VPI.src/M000054.html +16 -0
  215. data/doc/api/ruby/classes/VPI.src/M000055.html +16 -0
  216. data/doc/api/ruby/classes/VPI.src/M000056.html +16 -0
  217. data/doc/api/ruby/classes/VPI.src/M000057.html +16 -0
  218. data/doc/api/ruby/classes/VPI.src/M000058.html +16 -0
  219. data/doc/api/ruby/classes/VPI.src/M000059.html +16 -0
  220. data/doc/api/ruby/classes/VPI.src/M000060.html +16 -0
  221. data/doc/api/ruby/classes/VPI.src/M000061.html +16 -0
  222. data/doc/api/ruby/classes/VPI.src/M000062.html +16 -0
  223. data/doc/api/ruby/classes/VPI.src/M000063.html +16 -0
  224. data/doc/api/ruby/classes/VPI.src/M000064.html +16 -0
  225. data/doc/api/ruby/classes/VPI.src/M000065.html +16 -0
  226. data/doc/api/ruby/classes/VPI.src/M000066.html +16 -0
  227. data/doc/api/ruby/classes/VPI.src/M000067.html +16 -0
  228. data/doc/api/ruby/classes/VPI.src/M000068.html +16 -0
  229. data/doc/api/ruby/classes/VPI.src/M000069.html +16 -0
  230. data/doc/api/ruby/classes/VPI.src/M000070.html +16 -0
  231. data/doc/api/ruby/classes/VPI.src/M000071.html +16 -0
  232. data/doc/api/ruby/classes/VPI.src/M000072.html +16 -0
  233. data/doc/api/ruby/classes/VPI.src/M000073.html +16 -0
  234. data/doc/api/ruby/classes/VPI.src/M000074.html +16 -0
  235. data/doc/api/ruby/classes/VPI.src/M000075.html +16 -0
  236. data/doc/api/ruby/classes/VPI.src/M000076.html +16 -0
  237. data/doc/api/ruby/classes/VPI.src/M000077.html +16 -0
  238. data/doc/api/ruby/classes/VPI.src/M000078.html +16 -0
  239. data/doc/api/ruby/classes/VPI.src/M000079.html +16 -0
  240. data/doc/api/ruby/classes/VPI.src/M000080.html +16 -0
  241. data/doc/api/ruby/classes/VPI.src/M000081.html +16 -0
  242. data/doc/api/ruby/classes/VPI.src/M000082.html +16 -0
  243. data/doc/api/ruby/classes/VPI.src/M000083.html +16 -0
  244. data/doc/api/ruby/classes/VPI.src/M000084.html +16 -0
  245. data/doc/api/ruby/classes/VPI.src/M000085.html +16 -0
  246. data/doc/api/ruby/classes/VPI.src/M000086.html +16 -0
  247. data/doc/api/ruby/classes/VPI.src/M000087.html +16 -0
  248. data/doc/api/ruby/classes/VPI.src/M000088.html +16 -0
  249. data/doc/api/ruby/classes/VPI.src/M000089.html +16 -0
  250. data/doc/api/ruby/classes/VPI.src/M000090.html +16 -0
  251. data/doc/api/ruby/classes/VPI.src/M000091.html +16 -0
  252. data/doc/api/ruby/classes/VPI.src/M000092.html +16 -0
  253. data/doc/api/ruby/classes/VPI.src/M000093.html +16 -0
  254. data/doc/api/ruby/classes/VPI.src/M000094.html +16 -0
  255. data/doc/api/ruby/classes/VPI.src/M000095.html +16 -0
  256. data/doc/api/ruby/classes/VPI.src/M000096.html +16 -0
  257. data/doc/api/ruby/classes/VPI.src/M000097.html +16 -0
  258. data/doc/api/ruby/classes/VPI.src/M000098.html +16 -0
  259. data/doc/api/ruby/classes/VPI.src/M000099.html +16 -0
  260. data/doc/api/ruby/classes/VPI.src/M000100.html +16 -0
  261. data/doc/api/ruby/classes/VPI.src/M000101.html +16 -0
  262. data/doc/api/ruby/classes/VPI.src/M000102.html +16 -0
  263. data/doc/api/ruby/classes/VPI.src/M000103.html +16 -0
  264. data/doc/api/ruby/classes/VPI.src/M000104.html +16 -0
  265. data/doc/api/ruby/classes/VPI.src/M000105.html +16 -0
  266. data/doc/api/ruby/classes/VPI.src/M000106.html +16 -0
  267. data/doc/api/ruby/classes/VPI.src/M000107.html +16 -0
  268. data/doc/api/ruby/classes/VPI.src/M000108.html +16 -0
  269. data/doc/api/ruby/classes/VPI.src/M000109.html +16 -0
  270. data/doc/api/ruby/classes/VPI.src/M000110.html +16 -0
  271. data/doc/api/ruby/classes/VPI.src/M000111.html +16 -0
  272. data/doc/api/ruby/classes/VPI.src/M000112.html +16 -0
  273. data/doc/api/ruby/classes/VPI.src/M000113.html +16 -0
  274. data/doc/api/ruby/classes/VPI.src/M000114.html +16 -0
  275. data/doc/api/ruby/classes/VPI.src/M000115.html +16 -0
  276. data/doc/api/ruby/classes/VPI.src/M000116.html +16 -0
  277. data/doc/api/ruby/classes/VPI.src/M000117.html +16 -0
  278. data/doc/api/ruby/classes/VPI.src/M000118.html +16 -0
  279. data/doc/api/ruby/classes/VPI.src/M000119.html +16 -0
  280. data/doc/api/ruby/classes/VPI.src/M000120.html +16 -0
  281. data/doc/api/ruby/classes/VPI.src/M000121.html +16 -0
  282. data/doc/api/ruby/classes/VPI.src/M000122.html +16 -0
  283. data/doc/api/ruby/classes/VPI.src/M000123.html +16 -0
  284. data/doc/api/ruby/classes/VPI.src/M000124.html +16 -0
  285. data/doc/api/ruby/classes/VPI.src/M000125.html +16 -0
  286. data/doc/api/ruby/classes/VPI.src/M000126.html +16 -0
  287. data/doc/api/ruby/classes/VPI.src/M000127.html +16 -0
  288. data/doc/api/ruby/classes/VPI.src/M000128.html +16 -0
  289. data/doc/api/ruby/classes/VPI.src/M000129.html +16 -0
  290. data/doc/api/ruby/classes/VPI.src/M000130.html +16 -0
  291. data/doc/api/ruby/classes/VPI.src/M000131.html +16 -0
  292. data/doc/api/ruby/classes/VPI.src/M000132.html +16 -0
  293. data/doc/api/ruby/classes/VPI.src/M000133.html +16 -0
  294. data/doc/api/ruby/classes/VPI.src/M000134.html +16 -0
  295. data/doc/api/ruby/classes/VPI.src/M000135.html +16 -0
  296. data/doc/api/ruby/classes/VPI.src/M000136.html +16 -0
  297. data/doc/api/ruby/classes/VPI.src/M000137.html +16 -0
  298. data/doc/api/ruby/classes/VPI.src/M000138.html +16 -0
  299. data/doc/api/ruby/classes/VPI.src/M000139.html +16 -0
  300. data/doc/api/ruby/classes/VPI.src/M000140.html +16 -0
  301. data/doc/api/ruby/classes/VPI.src/M000141.html +16 -0
  302. data/doc/api/ruby/classes/VPI.src/M000142.html +16 -0
  303. data/doc/api/ruby/classes/VPI.src/M000143.html +16 -0
  304. data/doc/api/ruby/classes/VPI.src/M000144.html +16 -0
  305. data/doc/api/ruby/classes/VPI.src/M000145.html +16 -0
  306. data/doc/api/ruby/classes/VPI.src/M000146.html +16 -0
  307. data/doc/api/ruby/classes/VPI.src/M000147.html +16 -0
  308. data/doc/api/ruby/classes/VPI.src/M000148.html +16 -0
  309. data/doc/api/ruby/classes/VPI.src/M000149.html +16 -0
  310. data/doc/api/ruby/classes/VPI.src/M000150.html +16 -0
  311. data/doc/api/ruby/classes/VPI.src/M000151.html +16 -0
  312. data/doc/api/ruby/classes/VPI.src/M000152.html +16 -0
  313. data/doc/api/ruby/classes/VPI.src/M000153.html +16 -0
  314. data/doc/api/ruby/classes/VPI.src/M000154.html +16 -0
  315. data/doc/api/ruby/classes/VPI.src/M000155.html +16 -0
  316. data/doc/api/ruby/classes/VPI.src/M000156.html +16 -0
  317. data/doc/api/ruby/classes/VPI.src/M000157.html +16 -0
  318. data/doc/api/ruby/classes/VPI.src/M000158.html +16 -0
  319. data/doc/api/ruby/classes/VPI.src/M000159.html +16 -0
  320. data/doc/api/ruby/classes/VPI.src/M000160.html +16 -0
  321. data/doc/api/ruby/classes/VPI.src/M000161.html +16 -0
  322. data/doc/api/ruby/classes/VPI.src/M000162.html +16 -0
  323. data/doc/api/ruby/classes/VPI.src/M000163.html +16 -0
  324. data/doc/api/ruby/classes/VPI.src/M000164.html +16 -0
  325. data/doc/api/ruby/classes/VPI.src/M000165.html +16 -0
  326. data/doc/api/ruby/classes/VPI.src/M000166.html +16 -0
  327. data/doc/api/ruby/classes/VPI.src/M000167.html +16 -0
  328. data/doc/api/ruby/classes/VPI.src/M000168.html +16 -0
  329. data/doc/api/ruby/classes/VPI.src/M000169.html +16 -0
  330. data/doc/api/ruby/classes/VPI.src/M000170.html +16 -0
  331. data/doc/api/ruby/classes/VPI.src/M000171.html +16 -0
  332. data/doc/api/ruby/classes/VPI.src/M000172.html +16 -0
  333. data/doc/api/ruby/classes/VPI.src/M000173.html +16 -0
  334. data/doc/api/ruby/classes/VPI.src/M000174.html +16 -0
  335. data/doc/api/ruby/classes/VPI.src/M000175.html +16 -0
  336. data/doc/api/ruby/classes/VPI.src/M000176.html +16 -0
  337. data/doc/api/ruby/classes/VPI.src/M000177.html +16 -0
  338. data/doc/api/ruby/classes/VPI.src/M000178.html +16 -0
  339. data/doc/api/ruby/classes/VPI.src/M000179.html +16 -0
  340. data/doc/api/ruby/classes/VPI.src/M000180.html +16 -0
  341. data/doc/api/ruby/classes/VPI.src/M000181.html +16 -0
  342. data/doc/api/ruby/classes/VPI.src/M000182.html +16 -0
  343. data/doc/api/ruby/classes/VPI.src/M000183.html +16 -0
  344. data/doc/api/ruby/classes/VPI.src/M000184.html +16 -0
  345. data/doc/api/ruby/classes/VPI.src/M000185.html +16 -0
  346. data/doc/api/ruby/classes/VPI.src/M000186.html +16 -0
  347. data/doc/api/ruby/classes/VPI.src/M000187.html +16 -0
  348. data/doc/api/ruby/classes/VPI.src/M000188.html +16 -0
  349. data/doc/api/ruby/classes/VPI.src/M000189.html +16 -0
  350. data/doc/api/ruby/classes/VPI.src/M000190.html +16 -0
  351. data/doc/api/ruby/classes/VPI.src/M000191.html +16 -0
  352. data/doc/api/ruby/classes/VPI.src/M000192.html +16 -0
  353. data/doc/api/ruby/classes/VPI.src/M000193.html +16 -0
  354. data/doc/api/ruby/classes/VPI.src/M000194.html +16 -0
  355. data/doc/api/ruby/classes/VPI.src/M000195.html +16 -0
  356. data/doc/api/ruby/classes/VPI.src/M000196.html +16 -0
  357. data/doc/api/ruby/classes/VPI.src/M000197.html +16 -0
  358. data/doc/api/ruby/classes/VPI.src/M000198.html +16 -0
  359. data/doc/api/ruby/classes/VPI.src/M000199.html +16 -0
  360. data/doc/api/ruby/classes/VPI.src/M000200.html +16 -0
  361. data/doc/api/ruby/classes/VPI.src/M000201.html +16 -0
  362. data/doc/api/ruby/classes/VPI.src/M000202.html +16 -0
  363. data/doc/api/ruby/classes/VPI.src/M000203.html +16 -0
  364. data/doc/api/ruby/classes/VPI.src/M000204.html +16 -0
  365. data/doc/api/ruby/classes/VPI.src/M000205.html +16 -0
  366. data/doc/api/ruby/classes/VPI.src/M000206.html +16 -0
  367. data/doc/api/ruby/classes/VPI.src/M000207.html +16 -0
  368. data/doc/api/ruby/classes/VPI.src/M000208.html +16 -0
  369. data/doc/api/ruby/classes/VPI.src/M000209.html +16 -0
  370. data/doc/api/ruby/classes/VPI.src/M000210.html +16 -0
  371. data/doc/api/ruby/classes/VPI.src/M000211.html +16 -0
  372. data/doc/api/ruby/classes/VPI.src/M000212.html +16 -0
  373. data/doc/api/ruby/classes/VPI.src/M000213.html +16 -0
  374. data/doc/api/ruby/classes/VPI.src/M000214.html +16 -0
  375. data/doc/api/ruby/classes/VPI.src/M000215.html +16 -0
  376. data/doc/api/ruby/classes/VPI.src/M000216.html +16 -0
  377. data/doc/api/ruby/classes/VPI.src/M000217.html +16 -0
  378. data/doc/api/ruby/classes/VPI.src/M000218.html +16 -0
  379. data/doc/api/ruby/classes/VPI.src/M000219.html +16 -0
  380. data/doc/api/ruby/classes/VPI.src/M000220.html +16 -0
  381. data/doc/api/ruby/classes/VPI.src/M000221.html +16 -0
  382. data/doc/api/ruby/classes/VPI.src/M000222.html +16 -0
  383. data/doc/api/ruby/classes/VPI.src/M000223.html +16 -0
  384. data/doc/api/ruby/classes/VPI.src/M000224.html +16 -0
  385. data/doc/api/ruby/classes/VPI.src/M000225.html +16 -0
  386. data/doc/api/ruby/classes/VPI.src/M000226.html +16 -0
  387. data/doc/api/ruby/classes/VPI.src/M000227.html +16 -0
  388. data/doc/api/ruby/classes/VPI.src/M000228.html +16 -0
  389. data/doc/api/ruby/classes/VPI.src/M000229.html +16 -0
  390. data/doc/api/ruby/classes/VPI.src/M000230.html +16 -0
  391. data/doc/api/ruby/classes/VPI.src/M000231.html +16 -0
  392. data/doc/api/ruby/classes/VPI.src/M000232.html +16 -0
  393. data/doc/api/ruby/classes/VPI.src/M000233.html +16 -0
  394. data/doc/api/ruby/classes/VPI.src/M000234.html +16 -0
  395. data/doc/api/ruby/classes/VPI.src/M000235.html +16 -0
  396. data/doc/api/ruby/classes/VPI.src/M000236.html +16 -0
  397. data/doc/api/ruby/classes/VPI.src/M000237.html +16 -0
  398. data/doc/api/ruby/classes/VPI.src/M000238.html +16 -0
  399. data/doc/api/ruby/classes/VPI.src/M000239.html +16 -0
  400. data/doc/api/ruby/classes/VPI.src/M000240.html +16 -0
  401. data/doc/api/ruby/classes/VPI.src/M000241.html +16 -0
  402. data/doc/api/ruby/classes/VPI.src/M000242.html +16 -0
  403. data/doc/api/ruby/classes/VPI.src/M000243.html +16 -0
  404. data/doc/api/ruby/classes/VPI.src/M000244.html +16 -0
  405. data/doc/api/ruby/classes/VPI.src/M000245.html +16 -0
  406. data/doc/api/ruby/classes/VPI.src/M000246.html +16 -0
  407. data/doc/api/ruby/classes/VPI.src/M000247.html +16 -0
  408. data/doc/api/ruby/classes/VPI.src/M000248.html +16 -0
  409. data/doc/api/ruby/classes/VPI.src/M000249.html +16 -0
  410. data/doc/api/ruby/classes/VPI.src/M000250.html +16 -0
  411. data/doc/api/ruby/classes/VPI.src/M000251.html +16 -0
  412. data/doc/api/ruby/classes/VPI.src/M000252.html +16 -0
  413. data/doc/api/ruby/classes/VPI.src/M000253.html +16 -0
  414. data/doc/api/ruby/classes/VPI.src/M000254.html +16 -0
  415. data/doc/api/ruby/classes/VPI.src/M000255.html +16 -0
  416. data/doc/api/ruby/classes/VPI.src/M000256.html +16 -0
  417. data/doc/api/ruby/classes/VPI.src/M000257.html +16 -0
  418. data/doc/api/ruby/classes/VPI.src/M000258.html +16 -0
  419. data/doc/api/ruby/classes/VPI.src/M000259.html +16 -0
  420. data/doc/api/ruby/classes/VPI.src/M000260.html +16 -0
  421. data/doc/api/ruby/classes/VPI.src/M000261.html +16 -0
  422. data/doc/api/ruby/classes/VPI.src/M000262.html +16 -0
  423. data/doc/api/ruby/classes/VPI.src/M000263.html +16 -0
  424. data/doc/api/ruby/classes/VPI.src/M000264.html +16 -0
  425. data/doc/api/ruby/classes/VPI.src/M000265.html +16 -0
  426. data/doc/api/ruby/classes/VPI.src/M000266.html +16 -0
  427. data/doc/api/ruby/classes/VPI.src/M000267.html +16 -0
  428. data/doc/api/ruby/classes/VPI.src/M000268.html +16 -0
  429. data/doc/api/ruby/classes/VPI.src/M000269.html +16 -0
  430. data/doc/api/ruby/classes/VPI.src/M000270.html +16 -0
  431. data/doc/api/ruby/classes/VPI.src/M000271.html +16 -0
  432. data/doc/api/ruby/classes/VPI.src/M000272.html +16 -0
  433. data/doc/api/ruby/classes/VPI.src/M000273.html +16 -0
  434. data/doc/api/ruby/classes/VPI.src/M000274.html +16 -0
  435. data/doc/api/ruby/classes/VPI.src/M000275.html +16 -0
  436. data/doc/api/ruby/classes/VPI.src/M000276.html +16 -0
  437. data/doc/api/ruby/classes/VPI.src/M000277.html +16 -0
  438. data/doc/api/ruby/classes/VPI.src/M000278.html +16 -0
  439. data/doc/api/ruby/classes/VPI.src/M000279.html +16 -0
  440. data/doc/api/ruby/classes/VPI.src/M000280.html +16 -0
  441. data/doc/api/ruby/classes/VPI.src/M000281.html +16 -0
  442. data/doc/api/ruby/classes/VPI.src/M000282.html +16 -0
  443. data/doc/api/ruby/classes/VPI.src/M000283.html +16 -0
  444. data/doc/api/ruby/classes/VPI.src/M000284.html +16 -0
  445. data/doc/api/ruby/classes/VPI.src/M000285.html +16 -0
  446. data/doc/api/ruby/classes/VPI.src/M000286.html +16 -0
  447. data/doc/api/ruby/classes/VPI.src/M000287.html +16 -0
  448. data/doc/api/ruby/classes/VPI.src/M000288.html +16 -0
  449. data/doc/api/ruby/classes/VPI.src/M000289.html +16 -0
  450. data/doc/api/ruby/classes/VPI.src/M000290.html +16 -0
  451. data/doc/api/ruby/classes/VPI.src/M000291.html +16 -0
  452. data/doc/api/ruby/classes/VPI.src/M000292.html +16 -0
  453. data/doc/api/ruby/classes/VPI.src/M000293.html +16 -0
  454. data/doc/api/ruby/classes/VPI.src/M000294.html +16 -0
  455. data/doc/api/ruby/classes/VPI.src/M000295.html +16 -0
  456. data/doc/api/ruby/classes/VPI.src/M000296.html +16 -0
  457. data/doc/api/ruby/classes/VPI.src/M000297.html +16 -0
  458. data/doc/api/ruby/classes/VPI.src/M000298.html +16 -0
  459. data/doc/api/ruby/classes/VPI.src/M000299.html +16 -0
  460. data/doc/api/ruby/classes/VPI.src/M000300.html +16 -0
  461. data/doc/api/ruby/classes/VPI.src/M000301.html +16 -0
  462. data/doc/api/ruby/classes/VPI.src/M000302.html +16 -0
  463. data/doc/api/ruby/classes/VPI.src/M000303.html +16 -0
  464. data/doc/api/ruby/classes/VPI.src/M000304.html +16 -0
  465. data/doc/api/ruby/classes/VPI.src/M000305.html +16 -0
  466. data/doc/api/ruby/classes/VPI.src/M000306.html +16 -0
  467. data/doc/api/ruby/classes/VPI.src/M000307.html +16 -0
  468. data/doc/api/ruby/classes/VPI.src/M000308.html +16 -0
  469. data/doc/api/ruby/classes/VPI.src/M000309.html +16 -0
  470. data/doc/api/ruby/classes/VPI.src/M000310.html +16 -0
  471. data/doc/api/ruby/classes/VPI.src/M000311.html +16 -0
  472. data/doc/api/ruby/classes/VPI.src/M000312.html +16 -0
  473. data/doc/api/ruby/classes/VPI.src/M000313.html +16 -0
  474. data/doc/api/ruby/classes/VPI.src/M000314.html +16 -0
  475. data/doc/api/ruby/classes/VPI.src/M000315.html +16 -0
  476. data/doc/api/ruby/classes/VPI.src/M000316.html +16 -0
  477. data/doc/api/ruby/classes/VPI.src/M000317.html +16 -0
  478. data/doc/api/ruby/classes/VPI.src/M000318.html +16 -0
  479. data/doc/api/ruby/classes/VPI.src/M000319.html +16 -0
  480. data/doc/api/ruby/classes/VPI.src/M000320.html +16 -0
  481. data/doc/api/ruby/classes/VPI.src/M000321.html +16 -0
  482. data/doc/api/ruby/classes/VPI.src/M000322.html +16 -0
  483. data/doc/api/ruby/classes/VPI.src/M000323.html +16 -0
  484. data/doc/api/ruby/classes/VPI.src/M000324.html +16 -0
  485. data/doc/api/ruby/classes/VPI.src/M000325.html +16 -0
  486. data/doc/api/ruby/classes/VPI.src/M000326.html +16 -0
  487. data/doc/api/ruby/classes/VPI.src/M000327.html +16 -0
  488. data/doc/api/ruby/classes/VPI.src/M000328.html +16 -0
  489. data/doc/api/ruby/classes/VPI.src/M000329.html +16 -0
  490. data/doc/api/ruby/classes/VPI.src/M000330.html +16 -0
  491. data/doc/api/ruby/classes/VPI.src/M000331.html +16 -0
  492. data/doc/api/ruby/classes/VPI.src/M000332.html +16 -0
  493. data/doc/api/ruby/classes/VPI.src/M000333.html +16 -0
  494. data/doc/api/ruby/classes/VPI.src/M000334.html +16 -0
  495. data/doc/api/ruby/classes/VPI.src/M000335.html +16 -0
  496. data/doc/api/ruby/classes/VPI.src/M000336.html +16 -0
  497. data/doc/api/ruby/classes/VPI.src/M000337.html +16 -0
  498. data/doc/api/ruby/classes/VPI.src/M000338.html +16 -0
  499. data/doc/api/ruby/classes/VPI.src/M000339.html +16 -0
  500. data/doc/api/ruby/classes/VPI.src/M000340.html +16 -0
  501. data/doc/api/ruby/classes/VPI.src/M000341.html +16 -0
  502. data/doc/api/ruby/classes/VPI.src/M000342.html +16 -0
  503. data/doc/api/ruby/classes/VPI.src/M000343.html +16 -0
  504. data/doc/api/ruby/classes/VPI.src/M000344.html +16 -0
  505. data/doc/api/ruby/classes/VPI.src/M000345.html +16 -0
  506. data/doc/api/ruby/classes/VPI.src/M000346.html +16 -0
  507. data/doc/api/ruby/classes/VPI.src/M000347.html +16 -0
  508. data/doc/api/ruby/classes/VPI.src/M000348.html +16 -0
  509. data/doc/api/ruby/classes/VPI.src/M000349.html +16 -0
  510. data/doc/api/ruby/classes/VPI.src/M000350.html +16 -0
  511. data/doc/api/ruby/classes/VPI.src/M000351.html +16 -0
  512. data/doc/api/ruby/classes/VPI.src/M000352.html +16 -0
  513. data/doc/api/ruby/classes/VPI.src/M000353.html +16 -0
  514. data/doc/api/ruby/classes/VPI.src/M000354.html +16 -0
  515. data/doc/api/ruby/classes/VPI.src/M000355.html +16 -0
  516. data/doc/api/ruby/classes/VPI.src/M000356.html +16 -0
  517. data/doc/api/ruby/classes/VPI.src/M000357.html +16 -0
  518. data/doc/api/ruby/classes/VPI.src/M000358.html +16 -0
  519. data/doc/api/ruby/classes/VPI.src/M000359.html +16 -0
  520. data/doc/api/ruby/classes/VPI.src/M000360.html +16 -0
  521. data/doc/api/ruby/classes/VPI.src/M000361.html +16 -0
  522. data/doc/api/ruby/classes/VPI.src/M000362.html +16 -0
  523. data/doc/api/ruby/classes/VPI.src/M000363.html +16 -0
  524. data/doc/api/ruby/classes/VPI.src/M000364.html +16 -0
  525. data/doc/api/ruby/classes/VPI.src/M000365.html +16 -0
  526. data/doc/api/ruby/classes/VPI.src/M000366.html +16 -0
  527. data/doc/api/ruby/classes/VPI.src/M000367.html +16 -0
  528. data/doc/api/ruby/classes/VPI.src/M000368.html +16 -0
  529. data/doc/api/ruby/classes/VPI.src/M000369.html +16 -0
  530. data/doc/api/ruby/classes/VPI.src/M000370.html +16 -0
  531. data/doc/api/ruby/classes/VPI.src/M000371.html +16 -0
  532. data/doc/api/ruby/classes/VPI.src/M000372.html +16 -0
  533. data/doc/api/ruby/classes/VPI.src/M000373.html +16 -0
  534. data/doc/api/ruby/classes/VPI.src/M000374.html +16 -0
  535. data/doc/api/ruby/classes/VPI.src/M000375.html +16 -0
  536. data/doc/api/ruby/classes/VPI.src/M000376.html +16 -0
  537. data/doc/api/ruby/classes/VPI.src/M000377.html +16 -0
  538. data/doc/api/ruby/classes/VPI.src/M000378.html +16 -0
  539. data/doc/api/ruby/classes/VPI.src/M000379.html +16 -0
  540. data/doc/api/ruby/classes/VPI.src/M000380.html +16 -0
  541. data/doc/api/ruby/classes/VPI.src/M000381.html +16 -0
  542. data/doc/api/ruby/classes/VPI.src/M000382.html +16 -0
  543. data/doc/api/ruby/classes/VPI.src/M000383.html +16 -0
  544. data/doc/api/ruby/classes/VPI.src/M000384.html +16 -0
  545. data/doc/api/ruby/classes/VPI.src/M000385.html +16 -0
  546. data/doc/api/ruby/classes/VPI.src/M000386.html +16 -0
  547. data/doc/api/ruby/classes/VPI.src/M000387.html +16 -0
  548. data/doc/api/ruby/classes/VPI.src/M000388.html +16 -0
  549. data/doc/api/ruby/classes/VPI.src/M000389.html +16 -0
  550. data/doc/api/ruby/classes/VPI.src/M000390.html +16 -0
  551. data/doc/api/ruby/classes/VPI.src/M000391.html +16 -0
  552. data/doc/api/ruby/classes/VPI.src/M000392.html +16 -0
  553. data/doc/api/ruby/classes/VPI.src/M000393.html +16 -0
  554. data/doc/api/ruby/classes/VPI.src/M000394.html +16 -0
  555. data/doc/api/ruby/classes/VPI.src/M000395.html +16 -0
  556. data/doc/api/ruby/classes/VPI.src/M000396.html +16 -0
  557. data/doc/api/ruby/classes/VPI.src/M000397.html +16 -0
  558. data/doc/api/ruby/classes/VPI.src/M000398.html +16 -0
  559. data/doc/api/ruby/classes/VPI.src/M000399.html +16 -0
  560. data/doc/api/ruby/classes/VPI.src/M000400.html +16 -0
  561. data/doc/api/ruby/classes/VPI.src/M000401.html +16 -0
  562. data/doc/api/ruby/classes/VPI.src/M000402.html +16 -0
  563. data/doc/api/ruby/classes/VPI.src/M000403.html +16 -0
  564. data/doc/api/ruby/classes/VPI.src/M000404.html +16 -0
  565. data/doc/api/ruby/classes/VPI.src/M000405.html +16 -0
  566. data/doc/api/ruby/classes/VPI.src/M000406.html +16 -0
  567. data/doc/api/ruby/classes/VPI.src/M000407.html +16 -0
  568. data/doc/api/ruby/classes/VPI.src/M000408.html +16 -0
  569. data/doc/api/ruby/classes/VPI.src/M000409.html +16 -0
  570. data/doc/api/ruby/classes/VPI.src/M000410.html +16 -0
  571. data/doc/api/ruby/classes/VPI.src/M000411.html +16 -0
  572. data/doc/api/ruby/classes/VPI.src/M000412.html +16 -0
  573. data/doc/api/ruby/classes/VPI.src/M000413.html +16 -0
  574. data/doc/api/ruby/classes/VPI.src/M000414.html +16 -0
  575. data/doc/api/ruby/classes/VPI.src/M000415.html +16 -0
  576. data/doc/api/ruby/classes/VPI.src/M000416.html +16 -0
  577. data/doc/api/ruby/classes/VPI.src/M000417.html +16 -0
  578. data/doc/api/ruby/classes/VPI.src/M000418.html +16 -0
  579. data/doc/api/ruby/classes/VPI.src/M000419.html +16 -0
  580. data/doc/api/ruby/classes/VPI.src/M000420.html +16 -0
  581. data/doc/api/ruby/classes/VPI.src/M000421.html +16 -0
  582. data/doc/api/ruby/classes/VPI.src/M000422.html +16 -0
  583. data/doc/api/ruby/classes/VPI.src/M000423.html +16 -0
  584. data/doc/api/ruby/classes/VPI.src/M000424.html +16 -0
  585. data/doc/api/ruby/classes/VPI.src/M000425.html +16 -0
  586. data/doc/api/ruby/classes/VPI.src/M000426.html +16 -0
  587. data/doc/api/ruby/classes/VPI.src/M000427.html +16 -0
  588. data/doc/api/ruby/classes/VPI.src/M000428.html +16 -0
  589. data/doc/api/ruby/classes/VPI.src/M000429.html +16 -0
  590. data/doc/api/ruby/classes/VPI.src/M000430.html +16 -0
  591. data/{ref → doc/api}/ruby/classes/VerilogParser/Module/Port.html +17 -17
  592. data/doc/api/ruby/classes/VerilogParser/Module/Port.src/M000005.html +23 -0
  593. data/doc/api/ruby/classes/VerilogParser/Module/Port.src/M000006.html +18 -0
  594. data/doc/api/ruby/classes/VerilogParser/Module/Port.src/M000007.html +18 -0
  595. data/{ref → doc/api}/ruby/classes/VerilogParser/Module.html +7 -7
  596. data/doc/api/ruby/classes/VerilogParser/Module.src/M000004.html +29 -0
  597. data/{ref → doc/api}/ruby/classes/VerilogParser.html +7 -7
  598. data/doc/api/ruby/classes/VerilogParser.src/M000003.html +26 -0
  599. data/doc/api/ruby/created.rid +1 -0
  600. data/{ref → doc/api}/ruby/files/bin/convert_rb.html +4 -4
  601. data/{ref → doc/api}/ruby/files/bin/generate_rb.html +10 -6
  602. data/doc/api/ruby/files/bin/ruby-vpi.html +169 -0
  603. data/doc/api/ruby/files/bin/ruby-vpi.src/M000001.html +35 -0
  604. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/core/callback_rb.html +3 -3
  605. data/doc/api/ruby/files/lib/ruby-vpi/core/edge-methods_rb.html +107 -0
  606. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/core/edge_rb.html +3 -3
  607. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/core/handle_rb.html +10 -3
  608. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/core/scheduler_rb.html +3 -3
  609. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/core/struct_rb.html +2 -2
  610. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/core_rb.html +3 -3
  611. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/erb_rb.html +2 -2
  612. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/float_rb.html +2 -2
  613. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/integer_rb.html +2 -2
  614. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/rake_rb.html +3 -3
  615. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/rcov_rb.html +3 -4
  616. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/rdoc_rb.html +2 -2
  617. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/runner_boot_loader_rb.html +9 -10
  618. data/doc/api/ruby/files/lib/ruby-vpi/runner_boot_loader_rb.src/M000002.html +17 -0
  619. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/runner_proxy_rb.html +3 -3
  620. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/runner_rb.html +3 -3
  621. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/util_rb.html +2 -2
  622. data/{ref → doc/api}/ruby/files/lib/ruby-vpi/verilog_parser_rb.html +2 -2
  623. data/{ref → doc/api}/ruby/files/lib/ruby-vpi_rb.html +3 -3
  624. data/doc/api/ruby/files/ruby-vpi-dynamic_rb.html +110 -0
  625. data/{ref → doc/api}/ruby/fr_class_index.html +3 -2
  626. data/{ref → doc/api}/ruby/fr_file_index.html +5 -2
  627. data/doc/api/ruby/fr_method_index.html +567 -0
  628. data/{ref → doc/api}/ruby/index.html +5 -5
  629. data/{ref → doc/api}/ruby/rdoc-style.css +0 -0
  630. data/doc/{manual.doc → guide.erb} +379 -121
  631. data/doc/guide.html +3524 -0
  632. data/examples/counter/RSpec/counter_design.rb +7 -7
  633. data/examples/counter/RSpec/counter_loader.rb +1 -0
  634. data/examples/counter/RSpec/counter_proto.rb +8 -6
  635. data/examples/counter/RSpec/counter_runner.rake +9 -4
  636. data/examples/counter/RSpec/counter_spec.rb +13 -13
  637. data/examples/counter/xUnit/counter_design.rb +7 -6
  638. data/examples/counter/xUnit/counter_loader.rb +1 -0
  639. data/examples/counter/xUnit/counter_proto.rb +8 -6
  640. data/examples/counter/xUnit/counter_runner.rake +9 -4
  641. data/examples/counter/xUnit/counter_spec.rb +15 -15
  642. data/examples/pipelined_alu/hw5_unit_design.rb +11 -10
  643. data/examples/pipelined_alu/hw5_unit_loader.rb +1 -0
  644. data/examples/pipelined_alu/hw5_unit_proto.rb +4 -2
  645. data/examples/pipelined_alu/hw5_unit_runner.rake +9 -4
  646. data/examples/pipelined_alu/hw5_unit_spec.rb +18 -18
  647. data/examples/register_file/register_file_design.rb +2 -2
  648. data/examples/register_file/register_file_loader.rb +1 -0
  649. data/examples/register_file/register_file_proto.rb +15 -8
  650. data/examples/register_file/register_file_runner.rake +9 -4
  651. data/examples/register_file/register_file_spec.rb +15 -15
  652. data/ext/main.c +4 -4
  653. data/lib/ruby-vpi/core/edge-methods.rb +32 -0
  654. data/lib/ruby-vpi/core/edge.rb +8 -43
  655. data/lib/ruby-vpi/core/handle.rb +127 -91
  656. data/lib/ruby-vpi/core/scheduler.rb +14 -15
  657. data/lib/ruby-vpi/core.rb +1 -1
  658. data/lib/ruby-vpi/rake.rb +5 -7
  659. data/lib/ruby-vpi/rcov.rb +2 -7
  660. data/lib/ruby-vpi/runner.rb +16 -11
  661. data/lib/ruby-vpi/runner_boot_loader.rb +24 -60
  662. data/lib/ruby-vpi/runner_proxy.rb +2 -6
  663. data/lib/ruby-vpi.rb +56 -14
  664. metadata +809 -368
  665. data/doc/README +0 -9
  666. data/doc/Rakefile +0 -92
  667. data/doc/common.css +0 -108
  668. data/doc/common.inc +0 -14
  669. data/doc/common.tpl +0 -90
  670. data/doc/history.doc +0 -17
  671. data/doc/history.html +0 -2694
  672. data/doc/history.inc +0 -1077
  673. data/doc/history.rb +0 -22
  674. data/doc/history.yaml +0 -1409
  675. data/doc/images/feed-icon-28x28.png +0 -0
  676. data/doc/images/tango/LICENSE +0 -67
  677. data/doc/images/tango/caution.png +0 -0
  678. data/doc/images/tango/caution.svg +0 -290
  679. data/doc/images/tango/home.png +0 -0
  680. data/doc/images/tango/home.svg +0 -386
  681. data/doc/images/tango/important.png +0 -0
  682. data/doc/images/tango/important.svg +0 -163
  683. data/doc/images/tango/next.png +0 -0
  684. data/doc/images/tango/next.svg +0 -191
  685. data/doc/images/tango/note.png +0 -0
  686. data/doc/images/tango/note.svg +0 -483
  687. data/doc/images/tango/prev.png +0 -0
  688. data/doc/images/tango/prev.svg +0 -852
  689. data/doc/images/tango/tip.png +0 -0
  690. data/doc/images/tango/tip.svg +0 -1145
  691. data/doc/images/tango/up.png +0 -0
  692. data/doc/images/tango/up.svg +0 -195
  693. data/doc/images/tango/warning.png +0 -0
  694. data/doc/images/tango/warning.svg +0 -334
  695. data/doc/intro.inc +0 -215
  696. data/doc/lib/doc_format.rb +0 -137
  697. data/doc/lib/doc_proxy.rb +0 -562
  698. data/doc/lib/erb_content.rb +0 -55
  699. data/doc/lib/erb_proxy.rb +0 -42
  700. data/doc/manual.html +0 -3061
  701. data/doc/memo.doc +0 -66
  702. data/doc/memo.html +0 -210
  703. data/doc/print.css +0 -69
  704. data/doc/readme.doc +0 -10
  705. data/doc/readme.html +0 -515
  706. data/doc/rss.erb +0 -29
  707. data/doc/rss.xml +0 -186
  708. data/doc/screen.css +0 -146
  709. data/doc/spacing.css +0 -57
  710. data/index.html +0 -2
  711. data/ref/c/annotated.html +0 -34
  712. data/ref/c/functions.html +0 -182
  713. data/ref/c/functions_vars.html +0 -182
  714. data/ref/c/globals_0x73.html +0 -73
  715. data/ref/c/globals_type.html +0 -88
  716. data/ref/c/structt__vpi__value.html +0 -204
  717. data/ref/ruby/classes/ERB.src/M000024.html +0 -29
  718. data/ref/ruby/classes/FileUtils.src/M000025.html +0 -18
  719. data/ref/ruby/classes/FileUtils.src/M000026.html +0 -18
  720. data/ref/ruby/classes/Float.src/M000019.html +0 -19
  721. data/ref/ruby/classes/Integer.src/M000007.html +0 -25
  722. data/ref/ruby/classes/Integer.src/M000008.html +0 -18
  723. data/ref/ruby/classes/Integer.src/M000009.html +0 -18
  724. data/ref/ruby/classes/Integer.src/M000010.html +0 -18
  725. data/ref/ruby/classes/Integer.src/M000011.html +0 -18
  726. data/ref/ruby/classes/Integer.src/M000012.html +0 -18
  727. data/ref/ruby/classes/Integer.src/M000015.html +0 -25
  728. data/ref/ruby/classes/Integer.src/M000016.html +0 -31
  729. data/ref/ruby/classes/Integer.src/M000017.html +0 -25
  730. data/ref/ruby/classes/Integer.src/M000018.html +0 -30
  731. data/ref/ruby/classes/RDoc.src/M000081.html +0 -40
  732. data/ref/ruby/classes/String.src/M000020.html +0 -36
  733. data/ref/ruby/classes/String.src/M000021.html +0 -41
  734. data/ref/ruby/classes/String.src/M000022.html +0 -18
  735. data/ref/ruby/classes/String.src/M000023.html +0 -18
  736. data/ref/ruby/classes/VPI/Handle.html +0 -898
  737. data/ref/ruby/classes/VPI/Handle.src/M000037.html +0 -18
  738. data/ref/ruby/classes/VPI/Handle.src/M000038.html +0 -21
  739. data/ref/ruby/classes/VPI/Handle.src/M000039.html +0 -18
  740. data/ref/ruby/classes/VPI/Handle.src/M000040.html +0 -18
  741. data/ref/ruby/classes/VPI/Handle.src/M000045.html +0 -18
  742. data/ref/ruby/classes/VPI/Handle.src/M000046.html +0 -18
  743. data/ref/ruby/classes/VPI/Handle.src/M000057.html +0 -18
  744. data/ref/ruby/classes/VPI/Handle.src/M000058.html +0 -18
  745. data/ref/ruby/classes/VPI/Handle.src/M000061.html +0 -18
  746. data/ref/ruby/classes/VPI/Handle.src/M000062.html +0 -18
  747. data/ref/ruby/classes/VPI/Handle.src/M000065.html +0 -24
  748. data/ref/ruby/classes/VPI/Handle.src/M000067.html +0 -21
  749. data/ref/ruby/classes/VPI/Handle.src/M000068.html +0 -28
  750. data/ref/ruby/classes/VPI/Handle.src/M000069.html +0 -50
  751. data/ref/ruby/classes/VPI/Handle.src/M000070.html +0 -19
  752. data/ref/ruby/classes/VPI/Handle.src/M000071.html +0 -19
  753. data/ref/ruby/classes/VPI/Handle.src/M000072.html +0 -18
  754. data/ref/ruby/classes/VPI/Handle.src/M000073.html +0 -30
  755. data/ref/ruby/classes/VPI/Handle.src/M000075.html +0 -18
  756. data/ref/ruby/classes/VPI/Handle.src/M000076.html +0 -40
  757. data/ref/ruby/classes/VPI/Handle.src/M000077.html +0 -31
  758. data/ref/ruby/classes/VPI/S_vpi_time.src/M000078.html +0 -18
  759. data/ref/ruby/classes/VPI/S_vpi_time.src/M000079.html +0 -19
  760. data/ref/ruby/classes/VPI/S_vpi_value.src/M000034.html +0 -35
  761. data/ref/ruby/classes/VPI/S_vpi_value.src/M000035.html +0 -42
  762. data/ref/ruby/classes/VPI/S_vpi_value.src/M000036.html +0 -42
  763. data/ref/ruby/classes/VPI.html +0 -356
  764. data/ref/ruby/classes/VPI.src/M000027.html +0 -19
  765. data/ref/ruby/classes/VPI.src/M000028.html +0 -18
  766. data/ref/ruby/classes/VPI.src/M000029.html +0 -19
  767. data/ref/ruby/classes/VPI.src/M000031.html +0 -25
  768. data/ref/ruby/classes/VPI.src/M000032.html +0 -26
  769. data/ref/ruby/classes/VerilogParser/Module/Port.src/M000004.html +0 -23
  770. data/ref/ruby/classes/VerilogParser/Module/Port.src/M000005.html +0 -18
  771. data/ref/ruby/classes/VerilogParser/Module/Port.src/M000006.html +0 -18
  772. data/ref/ruby/classes/VerilogParser/Module.src/M000003.html +0 -29
  773. data/ref/ruby/classes/VerilogParser.src/M000002.html +0 -26
  774. data/ref/ruby/created.rid +0 -1
  775. data/ref/ruby/files/lib/ruby-vpi/runner_boot_loader_rb.src/M000001.html +0 -17
  776. data/ref/ruby/fr_method_index.html +0 -107
data/doc/history.yaml DELETED
@@ -1,1409 +0,0 @@
1
- -
2
- Version: 19.0.0
3
-
4
- Date: 2007-08-27
5
-
6
- Record: |
7
- This release restores support for Cadence NC-Sim, breaks support for Mentor Modelsim, adds support for concurrent processes which simplify implementing Ruby prototypess, and offers numerous other improvements.
8
-
9
- *Mentor Modelsim users, take note*: this release does not work very well with Mentor Modelsim, so do not upgrade until compatibility is restored in a future release. In the mean time, consider using this release with another simulator, such as "GPL Cver":http://www.pragmatic-c.com/gpl-cver/.
10
-
11
-
12
- h2. Thanks
13
-
14
- * Calvin Wong "requested the concurrent processes feature":http://rubyforge.org/pipermail/ruby-vpi-discuss/2007-August/000046.html, helped test it, and provided useful feedback.
15
-
16
-
17
- h2. Caution
18
-
19
- * Prototypes no longer have a @feign!@ method. Instead, they emulate the behavior of the real Verilog DUT using the new "concurrency model":manual.html#usage.concurrency.
20
-
21
- * All "initial" blocks in Verilog code are now evaluated _before_ the specification begins executing. This allows you to set the initial value of registers in Verilog before the specification interacts with them.
22
-
23
- * The @Vpi@ module has been renamed to @VPI@ for consistency with the project name.
24
-
25
- * The @VPI::simulation_time@ method has been renamed to @VPI::current_time@.
26
-
27
- * The @VPI::Handle.value_forced?@ method has been renamed to @VPI::Handle.force?@
28
-
29
- * The <tt>samp/</tt> directory has been renamed to <tt>examples/</tt>.
30
-
31
- * Code coverage analysis results are now produced only in plain-text format.
32
-
33
-
34
- h2. Repairs
35
-
36
- * You can now access VPI constants using their original uncapitalized names. For example, you can now write "vpiIntVal" instead of having to write "VpiIntVal". However, note that the capitalized names are still supported, so you are not required to change your code.
37
-
38
- * Value change / edge detection for VPI handles was previously incorrect: if you called the @VPI::Handle.posedge?@ function twice in the same time step, it would give you two different answers.
39
-
40
- * The problem of not being able to write values to nets in Cadence NC-Sim has been fixed.
41
-
42
-
43
- h2. Additions
44
-
45
- * Added support for "concurrent processes":manual.html#usage.concurrency, which make Ruby prototypes appear more like Verilog code and also give the ability to write parallel tests.
46
-
47
- * Added support for performance profiling using the "ruby-prof":http://ruby-prof.rubyforge.org project. The profiler can be enabled by setting the @PROFILER@ environment variable to "1" before running a Ruby-VPI test.
48
-
49
- * Added new method aliases to @VPI::Handle@ for value detection. The complete list of aliases is now:
50
- ** Tests if the logic value of this handle is unknown (x).
51
- *** x?
52
- *** unknown?
53
- *** dont_care?
54
- ** Sets the logic value of this handle to unknown (x).
55
- *** x!
56
- *** unknown!
57
- *** dont_care!
58
- ** Tests if the logic value of this handle is high impedance (z).
59
- *** z?
60
- *** hi_z?
61
- *** high_z?
62
- *** high_impedance?
63
- *** tri_state?
64
- *** floating?
65
- ** Sets the logic value of this handle to high impedance (z).
66
- *** z!
67
- *** hi_z!
68
- *** high_z!
69
- *** high_impedance!
70
- *** tri_state!
71
- *** floating!
72
- ** Tests if the logic value of this handle is at "logic high" level.
73
- *** high?
74
- *** one?
75
- ** Sets the logic value of this handle to "logic high" level.
76
- *** high!
77
- *** one!
78
- ** Tests if the logic value of this handle is at "logic low" level.
79
- *** low?
80
- *** zero?
81
- ** Sets the logic value of this handle to "logic low" level.
82
- *** low!
83
- *** zero!
84
-
85
- * Added new methods to @VPI::Handle@ for value change / edge detection:
86
- ** edge? - detects positive and negative edges
87
- ** change? - detects any kind of value change
88
- ** change_00? - detects a value change from 0 to 0
89
- ** change_01? - detects a value change from 0 to 1
90
- ** change_0x? - detects a value change from 0 to unknown
91
- ** change_0z? - detects a value change from 0 to high-Z
92
- ** change_10? - detects a value change from 1 to 0
93
- ** change_11? - detects a value change from 1 to 1
94
- ** change_1x? - detects a value change from 1 to unknown
95
- ** change_1z? - detects a value change from 1 to high-Z
96
- ** change_x0? - detects a value change from unknown to 0
97
- ** change_x1? - detects a value change from unknown to 1
98
- ** change_xx? - detects a value change from unknown to unknown
99
- ** change_xz? - detects a value change from unknown to high-Z
100
- ** change_z0? - detects a value change from high-Z to 0
101
- ** change_z1? - detects a value change from high-Z to 1
102
- ** change_zx? - detects a value change from high-Z to unknown
103
- ** change_zz? - detects a value change from high-Z to high-Z
104
-
105
-
106
- -
107
- Version: 18.0.2
108
-
109
- Date: 2007-08-03
110
-
111
- Record: |
112
- This release fixes a bug in error reporting.
113
-
114
-
115
- h2. Repairs
116
-
117
- * Unhandled Ruby exceptions and errors were not being printed to the screen because Ruby-VPI unconditionally gave control back to the Verilog simulator before it exited.
118
-
119
-
120
- -
121
- Version: 18.0.1
122
-
123
- Date: 2007-08-02
124
-
125
- Record: |
126
- This release fixes some bugs regarding simulation time and control.
127
-
128
-
129
- h2. Thanks
130
-
131
- * Calvin Wong reported the bugs listed in the Repairs section.
132
-
133
-
134
- h2. Repairs
135
-
136
- * VCS does not acknowledge passage of time when cbReadWriteSynch callback is used, so I reverted back to using the cbAfterDelay callback (as was done in version 17.0.0).
137
-
138
- * Ruby-VPI did not give control back to the Verilog simulator before it exited. As a result, the Verilog simulator did not have a chance to do any clean up or finish any pending tasks that remained in the simulation.
139
-
140
-
141
- -
142
- Version: 18.0.0
143
-
144
- Date: 2007-07-31
145
-
146
- Record: |
147
- This release restores support for Synopsys VCS and Cadence NC-Sim, improves portability and performance, and enhances the VPI abstraction layer.
148
-
149
-
150
- h2. Thanks
151
-
152
- * Calvin Wong discovered "how to bypass the following error":http://rubyforge.org/forum/message.php?msg_id=25691 emitted by Synopsys VCS when loading the Ruby-VPI shared object file.
153
-
154
- <pre>
155
- Could not open library specified in -load option obj/vcs
156
- obj/vcs: undefined symbol: vpi_put_data
157
- </pre>
158
-
159
-
160
- h2. Caution
161
-
162
- * "SWIG":http://www.swig.org/ is now required in order to compile and install Ruby-VPI.
163
-
164
- * @Vpi::Handle.put_value@ no longer checks whether the value written matches the value read back after writing because that only works when there is no VPI delay associated with the write.
165
-
166
- * When @Vpi::Handle.put_value@ is used to write a value to a wire (VpiNet), it now _forces_ the value. This is done to ensure portability:
167
-
168
- Synopsys VCS and Cadence NC-Sim forget the value written to a wire during the next simulation time step, whereas Mentor Modelsim and GPL Cver remember the value (thereby treating wires as registers).
169
-
170
- Note that you have to release a forced value (using @Vpi::Handle.release_value@) on a wire after writing to the wire if you want the design under test have the ability to update the value of the wire later on:
171
-
172
- <code>
173
- your_wire.intVal = 15
174
- your_wire.release_value
175
- advance_time # let the Verilog DUT modify your_wire
176
- </code>
177
-
178
- In addition, you can check if a wire has a forced value using the @Vpi::Handle.value_forced?@ method.
179
-
180
- * If the format is not specified, @Vpi::Handle.get_value@ now assumes that you want to read the value in VpiIntVal format (because this is the most common case).
181
-
182
- * The definition of "Derivatives" has been reworded for clarity in the "project license":readme.html#intro.license.
183
-
184
-
185
- h2. Repairs
186
-
187
- * Synopsys VCS and Cadence NC-Sim simulators now correctly load Ruby-VPI. Also, the 64-bit versions of these simulators are now supported.
188
-
189
-
190
- h2. Improvements
191
-
192
- * Added "force_value", "release_value", and "value_forced?" methods to the @Vpi::Handle@ class.
193
-
194
- * @Vpi::Handle.put_value@ now tries to automatically detect the format of the value to be written. As a result, you can now write @your_handle.put_value 35@ in lieu of writing @your_handle.intVal = 35@.
195
-
196
- * @Vpi::Handle.inspect@ now shows the hexStrVal of the handle (because it is a common case to want to see a handle's logic value along with its other information).
197
-
198
- * Added method caching (memoizing) for VPI property accesses on handles.
199
-
200
-
201
- -
202
- Version: 17.0.0
203
-
204
- Date: 2007-07-22
205
-
206
- Record: |
207
- This release makes the Ruby-VPI testing framework more lightweight by reducing the number of files and parameters involved.
208
-
209
-
210
- h2. Caution
211
-
212
- * The *generate_test.rb* and *convert.rb* executables have been replaced by a single *ruby-vpi* executable to avoid name conflicts with other software. They are now accessed using the <pre>ruby-vpi generate</pre> and <pre>ruby-vpi convert</pre> commands respectively.
213
-
214
- * The <tt>--name</tt> parameter has been removed from the automated test generator. Similarly, you can no longer insert an arbitrary name in a test's file names (see the "user manual":manual.html#Do_not_rename_generated_files for details).
215
-
216
- * The @DEBUG@ environment variable, which controls wether the test runner starts the interactive debugger, has been renamed to @DEBUGGER@.
217
-
218
- * The @SIMULATOR_TARGET@ and @SIMULATOR_INCLUDES@ parameters have been eliminated from test runners. The former is detected automatically. As for the latter, you can specify paths to directories in the @SIMULATOR_SOURCES@ parameter instead.
219
-
220
- * The <tt>bench.rb</tt> and <tt>bench.v</tt> files of a generated test are (1) no longer generated by the test generator and (2) are now ignored. You must move the functionality provided by these files into <tt>design.rb</tt> and your Verilog module's source file respectively.
221
-
222
- * The <tt>design.rb</tt> and <tt>proto.rb</tt> files are now loaded into a separate namespace (Ruby module). For example, if the Verilog module under test has the name "counter" and the <tt>design.rb</tt> file defines a class named "Foo", then that class will be accessible as "Counter::Foo".
223
-
224
- * The global @Vpi::simulate@ method has been replaced by the @cycle!@ method in the <tt>design.rb</tt> file.
225
-
226
- * The @simulate!@ method in the <tt>proto.rb</tt> file has been renamed to @feign!@ for accuracy.
227
-
228
- * The @RubyVpi@ module has been renamed to @RubyVPI@.
229
-
230
- * RSpec >= 1.0.0 is now required by Ruby-VPI.
231
-
232
- * The "project license":readme.html#intro.license has been further simplified.
233
-
234
-
235
- h2. Repairs
236
-
237
- * Restored support for Enumerable methods in @Vpi::Handle@.
238
-
239
- * The specification now begins to execute at simulation time 0. Previously it began at simulation time 1.
240
-
241
-
242
- h2. Improvements
243
-
244
- * The <tt>bench.rb</tt> and <tt>bench.v</tt> files of a generated test have been eliminated!
245
-
246
- One important benefit is that the Ruby interface to the Verilog module under test is now a direct reference, whereas previously it was an _indirect_ reference (it pointed to the Verilog module defined in <tt>bench.v</tt>, which in turn wrapped around the actual Verilog module under test).
247
-
248
- As a result, you can now access the internals of the Verilog module under test by simply calling methods on the Ruby interface, as you would naturally expect to be the case.
249
-
250
- * The "a" accessor, which returns an _array_ of child handles, has been added to "the method naming format":manual.html#tbl:accessors for accessing child handles.
251
-
252
- * All parameter objects in the Verilog module under test are automatically made available as constants. For example, if the Verilog module under test has the name @counter@ and has a parameter object named @WIDTH@, then you can access the integer value of that parameter using @Counter::WIDTH@.
253
-
254
- * The automated test generator now tries to automatically detect the clock and reset signal from Verilog module declarations.
255
-
256
- * The automated test generator now supports Verilog 95 style module declarations.
257
-
258
- * Exceptions are now raised when you try to write to a read-only VPI property, such as @VpiName@.
259
-
260
- * Added @high?@, @high!@, @low?@, and @low!@ methods to the @Vpi::Handle@ class.
261
-
262
- * Revised the user manual by removing unnecessary sections and adding newer material from my master's thesis.
263
-
264
-
265
- h2. Contributions
266
-
267
- * Added Jacinto Shy II's "register file example":http://jacintoshy.blogspot.com/2007/05/hacking-verilog-with-ruby-part-2.html to Ruby-VPI. It can be found in <tt>samp/register_file/</tt>.
268
-
269
-
270
- -
271
- Version: 16.0.1
272
-
273
- Date: 2007-05-27
274
-
275
- Record: |
276
- This release restores support for installation on Mac OS X.
277
-
278
- h2. Thanks
279
-
280
- * Mark Thompson "reported and solved":http://rubyforge.org/tracker/index.php?func=detail&aid=11125&group_id=1339&atid=5281 the problem.
281
-
282
- h2. Repairs
283
-
284
- * Shared-object files have a file extension of <tt>.so</tt> in Linux and <tt>.bundle</tt> on Mac OS X. Previously, only the Linux file extension was supported.
285
-
286
-
287
- -
288
- Version: 16.0.0
289
-
290
- Date: 2007-05-02
291
-
292
- Record: |
293
- This release adds support for the "Cadence NC-Sim":http://www.cadence.com/products/functional_ver/nc-verilog/ simulator, improves the project website and documentation, simplifies interaction with VPI, and comes with a more permissive license.
294
-
295
-
296
- h2. Caution
297
-
298
- * The @Integer.ensure_min@ and @Integer.ensure_max@ methods have been removed from the <tt>ruby-vpi/integer.rb</tt> library because Ruby already has idioms for these operations: <pre>
299
- >> 5.ensure_min 10
300
- => 10
301
- >> [5, 10].max
302
- => 10
303
-
304
- >> 5.ensure_max 10
305
- => 5
306
- >> [5, 10].min
307
- => 5
308
- </pre>
309
-
310
- * Ruby-VPI is now developed under a "more permissive license":readme.html#intro.license that better reflects my ethical beliefs than "the previous license":http://www.gnu.org/copyleft/gpl.html.
311
-
312
-
313
- h2. New features
314
-
315
- * The "Cadence NC-Sim":http://www.cadence.com/products/functional_ver/nc-verilog/ (ncsim) simulator is now supported.
316
-
317
- * VPI structures (whose names begin with "S_") now allow initialization of their members through their constructor, in the style of Ruby on Rails. For example, the expression @time = S_vpi_time.new :type => VpiSuppressTime@ is equivalent to: <code>
318
- time = S_vpi_time.new
319
- time.type = VpiSuppressTime
320
- </code>
321
-
322
- * Added the @Vpi::Handle.cbValueChange@ method which simplifies the registration of a value-change callback for a particular VPI handle. For instance, the user manual's "example of setting up a value-change callback":manual.html#ex..callback can now be written as follows: <code>
323
- Counter.count.cbValueChange do |s_cb_data|
324
- puts "hello from callback! time=#{s_cb_data.time.to_i} count=#{s_cb_data.obj.intVal}"
325
- end
326
- </code>
327
-
328
-
329
- h2. Details
330
-
331
- * Revised the project website according to the "Producing OSS":http://producingoss.com guidelines.
332
-
333
- * Added instructions for checking out source code and generating documentation.
334
-
335
-
336
- -
337
- Version: 15.0.2
338
-
339
- Date: 2007-01-22
340
-
341
- Record: |
342
- This release fixes problems with linking of the C extension and installation of the gem.
343
-
344
-
345
- h2. Details
346
-
347
- * Added checks for POSIX threads & Ruby libraries before creating makefile. Otherwise the <tt>.so</tt> files were not being linked to those libraries on the MASC machine!
348
-
349
- * The *make* program on the MASC machine does not like an empty Makefile. It was causing gem installation to fail.
350
-
351
-
352
- -
353
- Version: 15.0.1
354
-
355
- Date: 2007-01-15
356
-
357
- Record: |
358
- This release fixes another problem with compilation of the C extension and improves the user documentation's appearance.
359
-
360
-
361
- h2. Thanks
362
-
363
- * Derek Graham reported the problem with compilation of the C extension.
364
-
365
-
366
- h2. Details
367
-
368
- * Restored the monkey patch, which was removed in release 14.0.0, for the SWIG @va_list@ problem.
369
-
370
- * Made table of contents in-line with the content in user documentation.
371
-
372
- * Added printer-friendly stylesheet for user documentation.
373
-
374
-
375
- -
376
- Version: 15.0.0
377
-
378
- Date: 2007-01-13
379
-
380
- Record: |
381
- This release fixes a problem with compilation of the C extension, and makes clock generation code correctly affect Ruby prototypes.
382
-
383
-
384
- h2. Thanks
385
-
386
- * Derek Graham reported the problem with compilation of the C extension.
387
-
388
-
389
- h2. Caution
390
-
391
- * The @Vpi::advance_time@ method (instead of the @Vpi::simulate@ method) now invokes the design's @simulate!@ method when prototyping is enabled.
392
-
393
- This makes clock generation code (passed to the @RubyVpi::init_bench@ method) affect Ruby prototypes, just as it affects a real Verilog design.
394
-
395
- As a result, Ruby prototypes may need to check for edge-triggering through the new @Vpi::Handle.posedge?@ and @Vpi::Handle.negedge?@ methods. For example, see the "new implementation of the Counter prototype":manual.html#fig..counter_proto.rb.
396
-
397
- h3. New features
398
-
399
- * Added @Vpi::Handle.posedge?@ and @Vpi::Handle.negedge?@ methods which check if a handle's logic value is currently at a positive or negative edge, respectively.
400
-
401
- * Added @Vpi::S_vpi_time.integer@ and @Vpi::S_vpi_time.integer=@ methods which access the @high@ and @low@ integer fields as a single 64-bit integer.
402
-
403
- * Added utility methods for accessing the @value@ field in the @Vpi::S_vpi_value@ structure.
404
-
405
-
406
- h2. Details
407
-
408
- * Fixed problem with incorrect Ruby library flag in <tt>ext/extconf.rb</tt>. It happens that the @mkmf@ library determines the correct library flag all by itself!
409
-
410
- * Added new "prototyping section":manual.html#usage.prototyping to user manual.
411
-
412
- * Fixed some broken URLs in user documentation.
413
-
414
-
415
- -
416
- Version: 14.0.0
417
-
418
- Date: 2006-12-30
419
-
420
- Record: |
421
- This release adds support for simulation callbacks, renders Verilog benches _fully simplified_, and revises the user manual to reflect major changes.
422
-
423
-
424
- h2. Caution
425
-
426
- * The @Vpi::relay_verilog@ method has been replaced by @Vpi::simulate@.
427
-
428
- Please update you tests accordingly, because invoking the @Vpi::relay_verilog@ method directly will cause your tests to freeze/hang.
429
-
430
- * Verilog benches no longer contain any clock generation code. They are now mere skeletons, whose _only_ purpose is to instantiate the design under test.
431
-
432
- The clock generation code is now contained in the Ruby bench.
433
-
434
- h3. New features
435
-
436
- * The @RubyVpi::init_bench@ method now gives you _complete control_ over performing a clock/operation/whatever cycle for your design. This feature allows you to work with multi-clocked designs.
437
-
438
- * Callbacks are now supported through the @Vpi::vpi_register_cb@ method. See "the callbacks section in the user manual":manual.html#usage.vpi.callbacks for details.
439
-
440
- * Added the @Vpi::advance_time@ method, which makes the Verilog simulator simulate a given number of time steps.
441
-
442
- * Added the @Vpi::simulation_time@ method, which gives you the current simulation time as a 64-bit integer.
443
-
444
-
445
- h2. Details
446
-
447
- * Removed the monkey patch for the SWIG @va_list@ problem -- it no longer occurs.
448
-
449
- * Cleansed the appearance of the user documentation.
450
- ** Added indices to section headings, just like LaTeX.
451
- ** Admonition boxes no longer interfere with surrounding text, and they don't have big gap above them.
452
- ** Navigation menu is now elastic (fluid layout).
453
-
454
- * Revised the user manual and added new content.
455
- ** Moved "VPI utility layer" section from background chapter into usage chapter in user manual.
456
- ** Added a nice introduction to entire manual with links to reference documentation.
457
-
458
-
459
- -
460
- Version: 13.0.0
461
-
462
- Date: 2006-12-27
463
-
464
- Record: |
465
- This release fixes a _major_ instability bug, simplifies generated Verilog benches, and purifies the API reference documentation.
466
-
467
-
468
- h2. Caution
469
-
470
- * The @$ruby_init@ and @$ruby_relay@ system task/functions have been removed. Generated Verilog benches no longer use them.
471
- ** To pass your own command-line options to Ruby, set the @RUBYOPT@ environment variable before running a test.
472
-
473
- h3. New features
474
-
475
- * You can now choose when @Vpi::relay_verilog@ is triggered: upon positive/negative edge of the clock signal, or any other criteria. This is done by passing a block to the @RubyVpi::init_bench@ method (see "the API reference documentation":../ref/ruby/classes/RubyVpi.html for details).
476
-
477
-
478
- h2. Details
479
-
480
- * Fixed a major instability bug that was randomly causing segmentation faults and pthread assertion failures.
481
-
482
- The problem was that the @$ruby_init@ system task/function was mischeviously unlocking a pthread mutex. From then onward, all code assumed that the mutex was still locked -- but in reality, the mutex was already unlocked.
483
-
484
- * Replaced the @$ruby_init@ and @$ruby_relay@ system task/functions with callbacks.
485
-
486
- * Excluded internal stuff from the API reference documentation for Ruby.
487
-
488
- * Removed system-dependent path <tt>/usr/bin/ruby</tt> from the tools.
489
-
490
-
491
- -
492
- Version: 12.1.0
493
-
494
- Date: 2006-12-22
495
-
496
- Record: |
497
- This release adds interactive debugging support, adds new sections to the user manual, and cleanses some internals.
498
-
499
-
500
- h2. Caution
501
-
502
- * The <tt>lib/ruby-vpi/rspec.rb</tt> and <tt>lib/ruby-vpi/xx.rb</tt> files have been removed because they are no longer necessary.
503
-
504
- * rSpec 0.7.0 or newer is now required because the sample tests utilize the @should ==@ syntax.
505
-
506
- h3. New features
507
-
508
- * Test runners now support the @DEBUG@ environment variable, which enables the interactive debugger (ruby-debug) in "post-mortem debugging mode":http://www.datanoise.com/articles/2006/12/20/post-mortem-debugging.
509
- ** The @debugger@ command can also be used when the @DEBUG@ environment variable is not activated.
510
-
511
- * Status messages, which are shown during initialization of a Ruby bench, now appear in your simulator's log files.
512
-
513
-
514
- h2. Details
515
-
516
- * ruby-debug is now a gem dependency for Ruby-VPI.
517
-
518
- * Added documentation about "test runners":manual.html#usage.test-runner and the "interactive debugger":manual.html#usage.debugger in the user manual.
519
-
520
- * Added a <tt>README</tt> file with hint about where to find the user manual.
521
-
522
- * Removed code that wasn't being used, according to code coverage analysis, from the pipelined ALU sample.
523
-
524
-
525
- -
526
- Version: 12.0.2
527
-
528
- Date: 2006-12-18
529
-
530
- Record: |
531
- This release fixes a problem in the 12.0.1 gem, where the *generate_test.rb* and *header_to_ruby.rb* tools were not being installed properly.
532
-
533
-
534
- -
535
- Version: 12.0.1
536
-
537
- Date: 2006-12-18
538
-
539
- Record: |
540
- This release fixes a problem in code coverage analysis.
541
-
542
-
543
- h2. Thanks
544
-
545
- * Mauricio Fernandez helped me solve the problem with code coverage analysis.
546
-
547
-
548
- h2. Details
549
-
550
- Previously, code coverage reports were not providing any useful information because they were being generated _before_ the test had a chance to run. This problem has been fixed -- code coverage reports are now generated _after_ the test has finished running.
551
-
552
- This problem occurred because I had forgotten that @Kernel.at_exit@ invokes the blocks passed to it in _reverse_ order. So, the coverage report was being generated before Test::Unit had a chance to run (it also uses @Kernel.at_exit@).
553
-
554
-
555
- -
556
- Version: 12.0.0
557
-
558
- Date: 2006-12-07
559
-
560
- Record: |
561
- This release adds support for the "test/spec":http://chneukirchen.org/blog/archive/2006/10/announcing-test-spec-0-2-a-bdd-interface-for-test-unit.html library, fixes some bugs, and improves the user manual and generated tests.
562
-
563
-
564
- h2. Caution
565
-
566
- * Icarus Verilog 0.8 has been demoted to a "mostly acceptable":manual.html#setup.reqs status.
567
-
568
- * Generated Verilog benches no longer supply the <tt>-w</tt> option to the @$ruby_init@ task.
569
-
570
- * The @ruby-vpi/runner_proxy@ library now invokes test runners
571
- ** just before exiting. Thus, you can invoke tasks in the main <tt>Rakefile</tt> before the test runners are invoked.
572
- ** located within any directory that is a descendant of the current working directory.
573
-
574
- * The @SIMULATOR_ARGS@ parameter of generated runners has been renamed to @SIMULATOR_ARGUMENTS@ for clarity.
575
-
576
- * The automated test generator
577
- ** no longer displays the *backup* status indicator.
578
- ** now supplies a third argument to the @MERGER@ command.
579
- ** no longer replaces existing files with newly generated content during the *update* action. Instead, it now writes the newly generated output to a <tt>.new</tt> file and then invokes the @MERGER@ command.
580
-
581
-
582
- h2. Details
583
-
584
- * The @Vpi::Handle@ class has two new methods: @x!@ and @z!@, which set the handle's logic value to _unknown_ and _high impedance_ respectively.
585
-
586
- * The tests for the simple up-counter example were randomly failing because the specifications were not asserting the design's @reset@ signal long enough. So the design was getting into weird states and behaving in a non-deterministic way. This problem has been fixed.
587
-
588
- * The user manual has been revised and some minor issues have been fixed.
589
-
590
- h3. Test generation
591
-
592
- * The automated test generator accepts new command-line options:
593
- ** <tt>--test-unit</tt>
594
- ** <tt>--test-spec</tt>
595
- ** <tt>--tspec</tt>
596
-
597
- * The automated test generator was crashing when parsing module parameters of an input file which did not have any module parameters. This has been fixed.
598
-
599
- * Generated Verilog benches now contain simpler clock generation code.
600
-
601
- * Generated runners now contain
602
- ** a @:setup@ task which is invoked before the simulator runs. It can be used to make preprations, such as converting Verilog header files into Ruby, for the simulation.
603
- ** better explanations to accomodate new users.
604
-
605
- * Specifications generated in the *generic* format no longer contain a class that is instantiated in the generated Ruby bench.
606
-
607
-
608
- -
609
- Version: 11.1.1
610
-
611
- Date: 2006-11-15
612
-
613
- Record: |
614
- This release fixes a bug in the automated test generator, unifies the user manual and the website into a single documentation system, and adds support for rSpec 0.7.2.
615
-
616
-
617
- h2. Thanks
618
-
619
- * John Burr found the bug in the automated test generator.
620
-
621
-
622
- h2. Caution
623
-
624
- * The user manual is now available _only_ in HTML format. If you still wish to have a plain-text version, you can use a text-based browser, such as "lynx":http://lynx.browser.org/, to perform the necessary conversion.
625
-
626
-
627
- h2. Details
628
-
629
- * The automated test generator no longer crashes when parsing a Verilog module declaration that contains multiple module parameters.
630
-
631
- * The user manual and the website are now written using a custom documentation system based on RedCloth and ERB instead of DocBook-XML. This makes it easier to edit the user manual and reuse its content in other areas of the website.
632
-
633
-
634
- -
635
- Version: 11.1.0
636
-
637
- Date: 2006-11-08
638
-
639
- Record: |
640
- This release fixes a bug in generated benches, improves the "the @Vpi::Handle@ class":../ref/ruby/classes/Vpi/Handle.html, and improves performance by roughly 20%.
641
-
642
-
643
- h2. Thanks
644
-
645
- * Matt Fischler found the bug in generated benches (see below).
646
-
647
-
648
- h2. Caution
649
-
650
- * A bug in generated Verilog and Ruby benches, which caused the <pre>ruby: no such file to load -- ruby-vpi (LoadError)</pre> error, has been fixed. Please regenerate your tests to apply this bug fix to your tests.
651
-
652
-
653
- h2. Details
654
-
655
- * The class @SWIG::TYPE_p_unsigned_int@ has been aliased as @Vpi::Handle@ for easier access.
656
-
657
- * @Vpi::Handle.to_s@ and @Vpi::Handle.inspect@ now produce more informative output. For example, what used to appear as <pre>#<SWIG::TYPE_p_unsigned_int:0x2aaab6574fa0></pre> now appears as <pre>#<Vpi::Handle vpiModule fullName=counter_rspec_bench, size=-1, file=counter_rspec_bench.v, lineNo=2></pre> in this release.
658
- ** You can also provide a list of VPI properties, as names or integer constants, to those methods to see additional information in the output.
659
-
660
- * @Vpi::Handle@ now implements all methods from @Enumerable@, such as @map@, @each@, @select@, and so on. However, unlike their counterparts in @Enumerable@, these methods also accept a list of VPI properties, as names or integer constants. Thus, you are now able to write @handle.select(:reg, :net) {|h| h.size > 5}@ to obtain a list of child handles to registers and nets whose capacity is greater than 5 bits.
661
-
662
- * The @Vpi::Handle.[]@, @Vpi::Handle.get_value@, and @Vpi::Handle.put_value@ methods now accept names of VPI properties as well as their integer constants. Thus, you are now able to write @handle[:reg, :net]@ to obtain a list of handles to all child registers and nets.
663
-
664
- * @Vpi::Handle.method_missing@ has been refactored to cache queries. There is now, approximately, 20% improvement in performance.
665
-
666
- * @Vpi::Handle.method_missing@ has been fixed to accept operations with multiple underscores. For example, before this release, you could not write @handle.find_all_reg {|r| r.name =~ /foo/}@ because the "find_all_reg" method would be interpreted as the operation "find" and the VPI property "all_reg".
667
-
668
- * @Vpi::Handle.method_missing@ no longer requires that the first letter of a method be lower case. For example, now you can now write @handle.IntVal@ in addition to @handle.intVal@.
669
-
670
- * The @IntegerGenerator@ class, in the pipelined ALU example, has been fixed so that multiple instances do not interfere with the generation of each other's prime integers.
671
-
672
- * Due to a bug in the <tt>Rakefile</tt>, the reference documentation was not included in the previous few releases. This has been fixed.
673
-
674
-
675
- -
676
- Version: 11.0.0
677
-
678
- Date: 2006-11-05
679
-
680
- Record: |
681
- This release shortens generated Ruby benches and uses the less confusing notation for defining "singleton methods":http://wiki.rubygarden.org/Ruby/page/show/SingletonTutorial in generated designs and prototypes.
682
-
683
-
684
- h2. Caution
685
-
686
- * The arguments for the "@RubyVPI.init_bench@ method":../ref/ruby/classes/RubyVpi.html have changed.
687
-
688
- * *generate_test.rb* no longer emits undocumented status indicators: _name_ and _format_.
689
-
690
- * The source code is no longer distributed as a *zip* package, because it seems to be quite underutilized in comparison to the *tgz* and *gem* packages.
691
-
692
-
693
- h2. Details
694
-
695
- * Generated Ruby benches have been shortened to just _one_ line of code!
696
-
697
- * The less confusing notation of <code>def some_object.a_singleton_method
698
- do_stuff
699
- end</code> is now used instead of the <code>class << some_object
700
- def a_singleton_method
701
- do_stuff
702
- end
703
- end</code> notation.
704
- ** The tutorial and examples have been updated accordingly.
705
-
706
- * The pipelined ALU example now has an updated @IntegerGenerator@ class.
707
-
708
-
709
- -
710
- Version: 10.0.0
711
-
712
- Date: 2006-11-05
713
-
714
- Record: |
715
- This release adds the ability to access a handle's children and reduces the amount of code produced by the automated test generator.
716
-
717
-
718
- h2. Thanks
719
-
720
- * Matt Fischler found the problem of misdirected compilation errors in Verilog benches.
721
-
722
-
723
- h2. Caution
724
-
725
- * The way in which Ruby-VPI and generated tests interact has changed: the design is now a VPI handle object and the <tt>design.rb</tt> and <tt>proto.rb</tt> files define "singleton methods":http://wiki.rubygarden.org/Ruby/page/show/SingletonTutorial for that object.
726
- ** I suggest that you regenerate your existing tests (just run *generate_test.rb* again) whilst employing the service of a text merging tool (see the user manual).
727
-
728
- * You can now access a handle's children by simply calling methods on it. In the event that a child handle has the same name as a VPI property, the child is given priority. However, you can always access VPI properties explicitly via the @get_value@ and @put_value@ methods.
729
-
730
- * *generate_test.rb* no longer accepts the <pre>-s</pre> and <pre>-u</pre> options. Use their longer counterparts <pre>--rspec</pre> and <pre>--xunit</pre> instead.
731
-
732
-
733
-
734
- h2. Details
735
-
736
- h3. Automated test generator
737
-
738
- * 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).
739
-
740
- * The user is now notified when a backup of an existing file is made.
741
-
742
- * Generated tests have been greatly simplified to reduce the amount of work for the user.
743
- ** The design is now just a handle to the module in the Verilog bench.
744
- ** @include Vpi@ and @@design@ are no longer generated.
745
- ** The tutorial and examples have been updated accordingly.
746
-
747
- h3. User manual
748
-
749
- * Revised the stylesheet to make disjoint sections readily distinguishable from each other, through generous spacing and minor coloring.
750
-
751
- * Added tips about <tt>ruby-vpi/runner_proxy</tt>, <pre>rake -T</pre>, and using *kdiff3* with *generate_test.rb*.
752
-
753
- * Moved installation information into a new "setup" chapter.
754
-
755
-
756
- -
757
- Version: 9.0.0
758
-
759
- Date: 2006-10-28
760
-
761
- Record: |
762
- This release improves the automated test generator and adds new content to the user manual.
763
-
764
-
765
- h2. Thanks
766
-
767
- * Matt Fischler helped test and debug the installation of Ruby-VPI on Windows.
768
-
769
-
770
- h2. Caution
771
-
772
- * The command-line options for *generate_test.rb* have changed. Run the command <pre>generate_test.rb --help</pre> for details.
773
-
774
-
775
- h2. Details
776
-
777
- * Test runners now attempt to resolve paths in @SIMULATOR_SOURCES@ by searching for them within the directories specified in @SIMULATOR_INCLUDES@.
778
-
779
- * Synopsys VCS is now used in a better way (via the <pre>-load</pre> option).
780
- ** The old PLI table file (<tt>synopsys_vcs.tab</tt>) has been removed.
781
- ** The C extension has been revised accordingly.
782
-
783
- ** The C extension now compiles without errors in Cygwin.
784
-
785
- * The automated test generator now:
786
- ** Only creates output files when necessary.
787
- ** Updates existing output files using "text merging tools":manual.html#setup.recom if possible. (Refer to @MERGER@ in the help information of *generate_test.rb*.)
788
- ** Emits progress information similar to Ruby on Rails.
789
-
790
- * The user manual now:
791
- ** Includes instructions for installing on Windows (via Cygwin).
792
- ** Has a recommended software section, with links to text merging tools.
793
- ** Uses the term "xUnit":http://en.wikipedia.org/wiki/XUnit instead of "unit test".
794
- ** Correctly spells "rSpec".
795
-
796
-
797
- -
798
- Version: 8.2.0
799
-
800
- Date: 2006-10-24
801
-
802
- Record: |
803
- This release simplifies configuration of generated tests.
804
-
805
-
806
- h2. Thanks
807
-
808
- * "Students in the CMPE-126 class":http://www.soe.ucsc.edu/classes/cmpe126/Fall06/ for their comments and criticisms.
809
-
810
-
811
- h2. Caution
812
-
813
- * Generated runners now have a @SIMULATOR_INCLUDES@ array, whose entries specify places where Verilog source files, needed by the Verilog design, reside.
814
-
815
-
816
- h2. Details
817
-
818
- * Generated Verilog benches now inherit all @`include@ and @`define@ directives from the Verilog design in a simpler manner.
819
- * A generated test no longer requires its Verilog design to reside in the same directory.
820
- * The sample tests have been updated accordingly.
821
-
822
-
823
- -
824
- Version: 8.1.0
825
-
826
- Date: 2006-10-21
827
-
828
- Record: |
829
- This release adds an integer library and renames the vpi_util library.
830
-
831
-
832
- h2. Caution
833
-
834
- * The *vpi_util* library has been renamed to *vpi*. This change should not affect your code unless you explicitly imported this library via @require 'ruby-vpi/vpi_util'@. In which case, you should update your code to use @require 'ruby-vpi/vpi'@ accordingly.
835
-
836
-
837
- h2. Details
838
-
839
- * An integer library has been added to simplify common tasks related to hardware and the binary number system. You can import this library for use via @require 'ruby-vpi/integer'@.
840
-
841
-
842
- -
843
- Version: 8.0.0
844
-
845
- Date: 2006-10-13
846
-
847
- Record: |
848
- This release renames some identifiers for consistency, updates the documentation, and improves integration with RubyGems.
849
-
850
-
851
- h2. Caution
852
-
853
- * The @RubyVPI@ module has been renamed to @RubyVpi@.
854
-
855
- * The @PROTO@ environment variable has been renamed to @PROTOTYPE@.
856
- ** In addition to using *unset*, you can now disable simulation of the prototype by assigning an empty value to this variable.
857
-
858
-
859
- h2. Details
860
-
861
- * We now use "Darcs":http://darcs.net for revision control, instead of Subversion. The source repository can now be accessed at "http://ruby-vpi.rubyforge.org/src/ruby-vpi":http://ruby-vpi.rubyforge.org/src/ruby-vpi.
862
-
863
- * The source code is now distributed in tar.gz and zip form, in addition to gem.
864
-
865
- * Some identifiers have been renamed for better consistency.
866
-
867
- * The user manual now resides directly within the <tt>doc/</tt> directory.
868
- ** The integration of documentation in *gem_server* has been improved.
869
-
870
- * The glossary and tutorial in the user manual have been revised.
871
-
872
-
873
- -
874
- Version: 7.3.0
875
-
876
- Date: 2006-09-30
877
-
878
- Record: |
879
- This release fixes a bug in generated Verilog benches, includes parsed constants in generated tests, and adds new methods to handles.
880
-
881
-
882
- h2. Caution
883
-
884
- * Handles now have two new methods:
885
- ** @handle.x?@ checks if the logic value is "don't care"
886
- ** @handle.z?@ checks if the logic value is high impedance
887
-
888
-
889
- h2. Details
890
-
891
- * Module instantiation code in generated Verilog benches has been fixed. Whitespace between the module type and instance variable was missing.
892
-
893
- * The test generator tool now provides parsed Verilog constants and include-directives in generated Verilog benches; and parsed Verilog constants in generated Ruby designs.
894
- ** The pipelined ALU example has been revised accordingly.
895
-
896
- * A library for parsing Verilog source code has been added as <tt>lib/ruby-vpi/verilog_parser.rb</tt>.
897
-
898
-
899
- -
900
- Version: 7.2.0
901
-
902
- Date: 2006-09-15
903
-
904
- Record: |
905
- This release adds initial support for code coverage analysis via the "rcov library":http://eigenclass.org/hiki.rb?rcov.
906
-
907
-
908
- h2. Thanks
909
-
910
- * Mauricio Fernandez helped me use rcov without its runner.
911
-
912
-
913
- h2. Details
914
-
915
- * Added initial support (full capabilites of the rcov library, such as its various analysis modes, are not yet utilized) for code coverage analysis, which can be enabled by setting the @COVERAGE@ environment variable to a non-empty value before running a test.
916
- ** For example, you can run a test with the GPL Cver simulator while enabling the generation of code coverage reports as follows: <pre>export COVERAGE=1; rake cver</pre>
917
-
918
- * Coverage reports are generated in text and HTML formats.
919
-
920
-
921
- -
922
- Version: 7.1.0
923
-
924
- Date: 2006-08-29
925
-
926
- Record: |
927
- This release simplifies running of multiple tests, restores compatibility with Synopsys VCS, and better integrates with RubyGems.
928
-
929
-
930
- h2. Details
931
-
932
- * Added <tt>lib/ruby-vpi/runner_proxy.rb</tt> library which, when embedded into a Rakefile, runs all generated tests in the working directory with any specified arguments. For example, have a look at the <tt>samp/counter/Rakefile</tt> file.
933
-
934
- * Fixed a bug that prevented one from running tests with Synopsys VCS.
935
-
936
- * Ruby-VPI documentation is now available through RubyGems' "*gem_server* web interface":http://docs.rubygems.org/read/chapter/2#page10.
937
-
938
- * The user manual now discusses how to determine the location of a Ruby-VPI installation.
939
-
940
- * The <tt>tpl/</tt> directory has been removed.
941
-
942
-
943
- -
944
- Version: 7.0.0
945
-
946
- Date: 2006-08-29
947
-
948
- Record: |
949
- This release distributes Ruby-VPI as a gem, improves portability of generated tests, and fixes a bug.
950
-
951
-
952
- h2. Caution
953
-
954
- * @put_value()@ now accomodates register value overflows when verifying the value it has written.
955
-
956
- * The test generator's templates and the examples have been updated as follows:
957
- ** Test runners no longer have to specify the path to Ruby-VPI installation directory. Instead, they simply @require 'ruby-vpi/runner'@. Thus, you can run your tests on any machine with Ruby-VPI without having to know where it is installed.
958
- ** Ruby benches now invoke @RubyVPI.init_bench@ instead of @require 'bench'; setup_bench@ to become initialized.
959
-
960
- * All Ruby libraries in the <tt>lib/</tt> directory have been moved into <tt>lib/ruby-vpi/</tt> to prevent load-path clashes with other gems. You should access these libraries by prefixing their path with "ruby-vpi". For example, @require 'vpi_util'@ should now be written as @require 'ruby-vpi/vpi_util'@.
961
-
962
- * The <tt>src/</tt> directory has been renamed to <tt>ext/</tt> to follow RubyGems convention.
963
-
964
-
965
- h2. Details
966
-
967
- * Ruby-VPI is now distributed only as a "source gem":http://www.rubygems.org. You can decompress the gem without installing it onto your system by running the command <pre>gem install -i output_directory ruby-vpi-7.0.0.gem</pre>. In addition, you can still obtain the source code directly from the Subversion repository.
968
-
969
- * The tools in <tt>bin/</tt> become available in your system's <tt>bin/</tt> directory when the gem is installed.
970
- ** Usage and help information has been added to the *header_to_ruby.rb* tool.
971
-
972
- * Incorrect spelling of GPL Cver (v should be uncapitalized) has been fixed.
973
-
974
- * Incorrect link to GPL Cver website has been fixed.
975
-
976
- * The user manual has been updated according to all of the above changes.
977
-
978
-
979
- -
980
- Version: 6.3.0
981
-
982
- Date: 2006-08-27
983
-
984
- Record: |
985
- This release adds support for the GPL Cver simulator, provides both binary and source packages, and explicitly defines the version numbering system.
986
-
987
-
988
- h2. Caution
989
-
990
- * Ruby-VPI now only needs to be built once.
991
- ** You can run tests with different Verilog simulators without having to re-compile Ruby-VPI.
992
-
993
-
994
- h2. Details
995
-
996
- * The GPL Cver simulator is now supported.
997
-
998
- * Release packages are now available in both source and binary form.
999
-
1000
- * The RSpec based specifications for the counter example now use the @should_equal@ instead of the @should_be@ assertion, because the latter ensures strict equivalence. For instance, it will fail when a Fixnum is compared to a Bignum.
1001
-
1002
- * We now follow the RubyGems project's "rational versioning policy":http://www.rubygems.org/read/chapter/7. The version numbers of previous releases have been revised accordingly:
1003
- |_. Release date |_. Original version number |_. New version number |
1004
- | 1999-10-31 | 0.0 | 0.0.0 |
1005
- | 2006-02-26 | 0.1 | 1.0.0 |
1006
- | 2006-04-17 | 0.2 | 2.0.0 |
1007
- | 2006-04-23 | 0.3 | 3.0.0 |
1008
- | 2006-04-28 | 0.4 | 3.1.0 |
1009
- | 2006-05-13 | 0.5 | 3.2.0 |
1010
- | 2006-05-25 | 0.6 | 4.0.0 |
1011
- | 2006-07-22 | 0.7 | 5.0.0 |
1012
- | 2006-07-29 | 0.8 | 5.1.0 |
1013
- | 2006-08-04 | 0.8.1 | 5.1.1 |
1014
- | 2006-08-07 | 0.9 | 6.0.0 |
1015
- | 2006-08-09 | 0.9.1 | 6.1.0 |
1016
- | 2006-08-26 | 0.9.2 | 6.2.0 |
1017
-
1018
- -
1019
- Version: 6.2.0
1020
-
1021
- Date: 2006-08-26
1022
-
1023
- Record: |
1024
- This release beautifies generated tests, adds checks to find signal width bugs, and includes a new tool.
1025
-
1026
-
1027
- h2. Caution
1028
-
1029
- * @put_value()@ now returns the value it puts. Therefore, it is easier to chain together a series of assignments: @foo.intVal = bar.intVal = baz.intVal = 10@
1030
-
1031
- * @put_value()@ 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.
1032
-
1033
-
1034
- h2. Details
1035
-
1036
- * The test generator now uses ERB templates which ensures nice indentation of generated output.
1037
-
1038
- * The test generator now decouples Ruby-VPI paths from Verilog benches via the RUBYLIB environment variable.
1039
-
1040
- * A tool which converts Verilog headers into Ruby has been added.
1041
-
1042
- * The source code is now indented with two spaces instead of one tab character.
1043
-
1044
-
1045
- -
1046
- Version: 6.1.0
1047
-
1048
- Date: 2006-08-09
1049
-
1050
- Record: |
1051
- This release simplifies generated tests and fixes a bug.
1052
-
1053
-
1054
- h2. Details
1055
-
1056
- * The test generator now produces simpler Ruby benches and specifications.
1057
- ** A template used by generated specifications has been added.
1058
- ** The counter example and tutorial have also been simplified accordingly.
1059
-
1060
- * Boolean VPI property values are now correctly converted into Ruby truth values.
1061
-
1062
-
1063
- -
1064
- Version: 6.0.0
1065
-
1066
- Date: 2006-08-07
1067
-
1068
- Record: |
1069
- This release adds support and documentation for rapid prototyping of Verilog designs in Ruby.
1070
-
1071
-
1072
- h2. Caution
1073
-
1074
- * The directory structure has been reorganized as follows:
1075
- ** <tt>ext</tt> &rarr; <tt>src</tt>
1076
- ** <tt>tools</tt> &rarr; <tt>bin</tt>
1077
- ** <tt>examples</tt> &rarr; <tt>samp</tt>
1078
-
1079
- * All template files have been moved into the <tt>tpl</tt> directory.
1080
-
1081
-
1082
- h2. Details
1083
-
1084
- * Support for prototyping designs in Ruby, before they are implemented in Verilog, has been added.
1085
- ** The _same_ specification can be used to verify both prototype _and_ design! :-)
1086
- ** The tutorial in the user manual has been updated to discuss prototyping.
1087
- *** Prototypes have been added to the counter example.
1088
-
1089
- * The user manual has been revised for consistency.
1090
-
1091
-
1092
- -
1093
- Version: 5.1.1
1094
-
1095
- Date: 2006-08-04
1096
-
1097
- Record: |
1098
- This release fixes unreadable syntax coloring in the user manual.
1099
-
1100
-
1101
- h2. Thanks
1102
-
1103
- * Todd Nagengast and Matt Fischler notified me about unreadable text in the user manual.
1104
-
1105
-
1106
- h2. Details
1107
-
1108
- * Source code comments in the user manual are now readable.
1109
-
1110
- * The <tt>README</tt> and <tt>HISTORY</tt> files have been converted to "textile":http://www.textism.com/tools/textile/ format.
1111
-
1112
-
1113
- -
1114
- Version: 5.1.0
1115
-
1116
- Date: 2006-07-29
1117
-
1118
- Record: |
1119
- This release adds a tutorial to the user manual, and improves the tools and examples.
1120
-
1121
-
1122
- h2. Thanks
1123
-
1124
- * Phil Tomson corrected the URL of the RHDL website in the user manual.
1125
-
1126
-
1127
- h2. Details
1128
-
1129
- h3. User manual
1130
-
1131
- * A tutorial, based on the counter example, has been added to the user manual.
1132
-
1133
- * The user manual's appearance has been dramatically improved with syntax coloring for source code, and "graphics for admonitions and navigation":http://tango.freedesktop.org.
1134
-
1135
- h3. Examples
1136
-
1137
- * A specification, expressed in unit test format, has been added to the counter example.
1138
-
1139
- * The <pre>--name</pre> and <pre>-n</pre> options, which lets you specify an identifier for a generated test, have been added to the *generate_test.rb* tool.
1140
-
1141
- * Running <pre>rake clobber</pre> in an example directory no longer destroys documentation in the Ruby-VPI directory.
1142
-
1143
- * The examples' Rakefiles now invoke all tests present in the directory via the <tt>launcher_template.rake</tt> template.
1144
-
1145
- * The Rake template for test runners (generated by <tt>tools/generate_test.rb</tt>) has moved from <tt>examples/template.rake</tt> to <tt>examples/runner_template.rake</tt>.
1146
-
1147
- h3. VPI utility layer
1148
-
1149
- * The value of a handle's boolean VPI property is treated as @false@ if it is zero, because zero is @false@ in the C language.
1150
-
1151
-
1152
- -
1153
- Version: 5.0.0
1154
-
1155
- Date: 2006-07-22
1156
-
1157
- Record: |
1158
- This release enhances the VPI utility layer and adds new content to the user manual.
1159
-
1160
-
1161
- h2. Thanks
1162
-
1163
- * Jan Decaluwe corrected the description of MyHDL in the user manual.
1164
-
1165
-
1166
- h2. Caution
1167
-
1168
- * SWIG is no longer required for users because its output is included in the release package.
1169
-
1170
- * The @handle.value@ and @handle.value=@ methods have been removed.
1171
-
1172
-
1173
- h2. Details
1174
-
1175
- * The VPI utility layer provides access to VPI properties of handles in a "simpler, more powerful way":manual.html#background.org.vpi.
1176
-
1177
- ** All VPI properties, except delay values, are now accessible from a handle.
1178
-
1179
- * The user manual has been revised and new content in the organization and usage sections has been added.
1180
-
1181
- * This release was tested and developed using:
1182
- ** Ruby 1.8.4 and Icarus Verilog 0.8 on i686 GNU/Linux
1183
- ** Ruby 1.8.4 and Mentor Modelsim 6.1d on x86_64 GNU/Linux
1184
-
1185
-
1186
- -
1187
- Version: 4.0.0
1188
-
1189
- Date: 2006-05-25
1190
-
1191
- Record: |
1192
- This release adds a comprehensive user manual, upgrades from make to "Rake":http://rake.rubyforge.org, and improves the test generation tool.
1193
-
1194
-
1195
- h2. Thanks
1196
-
1197
- * Jose Renau solved the problem of strange delays that occurred whenever a design was reset.
1198
-
1199
-
1200
- h2. Caution
1201
-
1202
- * Rake has replaced the role of *make*. All makefiles have been converted accordingly.
1203
-
1204
- * The test generation tool now generates multiple files (runner, bench, design, spec) and makes backups of existing files. See its help information for details.
1205
-
1206
-
1207
- h2. Details
1208
-
1209
- * A comprehensive user manual, written in DocBook-XML, has been added.
1210
-
1211
- * Support for RSpec 0.5.4 has been added.
1212
- ** The counter example now makes use of RSpec.
1213
-
1214
- * This release was tested and developed using:
1215
- ** Ruby 1.8.4 and Icarus Verilog 0.8 on i686 GNU/Linux
1216
- ** Ruby 1.8.4 and Mentor Modelsim 6.1d on x86_64 GNU/Linux
1217
-
1218
-
1219
- -
1220
- Version: 3.2.0
1221
-
1222
- Date: 2006-05-13
1223
-
1224
- Record: |
1225
- This release adds a tool which generates test benches, and adds support for "Behavior Driven Development":http://behaviour-driven.org via the "RSpec":http://rspec.rubyforge.org library.
1226
-
1227
-
1228
- h2. Thanks
1229
-
1230
- * Scott L Holmes helped me "use the RSpec library without its runner":http://article.gmane.org/gmane.comp.lang.ruby.general/150087 program.
1231
-
1232
-
1233
- h2. Details
1234
-
1235
- * A tool, which generates most of a Ruby-VPI test bench from a Verilog 2001 module declaration, has been added.
1236
-
1237
- * Ability to use RSpec in a test bench has been added.
1238
-
1239
- * Ability to specify arbitrary command-line arguments to Verilog simulators has been added in the examples' makefile template.
1240
-
1241
- * This release was tested and developed using:
1242
- ** Ruby 1.8.4 and Icarus Verilog 0.8 on i686 GNU/Linux
1243
- ** Ruby 1.8.4 and Mentor Modelsim 6.1d on x86_64 GNU/Linux
1244
-
1245
-
1246
- -
1247
- Version: 3.1.0
1248
-
1249
- Date: 2006-04-28
1250
-
1251
- Record: |
1252
- This release adds simple ways of reading and writing values to VPI handles, adds documentation for the VPI utility layer, and fixes the pipelined ALU example.
1253
-
1254
-
1255
- h2. Caution
1256
-
1257
- * The *msim* Makefile target for Mentor Modelsim has been renamed back to *vsim*.
1258
-
1259
-
1260
- h2. Details
1261
-
1262
- * Simple, consistent ways of reading and writing values to handles have been added to the VPI utility layer. These ways are described in the @SWIG::TYPE_p_unsigned_int@ class' documentation.
1263
-
1264
- * The makefiles now use the *rbconfig* library to determine the default compiler and linker flags for Ruby.
1265
-
1266
- * A race condition in the pipelined ALU example has been fixed. This example should now run successfully in all Verilog simulators.
1267
-
1268
- * The project wiki has been abandoned in favor of RDoc.
1269
-
1270
- * The project website is now generated by RDoc.
1271
-
1272
- * This release was tested and developed using:
1273
- ** Ruby 1.8.4 and Icarus Verilog 0.8 on i686 GNU/Linux
1274
- ** Ruby 1.8.4 and Mentor Modelsim 6.1d on x86_64 GNU/Linux
1275
-
1276
-
1277
- -
1278
- Version: 3.0.0
1279
-
1280
- Date: 2006-04-23
1281
-
1282
- Record: |
1283
- This release adds support for the _entire_ "IEEE Std. 1364-2005":http://ieeexplore.ieee.org/xpl/standardstoc.jsp?isnumber=33945 VPI interface, and updates the examples into unit tests.
1284
-
1285
-
1286
- h2. Thanks
1287
-
1288
- * The "SWIG developers":http://www.swig.org/guilty.html made this project _much_ easier! ;-)
1289
-
1290
-
1291
- h2. Caution
1292
-
1293
- * The *vsim* Makefile target for Mentor Modelsim has been renamed to *msim*.
1294
-
1295
-
1296
- h2. Details
1297
-
1298
- * The Ruby interface to VPI is now generated by "SWIG":http://www.swig.org.
1299
- ** The main @VPI@ module has been renamed to @Vpi@.
1300
- ** The @VPI::Handle@ class has been removed.
1301
- ** The @VPI::stop@, @VPI::finish@, and @VPI::reset@ methods have been removed.
1302
-
1303
- * The "_final ballot_ version":http://www.boydtechinc.com/ptf/archive/ptf_2005/0737.html of the <tt>vpi_user.h</tt> header file is now packaged along with and used by Ruby-VPI.
1304
-
1305
- * The VPI module, its sub-classes, and its functionality have been replaced by the VPI utility layer (see <tt>src/vpi_util.rb</tt>).
1306
-
1307
- * The examples now make use of the *test/unit* unit testing framework.
1308
-
1309
- * The makefiles for the examples have been simplified through the use of a common template.
1310
-
1311
- * This release was tested and developed using:
1312
- ** Ruby 1.8.4 and Icarus Verilog 0.8 on i686 GNU/Linux
1313
- ** Ruby 1.8.4 and Mentor Modelsim 6.1d on x86_64 GNU/Linux
1314
-
1315
-
1316
- -
1317
- Version: 2.0.0
1318
-
1319
- Date: 2006-04-17
1320
-
1321
- Record: |
1322
- This release fixes major bugs, adds support for Mentor Modelsim, and removes the @$ruby_task@ callback.
1323
-
1324
-
1325
- h2. Thanks
1326
-
1327
- * Nobu Nakada explained the "cross-thread violation on rb_gc()":http://article.gmane.org/gmane.comp.lang.ruby.general/146653 error.
1328
-
1329
-
1330
- h2. Caution
1331
-
1332
- * Removed @$ruby_task@ callback and ability to dynamically register system tasks from Ruby because inter-process communication is complicated at present.
1333
-
1334
-
1335
- h2. Details
1336
-
1337
- * The "cross-thread violation on rb_gc()" error has been fixed.
1338
- ** The "stack level too deep (SystemStackError)" error has been fixed.
1339
- ** The test/unit library can be used in Ruby test bench.
1340
- ** Mentor Modelsim Verilog simulator works with Ruby-VPI.
1341
-
1342
- * Added piplelined ALU example.
1343
-
1344
- * This release was tested and developed using:
1345
- ** Ruby 1.8.4 and Icarus Verilog 0.8 on i686 GNU/Linux
1346
- ** Ruby 1.8.4 and Modelsim 6.1d on x86_64 GNU/Linux
1347
- ** Ruby 1.8.4 and Synopsys VCS-MX X-2005.06-SP1 on SPARC4 SunOS 5.10
1348
-
1349
-
1350
- -
1351
- Version: 1.0.0
1352
-
1353
- Date: 2006-02-26
1354
-
1355
- Record: |
1356
- This release adds enough Verilog VPI functionality to make Ruby-VPI usable for simple test benches:
1357
- * access Verilog objects through VPI handles
1358
- * read and change VPI handle values
1359
- * stop, finish, restart the simulation
1360
-
1361
-
1362
- h2. Thanks
1363
-
1364
- * Jose Renau helped me debug how Synopsys VCS works with Verilog VPI. The problem was that VCS required calltf signatures to be @void (*)(void)@, whereas the Verilog standard defines a calltf signature as @PLI_INT32 (*)(PLI_BYTE8*)@.
1365
-
1366
- * Ross Bamford, Eric Hodel, and Yukihiro Matsumoto "helped me discover":http://blade.nagaokaut.ac.jp/cgi-bin/scat.rb/ruby/ruby-talk/180662 why the @SystemStackError@ was happening.
1367
-
1368
-
1369
- h2. Details
1370
-
1371
- * Implemented some Verilog VPI functionality:
1372
- ** @VPI::handle_by_name(string, VPI::Handle)@ &rarr; @VPI::Handle@
1373
- ** @VPI::handle_by_name(string)@ &rarr; @VPI::Handle@
1374
- ** @VPI::Handle.put_value(integer)@
1375
- ** @VPI::Handle.value = integer@
1376
- ** @VPI::Handle.get_value@ &rarr; @integer@
1377
- ** @VPI::Handle.value@ &rarr; @integer@
1378
- ** @VPI::stop@
1379
- ** @VPI::finish@
1380
- ** @VPI::reset@
1381
-
1382
- * Implemented some additional functionality:
1383
- ** @VPI::register_task(string, &proc)@
1384
-
1385
- * Added ability to pass arbitrary command-line arguments to the Ruby interpreter (using @$ruby_init@). Now you can invoke any Ruby script you want, instead of <tt>pli_init.rb</tt>.
1386
-
1387
- * Added ability to dynamically register system tasks from Ruby, using @VPI::register_task("task name")@, and call them from Verilog, using @$ruby_task("task name")@.
1388
-
1389
- * Added @VPI::Handle@ class which encapsulates a @vpiHandle@ VPI object.
1390
-
1391
- * This release was tested and developed using:
1392
- ** Ruby 1.8.2 and Icarus Verilog 0.8 on i686 GNU/Linux
1393
- ** Ruby 1.8.4, Synopsys VCS X-2005.06, and Mentor Modelsim 6.1b on i686 GNU/Linux
1394
-
1395
-
1396
- -
1397
- Version: 0.0.0
1398
-
1399
- Date: 1999-10-31
1400
-
1401
- Record: |
1402
- This is Kazuhiro HIWADA's initial testing release of Ruby-VPI. See its "original announcement":http://blade.nagaokaut.ac.jp/cgi-bin/scat.rb/ruby/ruby-list/18193 and "source code":http://rubyforge.org/frs/?group_id=1339&release_id=8852.
1403
-
1404
-
1405
- h2. Details
1406
-
1407
- * Added ability to relay control from Verilog test bench to Ruby (using @$ruby_callback@) and vice versa (using @PLI::relay_Verilog@).
1408
-
1409
- * Tested and developed using Ruby 1.4 and Verilog-XL from Cadence systems, on a SPARC machine running Solaris 2.6.