wasmtime 11.0.0 → 12.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2468) hide show
  1. checksums.yaml +4 -4
  2. data/Cargo.lock +234 -173
  3. data/ext/Cargo.toml +7 -7
  4. data/ext/cargo-vendor/addr2line-0.20.0/.cargo-checksum.json +1 -0
  5. data/ext/cargo-vendor/addr2line-0.20.0/CHANGELOG.md +321 -0
  6. data/ext/cargo-vendor/addr2line-0.20.0/Cargo.lock +548 -0
  7. data/ext/cargo-vendor/addr2line-0.20.0/Cargo.toml +145 -0
  8. data/ext/cargo-vendor/addr2line-0.20.0/examples/addr2line.rs +306 -0
  9. data/ext/cargo-vendor/addr2line-0.20.0/src/builtin_split_dwarf_loader.rs +164 -0
  10. data/ext/cargo-vendor/addr2line-0.20.0/src/function.rs +555 -0
  11. data/ext/cargo-vendor/addr2line-0.20.0/src/lazy.rs +31 -0
  12. data/ext/cargo-vendor/addr2line-0.20.0/src/lib.rs +1729 -0
  13. data/ext/cargo-vendor/addr2line-0.20.0/tests/correctness.rs +126 -0
  14. data/ext/cargo-vendor/addr2line-0.20.0/tests/output_equivalence.rs +135 -0
  15. data/ext/cargo-vendor/addr2line-0.20.0/tests/parse.rs +114 -0
  16. data/ext/cargo-vendor/bytes-1.4.0/.cargo-checksum.json +1 -0
  17. data/ext/cargo-vendor/bytes-1.4.0/CHANGELOG.md +283 -0
  18. data/ext/cargo-vendor/bytes-1.4.0/Cargo.toml +54 -0
  19. data/ext/cargo-vendor/bytes-1.4.0/LICENSE +25 -0
  20. data/ext/cargo-vendor/bytes-1.4.0/README.md +56 -0
  21. data/ext/cargo-vendor/bytes-1.4.0/benches/buf.rs +186 -0
  22. data/ext/cargo-vendor/bytes-1.4.0/benches/bytes.rs +120 -0
  23. data/ext/cargo-vendor/bytes-1.4.0/benches/bytes_mut.rs +266 -0
  24. data/ext/cargo-vendor/bytes-1.4.0/ci/miri.sh +11 -0
  25. data/ext/cargo-vendor/bytes-1.4.0/ci/test-stable.sh +28 -0
  26. data/ext/cargo-vendor/bytes-1.4.0/ci/tsan.sh +13 -0
  27. data/ext/cargo-vendor/bytes-1.4.0/clippy.toml +1 -0
  28. data/ext/cargo-vendor/bytes-1.4.0/src/buf/buf_impl.rs +1394 -0
  29. data/ext/cargo-vendor/bytes-1.4.0/src/buf/buf_mut.rs +1493 -0
  30. data/ext/cargo-vendor/bytes-1.4.0/src/buf/chain.rs +242 -0
  31. data/ext/cargo-vendor/bytes-1.4.0/src/buf/iter.rs +130 -0
  32. data/ext/cargo-vendor/bytes-1.4.0/src/buf/limit.rs +75 -0
  33. data/ext/cargo-vendor/bytes-1.4.0/src/buf/mod.rs +41 -0
  34. data/ext/cargo-vendor/bytes-1.4.0/src/buf/reader.rs +81 -0
  35. data/ext/cargo-vendor/bytes-1.4.0/src/buf/take.rs +155 -0
  36. data/ext/cargo-vendor/bytes-1.4.0/src/buf/uninit_slice.rs +213 -0
  37. data/ext/cargo-vendor/bytes-1.4.0/src/buf/vec_deque.rs +22 -0
  38. data/ext/cargo-vendor/bytes-1.4.0/src/buf/writer.rs +88 -0
  39. data/ext/cargo-vendor/bytes-1.4.0/src/bytes.rs +1304 -0
  40. data/ext/cargo-vendor/bytes-1.4.0/src/bytes_mut.rs +1812 -0
  41. data/ext/cargo-vendor/bytes-1.4.0/src/fmt/debug.rs +49 -0
  42. data/ext/cargo-vendor/bytes-1.4.0/src/fmt/hex.rs +37 -0
  43. data/ext/cargo-vendor/bytes-1.4.0/src/fmt/mod.rs +5 -0
  44. data/ext/cargo-vendor/bytes-1.4.0/src/lib.rs +117 -0
  45. data/ext/cargo-vendor/bytes-1.4.0/src/loom.rs +30 -0
  46. data/ext/cargo-vendor/bytes-1.4.0/src/serde.rs +89 -0
  47. data/ext/cargo-vendor/bytes-1.4.0/tests/test_buf.rs +120 -0
  48. data/ext/cargo-vendor/bytes-1.4.0/tests/test_buf_mut.rs +178 -0
  49. data/ext/cargo-vendor/bytes-1.4.0/tests/test_bytes.rs +1210 -0
  50. data/ext/cargo-vendor/bytes-1.4.0/tests/test_bytes_odd_alloc.rs +97 -0
  51. data/ext/cargo-vendor/bytes-1.4.0/tests/test_bytes_vec_alloc.rs +143 -0
  52. data/ext/cargo-vendor/bytes-1.4.0/tests/test_chain.rs +177 -0
  53. data/ext/cargo-vendor/bytes-1.4.0/tests/test_debug.rs +35 -0
  54. data/ext/cargo-vendor/bytes-1.4.0/tests/test_iter.rs +21 -0
  55. data/ext/cargo-vendor/bytes-1.4.0/tests/test_reader.rs +29 -0
  56. data/ext/cargo-vendor/bytes-1.4.0/tests/test_serde.rs +20 -0
  57. data/ext/cargo-vendor/bytes-1.4.0/tests/test_take.rs +32 -0
  58. data/ext/cargo-vendor/cap-fs-ext-2.0.0/.cargo-checksum.json +1 -0
  59. data/ext/cargo-vendor/cap-fs-ext-2.0.0/Cargo.toml +63 -0
  60. data/ext/cargo-vendor/cap-fs-ext-2.0.0/src/is_file_read_write.rs +61 -0
  61. data/ext/cargo-vendor/cap-primitives-2.0.0/.cargo-checksum.json +1 -0
  62. data/ext/cargo-vendor/cap-primitives-2.0.0/Cargo.toml +81 -0
  63. data/ext/cargo-vendor/cap-primitives-2.0.0/src/fs/mod.rs +125 -0
  64. data/ext/cargo-vendor/cap-primitives-2.0.0/src/net/pool.rs +284 -0
  65. data/ext/cargo-vendor/cap-primitives-2.0.0/src/rustix/fs/copy_impl.rs +233 -0
  66. data/ext/cargo-vendor/cap-primitives-2.0.0/src/rustix/fs/metadata_ext.rs +384 -0
  67. data/ext/cargo-vendor/cap-primitives-2.0.0/src/rustix/fs/oflags.rs +98 -0
  68. data/ext/cargo-vendor/cap-primitives-2.0.0/src/rustix/fs/open_unchecked.rs +71 -0
  69. data/ext/cargo-vendor/cap-primitives-2.0.0/src/rustix/fs/reopen_impl.rs +18 -0
  70. data/ext/cargo-vendor/cap-primitives-2.0.0/src/rustix/fs/set_permissions_impl.rs +49 -0
  71. data/ext/cargo-vendor/cap-primitives-2.0.0/src/rustix/fs/stat_unchecked.rs +79 -0
  72. data/ext/cargo-vendor/cap-primitives-2.0.0/src/rustix/fs/times.rs +61 -0
  73. data/ext/cargo-vendor/cap-primitives-2.0.0/src/rustix/linux/fs/procfs.rs +81 -0
  74. data/ext/cargo-vendor/cap-primitives-2.0.0/src/windows/fs/create_file_at_w.rs +273 -0
  75. data/ext/cargo-vendor/cap-primitives-2.0.0/src/windows/fs/metadata_ext.rs +214 -0
  76. data/ext/cargo-vendor/cap-primitives-2.0.0/src/windows/fs/open_unchecked.rs +228 -0
  77. data/ext/cargo-vendor/cap-rand-2.0.0/.cargo-checksum.json +1 -0
  78. data/ext/cargo-vendor/cap-rand-2.0.0/Cargo.toml +38 -0
  79. data/ext/cargo-vendor/cap-std-2.0.0/.cargo-checksum.json +1 -0
  80. data/ext/cargo-vendor/cap-std-2.0.0/Cargo.toml +67 -0
  81. data/ext/cargo-vendor/cap-std-2.0.0/build.rs +41 -0
  82. data/ext/cargo-vendor/cap-std-2.0.0/src/fs/file.rs +614 -0
  83. data/ext/cargo-vendor/cap-std-2.0.0/src/fs_utf8/file.rs +608 -0
  84. data/ext/cargo-vendor/cap-std-2.0.0/src/lib.rs +51 -0
  85. data/ext/cargo-vendor/cap-std-2.0.0/src/net/udp_socket.rs +418 -0
  86. data/ext/cargo-vendor/cap-time-ext-2.0.0/.cargo-checksum.json +1 -0
  87. data/ext/cargo-vendor/cap-time-ext-2.0.0/Cargo.toml +42 -0
  88. data/ext/cargo-vendor/cap-time-ext-2.0.0/src/monotonic_clock.rs +62 -0
  89. data/ext/cargo-vendor/cap-time-ext-2.0.0/src/system_clock.rs +59 -0
  90. data/ext/cargo-vendor/cranelift-bforest-0.99.1/.cargo-checksum.json +1 -0
  91. data/ext/cargo-vendor/cranelift-bforest-0.99.1/Cargo.toml +31 -0
  92. data/ext/cargo-vendor/cranelift-codegen-0.99.1/.cargo-checksum.json +1 -0
  93. data/ext/cargo-vendor/cranelift-codegen-0.99.1/Cargo.toml +159 -0
  94. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/cursor.rs +644 -0
  95. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/ir/extfunc.rs +411 -0
  96. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/ir/function.rs +469 -0
  97. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/ir/globalvalue.rs +155 -0
  98. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/ir/mod.rs +106 -0
  99. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/aarch64/abi.rs +1543 -0
  100. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/aarch64/inst/emit.rs +3919 -0
  101. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/aarch64/inst/mod.rs +3039 -0
  102. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/aarch64/inst.isle +4048 -0
  103. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/aarch64/lower/isle.rs +873 -0
  104. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/aarch64/lower.isle +2907 -0
  105. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/riscv64/abi.rs +985 -0
  106. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/riscv64/inst/emit.rs +3254 -0
  107. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/riscv64/inst/mod.rs +2125 -0
  108. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/riscv64/inst.isle +2972 -0
  109. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/riscv64/lower/isle.rs +620 -0
  110. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/riscv64/lower.isle +2002 -0
  111. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/x64/abi.rs +1204 -0
  112. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/isa/x64/lower.isle +4651 -0
  113. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/lib.rs +140 -0
  114. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/machinst/abi.rs +2641 -0
  115. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/machinst/buffer.rs +2365 -0
  116. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/machinst/isle.rs +837 -0
  117. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/machinst/lower.rs +1393 -0
  118. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/machinst/vcode.rs +1591 -0
  119. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/opts/cprop.isle +200 -0
  120. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/opts/icmp.isle +177 -0
  121. data/ext/cargo-vendor/cranelift-codegen-0.99.1/src/value_label.rs +32 -0
  122. data/ext/cargo-vendor/cranelift-codegen-meta-0.99.1/.cargo-checksum.json +1 -0
  123. data/ext/cargo-vendor/cranelift-codegen-meta-0.99.1/Cargo.toml +26 -0
  124. data/ext/cargo-vendor/cranelift-codegen-meta-0.99.1/src/gen_inst.rs +1785 -0
  125. data/ext/cargo-vendor/cranelift-codegen-meta-0.99.1/src/isa/arm64.rs +53 -0
  126. data/ext/cargo-vendor/cranelift-codegen-meta-0.99.1/src/isa/mod.rs +66 -0
  127. data/ext/cargo-vendor/cranelift-codegen-meta-0.99.1/src/isa/riscv64.rs +101 -0
  128. data/ext/cargo-vendor/cranelift-codegen-meta-0.99.1/src/isa/s390x.rs +39 -0
  129. data/ext/cargo-vendor/cranelift-codegen-meta-0.99.1/src/isa/x86.rs +401 -0
  130. data/ext/cargo-vendor/cranelift-codegen-meta-0.99.1/src/lib.rs +59 -0
  131. data/ext/cargo-vendor/cranelift-codegen-meta-0.99.1/src/shared/mod.rs +88 -0
  132. data/ext/cargo-vendor/cranelift-codegen-shared-0.99.1/.cargo-checksum.json +1 -0
  133. data/ext/cargo-vendor/cranelift-codegen-shared-0.99.1/Cargo.toml +22 -0
  134. data/ext/cargo-vendor/cranelift-control-0.99.1/.cargo-checksum.json +1 -0
  135. data/ext/cargo-vendor/cranelift-control-0.99.1/Cargo.toml +30 -0
  136. data/ext/cargo-vendor/cranelift-entity-0.99.1/.cargo-checksum.json +1 -0
  137. data/ext/cargo-vendor/cranelift-entity-0.99.1/Cargo.toml +35 -0
  138. data/ext/cargo-vendor/cranelift-frontend-0.99.1/.cargo-checksum.json +1 -0
  139. data/ext/cargo-vendor/cranelift-frontend-0.99.1/Cargo.toml +53 -0
  140. data/ext/cargo-vendor/cranelift-frontend-0.99.1/src/lib.rs +204 -0
  141. data/ext/cargo-vendor/cranelift-isle-0.99.1/.cargo-checksum.json +1 -0
  142. data/ext/cargo-vendor/cranelift-isle-0.99.1/Cargo.toml +37 -0
  143. data/ext/cargo-vendor/cranelift-native-0.99.1/.cargo-checksum.json +1 -0
  144. data/ext/cargo-vendor/cranelift-native-0.99.1/Cargo.toml +38 -0
  145. data/ext/cargo-vendor/cranelift-wasm-0.99.1/.cargo-checksum.json +1 -0
  146. data/ext/cargo-vendor/cranelift-wasm-0.99.1/Cargo.toml +85 -0
  147. data/ext/cargo-vendor/cranelift-wasm-0.99.1/src/code_translator.rs +3608 -0
  148. data/ext/cargo-vendor/cranelift-wasm-0.99.1/src/environ/dummy.rs +942 -0
  149. data/ext/cargo-vendor/cranelift-wasm-0.99.1/src/environ/spec.rs +913 -0
  150. data/ext/cargo-vendor/cranelift-wasm-0.99.1/src/func_translator.rs +431 -0
  151. data/ext/cargo-vendor/cranelift-wasm-0.99.1/src/sections_translator.rs +420 -0
  152. data/ext/cargo-vendor/cranelift-wasm-0.99.1/tests/wasm_testsuite.rs +153 -0
  153. data/ext/cargo-vendor/fs-set-times-0.20.0/.cargo-checksum.json +1 -0
  154. data/ext/cargo-vendor/fs-set-times-0.20.0/Cargo.toml +45 -0
  155. data/ext/cargo-vendor/futures-0.3.28/.cargo-checksum.json +1 -0
  156. data/ext/cargo-vendor/futures-0.3.28/Cargo.toml +147 -0
  157. data/ext/cargo-vendor/futures-0.3.28/LICENSE-APACHE +202 -0
  158. data/ext/cargo-vendor/futures-0.3.28/LICENSE-MIT +26 -0
  159. data/ext/cargo-vendor/futures-0.3.28/README.md +61 -0
  160. data/ext/cargo-vendor/futures-0.3.28/src/lib.rs +260 -0
  161. data/ext/cargo-vendor/futures-0.3.28/tests/_require_features.rs +13 -0
  162. data/ext/cargo-vendor/futures-0.3.28/tests/async_await_macros.rs +393 -0
  163. data/ext/cargo-vendor/futures-0.3.28/tests/auto_traits.rs +1891 -0
  164. data/ext/cargo-vendor/futures-0.3.28/tests/bilock.rs +104 -0
  165. data/ext/cargo-vendor/futures-0.3.28/tests/compat.rs +16 -0
  166. data/ext/cargo-vendor/futures-0.3.28/tests/eager_drop.rs +121 -0
  167. data/ext/cargo-vendor/futures-0.3.28/tests/eventual.rs +179 -0
  168. data/ext/cargo-vendor/futures-0.3.28/tests/future_abortable.rs +44 -0
  169. data/ext/cargo-vendor/futures-0.3.28/tests/future_basic_combinators.rs +104 -0
  170. data/ext/cargo-vendor/futures-0.3.28/tests/future_fuse.rs +12 -0
  171. data/ext/cargo-vendor/futures-0.3.28/tests/future_inspect.rs +16 -0
  172. data/ext/cargo-vendor/futures-0.3.28/tests/future_join.rs +32 -0
  173. data/ext/cargo-vendor/futures-0.3.28/tests/future_join_all.rs +41 -0
  174. data/ext/cargo-vendor/futures-0.3.28/tests/future_obj.rs +33 -0
  175. data/ext/cargo-vendor/futures-0.3.28/tests/future_select_all.rs +25 -0
  176. data/ext/cargo-vendor/futures-0.3.28/tests/future_select_ok.rs +30 -0
  177. data/ext/cargo-vendor/futures-0.3.28/tests/future_shared.rs +273 -0
  178. data/ext/cargo-vendor/futures-0.3.28/tests/future_try_flatten_stream.rs +83 -0
  179. data/ext/cargo-vendor/futures-0.3.28/tests/future_try_join_all.rs +46 -0
  180. data/ext/cargo-vendor/futures-0.3.28/tests/io_buf_reader.rs +432 -0
  181. data/ext/cargo-vendor/futures-0.3.28/tests/io_buf_writer.rs +239 -0
  182. data/ext/cargo-vendor/futures-0.3.28/tests/io_cursor.rs +30 -0
  183. data/ext/cargo-vendor/futures-0.3.28/tests/io_line_writer.rs +73 -0
  184. data/ext/cargo-vendor/futures-0.3.28/tests/io_lines.rs +60 -0
  185. data/ext/cargo-vendor/futures-0.3.28/tests/io_read.rs +64 -0
  186. data/ext/cargo-vendor/futures-0.3.28/tests/io_read_exact.rs +17 -0
  187. data/ext/cargo-vendor/futures-0.3.28/tests/io_read_line.rs +58 -0
  188. data/ext/cargo-vendor/futures-0.3.28/tests/io_read_to_end.rs +65 -0
  189. data/ext/cargo-vendor/futures-0.3.28/tests/io_read_to_string.rs +44 -0
  190. data/ext/cargo-vendor/futures-0.3.28/tests/io_read_until.rs +60 -0
  191. data/ext/cargo-vendor/futures-0.3.28/tests/io_window.rs +30 -0
  192. data/ext/cargo-vendor/futures-0.3.28/tests/io_write.rs +65 -0
  193. data/ext/cargo-vendor/futures-0.3.28/tests/lock_mutex.rs +69 -0
  194. data/ext/cargo-vendor/futures-0.3.28/tests/macro_comma_support.rs +43 -0
  195. data/ext/cargo-vendor/futures-0.3.28/tests/object_safety.rs +49 -0
  196. data/ext/cargo-vendor/futures-0.3.28/tests/oneshot.rs +78 -0
  197. data/ext/cargo-vendor/futures-0.3.28/tests/ready_queue.rs +148 -0
  198. data/ext/cargo-vendor/futures-0.3.28/tests/recurse.rs +25 -0
  199. data/ext/cargo-vendor/futures-0.3.28/tests/sink.rs +554 -0
  200. data/ext/cargo-vendor/futures-0.3.28/tests/sink_fanout.rs +24 -0
  201. data/ext/cargo-vendor/futures-0.3.28/tests/stream.rs +537 -0
  202. data/ext/cargo-vendor/futures-0.3.28/tests/stream_abortable.rs +46 -0
  203. data/ext/cargo-vendor/futures-0.3.28/tests/stream_buffer_unordered.rs +73 -0
  204. data/ext/cargo-vendor/futures-0.3.28/tests/stream_catch_unwind.rs +27 -0
  205. data/ext/cargo-vendor/futures-0.3.28/tests/stream_futures_ordered.rs +172 -0
  206. data/ext/cargo-vendor/futures-0.3.28/tests/stream_futures_unordered.rs +383 -0
  207. data/ext/cargo-vendor/futures-0.3.28/tests/stream_into_async_read.rs +94 -0
  208. data/ext/cargo-vendor/futures-0.3.28/tests/stream_peekable.rs +58 -0
  209. data/ext/cargo-vendor/futures-0.3.28/tests/stream_select_all.rs +197 -0
  210. data/ext/cargo-vendor/futures-0.3.28/tests/stream_select_next_some.rs +86 -0
  211. data/ext/cargo-vendor/futures-0.3.28/tests/stream_split.rs +57 -0
  212. data/ext/cargo-vendor/futures-0.3.28/tests/stream_try_stream.rs +134 -0
  213. data/ext/cargo-vendor/futures-0.3.28/tests/stream_unfold.rs +32 -0
  214. data/ext/cargo-vendor/futures-0.3.28/tests/task_arc_wake.rs +79 -0
  215. data/ext/cargo-vendor/futures-0.3.28/tests/task_atomic_waker.rs +48 -0
  216. data/ext/cargo-vendor/futures-0.3.28/tests/test_macro.rs +20 -0
  217. data/ext/cargo-vendor/futures-0.3.28/tests/try_join.rs +35 -0
  218. data/ext/cargo-vendor/futures-0.3.28/tests_disabled/all.rs +400 -0
  219. data/ext/cargo-vendor/futures-0.3.28/tests_disabled/stream.rs +368 -0
  220. data/ext/cargo-vendor/futures-channel-0.3.28/.cargo-checksum.json +1 -0
  221. data/ext/cargo-vendor/futures-channel-0.3.28/Cargo.toml +52 -0
  222. data/ext/cargo-vendor/futures-channel-0.3.28/LICENSE-APACHE +202 -0
  223. data/ext/cargo-vendor/futures-channel-0.3.28/LICENSE-MIT +26 -0
  224. data/ext/cargo-vendor/futures-channel-0.3.28/README.md +23 -0
  225. data/ext/cargo-vendor/futures-channel-0.3.28/benches/sync_mpsc.rs +135 -0
  226. data/ext/cargo-vendor/futures-channel-0.3.28/build.rs +41 -0
  227. data/ext/cargo-vendor/futures-channel-0.3.28/no_atomic_cas.rs +17 -0
  228. data/ext/cargo-vendor/futures-channel-0.3.28/src/lib.rs +42 -0
  229. data/ext/cargo-vendor/futures-channel-0.3.28/src/lock.rs +102 -0
  230. data/ext/cargo-vendor/futures-channel-0.3.28/src/mpsc/mod.rs +1359 -0
  231. data/ext/cargo-vendor/futures-channel-0.3.28/src/mpsc/queue.rs +174 -0
  232. data/ext/cargo-vendor/futures-channel-0.3.28/src/mpsc/sink_impl.rs +73 -0
  233. data/ext/cargo-vendor/futures-channel-0.3.28/src/oneshot.rs +488 -0
  234. data/ext/cargo-vendor/futures-channel-0.3.28/tests/channel.rs +66 -0
  235. data/ext/cargo-vendor/futures-channel-0.3.28/tests/mpsc-close.rs +299 -0
  236. data/ext/cargo-vendor/futures-channel-0.3.28/tests/mpsc-size_hint.rs +40 -0
  237. data/ext/cargo-vendor/futures-channel-0.3.28/tests/mpsc.rs +634 -0
  238. data/ext/cargo-vendor/futures-channel-0.3.28/tests/oneshot.rs +256 -0
  239. data/ext/cargo-vendor/futures-core-0.3.28/.cargo-checksum.json +1 -0
  240. data/ext/cargo-vendor/futures-core-0.3.28/Cargo.toml +44 -0
  241. data/ext/cargo-vendor/futures-core-0.3.28/LICENSE-APACHE +202 -0
  242. data/ext/cargo-vendor/futures-core-0.3.28/LICENSE-MIT +26 -0
  243. data/ext/cargo-vendor/futures-core-0.3.28/README.md +23 -0
  244. data/ext/cargo-vendor/futures-core-0.3.28/build.rs +41 -0
  245. data/ext/cargo-vendor/futures-core-0.3.28/no_atomic_cas.rs +17 -0
  246. data/ext/cargo-vendor/futures-core-0.3.28/src/future.rs +103 -0
  247. data/ext/cargo-vendor/futures-core-0.3.28/src/lib.rs +27 -0
  248. data/ext/cargo-vendor/futures-core-0.3.28/src/stream.rs +235 -0
  249. data/ext/cargo-vendor/futures-core-0.3.28/src/task/__internal/atomic_waker.rs +421 -0
  250. data/ext/cargo-vendor/futures-core-0.3.28/src/task/__internal/mod.rs +4 -0
  251. data/ext/cargo-vendor/futures-core-0.3.28/src/task/mod.rs +10 -0
  252. data/ext/cargo-vendor/futures-core-0.3.28/src/task/poll.rs +12 -0
  253. data/ext/cargo-vendor/futures-io-0.3.28/.cargo-checksum.json +1 -0
  254. data/ext/cargo-vendor/futures-io-0.3.28/Cargo.toml +37 -0
  255. data/ext/cargo-vendor/futures-io-0.3.28/LICENSE-APACHE +202 -0
  256. data/ext/cargo-vendor/futures-io-0.3.28/LICENSE-MIT +26 -0
  257. data/ext/cargo-vendor/futures-io-0.3.28/README.md +23 -0
  258. data/ext/cargo-vendor/futures-io-0.3.28/src/lib.rs +558 -0
  259. data/ext/cargo-vendor/futures-sink-0.3.28/.cargo-checksum.json +1 -0
  260. data/ext/cargo-vendor/futures-sink-0.3.28/Cargo.toml +33 -0
  261. data/ext/cargo-vendor/futures-sink-0.3.28/LICENSE-APACHE +202 -0
  262. data/ext/cargo-vendor/futures-sink-0.3.28/LICENSE-MIT +26 -0
  263. data/ext/cargo-vendor/futures-sink-0.3.28/README.md +23 -0
  264. data/ext/cargo-vendor/futures-sink-0.3.28/src/lib.rs +240 -0
  265. data/ext/cargo-vendor/futures-task-0.3.28/.cargo-checksum.json +1 -0
  266. data/ext/cargo-vendor/futures-task-0.3.28/Cargo.toml +37 -0
  267. data/ext/cargo-vendor/futures-task-0.3.28/LICENSE-APACHE +202 -0
  268. data/ext/cargo-vendor/futures-task-0.3.28/LICENSE-MIT +26 -0
  269. data/ext/cargo-vendor/futures-task-0.3.28/README.md +23 -0
  270. data/ext/cargo-vendor/futures-task-0.3.28/build.rs +41 -0
  271. data/ext/cargo-vendor/futures-task-0.3.28/no_atomic_cas.rs +17 -0
  272. data/ext/cargo-vendor/futures-task-0.3.28/src/arc_wake.rs +49 -0
  273. data/ext/cargo-vendor/futures-task-0.3.28/src/future_obj.rs +335 -0
  274. data/ext/cargo-vendor/futures-task-0.3.28/src/lib.rs +50 -0
  275. data/ext/cargo-vendor/futures-task-0.3.28/src/noop_waker.rs +63 -0
  276. data/ext/cargo-vendor/futures-task-0.3.28/src/spawn.rs +192 -0
  277. data/ext/cargo-vendor/futures-task-0.3.28/src/waker.rs +59 -0
  278. data/ext/cargo-vendor/futures-task-0.3.28/src/waker_ref.rs +66 -0
  279. data/ext/cargo-vendor/futures-util-0.3.28/.cargo-checksum.json +1 -0
  280. data/ext/cargo-vendor/futures-util-0.3.28/Cargo.toml +135 -0
  281. data/ext/cargo-vendor/futures-util-0.3.28/LICENSE-APACHE +202 -0
  282. data/ext/cargo-vendor/futures-util-0.3.28/LICENSE-MIT +26 -0
  283. data/ext/cargo-vendor/futures-util-0.3.28/README.md +23 -0
  284. data/ext/cargo-vendor/futures-util-0.3.28/benches/bilock.rs +68 -0
  285. data/ext/cargo-vendor/futures-util-0.3.28/benches/flatten_unordered.rs +58 -0
  286. data/ext/cargo-vendor/futures-util-0.3.28/benches/futures_unordered.rs +43 -0
  287. data/ext/cargo-vendor/futures-util-0.3.28/benches/select.rs +35 -0
  288. data/ext/cargo-vendor/futures-util-0.3.28/build.rs +41 -0
  289. data/ext/cargo-vendor/futures-util-0.3.28/no_atomic_cas.rs +17 -0
  290. data/ext/cargo-vendor/futures-util-0.3.28/src/abortable.rs +209 -0
  291. data/ext/cargo-vendor/futures-util-0.3.28/src/async_await/join_mod.rs +110 -0
  292. data/ext/cargo-vendor/futures-util-0.3.28/src/async_await/mod.rs +58 -0
  293. data/ext/cargo-vendor/futures-util-0.3.28/src/async_await/pending.rs +43 -0
  294. data/ext/cargo-vendor/futures-util-0.3.28/src/async_await/poll.rs +39 -0
  295. data/ext/cargo-vendor/futures-util-0.3.28/src/async_await/random.rs +54 -0
  296. data/ext/cargo-vendor/futures-util-0.3.28/src/async_await/select_mod.rs +336 -0
  297. data/ext/cargo-vendor/futures-util-0.3.28/src/async_await/stream_select_mod.rs +40 -0
  298. data/ext/cargo-vendor/futures-util-0.3.28/src/compat/compat01as03.rs +454 -0
  299. data/ext/cargo-vendor/futures-util-0.3.28/src/compat/compat03as01.rs +265 -0
  300. data/ext/cargo-vendor/futures-util-0.3.28/src/compat/executor.rs +86 -0
  301. data/ext/cargo-vendor/futures-util-0.3.28/src/compat/mod.rs +22 -0
  302. data/ext/cargo-vendor/futures-util-0.3.28/src/fns.rs +372 -0
  303. data/ext/cargo-vendor/futures-util-0.3.28/src/future/abortable.rs +19 -0
  304. data/ext/cargo-vendor/futures-util-0.3.28/src/future/either.rs +317 -0
  305. data/ext/cargo-vendor/futures-util-0.3.28/src/future/future/catch_unwind.rs +38 -0
  306. data/ext/cargo-vendor/futures-util-0.3.28/src/future/future/flatten.rs +153 -0
  307. data/ext/cargo-vendor/futures-util-0.3.28/src/future/future/fuse.rs +91 -0
  308. data/ext/cargo-vendor/futures-util-0.3.28/src/future/future/map.rs +66 -0
  309. data/ext/cargo-vendor/futures-util-0.3.28/src/future/future/mod.rs +610 -0
  310. data/ext/cargo-vendor/futures-util-0.3.28/src/future/future/remote_handle.rs +126 -0
  311. data/ext/cargo-vendor/futures-util-0.3.28/src/future/future/shared.rs +413 -0
  312. data/ext/cargo-vendor/futures-util-0.3.28/src/future/join.rs +217 -0
  313. data/ext/cargo-vendor/futures-util-0.3.28/src/future/join_all.rs +166 -0
  314. data/ext/cargo-vendor/futures-util-0.3.28/src/future/lazy.rs +60 -0
  315. data/ext/cargo-vendor/futures-util-0.3.28/src/future/maybe_done.rs +104 -0
  316. data/ext/cargo-vendor/futures-util-0.3.28/src/future/mod.rs +131 -0
  317. data/ext/cargo-vendor/futures-util-0.3.28/src/future/option.rs +64 -0
  318. data/ext/cargo-vendor/futures-util-0.3.28/src/future/pending.rs +55 -0
  319. data/ext/cargo-vendor/futures-util-0.3.28/src/future/poll_fn.rs +58 -0
  320. data/ext/cargo-vendor/futures-util-0.3.28/src/future/poll_immediate.rs +126 -0
  321. data/ext/cargo-vendor/futures-util-0.3.28/src/future/ready.rs +82 -0
  322. data/ext/cargo-vendor/futures-util-0.3.28/src/future/select.rs +134 -0
  323. data/ext/cargo-vendor/futures-util-0.3.28/src/future/select_all.rs +75 -0
  324. data/ext/cargo-vendor/futures-util-0.3.28/src/future/select_ok.rs +85 -0
  325. data/ext/cargo-vendor/futures-util-0.3.28/src/future/try_future/into_future.rs +36 -0
  326. data/ext/cargo-vendor/futures-util-0.3.28/src/future/try_future/mod.rs +625 -0
  327. data/ext/cargo-vendor/futures-util-0.3.28/src/future/try_future/try_flatten.rs +162 -0
  328. data/ext/cargo-vendor/futures-util-0.3.28/src/future/try_future/try_flatten_err.rs +62 -0
  329. data/ext/cargo-vendor/futures-util-0.3.28/src/future/try_join.rs +256 -0
  330. data/ext/cargo-vendor/futures-util-0.3.28/src/future/try_join_all.rs +200 -0
  331. data/ext/cargo-vendor/futures-util-0.3.28/src/future/try_maybe_done.rs +92 -0
  332. data/ext/cargo-vendor/futures-util-0.3.28/src/future/try_select.rs +85 -0
  333. data/ext/cargo-vendor/futures-util-0.3.28/src/io/allow_std.rs +200 -0
  334. data/ext/cargo-vendor/futures-util-0.3.28/src/io/buf_reader.rs +263 -0
  335. data/ext/cargo-vendor/futures-util-0.3.28/src/io/buf_writer.rs +224 -0
  336. data/ext/cargo-vendor/futures-util-0.3.28/src/io/chain.rs +142 -0
  337. data/ext/cargo-vendor/futures-util-0.3.28/src/io/close.rs +28 -0
  338. data/ext/cargo-vendor/futures-util-0.3.28/src/io/copy.rs +58 -0
  339. data/ext/cargo-vendor/futures-util-0.3.28/src/io/copy_buf.rs +78 -0
  340. data/ext/cargo-vendor/futures-util-0.3.28/src/io/copy_buf_abortable.rs +124 -0
  341. data/ext/cargo-vendor/futures-util-0.3.28/src/io/cursor.rs +232 -0
  342. data/ext/cargo-vendor/futures-util-0.3.28/src/io/empty.rs +59 -0
  343. data/ext/cargo-vendor/futures-util-0.3.28/src/io/fill_buf.rs +51 -0
  344. data/ext/cargo-vendor/futures-util-0.3.28/src/io/flush.rs +31 -0
  345. data/ext/cargo-vendor/futures-util-0.3.28/src/io/into_sink.rs +82 -0
  346. data/ext/cargo-vendor/futures-util-0.3.28/src/io/line_writer.rs +155 -0
  347. data/ext/cargo-vendor/futures-util-0.3.28/src/io/lines.rs +47 -0
  348. data/ext/cargo-vendor/futures-util-0.3.28/src/io/mod.rs +841 -0
  349. data/ext/cargo-vendor/futures-util-0.3.28/src/io/read.rs +30 -0
  350. data/ext/cargo-vendor/futures-util-0.3.28/src/io/read_exact.rs +42 -0
  351. data/ext/cargo-vendor/futures-util-0.3.28/src/io/read_line.rs +57 -0
  352. data/ext/cargo-vendor/futures-util-0.3.28/src/io/read_to_end.rs +91 -0
  353. data/ext/cargo-vendor/futures-util-0.3.28/src/io/read_to_string.rs +59 -0
  354. data/ext/cargo-vendor/futures-util-0.3.28/src/io/read_until.rs +60 -0
  355. data/ext/cargo-vendor/futures-util-0.3.28/src/io/read_vectored.rs +30 -0
  356. data/ext/cargo-vendor/futures-util-0.3.28/src/io/repeat.rs +66 -0
  357. data/ext/cargo-vendor/futures-util-0.3.28/src/io/seek.rs +30 -0
  358. data/ext/cargo-vendor/futures-util-0.3.28/src/io/sink.rs +67 -0
  359. data/ext/cargo-vendor/futures-util-0.3.28/src/io/split.rs +115 -0
  360. data/ext/cargo-vendor/futures-util-0.3.28/src/io/take.rs +125 -0
  361. data/ext/cargo-vendor/futures-util-0.3.28/src/io/window.rs +104 -0
  362. data/ext/cargo-vendor/futures-util-0.3.28/src/io/write.rs +30 -0
  363. data/ext/cargo-vendor/futures-util-0.3.28/src/io/write_all.rs +43 -0
  364. data/ext/cargo-vendor/futures-util-0.3.28/src/io/write_all_vectored.rs +193 -0
  365. data/ext/cargo-vendor/futures-util-0.3.28/src/io/write_vectored.rs +30 -0
  366. data/ext/cargo-vendor/futures-util-0.3.28/src/lib.rs +337 -0
  367. data/ext/cargo-vendor/futures-util-0.3.28/src/lock/bilock.rs +293 -0
  368. data/ext/cargo-vendor/futures-util-0.3.28/src/lock/mod.rs +27 -0
  369. data/ext/cargo-vendor/futures-util-0.3.28/src/lock/mutex.rs +551 -0
  370. data/ext/cargo-vendor/futures-util-0.3.28/src/never.rs +18 -0
  371. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/buffer.rs +105 -0
  372. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/close.rs +32 -0
  373. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/drain.rs +59 -0
  374. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/err_into.rs +57 -0
  375. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/fanout.rs +111 -0
  376. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/feed.rs +43 -0
  377. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/flush.rs +36 -0
  378. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/map_err.rs +65 -0
  379. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/mod.rs +344 -0
  380. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/send.rs +41 -0
  381. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/send_all.rs +100 -0
  382. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/unfold.rs +89 -0
  383. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/with.rs +134 -0
  384. data/ext/cargo-vendor/futures-util-0.3.28/src/sink/with_flat_map.rs +127 -0
  385. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/abortable.rs +19 -0
  386. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/empty.rs +45 -0
  387. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/futures_ordered.rs +244 -0
  388. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/futures_unordered/abort.rs +12 -0
  389. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/futures_unordered/iter.rs +172 -0
  390. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/futures_unordered/mod.rs +661 -0
  391. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/futures_unordered/ready_to_run_queue.rs +122 -0
  392. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/futures_unordered/task.rs +125 -0
  393. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/iter.rs +49 -0
  394. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/mod.rs +148 -0
  395. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/once.rs +67 -0
  396. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/pending.rs +45 -0
  397. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/poll_fn.rs +57 -0
  398. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/poll_immediate.rs +80 -0
  399. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/repeat.rs +58 -0
  400. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/repeat_with.rs +93 -0
  401. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/select.rs +117 -0
  402. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/select_all.rs +249 -0
  403. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/select_with_strategy.rs +304 -0
  404. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/all.rs +92 -0
  405. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/any.rs +92 -0
  406. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/buffer_unordered.rs +120 -0
  407. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/buffered.rs +118 -0
  408. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/catch_unwind.rs +61 -0
  409. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/chain.rs +76 -0
  410. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/chunks.rs +103 -0
  411. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/collect.rs +56 -0
  412. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/concat.rs +62 -0
  413. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/count.rs +53 -0
  414. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/cycle.rs +68 -0
  415. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/enumerate.rs +64 -0
  416. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/filter.rs +117 -0
  417. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/filter_map.rs +111 -0
  418. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/flatten.rs +73 -0
  419. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/flatten_unordered.rs +536 -0
  420. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/fold.rs +88 -0
  421. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/for_each.rs +78 -0
  422. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/for_each_concurrent.rs +119 -0
  423. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/forward.rs +75 -0
  424. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/fuse.rs +75 -0
  425. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/into_future.rs +90 -0
  426. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/map.rs +77 -0
  427. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/mod.rs +1691 -0
  428. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/next.rs +34 -0
  429. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/peek.rs +433 -0
  430. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/ready_chunks.rs +93 -0
  431. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/scan.rs +128 -0
  432. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/select_next_some.rs +42 -0
  433. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/skip.rs +70 -0
  434. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/skip_while.rs +124 -0
  435. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/split.rs +144 -0
  436. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/take.rs +86 -0
  437. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/take_until.rs +170 -0
  438. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/take_while.rs +124 -0
  439. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/then.rs +101 -0
  440. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/unzip.rs +63 -0
  441. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/stream/zip.rs +128 -0
  442. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/and_then.rs +105 -0
  443. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/into_async_read.rs +166 -0
  444. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/into_stream.rs +52 -0
  445. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/mod.rs +1130 -0
  446. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/or_else.rs +109 -0
  447. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_buffer_unordered.rs +86 -0
  448. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_buffered.rs +87 -0
  449. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_chunks.rs +132 -0
  450. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_collect.rs +52 -0
  451. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_concat.rs +51 -0
  452. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_filter.rs +112 -0
  453. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_filter_map.rs +106 -0
  454. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_flatten.rs +84 -0
  455. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_flatten_unordered.rs +176 -0
  456. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_fold.rs +93 -0
  457. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_for_each.rs +68 -0
  458. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_for_each_concurrent.rs +133 -0
  459. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_next.rs +34 -0
  460. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_skip_while.rs +120 -0
  461. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_take_while.rs +129 -0
  462. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/try_stream/try_unfold.rs +122 -0
  463. data/ext/cargo-vendor/futures-util-0.3.28/src/stream/unfold.rs +119 -0
  464. data/ext/cargo-vendor/futures-util-0.3.28/src/task/mod.rs +37 -0
  465. data/ext/cargo-vendor/futures-util-0.3.28/src/task/spawn.rs +169 -0
  466. data/ext/cargo-vendor/futures-util-0.3.28/src/unfold_state.rs +39 -0
  467. data/ext/cargo-vendor/io-extras-0.18.0/.cargo-checksum.json +1 -0
  468. data/ext/cargo-vendor/io-extras-0.18.0/Cargo.toml +94 -0
  469. data/ext/cargo-vendor/io-extras-0.18.0/README.md +33 -0
  470. data/ext/cargo-vendor/io-extras-0.18.0/build.rs +43 -0
  471. data/ext/cargo-vendor/io-extras-0.18.0/src/os/windows/stdio.rs +328 -0
  472. data/ext/cargo-vendor/object-0.31.1/.cargo-checksum.json +1 -0
  473. data/ext/cargo-vendor/object-0.31.1/CHANGELOG.md +621 -0
  474. data/ext/cargo-vendor/object-0.31.1/Cargo.toml +161 -0
  475. data/ext/cargo-vendor/object-0.31.1/README.md +58 -0
  476. data/ext/cargo-vendor/object-0.31.1/clippy.toml +1 -0
  477. data/ext/cargo-vendor/object-0.31.1/src/common.rs +499 -0
  478. data/ext/cargo-vendor/object-0.31.1/src/elf.rs +6146 -0
  479. data/ext/cargo-vendor/object-0.31.1/src/endian.rs +831 -0
  480. data/ext/cargo-vendor/object-0.31.1/src/lib.rs +116 -0
  481. data/ext/cargo-vendor/object-0.31.1/src/macho.rs +3307 -0
  482. data/ext/cargo-vendor/object-0.31.1/src/pe.rs +3050 -0
  483. data/ext/cargo-vendor/object-0.31.1/src/read/any.rs +1323 -0
  484. data/ext/cargo-vendor/object-0.31.1/src/read/coff/comdat.rs +207 -0
  485. data/ext/cargo-vendor/object-0.31.1/src/read/coff/file.rs +364 -0
  486. data/ext/cargo-vendor/object-0.31.1/src/read/coff/relocation.rs +104 -0
  487. data/ext/cargo-vendor/object-0.31.1/src/read/coff/section.rs +574 -0
  488. data/ext/cargo-vendor/object-0.31.1/src/read/coff/symbol.rs +626 -0
  489. data/ext/cargo-vendor/object-0.31.1/src/read/elf/attributes.rs +303 -0
  490. data/ext/cargo-vendor/object-0.31.1/src/read/elf/comdat.rs +160 -0
  491. data/ext/cargo-vendor/object-0.31.1/src/read/elf/file.rs +910 -0
  492. data/ext/cargo-vendor/object-0.31.1/src/read/elf/hash.rs +220 -0
  493. data/ext/cargo-vendor/object-0.31.1/src/read/elf/mod.rs +42 -0
  494. data/ext/cargo-vendor/object-0.31.1/src/read/elf/note.rs +263 -0
  495. data/ext/cargo-vendor/object-0.31.1/src/read/elf/section.rs +1146 -0
  496. data/ext/cargo-vendor/object-0.31.1/src/read/elf/segment.rs +332 -0
  497. data/ext/cargo-vendor/object-0.31.1/src/read/elf/symbol.rs +577 -0
  498. data/ext/cargo-vendor/object-0.31.1/src/read/elf/version.rs +421 -0
  499. data/ext/cargo-vendor/object-0.31.1/src/read/macho/dyld_cache.rs +343 -0
  500. data/ext/cargo-vendor/object-0.31.1/src/read/macho/file.rs +731 -0
  501. data/ext/cargo-vendor/object-0.31.1/src/read/macho/load_command.rs +373 -0
  502. data/ext/cargo-vendor/object-0.31.1/src/read/macho/relocation.rs +127 -0
  503. data/ext/cargo-vendor/object-0.31.1/src/read/macho/section.rs +387 -0
  504. data/ext/cargo-vendor/object-0.31.1/src/read/macho/segment.rs +301 -0
  505. data/ext/cargo-vendor/object-0.31.1/src/read/macho/symbol.rs +488 -0
  506. data/ext/cargo-vendor/object-0.31.1/src/read/mod.rs +760 -0
  507. data/ext/cargo-vendor/object-0.31.1/src/read/pe/data_directory.rs +211 -0
  508. data/ext/cargo-vendor/object-0.31.1/src/read/pe/file.rs +1029 -0
  509. data/ext/cargo-vendor/object-0.31.1/src/read/pe/resource.rs +207 -0
  510. data/ext/cargo-vendor/object-0.31.1/src/read/pe/rich.rs +91 -0
  511. data/ext/cargo-vendor/object-0.31.1/src/read/pe/section.rs +434 -0
  512. data/ext/cargo-vendor/object-0.31.1/src/read/read_cache.rs +182 -0
  513. data/ext/cargo-vendor/object-0.31.1/src/read/read_ref.rs +137 -0
  514. data/ext/cargo-vendor/object-0.31.1/src/read/traits.rs +469 -0
  515. data/ext/cargo-vendor/object-0.31.1/src/read/util.rs +425 -0
  516. data/ext/cargo-vendor/object-0.31.1/src/read/wasm.rs +951 -0
  517. data/ext/cargo-vendor/object-0.31.1/src/read/xcoff/comdat.rs +129 -0
  518. data/ext/cargo-vendor/object-0.31.1/src/read/xcoff/relocation.rs +127 -0
  519. data/ext/cargo-vendor/object-0.31.1/src/read/xcoff/section.rs +427 -0
  520. data/ext/cargo-vendor/object-0.31.1/src/read/xcoff/segment.rs +113 -0
  521. data/ext/cargo-vendor/object-0.31.1/src/read/xcoff/symbol.rs +695 -0
  522. data/ext/cargo-vendor/object-0.31.1/src/write/coff.rs +725 -0
  523. data/ext/cargo-vendor/object-0.31.1/src/write/elf/object.rs +891 -0
  524. data/ext/cargo-vendor/object-0.31.1/src/write/elf/writer.rs +2143 -0
  525. data/ext/cargo-vendor/object-0.31.1/src/write/macho.rs +978 -0
  526. data/ext/cargo-vendor/object-0.31.1/src/write/mod.rs +943 -0
  527. data/ext/cargo-vendor/object-0.31.1/src/write/string.rs +159 -0
  528. data/ext/cargo-vendor/object-0.31.1/src/write/util.rs +260 -0
  529. data/ext/cargo-vendor/object-0.31.1/src/write/xcoff.rs +556 -0
  530. data/ext/cargo-vendor/object-0.31.1/src/xcoff.rs +893 -0
  531. data/ext/cargo-vendor/object-0.31.1/tests/read/coff.rs +23 -0
  532. data/ext/cargo-vendor/object-0.31.1/tests/round_trip/elf.rs +289 -0
  533. data/ext/cargo-vendor/object-0.31.1/tests/round_trip/macho.rs +24 -0
  534. data/ext/cargo-vendor/object-0.31.1/tests/round_trip/mod.rs +636 -0
  535. data/ext/cargo-vendor/pulldown-cmark-0.9.3/.cargo-checksum.json +1 -0
  536. data/ext/cargo-vendor/pulldown-cmark-0.9.3/CONTRIBUTING.md +21 -0
  537. data/ext/cargo-vendor/pulldown-cmark-0.9.3/Cargo.lock +1000 -0
  538. data/ext/cargo-vendor/pulldown-cmark-0.9.3/Cargo.toml +100 -0
  539. data/ext/cargo-vendor/pulldown-cmark-0.9.3/README.md +167 -0
  540. data/ext/cargo-vendor/pulldown-cmark-0.9.3/benches/html_rendering.rs +97 -0
  541. data/ext/cargo-vendor/pulldown-cmark-0.9.3/benches/lib.rs +51 -0
  542. data/ext/cargo-vendor/pulldown-cmark-0.9.3/benches/markdown-it.rs +29 -0
  543. data/ext/cargo-vendor/pulldown-cmark-0.9.3/build.rs +189 -0
  544. data/ext/cargo-vendor/pulldown-cmark-0.9.3/examples/broken-link-callbacks.rs +35 -0
  545. data/ext/cargo-vendor/pulldown-cmark-0.9.3/examples/event-filter.rs +27 -0
  546. data/ext/cargo-vendor/pulldown-cmark-0.9.3/examples/parser-map-event-print.rs +31 -0
  547. data/ext/cargo-vendor/pulldown-cmark-0.9.3/examples/parser-map-tag-print.rs +73 -0
  548. data/ext/cargo-vendor/pulldown-cmark-0.9.3/examples/string-to-string.rs +24 -0
  549. data/ext/cargo-vendor/pulldown-cmark-0.9.3/src/escape.rs +369 -0
  550. data/ext/cargo-vendor/pulldown-cmark-0.9.3/src/firstpass.rs +1927 -0
  551. data/ext/cargo-vendor/pulldown-cmark-0.9.3/src/html.rs +478 -0
  552. data/ext/cargo-vendor/pulldown-cmark-0.9.3/src/lib.rs +290 -0
  553. data/ext/cargo-vendor/pulldown-cmark-0.9.3/src/linklabel.rs +135 -0
  554. data/ext/cargo-vendor/pulldown-cmark-0.9.3/src/main.rs +123 -0
  555. data/ext/cargo-vendor/pulldown-cmark-0.9.3/src/parse.rs +1927 -0
  556. data/ext/cargo-vendor/pulldown-cmark-0.9.3/src/puncttable.rs +351 -0
  557. data/ext/cargo-vendor/pulldown-cmark-0.9.3/src/scanners.rs +1327 -0
  558. data/ext/cargo-vendor/pulldown-cmark-0.9.3/src/strings.rs +373 -0
  559. data/ext/cargo-vendor/pulldown-cmark-0.9.3/src/tree.rs +276 -0
  560. data/ext/cargo-vendor/pulldown-cmark-0.9.3/tests/errors.rs +131 -0
  561. data/ext/cargo-vendor/pulldown-cmark-0.9.3/tests/html.rs +250 -0
  562. data/ext/cargo-vendor/pulldown-cmark-0.9.3/tests/lib.rs +421 -0
  563. data/ext/cargo-vendor/pulldown-cmark-0.9.3/tests/serde.rs +78 -0
  564. data/ext/cargo-vendor/pulldown-cmark-0.9.3/tests/suite/gfm_strikethrough.rs +37 -0
  565. data/ext/cargo-vendor/pulldown-cmark-0.9.3/tests/suite/gfm_table.rs +205 -0
  566. data/ext/cargo-vendor/pulldown-cmark-0.9.3/tests/suite/heading_attrs.rs +571 -0
  567. data/ext/cargo-vendor/pulldown-cmark-0.9.3/tests/suite/mod.rs +14 -0
  568. data/ext/cargo-vendor/pulldown-cmark-0.9.3/tests/suite/regression.rs +1033 -0
  569. data/ext/cargo-vendor/pulldown-cmark-0.9.3/tests/suite/spec.rs +8490 -0
  570. data/ext/cargo-vendor/system-interface-0.26.0/.cargo-checksum.json +1 -0
  571. data/ext/cargo-vendor/system-interface-0.26.0/Cargo.toml +105 -0
  572. data/ext/cargo-vendor/system-interface-0.26.0/build.rs +53 -0
  573. data/ext/cargo-vendor/system-interface-0.26.0/src/fs/file_io_ext.rs +1185 -0
  574. data/ext/cargo-vendor/wasi-cap-std-sync-12.0.0/.cargo-checksum.json +1 -0
  575. data/ext/cargo-vendor/wasi-cap-std-sync-12.0.0/Cargo.toml +96 -0
  576. data/ext/cargo-vendor/wasi-cap-std-sync-12.0.0/src/sched/unix.rs +82 -0
  577. data/ext/cargo-vendor/wasi-common-12.0.0/.cargo-checksum.json +1 -0
  578. data/ext/cargo-vendor/wasi-common-12.0.0/Cargo.toml +87 -0
  579. data/ext/cargo-vendor/wasi-common-12.0.0/src/file.rs +269 -0
  580. data/ext/cargo-vendor/wasi-common-12.0.0/src/sched/subscription.rs +77 -0
  581. data/ext/cargo-vendor/wasi-common-12.0.0/src/snapshots/preview_1/error.rs +265 -0
  582. data/ext/cargo-vendor/wasmparser-0.110.0/.cargo-checksum.json +1 -0
  583. data/ext/cargo-vendor/wasmparser-0.110.0/Cargo.lock +644 -0
  584. data/ext/cargo-vendor/wasmparser-0.110.0/Cargo.toml +54 -0
  585. data/ext/cargo-vendor/wasmparser-0.110.0/benches/benchmark.rs +349 -0
  586. data/ext/cargo-vendor/wasmparser-0.110.0/src/lib.rs +726 -0
  587. data/ext/cargo-vendor/wasmparser-0.110.0/src/limits.rs +59 -0
  588. data/ext/cargo-vendor/wasmparser-0.110.0/src/parser.rs +1612 -0
  589. data/ext/cargo-vendor/wasmparser-0.110.0/src/readers/component/canonicals.rs +120 -0
  590. data/ext/cargo-vendor/wasmparser-0.110.0/src/readers/component/types.rs +548 -0
  591. data/ext/cargo-vendor/wasmparser-0.110.0/src/readers/core/elements.rs +152 -0
  592. data/ext/cargo-vendor/wasmparser-0.110.0/src/readers/core/types.rs +1141 -0
  593. data/ext/cargo-vendor/wasmparser-0.110.0/src/validator/component.rs +3144 -0
  594. data/ext/cargo-vendor/wasmparser-0.110.0/src/validator/core.rs +1314 -0
  595. data/ext/cargo-vendor/wasmparser-0.110.0/src/validator/operators.rs +3466 -0
  596. data/ext/cargo-vendor/wasmparser-0.110.0/src/validator/types.rs +3197 -0
  597. data/ext/cargo-vendor/wasmparser-0.110.0/src/validator.rs +1568 -0
  598. data/ext/cargo-vendor/wasmparser-0.110.0/tests/big-module.rs +33 -0
  599. data/ext/cargo-vendor/wasmtime-12.0.0/.cargo-checksum.json +1 -0
  600. data/ext/cargo-vendor/wasmtime-12.0.0/Cargo.toml +186 -0
  601. data/ext/cargo-vendor/wasmtime-12.0.0/README.md +119 -0
  602. data/ext/cargo-vendor/wasmtime-12.0.0/src/compiler.rs +666 -0
  603. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/component.rs +466 -0
  604. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/func/host.rs +456 -0
  605. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/func/options.rs +510 -0
  606. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/func/typed.rs +2326 -0
  607. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/func.rs +718 -0
  608. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/instance.rs +781 -0
  609. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/linker.rs +479 -0
  610. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/matching.rs +215 -0
  611. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/mod.rs +316 -0
  612. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/resources.rs +716 -0
  613. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/types.rs +562 -0
  614. data/ext/cargo-vendor/wasmtime-12.0.0/src/component/values.rs +1376 -0
  615. data/ext/cargo-vendor/wasmtime-12.0.0/src/config.rs +2096 -0
  616. data/ext/cargo-vendor/wasmtime-12.0.0/src/coredump.rs +115 -0
  617. data/ext/cargo-vendor/wasmtime-12.0.0/src/engine/serialization.rs +629 -0
  618. data/ext/cargo-vendor/wasmtime-12.0.0/src/externals.rs +768 -0
  619. data/ext/cargo-vendor/wasmtime-12.0.0/src/func.rs +2356 -0
  620. data/ext/cargo-vendor/wasmtime-12.0.0/src/instance.rs +883 -0
  621. data/ext/cargo-vendor/wasmtime-12.0.0/src/lib.rs +490 -0
  622. data/ext/cargo-vendor/wasmtime-12.0.0/src/memory.rs +954 -0
  623. data/ext/cargo-vendor/wasmtime-12.0.0/src/module/registry.rs +329 -0
  624. data/ext/cargo-vendor/wasmtime-12.0.0/src/module.rs +1346 -0
  625. data/ext/cargo-vendor/wasmtime-12.0.0/src/resources.rs +33 -0
  626. data/ext/cargo-vendor/wasmtime-12.0.0/src/store/data.rs +283 -0
  627. data/ext/cargo-vendor/wasmtime-12.0.0/src/store/func_refs.rs +85 -0
  628. data/ext/cargo-vendor/wasmtime-12.0.0/src/store.rs +2212 -0
  629. data/ext/cargo-vendor/wasmtime-12.0.0/src/trap.rs +639 -0
  630. data/ext/cargo-vendor/wasmtime-asm-macros-12.0.0/.cargo-checksum.json +1 -0
  631. data/ext/cargo-vendor/wasmtime-asm-macros-12.0.0/Cargo.toml +22 -0
  632. data/ext/cargo-vendor/wasmtime-cache-12.0.0/.cargo-checksum.json +1 -0
  633. data/ext/cargo-vendor/wasmtime-cache-12.0.0/Cargo.toml +73 -0
  634. data/ext/cargo-vendor/wasmtime-component-macro-12.0.0/.cargo-checksum.json +1 -0
  635. data/ext/cargo-vendor/wasmtime-component-macro-12.0.0/Cargo.toml +58 -0
  636. data/ext/cargo-vendor/wasmtime-component-macro-12.0.0/src/bindgen.rs +343 -0
  637. data/ext/cargo-vendor/wasmtime-component-macro-12.0.0/src/component.rs +1319 -0
  638. data/ext/cargo-vendor/wasmtime-component-util-12.0.0/.cargo-checksum.json +1 -0
  639. data/ext/cargo-vendor/wasmtime-component-util-12.0.0/Cargo.toml +25 -0
  640. data/ext/cargo-vendor/wasmtime-cranelift-12.0.0/.cargo-checksum.json +1 -0
  641. data/ext/cargo-vendor/wasmtime-cranelift-12.0.0/Cargo.toml +93 -0
  642. data/ext/cargo-vendor/wasmtime-cranelift-12.0.0/src/builder.rs +116 -0
  643. data/ext/cargo-vendor/wasmtime-cranelift-12.0.0/src/compiler/component.rs +959 -0
  644. data/ext/cargo-vendor/wasmtime-cranelift-12.0.0/src/compiler.rs +1297 -0
  645. data/ext/cargo-vendor/wasmtime-cranelift-12.0.0/src/debug/transform/expression.rs +1250 -0
  646. data/ext/cargo-vendor/wasmtime-cranelift-12.0.0/src/debug/transform/unit.rs +522 -0
  647. data/ext/cargo-vendor/wasmtime-cranelift-12.0.0/src/debug/transform/utils.rs +187 -0
  648. data/ext/cargo-vendor/wasmtime-cranelift-12.0.0/src/func_environ.rs +2377 -0
  649. data/ext/cargo-vendor/wasmtime-cranelift-12.0.0/src/lib.rs +186 -0
  650. data/ext/cargo-vendor/wasmtime-cranelift-shared-12.0.0/.cargo-checksum.json +1 -0
  651. data/ext/cargo-vendor/wasmtime-cranelift-shared-12.0.0/Cargo.toml +57 -0
  652. data/ext/cargo-vendor/wasmtime-cranelift-shared-12.0.0/src/lib.rs +129 -0
  653. data/ext/cargo-vendor/wasmtime-environ-12.0.0/.cargo-checksum.json +1 -0
  654. data/ext/cargo-vendor/wasmtime-environ-12.0.0/Cargo.lock +736 -0
  655. data/ext/cargo-vendor/wasmtime-environ-12.0.0/Cargo.toml +116 -0
  656. data/ext/cargo-vendor/wasmtime-environ-12.0.0/examples/factc.rs +207 -0
  657. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/compilation.rs +400 -0
  658. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/component/compiler.rs +47 -0
  659. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/component/dfg.rs +678 -0
  660. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/component/info.rs +583 -0
  661. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/component/translate/adapt.rs +457 -0
  662. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/component/translate/inline.rs +1327 -0
  663. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/component/translate.rs +943 -0
  664. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/component/types/resources.rs +240 -0
  665. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/component/types.rs +1920 -0
  666. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/component/vmcomponent_offsets.rs +316 -0
  667. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/component.rs +95 -0
  668. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/fact/signature.rs +135 -0
  669. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/fact/trampoline.rs +3269 -0
  670. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/fact/transcode.rs +168 -0
  671. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/fact.rs +713 -0
  672. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/module_environ.rs +887 -0
  673. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/trap_encoding.rs +246 -0
  674. data/ext/cargo-vendor/wasmtime-environ-12.0.0/src/tunables.rs +115 -0
  675. data/ext/cargo-vendor/wasmtime-fiber-12.0.0/.cargo-checksum.json +1 -0
  676. data/ext/cargo-vendor/wasmtime-fiber-12.0.0/Cargo.toml +51 -0
  677. data/ext/cargo-vendor/wasmtime-fiber-12.0.0/build.rs +26 -0
  678. data/ext/cargo-vendor/wasmtime-fiber-12.0.0/src/unix/aarch64.rs +184 -0
  679. data/ext/cargo-vendor/wasmtime-fiber-12.0.0/src/unix/arm.rs +85 -0
  680. data/ext/cargo-vendor/wasmtime-fiber-12.0.0/src/unix/riscv64.rs +158 -0
  681. data/ext/cargo-vendor/wasmtime-fiber-12.0.0/src/unix/s390x.S +123 -0
  682. data/ext/cargo-vendor/wasmtime-fiber-12.0.0/src/unix/x86_64.rs +160 -0
  683. data/ext/cargo-vendor/wasmtime-fiber-12.0.0/src/unix.rs +215 -0
  684. data/ext/cargo-vendor/wasmtime-fiber-12.0.0/src/windows.c +9 -0
  685. data/ext/cargo-vendor/wasmtime-fiber-12.0.0/src/windows.rs +162 -0
  686. data/ext/cargo-vendor/wasmtime-jit-12.0.0/.cargo-checksum.json +1 -0
  687. data/ext/cargo-vendor/wasmtime-jit-12.0.0/Cargo.toml +104 -0
  688. data/ext/cargo-vendor/wasmtime-jit-12.0.0/src/profiling.rs +108 -0
  689. data/ext/cargo-vendor/wasmtime-jit-debug-12.0.0/.cargo-checksum.json +1 -0
  690. data/ext/cargo-vendor/wasmtime-jit-debug-12.0.0/Cargo.toml +58 -0
  691. data/ext/cargo-vendor/wasmtime-jit-debug-12.0.0/src/gdb_jit_int.rs +130 -0
  692. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-12.0.0/.cargo-checksum.json +1 -0
  693. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-12.0.0/Cargo.toml +37 -0
  694. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/.cargo-checksum.json +1 -0
  695. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/Cargo.toml +119 -0
  696. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/build.rs +19 -0
  697. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/component/libcalls.rs +574 -0
  698. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/component/resources.rs +327 -0
  699. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/component.rs +853 -0
  700. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/debug_builtins.rs +59 -0
  701. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/helpers.c +108 -0
  702. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/instance/allocator/on_demand.rs +127 -0
  703. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/instance/allocator.rs +414 -0
  704. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/lib.rs +289 -0
  705. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/libcalls.rs +627 -0
  706. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/mmap/unix.rs +148 -0
  707. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/send_sync_ptr.rs +77 -0
  708. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/trampolines/aarch64.rs +42 -0
  709. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/trampolines/riscv64.rs +43 -0
  710. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/trampolines/s390x.S +62 -0
  711. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/trampolines/x86_64.rs +64 -0
  712. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/traphandlers/coredump.rs +38 -0
  713. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/traphandlers/unix.rs +402 -0
  714. data/ext/cargo-vendor/wasmtime-runtime-12.0.0/src/traphandlers.rs +782 -0
  715. data/ext/cargo-vendor/wasmtime-types-12.0.1/.cargo-checksum.json +1 -0
  716. data/ext/cargo-vendor/wasmtime-types-12.0.1/Cargo.toml +34 -0
  717. data/ext/cargo-vendor/wasmtime-types-12.0.1/src/lib.rs +504 -0
  718. data/ext/cargo-vendor/wasmtime-versioned-export-macros-12.0.0/.cargo-checksum.json +1 -0
  719. data/ext/cargo-vendor/wasmtime-versioned-export-macros-12.0.0/Cargo.toml +32 -0
  720. data/ext/cargo-vendor/wasmtime-versioned-export-macros-12.0.0/src/lib.rs +66 -0
  721. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/.cargo-checksum.json +1 -0
  722. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/Cargo.toml +191 -0
  723. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/command.rs +91 -0
  724. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/ctx.rs +237 -0
  725. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/filesystem.rs +216 -0
  726. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/mod.rs +185 -0
  727. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/pipe.rs +846 -0
  728. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/poll.rs +148 -0
  729. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/preview1/mod.rs +1870 -0
  730. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/preview2/clocks.rs +107 -0
  731. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/preview2/env.rs +37 -0
  732. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/preview2/exit.rs +11 -0
  733. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/preview2/filesystem/sync.rs +613 -0
  734. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/preview2/filesystem.rs +1096 -0
  735. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/preview2/io.rs +494 -0
  736. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/preview2/mod.rs +6 -0
  737. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/preview2/random.rs +36 -0
  738. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/stdio/unix.rs +133 -0
  739. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/stdio/worker_thread_stdin.rs +133 -0
  740. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/stdio.rs +218 -0
  741. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/stream.rs +302 -0
  742. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/src/preview2/table.rs +287 -0
  743. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/wit/deps/io/streams.wit +254 -0
  744. data/ext/cargo-vendor/wasmtime-wasi-12.0.0/wit/test.wit +28 -0
  745. data/ext/cargo-vendor/wasmtime-winch-12.0.0/.cargo-checksum.json +1 -0
  746. data/ext/cargo-vendor/wasmtime-winch-12.0.0/Cargo.toml +63 -0
  747. data/ext/cargo-vendor/wasmtime-winch-12.0.0/src/builder.rs +64 -0
  748. data/ext/cargo-vendor/wasmtime-winch-12.0.0/src/compiler.rs +217 -0
  749. data/ext/cargo-vendor/wasmtime-wit-bindgen-12.0.0/.cargo-checksum.json +1 -0
  750. data/ext/cargo-vendor/wasmtime-wit-bindgen-12.0.0/Cargo.toml +32 -0
  751. data/ext/cargo-vendor/wasmtime-wit-bindgen-12.0.0/src/lib.rs +1705 -0
  752. data/ext/cargo-vendor/wasmtime-wit-bindgen-12.0.0/src/rust.rs +498 -0
  753. data/ext/cargo-vendor/wasmtime-wit-bindgen-12.0.0/src/types.rs +185 -0
  754. data/ext/cargo-vendor/wiggle-12.0.0/.cargo-checksum.json +1 -0
  755. data/ext/cargo-vendor/wiggle-12.0.0/Cargo.toml +106 -0
  756. data/ext/cargo-vendor/wiggle-generate-12.0.0/.cargo-checksum.json +1 -0
  757. data/ext/cargo-vendor/wiggle-generate-12.0.0/Cargo.toml +58 -0
  758. data/ext/cargo-vendor/wiggle-generate-12.0.0/src/config.rs +697 -0
  759. data/ext/cargo-vendor/wiggle-generate-12.0.0/src/types/flags.rs +92 -0
  760. data/ext/cargo-vendor/wiggle-macro-12.0.0/.cargo-checksum.json +1 -0
  761. data/ext/cargo-vendor/wiggle-macro-12.0.0/Cargo.toml +55 -0
  762. data/ext/cargo-vendor/winch-codegen-0.10.0/.cargo-checksum.json +1 -0
  763. data/ext/cargo-vendor/winch-codegen-0.10.0/Cargo.toml +62 -0
  764. data/ext/cargo-vendor/winch-codegen-0.10.0/src/codegen/context.rs +368 -0
  765. data/ext/cargo-vendor/winch-codegen-0.10.0/src/codegen/control.rs +437 -0
  766. data/ext/cargo-vendor/winch-codegen-0.10.0/src/codegen/env.rs +74 -0
  767. data/ext/cargo-vendor/winch-codegen-0.10.0/src/codegen/mod.rs +330 -0
  768. data/ext/cargo-vendor/winch-codegen-0.10.0/src/visitor.rs +656 -0
  769. data/ext/cargo-vendor/wit-parser-0.9.2/.cargo-checksum.json +1 -0
  770. data/ext/cargo-vendor/wit-parser-0.9.2/Cargo.toml +62 -0
  771. data/ext/cargo-vendor/wit-parser-0.9.2/src/abi.rs +2199 -0
  772. data/ext/cargo-vendor/wit-parser-0.9.2/src/ast/lex.rs +717 -0
  773. data/ext/cargo-vendor/wit-parser-0.9.2/src/ast/resolve.rs +1437 -0
  774. data/ext/cargo-vendor/wit-parser-0.9.2/src/ast/toposort.rs +225 -0
  775. data/ext/cargo-vendor/wit-parser-0.9.2/src/ast.rs +1362 -0
  776. data/ext/cargo-vendor/wit-parser-0.9.2/src/lib.rs +666 -0
  777. data/ext/cargo-vendor/wit-parser-0.9.2/src/live.rs +116 -0
  778. data/ext/cargo-vendor/wit-parser-0.9.2/src/resolve.rs +1749 -0
  779. data/ext/cargo-vendor/wit-parser-0.9.2/src/sizealign.rs +145 -0
  780. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/complex-include/deps/bar/root.wit +9 -0
  781. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/complex-include/deps/baz/root.wit +9 -0
  782. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/complex-include/root.wit +26 -0
  783. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/cross-package-resource/deps/foo/foo.wit +5 -0
  784. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/cross-package-resource/foo.wit +7 -0
  785. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/foreign-deps/deps/another-pkg/other-doc.wit +3 -0
  786. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/foreign-deps/deps/corp/saas.wit +4 -0
  787. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/foreign-deps/deps/different-pkg/the-doc.wit +2 -0
  788. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/foreign-deps/deps/foreign-pkg/the-doc.wit +5 -0
  789. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/foreign-deps/deps/some-pkg/some-doc.wit +13 -0
  790. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/foreign-deps/deps/wasi/clocks.wit +5 -0
  791. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/foreign-deps/deps/wasi/filesystem.wit +7 -0
  792. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/foreign-deps-union/deps/wasi/wasi.wit +6 -0
  793. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/foreign-deps-union/root.wit +50 -0
  794. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/ignore-files-deps/deps/bar/types.wit +2 -0
  795. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/ignore-files-deps/deps/ignore-me.txt +1 -0
  796. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/ignore-files-deps/world.wit +5 -0
  797. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/include-reps.wit +15 -0
  798. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/kebab-name-include-with.wit +8 -0
  799. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/name-both-resource-and-type/deps/dep/foo.wit +5 -0
  800. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/name-both-resource-and-type/foo.wit +9 -0
  801. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-include1.wit +5 -0
  802. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-include1.wit.result +5 -0
  803. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-include2.wit +9 -0
  804. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-include2.wit.result +5 -0
  805. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-include3.wit +5 -0
  806. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-include3.wit.result +5 -0
  807. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-pkg1.wit.result +8 -0
  808. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource1.wit +5 -0
  809. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource1.wit.result +5 -0
  810. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource10.wit +5 -0
  811. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource10.wit.result +5 -0
  812. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource11.wit +5 -0
  813. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource11.wit.result +5 -0
  814. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource12.wit +6 -0
  815. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource12.wit.result +5 -0
  816. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource13.wit +6 -0
  817. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource13.wit.result +5 -0
  818. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource14.wit +7 -0
  819. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource14.wit.result +5 -0
  820. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource15/deps/foo/foo.wit +5 -0
  821. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource15/foo.wit +7 -0
  822. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource15.wit.result +5 -0
  823. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource2.wit +5 -0
  824. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource2.wit.result +5 -0
  825. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource3.wit +6 -0
  826. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource3.wit.result +5 -0
  827. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource4.wit +6 -0
  828. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource4.wit.result +5 -0
  829. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource5.wit +7 -0
  830. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource5.wit.result +5 -0
  831. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource6.wit +7 -0
  832. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource6.wit.result +5 -0
  833. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource7.wit +8 -0
  834. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource7.wit.result +5 -0
  835. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource8.wit +8 -0
  836. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource8.wit.result +5 -0
  837. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource9.wit +7 -0
  838. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/bad-resource9.wit.result +5 -0
  839. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/import-and-export1.wit.result +5 -0
  840. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/import-and-export2.wit +18 -0
  841. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/import-and-export2.wit.result +5 -0
  842. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/import-and-export3.wit.result +5 -0
  843. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/import-and-export4.wit +44 -0
  844. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/import-and-export4.wit.result +5 -0
  845. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/import-and-export5.wit +18 -0
  846. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/import-and-export5.wit.result +5 -0
  847. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/include-cycle.wit +9 -0
  848. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/include-cycle.wit.result +5 -0
  849. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/include-foreign/deps/bar/empty.wit +3 -0
  850. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/include-foreign/root.wit +5 -0
  851. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/include-foreign.wit.result +5 -0
  852. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/include-with-id.wit +11 -0
  853. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/include-with-id.wit.result +5 -0
  854. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/include-with-on-id.wit +11 -0
  855. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/include-with-on-id.wit.result +5 -0
  856. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/kebab-name-include-not-found.wit +8 -0
  857. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/kebab-name-include-not-found.wit.result +5 -0
  858. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/kebab-name-include.wit +8 -0
  859. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/kebab-name-include.wit.result +5 -0
  860. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/no-access-to-sibling-use.wit.result +8 -0
  861. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/non-existance-world-include/deps/bar/baz.wit +4 -0
  862. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/non-existance-world-include/root.wit +5 -0
  863. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/non-existance-world-include.wit.result +5 -0
  864. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/type-and-resource-same-name/deps/dep/foo.wit +5 -0
  865. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/type-and-resource-same-name/foo.wit +8 -0
  866. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/type-and-resource-same-name.wit.result +5 -0
  867. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/union-fuzz-2.wit +12 -0
  868. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/union-fuzz-2.wit.result +5 -0
  869. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/unknown-interface.wit.result +5 -0
  870. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/unresolved-interface2.wit.result +5 -0
  871. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/unresolved-interface3.wit.result +5 -0
  872. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/unresolved-use1.wit.result +5 -0
  873. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/unresolved-use9.wit.result +5 -0
  874. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/use-and-include-world/deps/bar/baz.wit +4 -0
  875. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/use-and-include-world/root.wit +7 -0
  876. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/use-and-include-world.wit.result +8 -0
  877. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/use-cycle1.wit.result +5 -0
  878. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/use-cycle4.wit.result +5 -0
  879. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/use-world/deps/bar/baz.wit +4 -0
  880. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/use-world/root.wit +7 -0
  881. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/use-world.wit.result +5 -0
  882. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/parse-fail/world-interface-clash.wit.result +5 -0
  883. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/resources-empty.wit +10 -0
  884. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/resources-multiple-returns-borrow.wit +10 -0
  885. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/resources-multiple-returns-own.wit +10 -0
  886. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/resources-multiple.wit +20 -0
  887. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/resources-return-borrow.wit +10 -0
  888. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/resources-return-own.wit +10 -0
  889. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/resources.wit +47 -0
  890. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/resources1.wit +12 -0
  891. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/shared-types.wit +10 -0
  892. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/stress-export-elaborate.wit +54 -0
  893. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/union-fuzz-1.wit +9 -0
  894. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/world-diamond.wit +22 -0
  895. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/world-same-fields4.wit +13 -0
  896. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/world-top-level-resources.wit +24 -0
  897. data/ext/cargo-vendor/wit-parser-0.9.2/tests/ui/worlds-union-dedup.wit +23 -0
  898. data/lib/wasmtime/version.rb +1 -1
  899. metadata +1992 -1571
  900. data/ext/cargo-vendor/addr2line-0.19.0/.cargo-checksum.json +0 -1
  901. data/ext/cargo-vendor/addr2line-0.19.0/CHANGELOG.md +0 -287
  902. data/ext/cargo-vendor/addr2line-0.19.0/Cargo.lock +0 -466
  903. data/ext/cargo-vendor/addr2line-0.19.0/Cargo.toml +0 -142
  904. data/ext/cargo-vendor/addr2line-0.19.0/examples/addr2line.rs +0 -289
  905. data/ext/cargo-vendor/addr2line-0.19.0/src/function.rs +0 -534
  906. data/ext/cargo-vendor/addr2line-0.19.0/src/lazy.rs +0 -27
  907. data/ext/cargo-vendor/addr2line-0.19.0/src/lib.rs +0 -1234
  908. data/ext/cargo-vendor/addr2line-0.19.0/tests/correctness.rs +0 -92
  909. data/ext/cargo-vendor/addr2line-0.19.0/tests/output_equivalence.rs +0 -146
  910. data/ext/cargo-vendor/addr2line-0.19.0/tests/parse.rs +0 -118
  911. data/ext/cargo-vendor/cap-fs-ext-1.0.15/.cargo-checksum.json +0 -1
  912. data/ext/cargo-vendor/cap-fs-ext-1.0.15/Cargo.toml +0 -63
  913. data/ext/cargo-vendor/cap-fs-ext-1.0.15/src/is_file_read_write.rs +0 -61
  914. data/ext/cargo-vendor/cap-primitives-1.0.15/.cargo-checksum.json +0 -1
  915. data/ext/cargo-vendor/cap-primitives-1.0.15/Cargo.toml +0 -81
  916. data/ext/cargo-vendor/cap-primitives-1.0.15/src/fs/mod.rs +0 -125
  917. data/ext/cargo-vendor/cap-primitives-1.0.15/src/net/pool.rs +0 -284
  918. data/ext/cargo-vendor/cap-primitives-1.0.15/src/rustix/fs/copy_impl.rs +0 -235
  919. data/ext/cargo-vendor/cap-primitives-1.0.15/src/rustix/fs/metadata_ext.rs +0 -385
  920. data/ext/cargo-vendor/cap-primitives-1.0.15/src/rustix/fs/oflags.rs +0 -98
  921. data/ext/cargo-vendor/cap-primitives-1.0.15/src/rustix/fs/open_unchecked.rs +0 -71
  922. data/ext/cargo-vendor/cap-primitives-1.0.15/src/rustix/fs/reopen_impl.rs +0 -18
  923. data/ext/cargo-vendor/cap-primitives-1.0.15/src/rustix/fs/set_permissions_impl.rs +0 -50
  924. data/ext/cargo-vendor/cap-primitives-1.0.15/src/rustix/fs/stat_unchecked.rs +0 -79
  925. data/ext/cargo-vendor/cap-primitives-1.0.15/src/rustix/fs/times.rs +0 -62
  926. data/ext/cargo-vendor/cap-primitives-1.0.15/src/rustix/linux/fs/procfs.rs +0 -76
  927. data/ext/cargo-vendor/cap-primitives-1.0.15/src/windows/fs/create_file_at_w.rs +0 -274
  928. data/ext/cargo-vendor/cap-primitives-1.0.15/src/windows/fs/metadata_ext.rs +0 -216
  929. data/ext/cargo-vendor/cap-primitives-1.0.15/src/windows/fs/open_unchecked.rs +0 -229
  930. data/ext/cargo-vendor/cap-rand-1.0.15/.cargo-checksum.json +0 -1
  931. data/ext/cargo-vendor/cap-rand-1.0.15/Cargo.toml +0 -38
  932. data/ext/cargo-vendor/cap-std-1.0.15/.cargo-checksum.json +0 -1
  933. data/ext/cargo-vendor/cap-std-1.0.15/Cargo.toml +0 -67
  934. data/ext/cargo-vendor/cap-std-1.0.15/build.rs +0 -43
  935. data/ext/cargo-vendor/cap-std-1.0.15/src/fs/file.rs +0 -616
  936. data/ext/cargo-vendor/cap-std-1.0.15/src/fs_utf8/file.rs +0 -610
  937. data/ext/cargo-vendor/cap-std-1.0.15/src/lib.rs +0 -53
  938. data/ext/cargo-vendor/cap-std-1.0.15/src/net/udp_socket.rs +0 -418
  939. data/ext/cargo-vendor/cap-time-ext-1.0.15/.cargo-checksum.json +0 -1
  940. data/ext/cargo-vendor/cap-time-ext-1.0.15/Cargo.toml +0 -42
  941. data/ext/cargo-vendor/cap-time-ext-1.0.15/src/monotonic_clock.rs +0 -63
  942. data/ext/cargo-vendor/cap-time-ext-1.0.15/src/system_clock.rs +0 -62
  943. data/ext/cargo-vendor/cranelift-bforest-0.98.1/.cargo-checksum.json +0 -1
  944. data/ext/cargo-vendor/cranelift-bforest-0.98.1/Cargo.toml +0 -31
  945. data/ext/cargo-vendor/cranelift-codegen-0.98.1/.cargo-checksum.json +0 -1
  946. data/ext/cargo-vendor/cranelift-codegen-0.98.1/Cargo.toml +0 -160
  947. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/cursor.rs +0 -644
  948. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/ir/extfunc.rs +0 -421
  949. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/ir/function.rs +0 -485
  950. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/ir/globalvalue.rs +0 -170
  951. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/ir/mod.rs +0 -107
  952. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/aarch64/abi.rs +0 -1506
  953. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/aarch64/inst/emit.rs +0 -3714
  954. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/aarch64/inst/mod.rs +0 -2980
  955. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/aarch64/inst.isle +0 -4037
  956. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/aarch64/lower/isle.rs +0 -837
  957. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/aarch64/lower.isle +0 -2899
  958. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/riscv64/abi.rs +0 -946
  959. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/riscv64/inst/emit.rs +0 -3058
  960. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/riscv64/inst/mod.rs +0 -2070
  961. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/riscv64/inst.isle +0 -2927
  962. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/riscv64/lower/isle.rs +0 -585
  963. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/riscv64/lower.isle +0 -1984
  964. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/x64/abi.rs +0 -1220
  965. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/isa/x64/lower.isle +0 -4650
  966. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/lib.rs +0 -140
  967. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/machinst/abi.rs +0 -2605
  968. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/machinst/buffer.rs +0 -2255
  969. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/machinst/isle.rs +0 -836
  970. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/machinst/lower.rs +0 -1388
  971. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/machinst/vcode.rs +0 -1580
  972. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/opts/cprop.isle +0 -197
  973. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/opts/icmp.isle +0 -177
  974. data/ext/cargo-vendor/cranelift-codegen-0.98.1/src/value_label.rs +0 -69
  975. data/ext/cargo-vendor/cranelift-codegen-meta-0.98.1/.cargo-checksum.json +0 -1
  976. data/ext/cargo-vendor/cranelift-codegen-meta-0.98.1/Cargo.toml +0 -23
  977. data/ext/cargo-vendor/cranelift-codegen-meta-0.98.1/src/gen_inst.rs +0 -1784
  978. data/ext/cargo-vendor/cranelift-codegen-meta-0.98.1/src/isa/arm64.rs +0 -61
  979. data/ext/cargo-vendor/cranelift-codegen-meta-0.98.1/src/isa/mod.rs +0 -67
  980. data/ext/cargo-vendor/cranelift-codegen-meta-0.98.1/src/isa/riscv64.rs +0 -108
  981. data/ext/cargo-vendor/cranelift-codegen-meta-0.98.1/src/isa/s390x.rs +0 -47
  982. data/ext/cargo-vendor/cranelift-codegen-meta-0.98.1/src/isa/x86.rs +0 -409
  983. data/ext/cargo-vendor/cranelift-codegen-meta-0.98.1/src/lib.rs +0 -66
  984. data/ext/cargo-vendor/cranelift-codegen-meta-0.98.1/src/shared/mod.rs +0 -87
  985. data/ext/cargo-vendor/cranelift-codegen-shared-0.98.1/.cargo-checksum.json +0 -1
  986. data/ext/cargo-vendor/cranelift-codegen-shared-0.98.1/Cargo.toml +0 -22
  987. data/ext/cargo-vendor/cranelift-control-0.98.1/.cargo-checksum.json +0 -1
  988. data/ext/cargo-vendor/cranelift-control-0.98.1/Cargo.toml +0 -30
  989. data/ext/cargo-vendor/cranelift-entity-0.98.1/.cargo-checksum.json +0 -1
  990. data/ext/cargo-vendor/cranelift-entity-0.98.1/Cargo.toml +0 -35
  991. data/ext/cargo-vendor/cranelift-frontend-0.98.1/.cargo-checksum.json +0 -1
  992. data/ext/cargo-vendor/cranelift-frontend-0.98.1/Cargo.toml +0 -53
  993. data/ext/cargo-vendor/cranelift-frontend-0.98.1/src/lib.rs +0 -204
  994. data/ext/cargo-vendor/cranelift-isle-0.98.1/.cargo-checksum.json +0 -1
  995. data/ext/cargo-vendor/cranelift-isle-0.98.1/Cargo.toml +0 -37
  996. data/ext/cargo-vendor/cranelift-native-0.98.1/.cargo-checksum.json +0 -1
  997. data/ext/cargo-vendor/cranelift-native-0.98.1/Cargo.toml +0 -38
  998. data/ext/cargo-vendor/cranelift-wasm-0.98.1/.cargo-checksum.json +0 -1
  999. data/ext/cargo-vendor/cranelift-wasm-0.98.1/Cargo.toml +0 -85
  1000. data/ext/cargo-vendor/cranelift-wasm-0.98.1/src/code_translator.rs +0 -3544
  1001. data/ext/cargo-vendor/cranelift-wasm-0.98.1/src/environ/dummy.rs +0 -924
  1002. data/ext/cargo-vendor/cranelift-wasm-0.98.1/src/environ/spec.rs +0 -852
  1003. data/ext/cargo-vendor/cranelift-wasm-0.98.1/src/func_translator.rs +0 -440
  1004. data/ext/cargo-vendor/cranelift-wasm-0.98.1/src/sections_translator.rs +0 -417
  1005. data/ext/cargo-vendor/cranelift-wasm-0.98.1/tests/wasm_testsuite.rs +0 -162
  1006. data/ext/cargo-vendor/fs-set-times-0.19.2/.cargo-checksum.json +0 -1
  1007. data/ext/cargo-vendor/fs-set-times-0.19.2/Cargo.toml +0 -45
  1008. data/ext/cargo-vendor/io-extras-0.17.4/.cargo-checksum.json +0 -1
  1009. data/ext/cargo-vendor/io-extras-0.17.4/Cargo.toml +0 -106
  1010. data/ext/cargo-vendor/io-extras-0.17.4/README.md +0 -33
  1011. data/ext/cargo-vendor/io-extras-0.17.4/build.rs +0 -79
  1012. data/ext/cargo-vendor/io-extras-0.17.4/src/os/windows/stdio.rs +0 -329
  1013. data/ext/cargo-vendor/memoffset-0.8.0/.cargo-checksum.json +0 -1
  1014. data/ext/cargo-vendor/memoffset-0.8.0/Cargo.toml +0 -36
  1015. data/ext/cargo-vendor/memoffset-0.8.0/LICENSE +0 -19
  1016. data/ext/cargo-vendor/memoffset-0.8.0/README.md +0 -85
  1017. data/ext/cargo-vendor/memoffset-0.8.0/build.rs +0 -25
  1018. data/ext/cargo-vendor/memoffset-0.8.0/src/lib.rs +0 -93
  1019. data/ext/cargo-vendor/memoffset-0.8.0/src/offset_of.rs +0 -356
  1020. data/ext/cargo-vendor/memoffset-0.8.0/src/raw_field.rs +0 -226
  1021. data/ext/cargo-vendor/memoffset-0.8.0/src/span_of.rs +0 -263
  1022. data/ext/cargo-vendor/object-0.30.4/.cargo-checksum.json +0 -1
  1023. data/ext/cargo-vendor/object-0.30.4/CHANGELOG.md +0 -524
  1024. data/ext/cargo-vendor/object-0.30.4/Cargo.toml +0 -154
  1025. data/ext/cargo-vendor/object-0.30.4/README.md +0 -58
  1026. data/ext/cargo-vendor/object-0.30.4/clippy.toml +0 -1
  1027. data/ext/cargo-vendor/object-0.30.4/src/common.rs +0 -480
  1028. data/ext/cargo-vendor/object-0.30.4/src/elf.rs +0 -6751
  1029. data/ext/cargo-vendor/object-0.30.4/src/endian.rs +0 -771
  1030. data/ext/cargo-vendor/object-0.30.4/src/lib.rs +0 -117
  1031. data/ext/cargo-vendor/object-0.30.4/src/macho.rs +0 -3307
  1032. data/ext/cargo-vendor/object-0.30.4/src/pe.rs +0 -3050
  1033. data/ext/cargo-vendor/object-0.30.4/src/read/any.rs +0 -1341
  1034. data/ext/cargo-vendor/object-0.30.4/src/read/coff/comdat.rs +0 -167
  1035. data/ext/cargo-vendor/object-0.30.4/src/read/coff/file.rs +0 -247
  1036. data/ext/cargo-vendor/object-0.30.4/src/read/coff/relocation.rs +0 -91
  1037. data/ext/cargo-vendor/object-0.30.4/src/read/coff/section.rs +0 -524
  1038. data/ext/cargo-vendor/object-0.30.4/src/read/coff/symbol.rs +0 -526
  1039. data/ext/cargo-vendor/object-0.30.4/src/read/elf/comdat.rs +0 -162
  1040. data/ext/cargo-vendor/object-0.30.4/src/read/elf/file.rs +0 -885
  1041. data/ext/cargo-vendor/object-0.30.4/src/read/elf/hash.rs +0 -220
  1042. data/ext/cargo-vendor/object-0.30.4/src/read/elf/mod.rs +0 -39
  1043. data/ext/cargo-vendor/object-0.30.4/src/read/elf/note.rs +0 -185
  1044. data/ext/cargo-vendor/object-0.30.4/src/read/elf/section.rs +0 -1090
  1045. data/ext/cargo-vendor/object-0.30.4/src/read/elf/segment.rs +0 -333
  1046. data/ext/cargo-vendor/object-0.30.4/src/read/elf/symbol.rs +0 -580
  1047. data/ext/cargo-vendor/object-0.30.4/src/read/elf/version.rs +0 -421
  1048. data/ext/cargo-vendor/object-0.30.4/src/read/macho/dyld_cache.rs +0 -343
  1049. data/ext/cargo-vendor/object-0.30.4/src/read/macho/file.rs +0 -731
  1050. data/ext/cargo-vendor/object-0.30.4/src/read/macho/load_command.rs +0 -353
  1051. data/ext/cargo-vendor/object-0.30.4/src/read/macho/relocation.rs +0 -126
  1052. data/ext/cargo-vendor/object-0.30.4/src/read/macho/section.rs +0 -384
  1053. data/ext/cargo-vendor/object-0.30.4/src/read/macho/segment.rs +0 -303
  1054. data/ext/cargo-vendor/object-0.30.4/src/read/macho/symbol.rs +0 -488
  1055. data/ext/cargo-vendor/object-0.30.4/src/read/mod.rs +0 -725
  1056. data/ext/cargo-vendor/object-0.30.4/src/read/pe/data_directory.rs +0 -211
  1057. data/ext/cargo-vendor/object-0.30.4/src/read/pe/file.rs +0 -1029
  1058. data/ext/cargo-vendor/object-0.30.4/src/read/pe/resource.rs +0 -207
  1059. data/ext/cargo-vendor/object-0.30.4/src/read/pe/rich.rs +0 -91
  1060. data/ext/cargo-vendor/object-0.30.4/src/read/pe/section.rs +0 -436
  1061. data/ext/cargo-vendor/object-0.30.4/src/read/read_cache.rs +0 -185
  1062. data/ext/cargo-vendor/object-0.30.4/src/read/read_ref.rs +0 -137
  1063. data/ext/cargo-vendor/object-0.30.4/src/read/traits.rs +0 -469
  1064. data/ext/cargo-vendor/object-0.30.4/src/read/util.rs +0 -383
  1065. data/ext/cargo-vendor/object-0.30.4/src/read/wasm.rs +0 -908
  1066. data/ext/cargo-vendor/object-0.30.4/src/read/xcoff/comdat.rs +0 -130
  1067. data/ext/cargo-vendor/object-0.30.4/src/read/xcoff/relocation.rs +0 -128
  1068. data/ext/cargo-vendor/object-0.30.4/src/read/xcoff/section.rs +0 -426
  1069. data/ext/cargo-vendor/object-0.30.4/src/read/xcoff/segment.rs +0 -115
  1070. data/ext/cargo-vendor/object-0.30.4/src/read/xcoff/symbol.rs +0 -634
  1071. data/ext/cargo-vendor/object-0.30.4/src/write/coff.rs +0 -713
  1072. data/ext/cargo-vendor/object-0.30.4/src/write/elf/object.rs +0 -838
  1073. data/ext/cargo-vendor/object-0.30.4/src/write/elf/writer.rs +0 -1955
  1074. data/ext/cargo-vendor/object-0.30.4/src/write/macho.rs +0 -876
  1075. data/ext/cargo-vendor/object-0.30.4/src/write/mod.rs +0 -917
  1076. data/ext/cargo-vendor/object-0.30.4/src/write/string.rs +0 -159
  1077. data/ext/cargo-vendor/object-0.30.4/src/write/util.rs +0 -210
  1078. data/ext/cargo-vendor/object-0.30.4/src/xcoff.rs +0 -893
  1079. data/ext/cargo-vendor/object-0.30.4/tests/read/coff.rs +0 -23
  1080. data/ext/cargo-vendor/object-0.30.4/tests/round_trip/elf.rs +0 -218
  1081. data/ext/cargo-vendor/object-0.30.4/tests/round_trip/macho.rs +0 -63
  1082. data/ext/cargo-vendor/object-0.30.4/tests/round_trip/mod.rs +0 -451
  1083. data/ext/cargo-vendor/pulldown-cmark-0.8.0/.cargo-checksum.json +0 -1
  1084. data/ext/cargo-vendor/pulldown-cmark-0.8.0/CONTRIBUTING.md +0 -21
  1085. data/ext/cargo-vendor/pulldown-cmark-0.8.0/Cargo.lock +0 -924
  1086. data/ext/cargo-vendor/pulldown-cmark-0.8.0/Cargo.toml +0 -68
  1087. data/ext/cargo-vendor/pulldown-cmark-0.8.0/README.md +0 -152
  1088. data/ext/cargo-vendor/pulldown-cmark-0.8.0/benches/html_rendering.rs +0 -101
  1089. data/ext/cargo-vendor/pulldown-cmark-0.8.0/benches/lib.rs +0 -49
  1090. data/ext/cargo-vendor/pulldown-cmark-0.8.0/build.rs +0 -186
  1091. data/ext/cargo-vendor/pulldown-cmark-0.8.0/examples/broken-link-callbacks.rs +0 -37
  1092. data/ext/cargo-vendor/pulldown-cmark-0.8.0/examples/event-filter.rs +0 -29
  1093. data/ext/cargo-vendor/pulldown-cmark-0.8.0/examples/string-to-string.rs +0 -26
  1094. data/ext/cargo-vendor/pulldown-cmark-0.8.0/src/escape.rs +0 -356
  1095. data/ext/cargo-vendor/pulldown-cmark-0.8.0/src/html.rs +0 -461
  1096. data/ext/cargo-vendor/pulldown-cmark-0.8.0/src/lib.rs +0 -76
  1097. data/ext/cargo-vendor/pulldown-cmark-0.8.0/src/linklabel.rs +0 -135
  1098. data/ext/cargo-vendor/pulldown-cmark-0.8.0/src/main.rs +0 -109
  1099. data/ext/cargo-vendor/pulldown-cmark-0.8.0/src/parse.rs +0 -3374
  1100. data/ext/cargo-vendor/pulldown-cmark-0.8.0/src/puncttable.rs +0 -351
  1101. data/ext/cargo-vendor/pulldown-cmark-0.8.0/src/scanners.rs +0 -1308
  1102. data/ext/cargo-vendor/pulldown-cmark-0.8.0/src/simd.rs +0 -248
  1103. data/ext/cargo-vendor/pulldown-cmark-0.8.0/src/strings.rs +0 -243
  1104. data/ext/cargo-vendor/pulldown-cmark-0.8.0/src/tree.rs +0 -216
  1105. data/ext/cargo-vendor/pulldown-cmark-0.8.0/tests/errors.rs +0 -44
  1106. data/ext/cargo-vendor/pulldown-cmark-0.8.0/tests/html.rs +0 -252
  1107. data/ext/cargo-vendor/pulldown-cmark-0.8.0/tests/lib.rs +0 -425
  1108. data/ext/cargo-vendor/pulldown-cmark-0.8.0/tests/suite/gfm_strikethrough.rs +0 -27
  1109. data/ext/cargo-vendor/pulldown-cmark-0.8.0/tests/suite/gfm_table.rs +0 -205
  1110. data/ext/cargo-vendor/pulldown-cmark-0.8.0/tests/suite/mod.rs +0 -13
  1111. data/ext/cargo-vendor/pulldown-cmark-0.8.0/tests/suite/regression.rs +0 -953
  1112. data/ext/cargo-vendor/pulldown-cmark-0.8.0/tests/suite/spec.rs +0 -8447
  1113. data/ext/cargo-vendor/system-interface-0.25.9/.cargo-checksum.json +0 -1
  1114. data/ext/cargo-vendor/system-interface-0.25.9/Cargo.toml +0 -105
  1115. data/ext/cargo-vendor/system-interface-0.25.9/build.rs +0 -55
  1116. data/ext/cargo-vendor/system-interface-0.25.9/src/fs/file_io_ext.rs +0 -1186
  1117. data/ext/cargo-vendor/wasi-cap-std-sync-11.0.0/.cargo-checksum.json +0 -1
  1118. data/ext/cargo-vendor/wasi-cap-std-sync-11.0.0/Cargo.toml +0 -90
  1119. data/ext/cargo-vendor/wasi-cap-std-sync-11.0.0/src/sched/unix.rs +0 -82
  1120. data/ext/cargo-vendor/wasi-common-11.0.0/.cargo-checksum.json +0 -1
  1121. data/ext/cargo-vendor/wasi-common-11.0.0/Cargo.toml +0 -87
  1122. data/ext/cargo-vendor/wasi-common-11.0.0/src/file.rs +0 -262
  1123. data/ext/cargo-vendor/wasi-common-11.0.0/src/sched/subscription.rs +0 -76
  1124. data/ext/cargo-vendor/wasi-common-11.0.0/src/snapshots/preview_1/error.rs +0 -255
  1125. data/ext/cargo-vendor/wasm-encoder-0.29.0/.cargo-checksum.json +0 -1
  1126. data/ext/cargo-vendor/wasm-encoder-0.29.0/Cargo.toml +0 -33
  1127. data/ext/cargo-vendor/wasm-encoder-0.29.0/README.md +0 -80
  1128. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/aliases.rs +0 -160
  1129. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/canonicals.rs +0 -159
  1130. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/components.rs +0 -29
  1131. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/exports.rs +0 -127
  1132. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/imports.rs +0 -200
  1133. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/instances.rs +0 -200
  1134. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/modules.rs +0 -29
  1135. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/names.rs +0 -149
  1136. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/start.rs +0 -52
  1137. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/types.rs +0 -759
  1138. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component.rs +0 -160
  1139. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/code.rs +0 -2913
  1140. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/custom.rs +0 -55
  1141. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/data.rs +0 -185
  1142. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/dump.rs +0 -627
  1143. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/elements.rs +0 -224
  1144. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/exports.rs +0 -85
  1145. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/functions.rs +0 -63
  1146. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/globals.rs +0 -90
  1147. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/imports.rs +0 -142
  1148. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/linking.rs +0 -263
  1149. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/memories.rs +0 -99
  1150. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/names.rs +0 -265
  1151. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/producers.rs +0 -180
  1152. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/start.rs +0 -39
  1153. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/tables.rs +0 -104
  1154. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/tags.rs +0 -85
  1155. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/types.rs +0 -246
  1156. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core.rs +0 -168
  1157. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/lib.rs +0 -215
  1158. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/raw.rs +0 -30
  1159. data/ext/cargo-vendor/wasmparser-0.107.0/.cargo-checksum.json +0 -1
  1160. data/ext/cargo-vendor/wasmparser-0.107.0/Cargo.lock +0 -621
  1161. data/ext/cargo-vendor/wasmparser-0.107.0/Cargo.toml +0 -54
  1162. data/ext/cargo-vendor/wasmparser-0.107.0/benches/benchmark.rs +0 -351
  1163. data/ext/cargo-vendor/wasmparser-0.107.0/src/lib.rs +0 -723
  1164. data/ext/cargo-vendor/wasmparser-0.107.0/src/limits.rs +0 -57
  1165. data/ext/cargo-vendor/wasmparser-0.107.0/src/parser.rs +0 -1535
  1166. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/component/canonicals.rs +0 -119
  1167. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/component/types.rs +0 -548
  1168. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/core/elements.rs +0 -158
  1169. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/core/types.rs +0 -874
  1170. data/ext/cargo-vendor/wasmparser-0.107.0/src/validator/component.rs +0 -3082
  1171. data/ext/cargo-vendor/wasmparser-0.107.0/src/validator/core.rs +0 -1334
  1172. data/ext/cargo-vendor/wasmparser-0.107.0/src/validator/operators.rs +0 -3463
  1173. data/ext/cargo-vendor/wasmparser-0.107.0/src/validator/types.rs +0 -3070
  1174. data/ext/cargo-vendor/wasmparser-0.107.0/src/validator.rs +0 -1589
  1175. data/ext/cargo-vendor/wasmparser-0.107.0/tests/big-module.rs +0 -32
  1176. data/ext/cargo-vendor/wasmtime-11.0.0/.cargo-checksum.json +0 -1
  1177. data/ext/cargo-vendor/wasmtime-11.0.0/Cargo.toml +0 -183
  1178. data/ext/cargo-vendor/wasmtime-11.0.0/README.md +0 -119
  1179. data/ext/cargo-vendor/wasmtime-11.0.0/src/compiler.rs +0 -710
  1180. data/ext/cargo-vendor/wasmtime-11.0.0/src/component/component.rs +0 -397
  1181. data/ext/cargo-vendor/wasmtime-11.0.0/src/component/func/host.rs +0 -472
  1182. data/ext/cargo-vendor/wasmtime-11.0.0/src/component/func/options.rs +0 -270
  1183. data/ext/cargo-vendor/wasmtime-11.0.0/src/component/func/typed.rs +0 -2298
  1184. data/ext/cargo-vendor/wasmtime-11.0.0/src/component/func.rs +0 -701
  1185. data/ext/cargo-vendor/wasmtime-11.0.0/src/component/instance.rs +0 -727
  1186. data/ext/cargo-vendor/wasmtime-11.0.0/src/component/linker.rs +0 -404
  1187. data/ext/cargo-vendor/wasmtime-11.0.0/src/component/matching.rs +0 -112
  1188. data/ext/cargo-vendor/wasmtime-11.0.0/src/component/mod.rs +0 -313
  1189. data/ext/cargo-vendor/wasmtime-11.0.0/src/component/types.rs +0 -514
  1190. data/ext/cargo-vendor/wasmtime-11.0.0/src/component/values.rs +0 -1319
  1191. data/ext/cargo-vendor/wasmtime-11.0.0/src/config.rs +0 -2058
  1192. data/ext/cargo-vendor/wasmtime-11.0.0/src/engine/serialization.rs +0 -622
  1193. data/ext/cargo-vendor/wasmtime-11.0.0/src/externals.rs +0 -763
  1194. data/ext/cargo-vendor/wasmtime-11.0.0/src/func.rs +0 -2355
  1195. data/ext/cargo-vendor/wasmtime-11.0.0/src/instance.rs +0 -905
  1196. data/ext/cargo-vendor/wasmtime-11.0.0/src/lib.rs +0 -486
  1197. data/ext/cargo-vendor/wasmtime-11.0.0/src/memory.rs +0 -950
  1198. data/ext/cargo-vendor/wasmtime-11.0.0/src/module/registry.rs +0 -321
  1199. data/ext/cargo-vendor/wasmtime-11.0.0/src/module.rs +0 -1274
  1200. data/ext/cargo-vendor/wasmtime-11.0.0/src/store/data.rs +0 -275
  1201. data/ext/cargo-vendor/wasmtime-11.0.0/src/store/func_refs.rs +0 -85
  1202. data/ext/cargo-vendor/wasmtime-11.0.0/src/store.rs +0 -2166
  1203. data/ext/cargo-vendor/wasmtime-11.0.0/src/trap.rs +0 -631
  1204. data/ext/cargo-vendor/wasmtime-asm-macros-11.0.0/.cargo-checksum.json +0 -1
  1205. data/ext/cargo-vendor/wasmtime-asm-macros-11.0.0/Cargo.toml +0 -22
  1206. data/ext/cargo-vendor/wasmtime-cache-11.0.0/.cargo-checksum.json +0 -1
  1207. data/ext/cargo-vendor/wasmtime-cache-11.0.0/Cargo.toml +0 -73
  1208. data/ext/cargo-vendor/wasmtime-component-macro-11.0.0/.cargo-checksum.json +0 -1
  1209. data/ext/cargo-vendor/wasmtime-component-macro-11.0.0/Cargo.toml +0 -58
  1210. data/ext/cargo-vendor/wasmtime-component-macro-11.0.0/src/bindgen.rs +0 -348
  1211. data/ext/cargo-vendor/wasmtime-component-macro-11.0.0/src/component.rs +0 -1354
  1212. data/ext/cargo-vendor/wasmtime-component-util-11.0.0/.cargo-checksum.json +0 -1
  1213. data/ext/cargo-vendor/wasmtime-component-util-11.0.0/Cargo.toml +0 -25
  1214. data/ext/cargo-vendor/wasmtime-cranelift-11.0.0/.cargo-checksum.json +0 -1
  1215. data/ext/cargo-vendor/wasmtime-cranelift-11.0.0/Cargo.toml +0 -90
  1216. data/ext/cargo-vendor/wasmtime-cranelift-11.0.0/src/builder.rs +0 -108
  1217. data/ext/cargo-vendor/wasmtime-cranelift-11.0.0/src/compiler/component.rs +0 -593
  1218. data/ext/cargo-vendor/wasmtime-cranelift-11.0.0/src/compiler.rs +0 -1297
  1219. data/ext/cargo-vendor/wasmtime-cranelift-11.0.0/src/debug/transform/expression.rs +0 -1250
  1220. data/ext/cargo-vendor/wasmtime-cranelift-11.0.0/src/debug/transform/unit.rs +0 -521
  1221. data/ext/cargo-vendor/wasmtime-cranelift-11.0.0/src/debug/transform/utils.rs +0 -187
  1222. data/ext/cargo-vendor/wasmtime-cranelift-11.0.0/src/func_environ.rs +0 -2218
  1223. data/ext/cargo-vendor/wasmtime-cranelift-11.0.0/src/lib.rs +0 -160
  1224. data/ext/cargo-vendor/wasmtime-cranelift-shared-11.0.0/.cargo-checksum.json +0 -1
  1225. data/ext/cargo-vendor/wasmtime-cranelift-shared-11.0.0/Cargo.toml +0 -57
  1226. data/ext/cargo-vendor/wasmtime-cranelift-shared-11.0.0/src/lib.rs +0 -120
  1227. data/ext/cargo-vendor/wasmtime-environ-11.0.0/.cargo-checksum.json +0 -1
  1228. data/ext/cargo-vendor/wasmtime-environ-11.0.0/Cargo.lock +0 -681
  1229. data/ext/cargo-vendor/wasmtime-environ-11.0.0/Cargo.toml +0 -116
  1230. data/ext/cargo-vendor/wasmtime-environ-11.0.0/examples/factc.rs +0 -209
  1231. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/compilation.rs +0 -400
  1232. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/component/compiler.rs +0 -84
  1233. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/component/dfg.rs +0 -629
  1234. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/component/info.rs +0 -530
  1235. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/component/translate/adapt.rs +0 -449
  1236. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/component/translate/inline.rs +0 -1069
  1237. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/component/translate.rs +0 -843
  1238. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/component/types.rs +0 -1827
  1239. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/component/vmcomponent_offsets.rs +0 -336
  1240. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/component.rs +0 -72
  1241. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/fact/signature.rs +0 -118
  1242. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/fact/trampoline.rs +0 -3173
  1243. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/fact/transcode.rs +0 -168
  1244. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/fact.rs +0 -623
  1245. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/module_environ.rs +0 -884
  1246. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/trap_encoding.rs +0 -238
  1247. data/ext/cargo-vendor/wasmtime-environ-11.0.0/src/tunables.rs +0 -111
  1248. data/ext/cargo-vendor/wasmtime-fiber-11.0.0/.cargo-checksum.json +0 -1
  1249. data/ext/cargo-vendor/wasmtime-fiber-11.0.0/Cargo.toml +0 -46
  1250. data/ext/cargo-vendor/wasmtime-fiber-11.0.0/build.rs +0 -23
  1251. data/ext/cargo-vendor/wasmtime-fiber-11.0.0/src/unix/aarch64.rs +0 -184
  1252. data/ext/cargo-vendor/wasmtime-fiber-11.0.0/src/unix/arm.rs +0 -85
  1253. data/ext/cargo-vendor/wasmtime-fiber-11.0.0/src/unix/riscv64.rs +0 -158
  1254. data/ext/cargo-vendor/wasmtime-fiber-11.0.0/src/unix/s390x.S +0 -120
  1255. data/ext/cargo-vendor/wasmtime-fiber-11.0.0/src/unix/x86_64.rs +0 -160
  1256. data/ext/cargo-vendor/wasmtime-fiber-11.0.0/src/unix.rs +0 -212
  1257. data/ext/cargo-vendor/wasmtime-fiber-11.0.0/src/windows.c +0 -5
  1258. data/ext/cargo-vendor/wasmtime-fiber-11.0.0/src/windows.rs +0 -161
  1259. data/ext/cargo-vendor/wasmtime-jit-11.0.0/.cargo-checksum.json +0 -1
  1260. data/ext/cargo-vendor/wasmtime-jit-11.0.0/Cargo.toml +0 -104
  1261. data/ext/cargo-vendor/wasmtime-jit-11.0.0/src/profiling.rs +0 -108
  1262. data/ext/cargo-vendor/wasmtime-jit-debug-11.0.0/.cargo-checksum.json +0 -1
  1263. data/ext/cargo-vendor/wasmtime-jit-debug-11.0.0/Cargo.toml +0 -55
  1264. data/ext/cargo-vendor/wasmtime-jit-debug-11.0.0/src/gdb_jit_int.rs +0 -128
  1265. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-11.0.0/.cargo-checksum.json +0 -1
  1266. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-11.0.0/Cargo.toml +0 -37
  1267. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/.cargo-checksum.json +0 -1
  1268. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/Cargo.toml +0 -110
  1269. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/build.rs +0 -17
  1270. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/component/transcode.rs +0 -451
  1271. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/component.rs +0 -727
  1272. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/debug_builtins.rs +0 -58
  1273. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/helpers.c +0 -104
  1274. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/instance/allocator.rs +0 -531
  1275. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/lib.rs +0 -285
  1276. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/libcalls.rs +0 -626
  1277. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/mmap/unix.rs +0 -148
  1278. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/send_sync_ptr.rs +0 -69
  1279. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/trampolines/aarch64.rs +0 -42
  1280. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/trampolines/riscv64.rs +0 -43
  1281. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/trampolines/s390x.S +0 -58
  1282. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/trampolines/x86_64.rs +0 -64
  1283. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/traphandlers/unix.rs +0 -387
  1284. data/ext/cargo-vendor/wasmtime-runtime-11.0.0/src/traphandlers.rs +0 -749
  1285. data/ext/cargo-vendor/wasmtime-types-11.0.1/.cargo-checksum.json +0 -1
  1286. data/ext/cargo-vendor/wasmtime-types-11.0.1/Cargo.toml +0 -34
  1287. data/ext/cargo-vendor/wasmtime-types-11.0.1/src/lib.rs +0 -462
  1288. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/.cargo-checksum.json +0 -1
  1289. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/Cargo.toml +0 -153
  1290. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/ctx.rs +0 -238
  1291. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/filesystem.rs +0 -269
  1292. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/mod.rs +0 -44
  1293. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/pipe.rs +0 -233
  1294. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/preview1/mod.rs +0 -1860
  1295. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/preview2/clocks.rs +0 -80
  1296. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/preview2/env.rs +0 -48
  1297. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/preview2/exit.rs +0 -12
  1298. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/preview2/filesystem.rs +0 -1020
  1299. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/preview2/io.rs +0 -215
  1300. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/preview2/mod.rs +0 -7
  1301. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/preview2/poll.rs +0 -83
  1302. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/preview2/random.rs +0 -41
  1303. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/sched/subscription.rs +0 -104
  1304. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/sched/sync.rs +0 -156
  1305. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/sched.rs +0 -110
  1306. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/stdio.rs +0 -176
  1307. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/stream.rs +0 -210
  1308. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/table.rs +0 -107
  1309. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/wasi/command.rs +0 -43
  1310. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/src/preview2/wasi/mod.rs +0 -30
  1311. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/wit/deps/io/streams.wit +0 -215
  1312. data/ext/cargo-vendor/wasmtime-wasi-11.0.0/wit/test.wit +0 -19
  1313. data/ext/cargo-vendor/wasmtime-winch-11.0.0/.cargo-checksum.json +0 -1
  1314. data/ext/cargo-vendor/wasmtime-winch-11.0.0/Cargo.toml +0 -63
  1315. data/ext/cargo-vendor/wasmtime-winch-11.0.0/src/builder.rs +0 -59
  1316. data/ext/cargo-vendor/wasmtime-winch-11.0.0/src/compiler.rs +0 -220
  1317. data/ext/cargo-vendor/wasmtime-wit-bindgen-11.0.0/.cargo-checksum.json +0 -1
  1318. data/ext/cargo-vendor/wasmtime-wit-bindgen-11.0.0/Cargo.toml +0 -29
  1319. data/ext/cargo-vendor/wasmtime-wit-bindgen-11.0.0/src/lib.rs +0 -1648
  1320. data/ext/cargo-vendor/wasmtime-wit-bindgen-11.0.0/src/rust.rs +0 -491
  1321. data/ext/cargo-vendor/wasmtime-wit-bindgen-11.0.0/src/types.rs +0 -183
  1322. data/ext/cargo-vendor/wiggle-11.0.0/.cargo-checksum.json +0 -1
  1323. data/ext/cargo-vendor/wiggle-11.0.0/Cargo.toml +0 -106
  1324. data/ext/cargo-vendor/wiggle-generate-11.0.0/.cargo-checksum.json +0 -1
  1325. data/ext/cargo-vendor/wiggle-generate-11.0.0/Cargo.toml +0 -58
  1326. data/ext/cargo-vendor/wiggle-generate-11.0.0/src/config.rs +0 -696
  1327. data/ext/cargo-vendor/wiggle-generate-11.0.0/src/types/flags.rs +0 -94
  1328. data/ext/cargo-vendor/wiggle-macro-11.0.0/.cargo-checksum.json +0 -1
  1329. data/ext/cargo-vendor/wiggle-macro-11.0.0/Cargo.toml +0 -55
  1330. data/ext/cargo-vendor/wiggle-macro-11.0.0/LICENSE +0 -220
  1331. data/ext/cargo-vendor/winch-codegen-0.9.0/.cargo-checksum.json +0 -1
  1332. data/ext/cargo-vendor/winch-codegen-0.9.0/Cargo.toml +0 -62
  1333. data/ext/cargo-vendor/winch-codegen-0.9.0/src/codegen/context.rs +0 -328
  1334. data/ext/cargo-vendor/winch-codegen-0.9.0/src/codegen/control.rs +0 -437
  1335. data/ext/cargo-vendor/winch-codegen-0.9.0/src/codegen/env.rs +0 -64
  1336. data/ext/cargo-vendor/winch-codegen-0.9.0/src/codegen/mod.rs +0 -319
  1337. data/ext/cargo-vendor/winch-codegen-0.9.0/src/visitor.rs +0 -630
  1338. data/ext/cargo-vendor/winx-0.35.1/.cargo-checksum.json +0 -1
  1339. data/ext/cargo-vendor/winx-0.35.1/Cargo.toml +0 -50
  1340. data/ext/cargo-vendor/winx-0.35.1/LICENSE +0 -220
  1341. data/ext/cargo-vendor/winx-0.35.1/README.md +0 -5
  1342. data/ext/cargo-vendor/winx-0.35.1/src/cvt.rs +0 -24
  1343. data/ext/cargo-vendor/winx-0.35.1/src/file.rs +0 -420
  1344. data/ext/cargo-vendor/winx-0.35.1/src/lib.rs +0 -31
  1345. data/ext/cargo-vendor/winx-0.35.1/src/ntdll.rs +0 -69
  1346. data/ext/cargo-vendor/winx-0.35.1/src/time.rs +0 -11
  1347. data/ext/cargo-vendor/winx-0.35.1/src/winapi_util/file.rs +0 -171
  1348. data/ext/cargo-vendor/winx-0.35.1/src/winapi_util/mod.rs +0 -9
  1349. data/ext/cargo-vendor/wit-parser-0.8.0/.cargo-checksum.json +0 -1
  1350. data/ext/cargo-vendor/wit-parser-0.8.0/Cargo.toml +0 -62
  1351. data/ext/cargo-vendor/wit-parser-0.8.0/src/abi.rs +0 -2134
  1352. data/ext/cargo-vendor/wit-parser-0.8.0/src/ast/lex.rs +0 -679
  1353. data/ext/cargo-vendor/wit-parser-0.8.0/src/ast/resolve.rs +0 -1122
  1354. data/ext/cargo-vendor/wit-parser-0.8.0/src/ast/toposort.rs +0 -204
  1355. data/ext/cargo-vendor/wit-parser-0.8.0/src/ast.rs +0 -1207
  1356. data/ext/cargo-vendor/wit-parser-0.8.0/src/lib.rs +0 -622
  1357. data/ext/cargo-vendor/wit-parser-0.8.0/src/live.rs +0 -111
  1358. data/ext/cargo-vendor/wit-parser-0.8.0/src/resolve.rs +0 -1307
  1359. data/ext/cargo-vendor/wit-parser-0.8.0/src/sizealign.rs +0 -140
  1360. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg1.wit.result +0 -8
  1361. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/no-access-to-sibling-use.wit.result +0 -8
  1362. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unknown-interface.wit.result +0 -5
  1363. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-interface2.wit.result +0 -5
  1364. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-interface3.wit.result +0 -5
  1365. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use1.wit.result +0 -5
  1366. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use9.wit.result +0 -5
  1367. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-cycle1.wit.result +0 -5
  1368. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-cycle4.wit.result +0 -5
  1369. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/world-interface-clash.wit.result +0 -5
  1370. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/shared-types.wit +0 -10
  1371. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/world-diamond.wit +0 -22
  1372. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/world-same-fields4.wit +0 -13
  1373. /data/ext/cargo-vendor/{addr2line-0.19.0 → addr2line-0.20.0}/LICENSE-APACHE +0 -0
  1374. /data/ext/cargo-vendor/{addr2line-0.19.0 → addr2line-0.20.0}/LICENSE-MIT +0 -0
  1375. /data/ext/cargo-vendor/{addr2line-0.19.0 → addr2line-0.20.0}/README.md +0 -0
  1376. /data/ext/cargo-vendor/{addr2line-0.19.0 → addr2line-0.20.0}/bench.plot.r +0 -0
  1377. /data/ext/cargo-vendor/{addr2line-0.19.0 → addr2line-0.20.0}/benchmark.sh +0 -0
  1378. /data/ext/cargo-vendor/{addr2line-0.19.0 → addr2line-0.20.0}/coverage.sh +0 -0
  1379. /data/ext/cargo-vendor/{addr2line-0.19.0 → addr2line-0.20.0}/rustfmt.toml +0 -0
  1380. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/COPYRIGHT +0 -0
  1381. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/LICENSE-APACHE +0 -0
  1382. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/LICENSE-Apache-2.0_WITH_LLVM-exception +0 -0
  1383. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/LICENSE-MIT +0 -0
  1384. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/README.md +0 -0
  1385. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/build.rs +0 -0
  1386. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/src/dir_entry_ext.rs +0 -0
  1387. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/src/dir_ext.rs +0 -0
  1388. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/src/file_type_ext.rs +0 -0
  1389. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/src/lib.rs +0 -0
  1390. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/src/metadata_ext.rs +0 -0
  1391. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/src/open_options_follow_ext.rs +0 -0
  1392. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/src/open_options_maybe_dir_ext.rs +0 -0
  1393. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/src/open_options_sync_ext.rs +0 -0
  1394. /data/ext/cargo-vendor/{cap-fs-ext-1.0.15 → cap-fs-ext-2.0.0}/src/reopen.rs +0 -0
  1395. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/COPYRIGHT +0 -0
  1396. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/LICENSE-APACHE +0 -0
  1397. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/LICENSE-Apache-2.0_WITH_LLVM-exception +0 -0
  1398. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/LICENSE-MIT +0 -0
  1399. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/README.md +0 -0
  1400. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/build.rs +0 -0
  1401. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/assert_same_file.rs +0 -0
  1402. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/canonicalize.rs +0 -0
  1403. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/copy.rs +0 -0
  1404. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/create_dir.rs +0 -0
  1405. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/dir_builder.rs +0 -0
  1406. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/dir_entry.rs +0 -0
  1407. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/dir_options.rs +0 -0
  1408. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/errors.rs +0 -0
  1409. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/file_path_by_searching.rs +0 -0
  1410. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/file_type.rs +0 -0
  1411. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/follow_symlinks.rs +0 -0
  1412. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/hard_link.rs +0 -0
  1413. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/is_file_read_write.rs +0 -0
  1414. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/manually/canonical_path.rs +0 -0
  1415. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/manually/canonicalize.rs +0 -0
  1416. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/manually/cow_component.rs +0 -0
  1417. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/manually/mod.rs +0 -0
  1418. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/manually/open.rs +0 -0
  1419. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/manually/open_entry.rs +0 -0
  1420. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/manually/read_link_one.rs +0 -0
  1421. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/maybe_owned_file.rs +0 -0
  1422. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/metadata.rs +0 -0
  1423. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/open.rs +0 -0
  1424. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/open_ambient.rs +0 -0
  1425. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/open_dir.rs +0 -0
  1426. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/open_options.rs +0 -0
  1427. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/open_unchecked_error.rs +0 -0
  1428. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/permissions.rs +0 -0
  1429. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/read_dir.rs +0 -0
  1430. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/read_link.rs +0 -0
  1431. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/remove_dir.rs +0 -0
  1432. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/remove_dir_all.rs +0 -0
  1433. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/remove_file.rs +0 -0
  1434. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/remove_open_dir.rs +0 -0
  1435. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/rename.rs +0 -0
  1436. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/reopen.rs +0 -0
  1437. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/set_permissions.rs +0 -0
  1438. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/set_times.rs +0 -0
  1439. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/stat.rs +0 -0
  1440. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/symlink.rs +0 -0
  1441. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/system_time_spec.rs +0 -0
  1442. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/via_parent/create_dir.rs +0 -0
  1443. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/via_parent/hard_link.rs +0 -0
  1444. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/via_parent/mod.rs +0 -0
  1445. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/via_parent/open_parent.rs +0 -0
  1446. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/via_parent/read_link.rs +0 -0
  1447. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/via_parent/remove_dir.rs +0 -0
  1448. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/via_parent/remove_file.rs +0 -0
  1449. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/via_parent/rename.rs +0 -0
  1450. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/via_parent/set_permissions.rs +0 -0
  1451. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/via_parent/set_times_nofollow.rs +0 -0
  1452. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/fs/via_parent/symlink.rs +0 -0
  1453. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/lib.rs +0 -0
  1454. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/net/mod.rs +0 -0
  1455. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/darwin/fs/file_path.rs +0 -0
  1456. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/darwin/fs/mod.rs +0 -0
  1457. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/darwin/mod.rs +0 -0
  1458. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/create_dir_unchecked.rs +0 -0
  1459. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/cvt.rs +0 -0
  1460. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/dir_entry_inner.rs +0 -0
  1461. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/dir_options_ext.rs +0 -0
  1462. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/dir_utils.rs +0 -0
  1463. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/errors.rs +0 -0
  1464. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/file_path.rs +0 -0
  1465. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/file_type_ext.rs +0 -0
  1466. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/hard_link_unchecked.rs +0 -0
  1467. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/is_file_read_write_impl.rs +0 -0
  1468. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/is_root_dir.rs +0 -0
  1469. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/is_same_file.rs +0 -0
  1470. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/mod.rs +0 -0
  1471. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/open_options_ext.rs +0 -0
  1472. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/permissions_ext.rs +0 -0
  1473. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/read_dir_inner.rs +0 -0
  1474. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/read_link_unchecked.rs +0 -0
  1475. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/remove_dir_all_impl.rs +0 -0
  1476. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/remove_dir_unchecked.rs +0 -0
  1477. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/remove_file_unchecked.rs +0 -0
  1478. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/remove_open_dir_by_searching.rs +0 -0
  1479. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/rename_unchecked.rs +0 -0
  1480. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/set_times_impl.rs +0 -0
  1481. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/fs/symlink_unchecked.rs +0 -0
  1482. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/linux/fs/canonicalize_impl.rs +0 -0
  1483. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/linux/fs/file_metadata.rs +0 -0
  1484. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/linux/fs/file_path.rs +0 -0
  1485. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/linux/fs/mod.rs +0 -0
  1486. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/linux/fs/open_entry_impl.rs +0 -0
  1487. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/linux/fs/open_impl.rs +0 -0
  1488. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/linux/fs/set_permissions_impl.rs +0 -0
  1489. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/linux/fs/set_times_impl.rs +0 -0
  1490. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/linux/fs/stat_impl.rs +0 -0
  1491. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/linux/mod.rs +0 -0
  1492. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/rustix/mod.rs +0 -0
  1493. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/time/instant.rs +0 -0
  1494. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/time/mod.rs +0 -0
  1495. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/time/monotonic_clock.rs +0 -0
  1496. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/time/system_clock.rs +0 -0
  1497. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/time/system_time.rs +0 -0
  1498. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/copy.rs +0 -0
  1499. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/create_dir_unchecked.rs +0 -0
  1500. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/dir_entry_inner.rs +0 -0
  1501. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/dir_options_ext.rs +0 -0
  1502. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/dir_utils.rs +0 -0
  1503. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/errors.rs +0 -0
  1504. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/file_type_ext.rs +0 -0
  1505. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/get_path.rs +0 -0
  1506. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/hard_link_unchecked.rs +0 -0
  1507. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/is_file_read_write_impl.rs +0 -0
  1508. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/is_same_file.rs +0 -0
  1509. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/mod.rs +0 -0
  1510. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/oflags.rs +0 -0
  1511. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/open_impl.rs +0 -0
  1512. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/open_options_ext.rs +0 -0
  1513. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/read_dir_inner.rs +0 -0
  1514. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/read_link_impl.rs +0 -0
  1515. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/read_link_unchecked.rs +0 -0
  1516. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/remove_dir_all_impl.rs +0 -0
  1517. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/remove_dir_unchecked.rs +0 -0
  1518. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/remove_file_unchecked.rs +0 -0
  1519. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/remove_open_dir_impl.rs +0 -0
  1520. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/rename_unchecked.rs +0 -0
  1521. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/reopen_impl.rs +0 -0
  1522. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/set_permissions_unchecked.rs +0 -0
  1523. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/set_times_impl.rs +0 -0
  1524. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/stat_unchecked.rs +0 -0
  1525. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/fs/symlink_unchecked.rs +0 -0
  1526. /data/ext/cargo-vendor/{cap-primitives-1.0.15 → cap-primitives-2.0.0}/src/windows/mod.rs +0 -0
  1527. /data/ext/cargo-vendor/{cap-rand-1.0.15 → cap-rand-2.0.0}/COPYRIGHT +0 -0
  1528. /data/ext/cargo-vendor/{cap-rand-1.0.15 → cap-rand-2.0.0}/LICENSE-APACHE +0 -0
  1529. /data/ext/cargo-vendor/{cap-rand-1.0.15 → cap-rand-2.0.0}/LICENSE-Apache-2.0_WITH_LLVM-exception +0 -0
  1530. /data/ext/cargo-vendor/{cap-rand-1.0.15 → cap-rand-2.0.0}/LICENSE-MIT +0 -0
  1531. /data/ext/cargo-vendor/{cap-rand-1.0.15 → cap-rand-2.0.0}/README.md +0 -0
  1532. /data/ext/cargo-vendor/{cap-rand-1.0.15 → cap-rand-2.0.0}/src/lib.rs +0 -0
  1533. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/COPYRIGHT +0 -0
  1534. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/LICENSE-APACHE +0 -0
  1535. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/LICENSE-Apache-2.0_WITH_LLVM-exception +0 -0
  1536. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/LICENSE-MIT +0 -0
  1537. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/README.md +0 -0
  1538. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/fs/dir.rs +0 -0
  1539. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/fs/dir_entry.rs +0 -0
  1540. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/fs/mod.rs +0 -0
  1541. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/fs/read_dir.rs +0 -0
  1542. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/fs_utf8/dir.rs +0 -0
  1543. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/fs_utf8/dir_entry.rs +0 -0
  1544. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/fs_utf8/mod.rs +0 -0
  1545. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/fs_utf8/read_dir.rs +0 -0
  1546. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/net/incoming.rs +0 -0
  1547. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/net/mod.rs +0 -0
  1548. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/net/pool.rs +0 -0
  1549. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/net/tcp_listener.rs +0 -0
  1550. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/net/tcp_stream.rs +0 -0
  1551. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/os/mod.rs +0 -0
  1552. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/os/unix/mod.rs +0 -0
  1553. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/os/unix/net/incoming.rs +0 -0
  1554. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/os/unix/net/mod.rs +0 -0
  1555. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/os/unix/net/unix_datagram.rs +0 -0
  1556. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/os/unix/net/unix_listener.rs +0 -0
  1557. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/os/unix/net/unix_stream.rs +0 -0
  1558. /data/ext/cargo-vendor/{cap-std-1.0.15 → cap-std-2.0.0}/src/time/mod.rs +0 -0
  1559. /data/ext/cargo-vendor/{cap-time-ext-1.0.15 → cap-time-ext-2.0.0}/COPYRIGHT +0 -0
  1560. /data/ext/cargo-vendor/{cap-time-ext-1.0.15 → cap-time-ext-2.0.0}/LICENSE-APACHE +0 -0
  1561. /data/ext/cargo-vendor/{cap-time-ext-1.0.15 → cap-time-ext-2.0.0}/LICENSE-Apache-2.0_WITH_LLVM-exception +0 -0
  1562. /data/ext/cargo-vendor/{cap-time-ext-1.0.15 → cap-time-ext-2.0.0}/LICENSE-MIT +0 -0
  1563. /data/ext/cargo-vendor/{cap-time-ext-1.0.15 → cap-time-ext-2.0.0}/README.md +0 -0
  1564. /data/ext/cargo-vendor/{cap-time-ext-1.0.15 → cap-time-ext-2.0.0}/src/lib.rs +0 -0
  1565. /data/ext/cargo-vendor/{cranelift-bforest-0.98.1 → cranelift-bforest-0.99.1}/LICENSE +0 -0
  1566. /data/ext/cargo-vendor/{cranelift-bforest-0.98.1 → cranelift-bforest-0.99.1}/README.md +0 -0
  1567. /data/ext/cargo-vendor/{cranelift-bforest-0.98.1 → cranelift-bforest-0.99.1}/src/lib.rs +0 -0
  1568. /data/ext/cargo-vendor/{cranelift-bforest-0.98.1 → cranelift-bforest-0.99.1}/src/map.rs +0 -0
  1569. /data/ext/cargo-vendor/{cranelift-bforest-0.98.1 → cranelift-bforest-0.99.1}/src/node.rs +0 -0
  1570. /data/ext/cargo-vendor/{cranelift-bforest-0.98.1 → cranelift-bforest-0.99.1}/src/path.rs +0 -0
  1571. /data/ext/cargo-vendor/{cranelift-bforest-0.98.1 → cranelift-bforest-0.99.1}/src/pool.rs +0 -0
  1572. /data/ext/cargo-vendor/{cranelift-bforest-0.98.1 → cranelift-bforest-0.99.1}/src/set.rs +0 -0
  1573. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/LICENSE +0 -0
  1574. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/README.md +0 -0
  1575. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/benches/x64-evex-encoding.rs +0 -0
  1576. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/build.rs +0 -0
  1577. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/alias_analysis.rs +0 -0
  1578. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/binemit/mod.rs +0 -0
  1579. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/binemit/stack_map.rs +0 -0
  1580. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/bitset.rs +0 -0
  1581. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/cfg_printer.rs +0 -0
  1582. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/constant_hash.rs +0 -0
  1583. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/context.rs +0 -0
  1584. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ctxhash.rs +0 -0
  1585. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/data_value.rs +0 -0
  1586. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/dbg.rs +0 -0
  1587. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/dce.rs +0 -0
  1588. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/dominator_tree.rs +0 -0
  1589. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/egraph/cost.rs +0 -0
  1590. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/egraph/domtree.rs +0 -0
  1591. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/egraph/elaborate.rs +0 -0
  1592. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/egraph.rs +0 -0
  1593. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/flowgraph.rs +0 -0
  1594. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/fx.rs +0 -0
  1595. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/incremental_cache.rs +0 -0
  1596. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/inst_predicates.rs +0 -0
  1597. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/atomic_rmw_op.rs +0 -0
  1598. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/builder.rs +0 -0
  1599. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/condcodes.rs +0 -0
  1600. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/constant.rs +0 -0
  1601. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/dfg.rs +0 -0
  1602. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/dynamic_type.rs +0 -0
  1603. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/entities.rs +0 -0
  1604. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/extname.rs +0 -0
  1605. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/immediates.rs +0 -0
  1606. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/instructions.rs +0 -0
  1607. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/jumptable.rs +0 -0
  1608. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/known_symbol.rs +0 -0
  1609. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/layout.rs +0 -0
  1610. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/libcall.rs +0 -0
  1611. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/memflags.rs +0 -0
  1612. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/progpoint.rs +0 -0
  1613. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/sourceloc.rs +0 -0
  1614. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/stackslot.rs +0 -0
  1615. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/table.rs +0 -0
  1616. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/trapcode.rs +0 -0
  1617. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/ir/types.rs +0 -0
  1618. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/inst/args.rs +0 -0
  1619. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/inst/emit_tests.rs +0 -0
  1620. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/inst/imms.rs +0 -0
  1621. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/inst/regs.rs +0 -0
  1622. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/inst/unwind/systemv.rs +0 -0
  1623. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/inst/unwind.rs +0 -0
  1624. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/inst_neon.isle +0 -0
  1625. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/lower/isle/generated_code.rs +0 -0
  1626. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/lower.rs +0 -0
  1627. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/lower_dynamic_neon.isle +0 -0
  1628. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/mod.rs +0 -0
  1629. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/aarch64/settings.rs +0 -0
  1630. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/call_conv.rs +0 -0
  1631. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/mod.rs +0 -0
  1632. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/inst/args.rs +0 -0
  1633. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/inst/emit_tests.rs +0 -0
  1634. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/inst/encode.rs +0 -0
  1635. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/inst/imms.rs +0 -0
  1636. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/inst/regs.rs +0 -0
  1637. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/inst/unwind/systemv.rs +0 -0
  1638. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/inst/unwind.rs +0 -0
  1639. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/inst/vector.rs +0 -0
  1640. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/inst_vector.isle +0 -0
  1641. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/lower/isle/generated_code.rs +0 -0
  1642. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/lower.rs +0 -0
  1643. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/mod.rs +0 -0
  1644. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/riscv64/settings.rs +0 -0
  1645. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/abi.rs +0 -0
  1646. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/inst/args.rs +0 -0
  1647. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/inst/emit.rs +0 -0
  1648. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/inst/emit_tests.rs +0 -0
  1649. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/inst/imms.rs +0 -0
  1650. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/inst/mod.rs +0 -0
  1651. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/inst/regs.rs +0 -0
  1652. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/inst/unwind/systemv.rs +0 -0
  1653. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/inst/unwind.rs +0 -0
  1654. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/inst.isle +0 -0
  1655. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/lower/isle/generated_code.rs +0 -0
  1656. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/lower/isle.rs +0 -0
  1657. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/lower.isle +0 -0
  1658. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/lower.rs +0 -0
  1659. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/mod.rs +0 -0
  1660. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/s390x/settings.rs +0 -0
  1661. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/unwind/systemv.rs +0 -0
  1662. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/unwind/winx64.rs +0 -0
  1663. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/unwind.rs +0 -0
  1664. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/encoding/evex.rs +0 -0
  1665. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/encoding/mod.rs +0 -0
  1666. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/encoding/rex.rs +0 -0
  1667. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/encoding/vex.rs +0 -0
  1668. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/inst/args.rs +0 -0
  1669. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/inst/emit.rs +0 -0
  1670. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/inst/emit_state.rs +0 -0
  1671. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/inst/emit_tests.rs +0 -0
  1672. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/inst/mod.rs +0 -0
  1673. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/inst/regs.rs +0 -0
  1674. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/inst/unwind/systemv.rs +0 -0
  1675. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/inst/unwind/winx64.rs +0 -0
  1676. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/inst/unwind.rs +0 -0
  1677. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/inst.isle +0 -0
  1678. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/lower/isle/generated_code.rs +0 -0
  1679. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/lower/isle.rs +0 -0
  1680. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/lower.rs +0 -0
  1681. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/mod.rs +0 -0
  1682. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isa/x64/settings.rs +0 -0
  1683. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/isle_prelude.rs +0 -0
  1684. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/iterators.rs +0 -0
  1685. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/legalizer/globalvalue.rs +0 -0
  1686. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/legalizer/mod.rs +0 -0
  1687. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/legalizer/table.rs +0 -0
  1688. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/loop_analysis.rs +0 -0
  1689. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/machinst/blockorder.rs +0 -0
  1690. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/machinst/compile.rs +0 -0
  1691. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/machinst/helpers.rs +0 -0
  1692. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/machinst/inst_common.rs +0 -0
  1693. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/machinst/mod.rs +0 -0
  1694. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/machinst/reg.rs +0 -0
  1695. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/machinst/valueregs.rs +0 -0
  1696. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/nan_canonicalization.rs +0 -0
  1697. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/opts/README.md +0 -0
  1698. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/opts/arithmetic.isle +0 -0
  1699. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/opts/bitops.isle +0 -0
  1700. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/opts/extends.isle +0 -0
  1701. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/opts/generated_code.rs +0 -0
  1702. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/opts/remat.isle +0 -0
  1703. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/opts/selects.isle +0 -0
  1704. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/opts/shifts.isle +0 -0
  1705. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/opts/vector.isle +0 -0
  1706. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/opts.rs +0 -0
  1707. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/prelude.isle +0 -0
  1708. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/prelude_lower.isle +0 -0
  1709. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/prelude_opt.isle +0 -0
  1710. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/print_errors.rs +0 -0
  1711. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/remove_constant_phis.rs +0 -0
  1712. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/result.rs +0 -0
  1713. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/scoped_hash_map.rs +0 -0
  1714. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/settings.rs +0 -0
  1715. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/souper_harvest.rs +0 -0
  1716. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/timing.rs +0 -0
  1717. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/unionfind.rs +0 -0
  1718. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/unreachable_code.rs +0 -0
  1719. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/verifier/mod.rs +0 -0
  1720. /data/ext/cargo-vendor/{cranelift-codegen-0.98.1 → cranelift-codegen-0.99.1}/src/write.rs +0 -0
  1721. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/LICENSE +0 -0
  1722. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/README.md +0 -0
  1723. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/cdsl/formats.rs +0 -0
  1724. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/cdsl/instructions.rs +0 -0
  1725. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/cdsl/isa.rs +0 -0
  1726. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/cdsl/mod.rs +0 -0
  1727. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/cdsl/operands.rs +0 -0
  1728. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/cdsl/settings.rs +0 -0
  1729. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/cdsl/types.rs +0 -0
  1730. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/cdsl/typevar.rs +0 -0
  1731. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/constant_hash.rs +0 -0
  1732. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/error.rs +0 -0
  1733. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/gen_settings.rs +0 -0
  1734. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/gen_types.rs +0 -0
  1735. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/shared/entities.rs +0 -0
  1736. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/shared/formats.rs +0 -0
  1737. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/shared/immediates.rs +0 -0
  1738. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/shared/instructions.rs +0 -0
  1739. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/shared/settings.rs +0 -0
  1740. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/shared/types.rs +0 -0
  1741. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/srcgen.rs +0 -0
  1742. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.98.1 → cranelift-codegen-meta-0.99.1}/src/unique_table.rs +0 -0
  1743. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.98.1 → cranelift-codegen-shared-0.99.1}/LICENSE +0 -0
  1744. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.98.1 → cranelift-codegen-shared-0.99.1}/README.md +0 -0
  1745. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.98.1 → cranelift-codegen-shared-0.99.1}/src/constant_hash.rs +0 -0
  1746. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.98.1 → cranelift-codegen-shared-0.99.1}/src/constants.rs +0 -0
  1747. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.98.1 → cranelift-codegen-shared-0.99.1}/src/lib.rs +0 -0
  1748. /data/ext/cargo-vendor/{cranelift-control-0.98.1 → cranelift-control-0.99.1}/LICENSE +0 -0
  1749. /data/ext/cargo-vendor/{cranelift-control-0.98.1 → cranelift-control-0.99.1}/README.md +0 -0
  1750. /data/ext/cargo-vendor/{cranelift-control-0.98.1 → cranelift-control-0.99.1}/src/chaos.rs +0 -0
  1751. /data/ext/cargo-vendor/{cranelift-control-0.98.1 → cranelift-control-0.99.1}/src/lib.rs +0 -0
  1752. /data/ext/cargo-vendor/{cranelift-control-0.98.1 → cranelift-control-0.99.1}/src/zero_sized.rs +0 -0
  1753. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/LICENSE +0 -0
  1754. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/README.md +0 -0
  1755. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/src/boxed_slice.rs +0 -0
  1756. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/src/iter.rs +0 -0
  1757. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/src/keys.rs +0 -0
  1758. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/src/lib.rs +0 -0
  1759. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/src/list.rs +0 -0
  1760. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/src/map.rs +0 -0
  1761. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/src/packed_option.rs +0 -0
  1762. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/src/primary.rs +0 -0
  1763. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/src/set.rs +0 -0
  1764. /data/ext/cargo-vendor/{cranelift-entity-0.98.1 → cranelift-entity-0.99.1}/src/sparse.rs +0 -0
  1765. /data/ext/cargo-vendor/{cranelift-frontend-0.98.1 → cranelift-frontend-0.99.1}/LICENSE +0 -0
  1766. /data/ext/cargo-vendor/{cranelift-frontend-0.98.1 → cranelift-frontend-0.99.1}/README.md +0 -0
  1767. /data/ext/cargo-vendor/{cranelift-frontend-0.98.1 → cranelift-frontend-0.99.1}/src/frontend.rs +0 -0
  1768. /data/ext/cargo-vendor/{cranelift-frontend-0.98.1 → cranelift-frontend-0.99.1}/src/ssa.rs +0 -0
  1769. /data/ext/cargo-vendor/{cranelift-frontend-0.98.1 → cranelift-frontend-0.99.1}/src/switch.rs +0 -0
  1770. /data/ext/cargo-vendor/{cranelift-frontend-0.98.1 → cranelift-frontend-0.99.1}/src/variable.rs +0 -0
  1771. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/README.md +0 -0
  1772. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/build.rs +0 -0
  1773. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/fail/bad_converters.isle +0 -0
  1774. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/fail/bound_var_type_mismatch.isle +0 -0
  1775. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/fail/converter_extractor_constructor.isle +0 -0
  1776. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/fail/error1.isle +0 -0
  1777. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/fail/extra_parens.isle +0 -0
  1778. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/fail/impure_expression.isle +0 -0
  1779. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/fail/impure_rhs.isle +0 -0
  1780. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/fail/multi_internal_etor.isle +0 -0
  1781. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/fail/multi_prio.isle +0 -0
  1782. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/link/borrows.isle +0 -0
  1783. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/link/borrows_main.rs +0 -0
  1784. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/link/iflets.isle +0 -0
  1785. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/link/iflets_main.rs +0 -0
  1786. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/link/multi_constructor.isle +0 -0
  1787. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/link/multi_constructor_main.rs +0 -0
  1788. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/link/multi_extractor.isle +0 -0
  1789. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/link/multi_extractor_main.rs +0 -0
  1790. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/link/test.isle +0 -0
  1791. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/link/test_main.rs +0 -0
  1792. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/pass/bound_var.isle +0 -0
  1793. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/pass/construct_and_extract.isle +0 -0
  1794. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/pass/conversions.isle +0 -0
  1795. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/pass/conversions_extern.isle +0 -0
  1796. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/pass/let.isle +0 -0
  1797. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/pass/nodebug.isle +0 -0
  1798. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/pass/prio_trie_bug.isle +0 -0
  1799. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/pass/test2.isle +0 -0
  1800. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/pass/test3.isle +0 -0
  1801. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/pass/test4.isle +0 -0
  1802. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/pass/tutorial.isle +0 -0
  1803. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/run/iconst.isle +0 -0
  1804. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/run/iconst_main.rs +0 -0
  1805. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/run/let_shadowing.isle +0 -0
  1806. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/isle_examples/run/let_shadowing_main.rs +0 -0
  1807. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/ast.rs +0 -0
  1808. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/codegen.rs +0 -0
  1809. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/compile.rs +0 -0
  1810. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/error.rs +0 -0
  1811. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/lexer.rs +0 -0
  1812. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/lib.rs +0 -0
  1813. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/log.rs +0 -0
  1814. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/overlap.rs +0 -0
  1815. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/parser.rs +0 -0
  1816. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/sema.rs +0 -0
  1817. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/serialize.rs +0 -0
  1818. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/src/trie_again.rs +0 -0
  1819. /data/ext/cargo-vendor/{cranelift-isle-0.98.1 → cranelift-isle-0.99.1}/tests/run_tests.rs +0 -0
  1820. /data/ext/cargo-vendor/{cranelift-native-0.98.1 → cranelift-native-0.99.1}/LICENSE +0 -0
  1821. /data/ext/cargo-vendor/{cranelift-native-0.98.1 → cranelift-native-0.99.1}/README.md +0 -0
  1822. /data/ext/cargo-vendor/{cranelift-native-0.98.1 → cranelift-native-0.99.1}/src/lib.rs +0 -0
  1823. /data/ext/cargo-vendor/{cranelift-native-0.98.1 → cranelift-native-0.99.1}/src/riscv.rs +0 -0
  1824. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/LICENSE +0 -0
  1825. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/README.md +0 -0
  1826. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/src/code_translator/bounds_checks.rs +0 -0
  1827. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/src/environ/mod.rs +0 -0
  1828. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/src/heap.rs +0 -0
  1829. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/src/lib.rs +0 -0
  1830. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/src/module_translator.rs +0 -0
  1831. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/src/state.rs +0 -0
  1832. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/src/translation_utils.rs +0 -0
  1833. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/arith.wat +0 -0
  1834. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/br_table.wat +0 -0
  1835. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/call-simd.wat +0 -0
  1836. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/call.wat +0 -0
  1837. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/embenchen_fannkuch.wat +0 -0
  1838. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/embenchen_fasta.wat +0 -0
  1839. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/embenchen_ifs.wat +0 -0
  1840. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/embenchen_primes.wat +0 -0
  1841. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/fac-multi-value.wat +0 -0
  1842. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/fibonacci.wat +0 -0
  1843. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/globals.wat +0 -0
  1844. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/icall-simd.wat +0 -0
  1845. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/icall.wat +0 -0
  1846. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/if-reachability-translation-0.wat +0 -0
  1847. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/if-reachability-translation-1.wat +0 -0
  1848. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/if-reachability-translation-2.wat +0 -0
  1849. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/if-reachability-translation-3.wat +0 -0
  1850. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/if-reachability-translation-4.wat +0 -0
  1851. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/if-reachability-translation-5.wat +0 -0
  1852. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/if-reachability-translation-6.wat +0 -0
  1853. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/if-unreachable-else-params-2.wat +0 -0
  1854. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/if-unreachable-else-params.wat +0 -0
  1855. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/issue-1306-name-section-with-u32-max-function-index.wasm +0 -0
  1856. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/memory.wat +0 -0
  1857. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-0.wat +0 -0
  1858. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-1.wat +0 -0
  1859. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-10.wat +0 -0
  1860. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-11.wat +0 -0
  1861. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-12.wat +0 -0
  1862. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-13.wat +0 -0
  1863. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-14.wat +0 -0
  1864. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-15.wat +0 -0
  1865. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-16.wat +0 -0
  1866. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-17.wat +0 -0
  1867. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-2.wat +0 -0
  1868. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-3.wat +0 -0
  1869. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-4.wat +0 -0
  1870. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-5.wat +0 -0
  1871. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-6.wat +0 -0
  1872. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-7.wat +0 -0
  1873. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-8.wat +0 -0
  1874. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/multi-9.wat +0 -0
  1875. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/nullref.wat +0 -0
  1876. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/passive-data.wat +0 -0
  1877. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/pr2303.wat +0 -0
  1878. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/pr2559.wat +0 -0
  1879. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/ref-func-0.wat +0 -0
  1880. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/rust_fannkuch.wat +0 -0
  1881. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/select.wat +0 -0
  1882. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/simd-store.wat +0 -0
  1883. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/simd.wat +0 -0
  1884. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/table-copy.wat +0 -0
  1885. /data/ext/cargo-vendor/{cranelift-wasm-0.98.1 → cranelift-wasm-0.99.1}/wasmtests/unreachable_code.wat +0 -0
  1886. /data/ext/cargo-vendor/{fs-set-times-0.19.2 → fs-set-times-0.20.0}/CODE_OF_CONDUCT.md +0 -0
  1887. /data/ext/cargo-vendor/{fs-set-times-0.19.2 → fs-set-times-0.20.0}/COPYRIGHT +0 -0
  1888. /data/ext/cargo-vendor/{fs-set-times-0.19.2 → fs-set-times-0.20.0}/LICENSE-APACHE +0 -0
  1889. /data/ext/cargo-vendor/{fs-set-times-0.19.2 → fs-set-times-0.20.0}/LICENSE-Apache-2.0_WITH_LLVM-exception +0 -0
  1890. /data/ext/cargo-vendor/{fs-set-times-0.19.2 → fs-set-times-0.20.0}/LICENSE-MIT +0 -0
  1891. /data/ext/cargo-vendor/{fs-set-times-0.19.2 → fs-set-times-0.20.0}/ORG_CODE_OF_CONDUCT.md +0 -0
  1892. /data/ext/cargo-vendor/{fs-set-times-0.19.2 → fs-set-times-0.20.0}/README.md +0 -0
  1893. /data/ext/cargo-vendor/{fs-set-times-0.19.2 → fs-set-times-0.20.0}/SECURITY.md +0 -0
  1894. /data/ext/cargo-vendor/{fs-set-times-0.19.2 → fs-set-times-0.20.0}/src/lib.rs +0 -0
  1895. /data/ext/cargo-vendor/{fs-set-times-0.19.2 → fs-set-times-0.20.0}/src/set_times.rs +0 -0
  1896. /data/ext/cargo-vendor/{fs-set-times-0.19.2 → fs-set-times-0.20.0}/src/system_time_spec.rs +0 -0
  1897. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/CODE_OF_CONDUCT.md +0 -0
  1898. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/COPYRIGHT +0 -0
  1899. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/LICENSE-APACHE +0 -0
  1900. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/LICENSE-Apache-2.0_WITH_LLVM-exception +0 -0
  1901. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/LICENSE-MIT +0 -0
  1902. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/ORG_CODE_OF_CONDUCT.md +0 -0
  1903. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/SECURITY.md +0 -0
  1904. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/src/borrowed.rs +0 -0
  1905. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/src/grip.rs +0 -0
  1906. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/src/lib.rs +0 -0
  1907. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/src/os/mod.rs +0 -0
  1908. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/src/os/rustix.rs +0 -0
  1909. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/src/os/windows/mod.rs +0 -0
  1910. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/src/os/windows/traits.rs +0 -0
  1911. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/src/os/windows/types.rs +0 -0
  1912. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/src/owned.rs +0 -0
  1913. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/src/raw.rs +0 -0
  1914. /data/ext/cargo-vendor/{io-extras-0.17.4 → io-extras-0.18.0}/src/read_write.rs +0 -0
  1915. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/LICENSE-APACHE +0 -0
  1916. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/LICENSE-MIT +0 -0
  1917. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/archive.rs +0 -0
  1918. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/pod.rs +0 -0
  1919. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/archive.rs +0 -0
  1920. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/coff/mod.rs +0 -0
  1921. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/elf/compression.rs +0 -0
  1922. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/elf/dynamic.rs +0 -0
  1923. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/elf/relocation.rs +0 -0
  1924. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/macho/fat.rs +0 -0
  1925. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/macho/mod.rs +0 -0
  1926. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/pe/export.rs +0 -0
  1927. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/pe/import.rs +0 -0
  1928. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/pe/mod.rs +0 -0
  1929. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/pe/relocation.rs +0 -0
  1930. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/xcoff/file.rs +0 -0
  1931. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/read/xcoff/mod.rs +0 -0
  1932. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/write/elf/mod.rs +0 -0
  1933. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/src/write/pe.rs +0 -0
  1934. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/tests/integration.rs +0 -0
  1935. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/tests/parse_self.rs +0 -0
  1936. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/tests/read/mod.rs +0 -0
  1937. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/tests/round_trip/bss.rs +0 -0
  1938. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/tests/round_trip/coff.rs +0 -0
  1939. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/tests/round_trip/comdat.rs +0 -0
  1940. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/tests/round_trip/common.rs +0 -0
  1941. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/tests/round_trip/section_flags.rs +0 -0
  1942. /data/ext/cargo-vendor/{object-0.30.4 → object-0.31.1}/tests/round_trip/tls.rs +0 -0
  1943. /data/ext/cargo-vendor/{pulldown-cmark-0.8.0 → pulldown-cmark-0.9.3}/LICENSE +0 -0
  1944. /data/ext/cargo-vendor/{pulldown-cmark-0.8.0 → pulldown-cmark-0.9.3}/src/entities.rs +0 -0
  1945. /data/ext/cargo-vendor/{pulldown-cmark-0.8.0 → pulldown-cmark-0.9.3}/tests/suite/footnotes.rs +0 -0
  1946. /data/ext/cargo-vendor/{pulldown-cmark-0.8.0 → pulldown-cmark-0.9.3}/tests/suite/gfm_tasklist.rs +0 -0
  1947. /data/ext/cargo-vendor/{pulldown-cmark-0.8.0 → pulldown-cmark-0.9.3}/tests/suite/smart_punct.rs +0 -0
  1948. /data/ext/cargo-vendor/{pulldown-cmark-0.8.0 → pulldown-cmark-0.9.3}/tests/suite/table.rs +0 -0
  1949. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/CODE_OF_CONDUCT.md +0 -0
  1950. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/COPYRIGHT +0 -0
  1951. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/LICENSE-APACHE +0 -0
  1952. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/LICENSE-Apache-2.0_WITH_LLVM-exception +0 -0
  1953. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/LICENSE-MIT +0 -0
  1954. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/ORG_CODE_OF_CONDUCT.md +0 -0
  1955. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/README.md +0 -0
  1956. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/SECURITY.md +0 -0
  1957. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/src/fs/fd_flags.rs +0 -0
  1958. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/src/fs/mod.rs +0 -0
  1959. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/src/io/io_ext.rs +0 -0
  1960. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/src/io/is_read_write.rs +0 -0
  1961. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/src/io/mod.rs +0 -0
  1962. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/src/io/peek.rs +0 -0
  1963. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/src/io/read_ready.rs +0 -0
  1964. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/src/lib.rs +0 -0
  1965. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/tests/allocate.rs +0 -0
  1966. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/tests/append.rs +0 -0
  1967. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/tests/fd_flags.rs +0 -0
  1968. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/tests/is_read_write.rs +0 -0
  1969. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/tests/live_rename.rs +0 -0
  1970. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/tests/peek.rs +0 -0
  1971. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/tests/read_ready.rs +0 -0
  1972. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/tests/read_to_end.rs +0 -0
  1973. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/tests/sys_common/io.rs +0 -0
  1974. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/tests/sys_common/mod.rs +0 -0
  1975. /data/ext/cargo-vendor/{system-interface-0.25.9 → system-interface-0.26.0}/tests/vectored_at.rs +0 -0
  1976. /data/ext/cargo-vendor/{wasi-cap-std-sync-11.0.0 → wasi-cap-std-sync-12.0.0}/LICENSE +0 -0
  1977. /data/ext/cargo-vendor/{wasi-cap-std-sync-11.0.0 → wasi-cap-std-sync-12.0.0}/README.md +0 -0
  1978. /data/ext/cargo-vendor/{wasi-cap-std-sync-11.0.0 → wasi-cap-std-sync-12.0.0}/src/clocks.rs +0 -0
  1979. /data/ext/cargo-vendor/{wasi-cap-std-sync-11.0.0 → wasi-cap-std-sync-12.0.0}/src/dir.rs +0 -0
  1980. /data/ext/cargo-vendor/{wasi-cap-std-sync-11.0.0 → wasi-cap-std-sync-12.0.0}/src/file.rs +0 -0
  1981. /data/ext/cargo-vendor/{wasi-cap-std-sync-11.0.0 → wasi-cap-std-sync-12.0.0}/src/lib.rs +0 -0
  1982. /data/ext/cargo-vendor/{wasi-cap-std-sync-11.0.0 → wasi-cap-std-sync-12.0.0}/src/net.rs +0 -0
  1983. /data/ext/cargo-vendor/{wasi-cap-std-sync-11.0.0 → wasi-cap-std-sync-12.0.0}/src/sched/windows.rs +0 -0
  1984. /data/ext/cargo-vendor/{wasi-cap-std-sync-11.0.0 → wasi-cap-std-sync-12.0.0}/src/sched.rs +0 -0
  1985. /data/ext/cargo-vendor/{wasi-cap-std-sync-11.0.0 → wasi-cap-std-sync-12.0.0}/src/stdio.rs +0 -0
  1986. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/LICENSE +0 -0
  1987. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/README.md +0 -0
  1988. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/README.md +0 -0
  1989. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/docs/README.md +0 -0
  1990. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/README.md +0 -0
  1991. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/docs.md +0 -0
  1992. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/witx/typenames.witx +0 -0
  1993. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_args.witx +0 -0
  1994. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_clock.witx +0 -0
  1995. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_environ.witx +0 -0
  1996. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_fd.witx +0 -0
  1997. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_path.witx +0 -0
  1998. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_poll.witx +0 -0
  1999. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_proc.witx +0 -0
  2000. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_random.witx +0 -0
  2001. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_sched.witx +0 -0
  2002. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_sock.witx +0 -0
  2003. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/old/snapshot_0/docs.md +0 -0
  2004. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/old/snapshot_0/witx/typenames.witx +0 -0
  2005. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/old/snapshot_0/witx/wasi_unstable.witx +0 -0
  2006. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/snapshot/docs.html +0 -0
  2007. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/snapshot/docs.md +0 -0
  2008. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/snapshot/witx/typenames.witx +0 -0
  2009. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/phases/snapshot/witx/wasi_snapshot_preview1.witx +0 -0
  2010. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/proposal-template/README.md +0 -0
  2011. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/proposals/README.md +0 -0
  2012. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/snapshots/README.md +0 -0
  2013. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/WASI/standard/README.md +0 -0
  2014. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/build.rs +0 -0
  2015. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/clocks.rs +0 -0
  2016. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/ctx.rs +0 -0
  2017. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/dir.rs +0 -0
  2018. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/error.rs +0 -0
  2019. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/lib.rs +0 -0
  2020. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/pipe.rs +0 -0
  2021. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/random.rs +0 -0
  2022. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/sched.rs +0 -0
  2023. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/snapshots/mod.rs +0 -0
  2024. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/snapshots/preview_0.rs +0 -0
  2025. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/snapshots/preview_1.rs +0 -0
  2026. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/string_array.rs +0 -0
  2027. /data/ext/cargo-vendor/{wasi-common-11.0.0 → wasi-common-12.0.0}/src/table.rs +0 -0
  2028. /data/ext/cargo-vendor/{wasm-encoder-0.29.0 → wasmparser-0.110.0}/LICENSE +0 -0
  2029. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/README.md +0 -0
  2030. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/examples/simple.rs +0 -0
  2031. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/binary_reader.rs +0 -0
  2032. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/component/aliases.rs +0 -0
  2033. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/component/exports.rs +0 -0
  2034. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/component/imports.rs +0 -0
  2035. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/component/instances.rs +0 -0
  2036. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/component/names.rs +0 -0
  2037. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/component/start.rs +0 -0
  2038. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/component.rs +0 -0
  2039. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/code.rs +0 -0
  2040. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/coredumps.rs +0 -0
  2041. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/custom.rs +0 -0
  2042. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/data.rs +0 -0
  2043. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/exports.rs +0 -0
  2044. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/functions.rs +0 -0
  2045. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/globals.rs +0 -0
  2046. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/imports.rs +0 -0
  2047. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/init.rs +0 -0
  2048. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/memories.rs +0 -0
  2049. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/names.rs +0 -0
  2050. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/operators.rs +0 -0
  2051. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/producers.rs +0 -0
  2052. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/tables.rs +0 -0
  2053. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core/tags.rs +0 -0
  2054. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers/core.rs +0 -0
  2055. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/readers.rs +0 -0
  2056. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/resources.rs +0 -0
  2057. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/validator/func.rs +0 -0
  2058. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmparser-0.110.0}/src/validator/names.rs +0 -0
  2059. /data/ext/cargo-vendor/{wasmparser-0.107.0 → wasmtime-12.0.0}/LICENSE +0 -0
  2060. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/code.rs +0 -0
  2061. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/component/storage.rs +0 -0
  2062. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/component/store.rs +0 -0
  2063. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/engine.rs +0 -0
  2064. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/func/typed.rs +0 -0
  2065. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/limits.rs +0 -0
  2066. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/linker.rs +0 -0
  2067. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/profiling.rs +0 -0
  2068. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/ref.rs +0 -0
  2069. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/signatures.rs +0 -0
  2070. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/store/context.rs +0 -0
  2071. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/trampoline/func.rs +0 -0
  2072. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/trampoline/global.rs +0 -0
  2073. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/trampoline/memory.rs +0 -0
  2074. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/trampoline/table.rs +0 -0
  2075. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/trampoline.rs +0 -0
  2076. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/types/matching.rs +0 -0
  2077. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/types.rs +0 -0
  2078. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/unix.rs +0 -0
  2079. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/values.rs +0 -0
  2080. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-12.0.0}/src/windows.rs +0 -0
  2081. /data/ext/cargo-vendor/{wasmtime-asm-macros-11.0.0 → wasmtime-asm-macros-12.0.0}/src/lib.rs +0 -0
  2082. /data/ext/cargo-vendor/{wasmtime-11.0.0 → wasmtime-cache-12.0.0}/LICENSE +0 -0
  2083. /data/ext/cargo-vendor/{wasmtime-cache-11.0.0 → wasmtime-cache-12.0.0}/build.rs +0 -0
  2084. /data/ext/cargo-vendor/{wasmtime-cache-11.0.0 → wasmtime-cache-12.0.0}/src/config/tests.rs +0 -0
  2085. /data/ext/cargo-vendor/{wasmtime-cache-11.0.0 → wasmtime-cache-12.0.0}/src/config.rs +0 -0
  2086. /data/ext/cargo-vendor/{wasmtime-cache-11.0.0 → wasmtime-cache-12.0.0}/src/lib.rs +0 -0
  2087. /data/ext/cargo-vendor/{wasmtime-cache-11.0.0 → wasmtime-cache-12.0.0}/src/tests.rs +0 -0
  2088. /data/ext/cargo-vendor/{wasmtime-cache-11.0.0 → wasmtime-cache-12.0.0}/src/worker/tests/system_time_stub.rs +0 -0
  2089. /data/ext/cargo-vendor/{wasmtime-cache-11.0.0 → wasmtime-cache-12.0.0}/src/worker/tests.rs +0 -0
  2090. /data/ext/cargo-vendor/{wasmtime-cache-11.0.0 → wasmtime-cache-12.0.0}/src/worker.rs +0 -0
  2091. /data/ext/cargo-vendor/{wasmtime-cache-11.0.0 → wasmtime-cache-12.0.0}/tests/cache_write_default_config.rs +0 -0
  2092. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/src/lib.rs +0 -0
  2093. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/char.wit +0 -0
  2094. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/conventions.wit +0 -0
  2095. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/direct-import.wit +0 -0
  2096. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/empty.wit +0 -0
  2097. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/flags.wit +0 -0
  2098. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/floats.wit +0 -0
  2099. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/function-new.wit +0 -0
  2100. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/integers.wit +0 -0
  2101. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/lists.wit +0 -0
  2102. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/many-arguments.wit +0 -0
  2103. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/multi-return.wit +0 -0
  2104. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/records.wit +0 -0
  2105. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/rename.wit +0 -0
  2106. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/share-types.wit +0 -0
  2107. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/simple-functions.wit +0 -0
  2108. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/simple-lists.wit +0 -0
  2109. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/simple-wasi.wit +0 -0
  2110. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/small-anonymous.wit +0 -0
  2111. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/smoke-default.wit +0 -0
  2112. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/smoke-export.wit +0 -0
  2113. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/smoke.wit +0 -0
  2114. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/strings.wit +0 -0
  2115. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/unions.wit +0 -0
  2116. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/use-paths.wit +0 -0
  2117. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/variants.wit +0 -0
  2118. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen/worlds-with-types.wit +0 -0
  2119. /data/ext/cargo-vendor/{wasmtime-component-macro-11.0.0 → wasmtime-component-macro-12.0.0}/tests/codegen.rs +0 -0
  2120. /data/ext/cargo-vendor/{wasmtime-component-util-11.0.0 → wasmtime-component-util-12.0.0}/src/lib.rs +0 -0
  2121. /data/ext/cargo-vendor/{wasmtime-cache-11.0.0 → wasmtime-cranelift-12.0.0}/LICENSE +0 -0
  2122. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-cranelift-12.0.0}/SECURITY.md +0 -0
  2123. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-cranelift-12.0.0}/src/debug/gc.rs +0 -0
  2124. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-cranelift-12.0.0}/src/debug/transform/address_transform.rs +0 -0
  2125. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-cranelift-12.0.0}/src/debug/transform/attr.rs +0 -0
  2126. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-cranelift-12.0.0}/src/debug/transform/line_program.rs +0 -0
  2127. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-cranelift-12.0.0}/src/debug/transform/mod.rs +0 -0
  2128. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-cranelift-12.0.0}/src/debug/transform/range_info_builder.rs +0 -0
  2129. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-cranelift-12.0.0}/src/debug/transform/refs.rs +0 -0
  2130. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-cranelift-12.0.0}/src/debug/transform/simulate.rs +0 -0
  2131. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-cranelift-12.0.0}/src/debug/write_debuginfo.rs +0 -0
  2132. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-cranelift-12.0.0}/src/debug.rs +0 -0
  2133. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-11.0.0 → wasmtime-cranelift-shared-12.0.0}/src/compiled_function.rs +0 -0
  2134. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-11.0.0 → wasmtime-cranelift-shared-12.0.0}/src/isa_builder.rs +0 -0
  2135. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-11.0.0 → wasmtime-cranelift-shared-12.0.0}/src/obj.rs +0 -0
  2136. /data/ext/cargo-vendor/{wasmtime-cranelift-11.0.0 → wasmtime-environ-12.0.0}/LICENSE +0 -0
  2137. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/address_map.rs +0 -0
  2138. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/builtin.rs +0 -0
  2139. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/fact/core_types.rs +0 -0
  2140. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/fact/traps.rs +0 -0
  2141. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/lib.rs +0 -0
  2142. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/module.rs +0 -0
  2143. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/module_types.rs +0 -0
  2144. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/obj.rs +0 -0
  2145. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/ref_bits.rs +0 -0
  2146. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/scopevec.rs +0 -0
  2147. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/stack_map.rs +0 -0
  2148. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-environ-12.0.0}/src/vmoffsets.rs +0 -0
  2149. /data/ext/cargo-vendor/{wasmtime-environ-11.0.0 → wasmtime-fiber-12.0.0}/LICENSE +0 -0
  2150. /data/ext/cargo-vendor/{wasmtime-fiber-11.0.0 → wasmtime-fiber-12.0.0}/src/lib.rs +0 -0
  2151. /data/ext/cargo-vendor/{wasmtime-fiber-11.0.0 → wasmtime-fiber-12.0.0}/src/unix/x86.rs +0 -0
  2152. /data/ext/cargo-vendor/{wasmtime-fiber-11.0.0 → wasmtime-jit-12.0.0}/LICENSE +0 -0
  2153. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/code_memory.rs +0 -0
  2154. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/debug.rs +0 -0
  2155. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/demangling.rs +0 -0
  2156. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/instantiate.rs +0 -0
  2157. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/lib.rs +0 -0
  2158. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/profiling/jitdump.rs +0 -0
  2159. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/profiling/perfmap.rs +0 -0
  2160. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/profiling/vtune.rs +0 -0
  2161. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/unwind/miri.rs +0 -0
  2162. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/unwind/systemv.rs +0 -0
  2163. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/unwind/winx64.rs +0 -0
  2164. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-jit-12.0.0}/src/unwind.rs +0 -0
  2165. /data/ext/cargo-vendor/{wasmtime-jit-debug-11.0.0 → wasmtime-jit-debug-12.0.0}/README.md +0 -0
  2166. /data/ext/cargo-vendor/{wasmtime-jit-debug-11.0.0 → wasmtime-jit-debug-12.0.0}/src/lib.rs +0 -0
  2167. /data/ext/cargo-vendor/{wasmtime-jit-debug-11.0.0 → wasmtime-jit-debug-12.0.0}/src/perf_jitdump.rs +0 -0
  2168. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-11.0.0 → wasmtime-jit-icache-coherence-12.0.0}/src/lib.rs +0 -0
  2169. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-11.0.0 → wasmtime-jit-icache-coherence-12.0.0}/src/libc.rs +0 -0
  2170. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-11.0.0 → wasmtime-jit-icache-coherence-12.0.0}/src/miri.rs +0 -0
  2171. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-11.0.0 → wasmtime-jit-icache-coherence-12.0.0}/src/win.rs +0 -0
  2172. /data/ext/cargo-vendor/{wasmtime-jit-11.0.0 → wasmtime-runtime-12.0.0}/LICENSE +0 -0
  2173. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/cow.rs +0 -0
  2174. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/export.rs +0 -0
  2175. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/externref.rs +0 -0
  2176. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/imports.rs +0 -0
  2177. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/instance/allocator/pooling/index_allocator.rs +0 -0
  2178. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/instance/allocator/pooling/unix.rs +0 -0
  2179. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/instance/allocator/pooling/windows.rs +0 -0
  2180. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/instance/allocator/pooling.rs +0 -0
  2181. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/instance.rs +0 -0
  2182. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/memory.rs +0 -0
  2183. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/mmap/miri.rs +0 -0
  2184. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/mmap/windows.rs +0 -0
  2185. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/mmap.rs +0 -0
  2186. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/mmap_vec.rs +0 -0
  2187. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/module_id.rs +0 -0
  2188. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/parking_spot.rs +0 -0
  2189. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/store_box.rs +0 -0
  2190. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/table.rs +0 -0
  2191. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/trampolines/s390x.rs +0 -0
  2192. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/trampolines.rs +0 -0
  2193. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/traphandlers/backtrace/aarch64.rs +0 -0
  2194. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/traphandlers/backtrace/riscv64.rs +0 -0
  2195. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/traphandlers/backtrace/s390x.rs +0 -0
  2196. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/traphandlers/backtrace/x86_64.rs +0 -0
  2197. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/traphandlers/backtrace.rs +0 -0
  2198. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/traphandlers/macos.rs +0 -0
  2199. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/traphandlers/windows.rs +0 -0
  2200. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/vmcontext/vm_host_func_context.rs +0 -0
  2201. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-runtime-12.0.0}/src/vmcontext.rs +0 -0
  2202. /data/ext/cargo-vendor/{wasmtime-runtime-11.0.0 → wasmtime-types-12.0.1}/LICENSE +0 -0
  2203. /data/ext/cargo-vendor/{wasmtime-types-11.0.1 → wasmtime-types-12.0.1}/src/error.rs +0 -0
  2204. /data/ext/cargo-vendor/{wasmtime-types-11.0.1 → wasmtime-wasi-12.0.0}/LICENSE +0 -0
  2205. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/README.md +0 -0
  2206. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/build.rs +0 -0
  2207. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/src/lib.rs +0 -0
  2208. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/src/preview2/clocks/host.rs +0 -0
  2209. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/src/preview2/clocks.rs +0 -0
  2210. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/src/preview2/error.rs +0 -0
  2211. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/src/preview2/random.rs +0 -0
  2212. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/clocks/monotonic-clock.wit +0 -0
  2213. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/clocks/timezone.wit +0 -0
  2214. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/clocks/wall-clock.wit +0 -0
  2215. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/filesystem/filesystem.wit +0 -0
  2216. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/http/incoming-handler.wit +0 -0
  2217. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/http/outgoing-handler.wit +0 -0
  2218. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/http/types.wit +0 -0
  2219. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/logging/handler.wit +0 -0
  2220. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/poll/poll.wit +0 -0
  2221. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/preview/command-extended.wit +0 -0
  2222. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/preview/command.wit +0 -0
  2223. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/preview/proxy.wit +0 -0
  2224. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/preview/reactor.wit +0 -0
  2225. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/random/insecure-seed.wit +0 -0
  2226. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/random/insecure.wit +0 -0
  2227. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/random/random.wit +0 -0
  2228. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/sockets/instance-network.wit +0 -0
  2229. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/sockets/ip-name-lookup.wit +0 -0
  2230. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/sockets/network.wit +0 -0
  2231. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/sockets/tcp-create-socket.wit +0 -0
  2232. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/sockets/tcp.wit +0 -0
  2233. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/sockets/udp-create-socket.wit +0 -0
  2234. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/sockets/udp.wit +0 -0
  2235. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/wasi-cli-base/environment.wit +0 -0
  2236. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/wasi-cli-base/exit.wit +0 -0
  2237. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/wasi-cli-base/preopens.wit +0 -0
  2238. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/deps/wasi-cli-base/stdio.wit +0 -0
  2239. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/wit/main.wit +0 -0
  2240. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/witx/typenames.witx +0 -0
  2241. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wasmtime-wasi-12.0.0}/witx/wasi_snapshot_preview1.witx +0 -0
  2242. /data/ext/cargo-vendor/{wasmtime-winch-11.0.0 → wasmtime-winch-12.0.0}/LICENSE +0 -0
  2243. /data/ext/cargo-vendor/{wasmtime-winch-11.0.0 → wasmtime-winch-12.0.0}/src/lib.rs +0 -0
  2244. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-11.0.0 → wasmtime-wit-bindgen-12.0.0}/src/source.rs +0 -0
  2245. /data/ext/cargo-vendor/{wasmtime-wasi-11.0.0 → wiggle-12.0.0}/LICENSE +0 -0
  2246. /data/ext/cargo-vendor/{wiggle-11.0.0 → wiggle-12.0.0}/README.md +0 -0
  2247. /data/ext/cargo-vendor/{wiggle-11.0.0 → wiggle-12.0.0}/src/borrow.rs +0 -0
  2248. /data/ext/cargo-vendor/{wiggle-11.0.0 → wiggle-12.0.0}/src/error.rs +0 -0
  2249. /data/ext/cargo-vendor/{wiggle-11.0.0 → wiggle-12.0.0}/src/guest_type.rs +0 -0
  2250. /data/ext/cargo-vendor/{wiggle-11.0.0 → wiggle-12.0.0}/src/lib.rs +0 -0
  2251. /data/ext/cargo-vendor/{wiggle-11.0.0 → wiggle-12.0.0}/src/region.rs +0 -0
  2252. /data/ext/cargo-vendor/{wiggle-11.0.0 → wiggle-12.0.0}/src/wasmtime.rs +0 -0
  2253. /data/ext/cargo-vendor/{wiggle-11.0.0 → wiggle-generate-12.0.0}/LICENSE +0 -0
  2254. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/README.md +0 -0
  2255. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/codegen_settings.rs +0 -0
  2256. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/funcs.rs +0 -0
  2257. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/lib.rs +0 -0
  2258. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/lifetimes.rs +0 -0
  2259. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/module_trait.rs +0 -0
  2260. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/names.rs +0 -0
  2261. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/types/error.rs +0 -0
  2262. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/types/handle.rs +0 -0
  2263. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/types/mod.rs +0 -0
  2264. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/types/record.rs +0 -0
  2265. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/types/variant.rs +0 -0
  2266. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-generate-12.0.0}/src/wasmtime.rs +0 -0
  2267. /data/ext/cargo-vendor/{wiggle-generate-11.0.0 → wiggle-macro-12.0.0}/LICENSE +0 -0
  2268. /data/ext/cargo-vendor/{wiggle-macro-11.0.0 → wiggle-macro-12.0.0}/src/lib.rs +0 -0
  2269. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/LICENSE +0 -0
  2270. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/build.rs +0 -0
  2271. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/abi/local.rs +0 -0
  2272. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/abi/mod.rs +0 -0
  2273. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/codegen/call.rs +0 -0
  2274. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/frame/mod.rs +0 -0
  2275. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/aarch64/abi.rs +0 -0
  2276. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/aarch64/address.rs +0 -0
  2277. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/aarch64/asm.rs +0 -0
  2278. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/aarch64/masm.rs +0 -0
  2279. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/aarch64/mod.rs +0 -0
  2280. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/aarch64/regs.rs +0 -0
  2281. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/mod.rs +0 -0
  2282. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/reg.rs +0 -0
  2283. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/x64/abi.rs +0 -0
  2284. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/x64/address.rs +0 -0
  2285. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/x64/asm.rs +0 -0
  2286. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/x64/masm.rs +0 -0
  2287. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/x64/mod.rs +0 -0
  2288. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/isa/x64/regs.rs +0 -0
  2289. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/lib.rs +0 -0
  2290. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/masm.rs +0 -0
  2291. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/regalloc.rs +0 -0
  2292. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/regset.rs +0 -0
  2293. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/stack.rs +0 -0
  2294. /data/ext/cargo-vendor/{winch-codegen-0.9.0 → winch-codegen-0.10.0}/src/trampoline.rs +0 -0
  2295. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/README.md +0 -0
  2296. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/all.rs +0 -0
  2297. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/comments.wit +0 -0
  2298. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/diamond1/deps/dep1/types.wit +0 -0
  2299. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/diamond1/deps/dep2/types.wit +0 -0
  2300. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/diamond1/join.wit +0 -0
  2301. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/disambiguate-diamond/shared1.wit +0 -0
  2302. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/disambiguate-diamond/shared2.wit +0 -0
  2303. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/disambiguate-diamond/world.wit +0 -0
  2304. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/embedded.wit.md +0 -0
  2305. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/empty.wit +0 -0
  2306. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/foreign-deps/root.wit +0 -0
  2307. /data/ext/cargo-vendor/{wit-parser-0.8.0/tests/ui/foreign-deps → wit-parser-0.9.2/tests/ui/foreign-deps-union}/deps/another-pkg/other-doc.wit +0 -0
  2308. /data/ext/cargo-vendor/{wit-parser-0.8.0/tests/ui/foreign-deps → wit-parser-0.9.2/tests/ui/foreign-deps-union}/deps/corp/saas.wit +0 -0
  2309. /data/ext/cargo-vendor/{wit-parser-0.8.0/tests/ui/foreign-deps → wit-parser-0.9.2/tests/ui/foreign-deps-union}/deps/different-pkg/the-doc.wit +0 -0
  2310. /data/ext/cargo-vendor/{wit-parser-0.8.0/tests/ui/foreign-deps → wit-parser-0.9.2/tests/ui/foreign-deps-union}/deps/foreign-pkg/the-doc.wit +0 -0
  2311. /data/ext/cargo-vendor/{wit-parser-0.8.0/tests/ui/foreign-deps → wit-parser-0.9.2/tests/ui/foreign-deps-union}/deps/some-pkg/some-doc.wit +0 -0
  2312. /data/ext/cargo-vendor/{wit-parser-0.8.0/tests/ui/foreign-deps → wit-parser-0.9.2/tests/ui/foreign-deps-union}/deps/wasi/clocks.wit +0 -0
  2313. /data/ext/cargo-vendor/{wit-parser-0.8.0/tests/ui/foreign-deps → wit-parser-0.9.2/tests/ui/foreign-deps-union}/deps/wasi/filesystem.wit +0 -0
  2314. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/functions.wit +0 -0
  2315. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/many-names/a.wit +0 -0
  2316. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/many-names/b.wit +0 -0
  2317. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/multi-file/bar.wit +0 -0
  2318. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/multi-file/cycle-a.wit +0 -0
  2319. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/multi-file/cycle-b.wit +0 -0
  2320. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/multi-file/foo.wit +0 -0
  2321. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/package-syntax1.wit +0 -0
  2322. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/package-syntax3.wit +0 -0
  2323. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/package-syntax4.wit +0 -0
  2324. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/alias-no-type.wit +0 -0
  2325. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/alias-no-type.wit.result +0 -0
  2326. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/async.wit.result +0 -0
  2327. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/async1.wit.result +0 -0
  2328. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-function.wit +0 -0
  2329. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-function.wit.result +0 -0
  2330. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-function2.wit +0 -0
  2331. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-function2.wit.result +0 -0
  2332. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-list.wit +0 -0
  2333. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-list.wit.result +0 -0
  2334. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg1/root.wit +0 -0
  2335. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg2/deps/bar/empty.wit +0 -0
  2336. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg2/root.wit +0 -0
  2337. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg2.wit.result +0 -0
  2338. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg3/deps/bar/baz.wit +0 -0
  2339. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg3/root.wit +0 -0
  2340. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg3.wit.result +0 -0
  2341. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg4/deps/bar/baz.wit +0 -0
  2342. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg4/root.wit +0 -0
  2343. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg4.wit.result +0 -0
  2344. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg5/deps/bar/baz.wit +0 -0
  2345. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg5/root.wit +0 -0
  2346. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg5.wit.result +0 -0
  2347. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg6/deps/bar/baz.wit +0 -0
  2348. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg6/root.wit +0 -0
  2349. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-pkg6.wit.result +0 -0
  2350. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-world-type1.wit +0 -0
  2351. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/bad-world-type1.wit.result +0 -0
  2352. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/conflicting-package/a.wit +0 -0
  2353. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/conflicting-package/b.wit +0 -0
  2354. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/conflicting-package.wit.result +0 -0
  2355. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/cycle.wit +0 -0
  2356. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/cycle.wit.result +0 -0
  2357. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/cycle2.wit +0 -0
  2358. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/cycle2.wit.result +0 -0
  2359. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/cycle3.wit +0 -0
  2360. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/cycle3.wit.result +0 -0
  2361. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/cycle4.wit +0 -0
  2362. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/cycle4.wit.result +0 -0
  2363. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/cycle5.wit +0 -0
  2364. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/cycle5.wit.result +0 -0
  2365. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/dangling-type.wit +0 -0
  2366. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/dangling-type.wit.result +0 -0
  2367. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/duplicate-functions.wit +0 -0
  2368. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/duplicate-functions.wit.result +0 -0
  2369. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/duplicate-interface.wit +0 -0
  2370. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/duplicate-interface.wit.result +0 -0
  2371. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/duplicate-interface2/foo.wit +0 -0
  2372. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/duplicate-interface2/foo2.wit +0 -0
  2373. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/duplicate-interface2.wit.result +0 -0
  2374. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/duplicate-type.wit +0 -0
  2375. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/duplicate-type.wit.result +0 -0
  2376. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/empty-enum.wit +0 -0
  2377. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/empty-enum.wit.result +0 -0
  2378. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/empty-union.wit +0 -0
  2379. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/empty-union.wit.result +0 -0
  2380. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/empty-variant1.wit +0 -0
  2381. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/empty-variant1.wit.result +0 -0
  2382. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/export-twice.wit +0 -0
  2383. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/export-twice.wit.result +0 -0
  2384. /data/ext/cargo-vendor/{wit-parser-0.8.0/tests/ui/worlds-same-fields5.wit → wit-parser-0.9.2/tests/ui/parse-fail/import-and-export1.wit} +0 -0
  2385. /data/ext/cargo-vendor/{wit-parser-0.8.0/tests/ui/worlds.wit → wit-parser-0.9.2/tests/ui/parse-fail/import-and-export3.wit} +0 -0
  2386. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/import-export-overlap1.wit +0 -0
  2387. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/import-export-overlap1.wit.result +0 -0
  2388. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/import-export-overlap2.wit +0 -0
  2389. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/import-export-overlap2.wit.result +0 -0
  2390. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/import-twice.wit +0 -0
  2391. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/import-twice.wit.result +0 -0
  2392. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/invalid-md.md +0 -0
  2393. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/invalid-md.wit.result +0 -0
  2394. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/invalid-toplevel.wit +0 -0
  2395. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/invalid-toplevel.wit.result +0 -0
  2396. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/invalid-type-reference.wit +0 -0
  2397. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/invalid-type-reference.wit.result +0 -0
  2398. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/invalid-type-reference2.wit +0 -0
  2399. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/invalid-type-reference2.wit.result +0 -0
  2400. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/keyword.wit +0 -0
  2401. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/keyword.wit.result +0 -0
  2402. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/missing-package.wit +0 -0
  2403. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/missing-package.wit.result +0 -0
  2404. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/no-access-to-sibling-use/bar.wit +0 -0
  2405. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/no-access-to-sibling-use/foo.wit +0 -0
  2406. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/pkg-cycle/deps/a1/root.wit +0 -0
  2407. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/pkg-cycle/root.wit +0 -0
  2408. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/pkg-cycle.wit.result +0 -0
  2409. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/pkg-cycle2/deps/a1/root.wit +0 -0
  2410. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/pkg-cycle2/deps/a2/root.wit +0 -0
  2411. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/pkg-cycle2/root.wit +0 -0
  2412. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/pkg-cycle2.wit.result +0 -0
  2413. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/undefined-typed.wit +0 -0
  2414. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/undefined-typed.wit.result +0 -0
  2415. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unknown-interface.wit +0 -0
  2416. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-interface1.wit +0 -0
  2417. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-interface1.wit.result +0 -0
  2418. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-interface2.wit +0 -0
  2419. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-interface3.wit +0 -0
  2420. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-interface4.wit +0 -0
  2421. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-interface4.wit.result +0 -0
  2422. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use1.wit +0 -0
  2423. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use10/bar.wit +0 -0
  2424. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use10/foo.wit +0 -0
  2425. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use10.wit.result +0 -0
  2426. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use2.wit +0 -0
  2427. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use2.wit.result +0 -0
  2428. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use3.wit +0 -0
  2429. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use3.wit.result +0 -0
  2430. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use7.wit +0 -0
  2431. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use7.wit.result +0 -0
  2432. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use8.wit +0 -0
  2433. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use8.wit.result +0 -0
  2434. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unresolved-use9.wit +0 -0
  2435. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/unterminated-string.wit.result +0 -0
  2436. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/use-conflict.wit +0 -0
  2437. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/use-conflict.wit.result +0 -0
  2438. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/use-conflict2.wit +0 -0
  2439. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/use-conflict2.wit.result +0 -0
  2440. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/use-conflict3.wit +0 -0
  2441. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/use-conflict3.wit.result +0 -0
  2442. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/use-cycle1.wit +0 -0
  2443. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/use-cycle4.wit +0 -0
  2444. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/use-shadow1.wit +0 -0
  2445. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/use-shadow1.wit.result +0 -0
  2446. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/world-interface-clash.wit +0 -0
  2447. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/world-same-fields2.wit +0 -0
  2448. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/world-same-fields2.wit.result +0 -0
  2449. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/world-same-fields3.wit +0 -0
  2450. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/world-same-fields3.wit.result +0 -0
  2451. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/world-top-level-func.wit +0 -0
  2452. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/world-top-level-func.wit.result +0 -0
  2453. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/world-top-level-func2.wit +0 -0
  2454. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/parse-fail/world-top-level-func2.wit.result +0 -0
  2455. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/type-then-eof.wit +0 -0
  2456. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/types.wit +0 -0
  2457. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/use-chain.wit +0 -0
  2458. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/use.wit +0 -0
  2459. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/versions/deps/a1/foo.wit +0 -0
  2460. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/versions/deps/a2/foo.wit +0 -0
  2461. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/versions/foo.wit +0 -0
  2462. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/wasi.wit +0 -0
  2463. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/world-iface-no-collide.wit +0 -0
  2464. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/world-implicit-import1.wit +0 -0
  2465. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/world-implicit-import2.wit +0 -0
  2466. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/world-implicit-import3.wit +0 -0
  2467. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/world-top-level-funcs.wit +0 -0
  2468. /data/ext/cargo-vendor/{wit-parser-0.8.0 → wit-parser-0.9.2}/tests/ui/worlds-with-types.wit +0 -0
@@ -0,0 +1,3144 @@
1
+ //! State relating to validating a WebAssembly component.
2
+
3
+ use super::{
4
+ check_max, combine_type_sizes,
5
+ core::Module,
6
+ types::{
7
+ ComponentFuncType, ComponentInstanceType, ComponentType, ComponentValType, EntityType,
8
+ InstanceType, ModuleType, RecordType, Remapping, ResourceId, Type, TypeAlloc, TypeId,
9
+ TypeList, VariantCase,
10
+ },
11
+ };
12
+ use crate::validator::names::{KebabName, KebabNameKind, KebabStr, KebabString};
13
+ use crate::{
14
+ limits::*,
15
+ types::{
16
+ ComponentDefinedType, ComponentEntityType, Context, InstanceTypeKind, LoweringInfo, Remap,
17
+ SubtypeCx, TupleType, UnionType, VariantType,
18
+ },
19
+ BinaryReaderError, CanonicalOption, ComponentExternName, ComponentExternalKind,
20
+ ComponentOuterAliasKind, ComponentTypeRef, ExternalKind, FuncType, GlobalType,
21
+ InstantiationArgKind, MemoryType, Result, StructuralType, SubType, TableType, TypeBounds,
22
+ ValType, WasmFeatures,
23
+ };
24
+ use indexmap::{map::Entry, IndexMap, IndexSet};
25
+ use std::collections::{HashMap, HashSet};
26
+ use std::mem;
27
+
28
+ fn to_kebab_str<'a>(s: &'a str, desc: &str, offset: usize) -> Result<&'a KebabStr> {
29
+ match KebabStr::new(s) {
30
+ Some(s) => Ok(s),
31
+ None => {
32
+ if s.is_empty() {
33
+ bail!(offset, "{desc} name cannot be empty");
34
+ }
35
+
36
+ bail!(offset, "{desc} name `{s}` is not in kebab case");
37
+ }
38
+ }
39
+ }
40
+
41
+ pub(crate) struct ComponentState {
42
+ /// Whether this state is a concrete component, an instance type, or a
43
+ /// component type.
44
+ kind: ComponentKind,
45
+
46
+ // Core index spaces
47
+ pub core_types: Vec<TypeId>,
48
+ pub core_modules: Vec<TypeId>,
49
+ pub core_instances: Vec<TypeId>,
50
+ pub core_funcs: Vec<TypeId>,
51
+ pub core_memories: Vec<MemoryType>,
52
+ pub core_tables: Vec<TableType>,
53
+ pub core_globals: Vec<GlobalType>,
54
+ pub core_tags: Vec<TypeId>,
55
+
56
+ // Component index spaces
57
+ pub types: Vec<TypeId>,
58
+ pub funcs: Vec<TypeId>,
59
+ pub values: Vec<(ComponentValType, bool)>,
60
+ pub instances: Vec<TypeId>,
61
+ pub components: Vec<TypeId>,
62
+
63
+ pub imports: IndexMap<String, ComponentEntityType>,
64
+ pub exports: IndexMap<String, ComponentEntityType>,
65
+ pub kebab_named_externs: IndexSet<KebabName>,
66
+
67
+ has_start: bool,
68
+ type_size: u32,
69
+
70
+ /// A mapping of imported resources in this component.
71
+ ///
72
+ /// This mapping represents all "type variables" imported into the
73
+ /// component, or resources. This could be resources imported directly as
74
+ /// a top-level type import or additionally transitively through other
75
+ /// imported instances.
76
+ ///
77
+ /// The mapping element here is a "path" which is a list of indexes into
78
+ /// the import map that will be generated for this component. Each index
79
+ /// is an index into an `IndexMap`, and each list is guaranteed to have at
80
+ /// least one element.
81
+ ///
82
+ /// An example of this map is:
83
+ ///
84
+ /// ```wasm
85
+ /// (component
86
+ /// ;; [0] - the first import
87
+ /// (import "r" (type (sub resource)))
88
+ ///
89
+ /// ;; [1] - the second import
90
+ /// (import "r2" (type (sub resource)))
91
+ ///
92
+ /// (import "i" (instance
93
+ /// ;; [2, 0] - the third import, and the first export the instance
94
+ /// (export "r3" (type (sub resource)))
95
+ /// ;; [2, 1] - the third import, and the second export the instance
96
+ /// (export "r4" (type (sub resource)))
97
+ /// ))
98
+ ///
99
+ /// ;; ...
100
+ /// )
101
+ /// ```
102
+ ///
103
+ /// The `Vec<usize>` here can be thought of as `Vec<String>` but a
104
+ /// (hopefully) more efficient representation.
105
+ ///
106
+ /// Finally note that this map is listed as an "append only" map because all
107
+ /// insertions into it should always succeed. Any insertion which overlaps
108
+ /// with a previous entry indicates a bug in the validator which needs to be
109
+ /// corrected via other means.
110
+ //
111
+ // TODO: make these `SkolemResourceId` and then go fix all the compile
112
+ // errors, don't add skolem things into the type area
113
+ imported_resources: IndexMapAppendOnly<ResourceId, Vec<usize>>,
114
+
115
+ /// A mapping of "defined" resources in this component, or those which
116
+ /// are defined within the instantiation of this component.
117
+ ///
118
+ /// Defined resources, as the name implies, can sort of be thought of as
119
+ /// "these are defined within the component". Note though that the means by
120
+ /// which a local definition can occur are not simply those defined in the
121
+ /// component but also in its transitively instantiated components
122
+ /// internally. This means that this set closes over many transitive
123
+ /// internal items in addition to those defined immediately in the component
124
+ /// itself.
125
+ ///
126
+ /// The `Option<ValType>` in this mapping is whether or not the underlying
127
+ /// reprsentation of the resource is known to this component. Immediately
128
+ /// defined resources, for example, will have `Some(I32)` here. Resources
129
+ /// that come from transitively defined components, for example, will have
130
+ /// `None`. In the type context all entries here are `None`.
131
+ ///
132
+ /// Note that like `imported_resources` all insertions into this map are
133
+ /// expected to succeed to it's declared as append-only.
134
+ defined_resources: IndexMapAppendOnly<ResourceId, Option<ValType>>,
135
+
136
+ /// A mapping of explicitly exported resources from this component in
137
+ /// addition to the path that they're exported at.
138
+ ///
139
+ /// For more information on the path here see the documentation for
140
+ /// `imported_resources`. Note that the indexes here index into the
141
+ /// list of exports of this component.
142
+ explicit_resources: IndexMap<ResourceId, Vec<usize>>,
143
+
144
+ /// The set of types which are considered "exported" from this component.
145
+ ///
146
+ /// This is added to whenever a type export is found, or an instance export
147
+ /// which itself contains a type export. This additionally includes all
148
+ /// imported types since those are suitable for export as well.
149
+ ///
150
+ /// This set is consulted whenever an exported item is added since all
151
+ /// referenced types must be members of this set.
152
+ exported_types: HashSet<TypeId>,
153
+
154
+ /// Same as `exported_types`, but for imports.
155
+ imported_types: HashSet<TypeId>,
156
+
157
+ /// The set of top-level resource exports and their names.
158
+ ///
159
+ /// This context is used to validate method names such as `[method]foo.bar`
160
+ /// to ensure that `foo` is an exported resource and that the type mentioned
161
+ /// in a function type is actually named `foo`.
162
+ ///
163
+ /// Note that imports/exports have disjoint contexts to ensure that they're
164
+ /// validated correctly. Namely you can't retroactively attach methods to an
165
+ /// import, for example.
166
+ toplevel_exported_resources: KebabNameContext,
167
+
168
+ /// Same as `toplevel_exported_resources`, but for imports.
169
+ toplevel_imported_resources: KebabNameContext,
170
+ }
171
+
172
+ #[derive(Copy, Clone, Debug, PartialEq, Eq)]
173
+ pub enum ComponentKind {
174
+ Component,
175
+ InstanceType,
176
+ ComponentType,
177
+ }
178
+
179
+ /// Helper context used to track information about resource names for method
180
+ /// name validation.
181
+ #[derive(Default)]
182
+ struct KebabNameContext {
183
+ /// A map from a resource type id to an index in the `all_resource_names`
184
+ /// set for the name of that resource.
185
+ resource_name_map: HashMap<TypeId, usize>,
186
+
187
+ /// All known resource names in this context, used to validate static method
188
+ /// names to by ensuring that static methods' resource names are somewhere
189
+ /// in this set.
190
+ all_resource_names: IndexSet<String>,
191
+ }
192
+
193
+ #[derive(Debug, Copy, Clone)]
194
+ pub enum ExternKind {
195
+ Import,
196
+ Export,
197
+ }
198
+
199
+ impl ExternKind {
200
+ pub fn desc(&self) -> &'static str {
201
+ match self {
202
+ ExternKind::Import => "import",
203
+ ExternKind::Export => "export",
204
+ }
205
+ }
206
+ }
207
+
208
+ impl ComponentState {
209
+ pub fn new(kind: ComponentKind) -> Self {
210
+ Self {
211
+ kind,
212
+ core_types: Default::default(),
213
+ core_modules: Default::default(),
214
+ core_instances: Default::default(),
215
+ core_funcs: Default::default(),
216
+ core_memories: Default::default(),
217
+ core_tables: Default::default(),
218
+ core_globals: Default::default(),
219
+ core_tags: Default::default(),
220
+ types: Default::default(),
221
+ funcs: Default::default(),
222
+ values: Default::default(),
223
+ instances: Default::default(),
224
+ components: Default::default(),
225
+ imports: Default::default(),
226
+ exports: Default::default(),
227
+ kebab_named_externs: Default::default(),
228
+ has_start: Default::default(),
229
+ type_size: 1,
230
+ imported_resources: Default::default(),
231
+ defined_resources: Default::default(),
232
+ explicit_resources: Default::default(),
233
+ exported_types: Default::default(),
234
+ imported_types: Default::default(),
235
+ toplevel_exported_resources: Default::default(),
236
+ toplevel_imported_resources: Default::default(),
237
+ }
238
+ }
239
+
240
+ pub fn type_count(&self) -> usize {
241
+ self.core_types.len() + self.types.len()
242
+ }
243
+
244
+ pub fn instance_count(&self) -> usize {
245
+ self.core_instances.len() + self.instances.len()
246
+ }
247
+
248
+ pub fn function_count(&self) -> usize {
249
+ self.core_funcs.len() + self.funcs.len()
250
+ }
251
+
252
+ pub fn add_core_type(
253
+ components: &mut [Self],
254
+ ty: crate::CoreType,
255
+ features: &WasmFeatures,
256
+ types: &mut TypeAlloc,
257
+ offset: usize,
258
+ check_limit: bool,
259
+ ) -> Result<()> {
260
+ let ty = match ty {
261
+ crate::CoreType::Func(ty) => Type::Sub(SubType {
262
+ is_final: false,
263
+ supertype_idx: None,
264
+ structural_type: StructuralType::Func(ty),
265
+ }),
266
+ crate::CoreType::Module(decls) => Type::Module(Box::new(Self::create_module_type(
267
+ components,
268
+ decls.into_vec(),
269
+ features,
270
+ types,
271
+ offset,
272
+ )?)),
273
+ };
274
+
275
+ let current = components.last_mut().unwrap();
276
+
277
+ if check_limit {
278
+ check_max(current.type_count(), 1, MAX_WASM_TYPES, "types", offset)?;
279
+ }
280
+
281
+ let id = types.push_ty(ty);
282
+ current.core_types.push(id);
283
+
284
+ Ok(())
285
+ }
286
+
287
+ pub fn add_core_module(
288
+ &mut self,
289
+ module: &Module,
290
+ types: &mut TypeAlloc,
291
+ offset: usize,
292
+ ) -> Result<()> {
293
+ let imports = module.imports_for_module_type(offset)?;
294
+
295
+ // We have to clone the module's imports and exports here
296
+ // because we cannot take the data out of the `MaybeOwned`
297
+ // as it might be shared with a function validator.
298
+ let ty = Type::Module(Box::new(ModuleType {
299
+ type_size: module.type_size,
300
+ imports,
301
+ exports: module.exports.clone(),
302
+ }));
303
+
304
+ let id = types.push_ty(ty);
305
+ self.core_modules.push(id);
306
+
307
+ Ok(())
308
+ }
309
+
310
+ pub fn add_core_instance(
311
+ &mut self,
312
+ instance: crate::Instance,
313
+ types: &mut TypeAlloc,
314
+ offset: usize,
315
+ ) -> Result<()> {
316
+ let instance = match instance {
317
+ crate::Instance::Instantiate { module_index, args } => {
318
+ self.instantiate_module(module_index, args.into_vec(), types, offset)?
319
+ }
320
+ crate::Instance::FromExports(exports) => {
321
+ self.instantiate_core_exports(exports.into_vec(), types, offset)?
322
+ }
323
+ };
324
+
325
+ self.core_instances.push(instance);
326
+
327
+ Ok(())
328
+ }
329
+
330
+ pub fn add_type(
331
+ components: &mut Vec<Self>,
332
+ ty: crate::ComponentType,
333
+ features: &WasmFeatures,
334
+ types: &mut TypeAlloc,
335
+ offset: usize,
336
+ check_limit: bool,
337
+ ) -> Result<()> {
338
+ assert!(!components.is_empty());
339
+ let ty = match ty {
340
+ crate::ComponentType::Defined(ty) => Type::Defined(
341
+ components
342
+ .last_mut()
343
+ .unwrap()
344
+ .create_defined_type(ty, types, offset)?,
345
+ ),
346
+ crate::ComponentType::Func(ty) => Type::ComponentFunc(
347
+ components
348
+ .last_mut()
349
+ .unwrap()
350
+ .create_function_type(ty, types, offset)?,
351
+ ),
352
+ crate::ComponentType::Component(decls) => Type::Component(Box::new(
353
+ Self::create_component_type(components, decls.into_vec(), features, types, offset)?,
354
+ )),
355
+ crate::ComponentType::Instance(decls) => Type::ComponentInstance(Box::new(
356
+ Self::create_instance_type(components, decls.into_vec(), features, types, offset)?,
357
+ )),
358
+ crate::ComponentType::Resource { rep, dtor } => {
359
+ let component = components.last_mut().unwrap();
360
+
361
+ // Resource types cannot be declared in a type context, only
362
+ // within a component context.
363
+ if component.kind != ComponentKind::Component {
364
+ bail!(
365
+ offset,
366
+ "resources can only be defined within a concrete component"
367
+ );
368
+ }
369
+
370
+ // Current MVP restriction of the component model.
371
+ if rep != ValType::I32 {
372
+ bail!(offset, "resources can only be represented by `i32`");
373
+ }
374
+
375
+ // If specified validate that the destructor is both a valid
376
+ // function and has the correct signature.
377
+ if let Some(dtor) = dtor {
378
+ let ty = component.core_function_at(dtor, offset)?;
379
+ let ty = types[ty].unwrap_func();
380
+ if ty.params() != [rep] || ty.results() != [] {
381
+ bail!(
382
+ offset,
383
+ "core function {dtor} has wrong signature for a destructor"
384
+ );
385
+ }
386
+ }
387
+
388
+ // As this is the introduction of a resource create a fresh new
389
+ // identifier for the resource. This is then added into the
390
+ // list of defined resources for this component, notably with a
391
+ // rep listed to enable getting access to various intrinsics
392
+ // such as `resource.rep`.
393
+ let id = types.alloc_resource_id();
394
+ component.defined_resources.insert(id, Some(rep));
395
+ Type::Resource(id)
396
+ }
397
+ };
398
+
399
+ let current = components.last_mut().unwrap();
400
+ if check_limit {
401
+ check_max(current.type_count(), 1, MAX_WASM_TYPES, "types", offset)?;
402
+ }
403
+
404
+ let id = types.push_ty(ty);
405
+ current.types.push(id);
406
+
407
+ Ok(())
408
+ }
409
+
410
+ pub fn add_import(
411
+ &mut self,
412
+ import: crate::ComponentImport,
413
+ features: &WasmFeatures,
414
+ types: &mut TypeAlloc,
415
+ offset: usize,
416
+ ) -> Result<()> {
417
+ let mut entity = self.check_type_ref(&import.ty, features, types, offset)?;
418
+ self.add_entity(
419
+ &mut entity,
420
+ Some((import.name.as_str(), ExternKind::Import)),
421
+ features,
422
+ types,
423
+ offset,
424
+ )?;
425
+ self.toplevel_imported_resources.validate_extern(
426
+ import.name,
427
+ "import",
428
+ &entity,
429
+ types,
430
+ offset,
431
+ &mut self.kebab_named_externs,
432
+ &mut self.imports,
433
+ &mut self.type_size,
434
+ )?;
435
+ Ok(())
436
+ }
437
+
438
+ fn add_entity(
439
+ &mut self,
440
+ ty: &mut ComponentEntityType,
441
+ name_and_kind: Option<(&str, ExternKind)>,
442
+ features: &WasmFeatures,
443
+ types: &mut TypeAlloc,
444
+ offset: usize,
445
+ ) -> Result<()> {
446
+ let kind = name_and_kind.map(|(_, k)| k);
447
+ let (len, max, desc) = match ty {
448
+ ComponentEntityType::Module(id) => {
449
+ self.core_modules.push(*id);
450
+ (self.core_modules.len(), MAX_WASM_MODULES, "modules")
451
+ }
452
+ ComponentEntityType::Component(id) => {
453
+ self.components.push(*id);
454
+ (self.components.len(), MAX_WASM_COMPONENTS, "components")
455
+ }
456
+ ComponentEntityType::Instance(id) => {
457
+ match kind {
458
+ Some(ExternKind::Import) => self.prepare_instance_import(id, types),
459
+ Some(ExternKind::Export) => self.prepare_instance_export(id, types),
460
+ None => {}
461
+ }
462
+ self.instances.push(*id);
463
+ (self.instance_count(), MAX_WASM_INSTANCES, "instances")
464
+ }
465
+ ComponentEntityType::Func(id) => {
466
+ self.funcs.push(*id);
467
+ (self.function_count(), MAX_WASM_FUNCTIONS, "functions")
468
+ }
469
+ ComponentEntityType::Value(ty) => {
470
+ self.check_value_support(features, offset)?;
471
+ let value_used = match kind {
472
+ Some(ExternKind::Import) | None => false,
473
+ Some(ExternKind::Export) => true,
474
+ };
475
+ self.values.push((*ty, value_used));
476
+ (self.values.len(), MAX_WASM_VALUES, "values")
477
+ }
478
+ ComponentEntityType::Type {
479
+ created,
480
+ referenced,
481
+ } => {
482
+ self.types.push(*created);
483
+
484
+ // Extra logic here for resources being imported and exported.
485
+ // Note that if `created` is the same as `referenced` then this
486
+ // is the original introduction of the resource which is where
487
+ // `self.{imported,defined}_resources` are updated.
488
+ if let Type::Resource(id) = types[*created] {
489
+ match kind {
490
+ Some(ExternKind::Import) => {
491
+ // A fresh new resource is being imported into a
492
+ // component. This arises from the import section of
493
+ // a component or from the import declaration in a
494
+ // component type. In both cases a new imported
495
+ // resource is injected with a fresh new identifier
496
+ // into our state.
497
+ if created == referenced {
498
+ self.imported_resources.insert(id, vec![self.imports.len()]);
499
+ }
500
+ }
501
+
502
+ Some(ExternKind::Export) => {
503
+ // A fresh resource is being exported from this
504
+ // component. This arises as part of the
505
+ // declaration of a component type, for example. In
506
+ // this situation brand new resource identifier is
507
+ // allocated and a definition is added, unlike the
508
+ // import case where an imported resource is added.
509
+ // Notably the representation of this new resource
510
+ // is unknown so it's listed as `None`.
511
+ if created == referenced {
512
+ self.defined_resources.insert(id, None);
513
+ }
514
+
515
+ // If this is a type export of a resource type then
516
+ // update the `explicit_resources` list. A new
517
+ // export path is about to be created for this
518
+ // resource and this keeps track of that.
519
+ self.explicit_resources.insert(id, vec![self.exports.len()]);
520
+ }
521
+
522
+ None => {}
523
+ }
524
+ }
525
+ (self.types.len(), MAX_WASM_TYPES, "types")
526
+ }
527
+ };
528
+
529
+ check_max(len, 0, max, desc, offset)?;
530
+
531
+ // Before returning perform the final validation of the type of the item
532
+ // being imported/exported. This will ensure that everything is
533
+ // appropriately named with respect to type definitions, resources, etc.
534
+ if let Some((name, kind)) = name_and_kind {
535
+ if !self.validate_and_register_named_types(Some(name), kind, ty, types) {
536
+ bail!(
537
+ offset,
538
+ "{} not valid to be used as {}",
539
+ ty.desc(),
540
+ kind.desc()
541
+ );
542
+ }
543
+ }
544
+ Ok(())
545
+ }
546
+
547
+ /// Validates that the `ty` referenced only refers to named types internally
548
+ /// and then inserts anything necessary, if applicable, to the defined sets
549
+ /// within this component.
550
+ ///
551
+ /// This function will validate that `ty` only refers to named types. For
552
+ /// example if it's a record then all of its fields must refer to named
553
+ /// types. This consults either `self.imported_types` or
554
+ /// `self.exported_types` as specified by `kind`. Note that this is not
555
+ /// inherently recursive itself but it ends up being recursive since if
556
+ /// recursive members were named then all their components must also be
557
+ /// named. Consequently this check stops at the "one layer deep" position,
558
+ /// or more accurately the position where types must be named (e.g. tuples
559
+ /// aren't required to be named).
560
+ fn validate_and_register_named_types(
561
+ &mut self,
562
+ toplevel_name: Option<&str>,
563
+ kind: ExternKind,
564
+ ty: &ComponentEntityType,
565
+ types: &TypeAlloc,
566
+ ) -> bool {
567
+ if let ComponentEntityType::Type { created, .. } = ty {
568
+ // If this is a top-level resource then register it in the
569
+ // appropriate context so later validation of method-like-names
570
+ // works out.
571
+ if let Some(name) = toplevel_name {
572
+ if let Type::Resource(_) = types[*created] {
573
+ let cx = match kind {
574
+ ExternKind::Import => &mut self.toplevel_imported_resources,
575
+ ExternKind::Export => &mut self.toplevel_exported_resources,
576
+ };
577
+ cx.register(name, *created);
578
+ }
579
+ }
580
+ }
581
+
582
+ match self.kind {
583
+ ComponentKind::Component | ComponentKind::ComponentType => {}
584
+ ComponentKind::InstanceType => return true,
585
+ }
586
+ let set = match kind {
587
+ ExternKind::Import => &self.imported_types,
588
+ ExternKind::Export => &self.exported_types,
589
+ };
590
+ match ty {
591
+ // When a type is imported or exported than any recursive type
592
+ // referred to by that import/export must additionally be exported
593
+ // or imported. Here this walks the "first layer" of the type which
594
+ // delegates to `TypeAlloc::type_named_type_id` to determine whether
595
+ // the components of the type being named here are indeed all they
596
+ // themselves named.
597
+ ComponentEntityType::Type {
598
+ created,
599
+ referenced,
600
+ } => {
601
+ if !self.all_valtypes_named(types, *referenced, set) {
602
+ return false;
603
+ }
604
+ match kind {
605
+ // Imported types are both valid for import and valid for
606
+ // export.
607
+ ExternKind::Import => {
608
+ self.imported_types.insert(*created);
609
+ self.exported_types.insert(*created);
610
+ }
611
+ ExternKind::Export => {
612
+ self.exported_types.insert(*created);
613
+ }
614
+ }
615
+
616
+ true
617
+ }
618
+
619
+ // Instances are slightly nuanced here. The general idea is that if
620
+ // an instance is imported, then any type exported by the instance
621
+ // is then also exported. Additionally for exports. To get this to
622
+ // work out this arm will recursively call
623
+ // `validate_and_register_named_types` which means that types are
624
+ // inserted into `self.{imported,exported}_types` as-we-go rather
625
+ // than all at once.
626
+ //
627
+ // This then recursively validates that all items in the instance
628
+ // itself are valid to import/export, recursive instances are
629
+ // captured, and everything is appropriately added to the right
630
+ // imported/exported set.
631
+ ComponentEntityType::Instance(i) => {
632
+ let ty = types[*i].unwrap_component_instance();
633
+ ty.exports
634
+ .values()
635
+ .all(|ty| self.validate_and_register_named_types(None, kind, ty, types))
636
+ }
637
+
638
+ // All types referred to by a function must be named.
639
+ ComponentEntityType::Func(id) => self.all_valtypes_named(types, *id, set),
640
+
641
+ ComponentEntityType::Value(ty) => types.type_named_valtype(ty, set),
642
+
643
+ // Components/modules are always "closed" or "standalone" and don't
644
+ // need validation with respect to their named types.
645
+ ComponentEntityType::Component(_) | ComponentEntityType::Module(_) => true,
646
+ }
647
+ }
648
+ fn all_valtypes_named(&self, types: &TypeAlloc, id: TypeId, set: &HashSet<TypeId>) -> bool {
649
+ match &types[id] {
650
+ Type::Defined(i) => match i {
651
+ // These types do not contain anything which must be
652
+ // named.
653
+ ComponentDefinedType::Primitive(_)
654
+ | ComponentDefinedType::Flags(_)
655
+ | ComponentDefinedType::Enum(_) => true,
656
+
657
+ // Referenced types of all these aggregates must all be
658
+ // named.
659
+ ComponentDefinedType::Record(r) => {
660
+ r.fields.values().all(|t| types.type_named_valtype(t, set))
661
+ }
662
+ ComponentDefinedType::Tuple(r) => {
663
+ r.types.iter().all(|t| types.type_named_valtype(t, set))
664
+ }
665
+ ComponentDefinedType::Union(r) => {
666
+ r.types.iter().all(|t| types.type_named_valtype(t, set))
667
+ }
668
+ ComponentDefinedType::Variant(r) => r
669
+ .cases
670
+ .values()
671
+ .filter_map(|t| t.ty.as_ref())
672
+ .all(|t| types.type_named_valtype(t, set)),
673
+ ComponentDefinedType::Result { ok, err } => {
674
+ ok.as_ref()
675
+ .map(|t| types.type_named_valtype(t, set))
676
+ .unwrap_or(true)
677
+ && err
678
+ .as_ref()
679
+ .map(|t| types.type_named_valtype(t, set))
680
+ .unwrap_or(true)
681
+ }
682
+ ComponentDefinedType::List(ty) | ComponentDefinedType::Option(ty) => {
683
+ types.type_named_valtype(ty, set)
684
+ }
685
+
686
+ // The resource referred to by own/borrow must be named.
687
+ ComponentDefinedType::Own(id) | ComponentDefinedType::Borrow(id) => {
688
+ set.contains(id)
689
+ }
690
+ },
691
+
692
+ // Core wasm constructs are always valid with respect to
693
+ // exported types, since they have none.
694
+ Type::Module(_) | Type::Instance(_) | Type::Sub(_) => true,
695
+
696
+ // Resource types, in isolation, are always valid to import
697
+ // or export since they're either attached to an import or
698
+ // being exported.
699
+ //
700
+ // Note that further validation of this happens in `finish`,
701
+ // too.
702
+ Type::Resource(_) => true,
703
+
704
+ // Component types are validated as they are constructed,
705
+ // so all component types are valid to export if they've
706
+ // already been constructed.
707
+ Type::Component(_) => true,
708
+
709
+ // Function types must have all their parameters/results named.
710
+ Type::ComponentFunc(ty) => ty
711
+ .params
712
+ .iter()
713
+ .map(|(_, ty)| ty)
714
+ .chain(ty.results.iter().map(|(_, ty)| ty))
715
+ .all(|ty| types.type_named_valtype(ty, set)),
716
+
717
+ // Instances must recursively have all referenced types named.
718
+ Type::ComponentInstance(ty) => ty.exports.values().all(|ty| {
719
+ let id = match ty {
720
+ ComponentEntityType::Module(id)
721
+ | ComponentEntityType::Func(id)
722
+ | ComponentEntityType::Value(ComponentValType::Type(id))
723
+ | ComponentEntityType::Type { created: id, .. }
724
+ | ComponentEntityType::Instance(id)
725
+ | ComponentEntityType::Component(id) => *id,
726
+ ComponentEntityType::Value(ComponentValType::Primitive(_)) => return true,
727
+ };
728
+ self.all_valtypes_named(types, id, set)
729
+ }),
730
+ }
731
+ }
732
+
733
+ /// Updates the type `id` specified, an identifier for a component instance
734
+ /// type, to be imported into this component.
735
+ ///
736
+ /// Importing an instance type into a component specially handles the
737
+ /// defined resources registered in the instance type. Notably all
738
+ /// defined resources are "freshened" into brand new type variables and
739
+ /// these new variables are substituted within the type. This is what
740
+ /// creates a new `TypeId` and may update the `id` specified.
741
+ ///
742
+ /// One side effect of this operation, for example, is that if an instance
743
+ /// type is used twice to import two different instances then the instances
744
+ /// do not share resource types despite sharing the same original instance
745
+ /// type.
746
+ fn prepare_instance_import(&mut self, id: &mut TypeId, types: &mut TypeAlloc) {
747
+ let ty = types[*id].unwrap_component_instance();
748
+
749
+ // No special treatment for imports of instances which themselves have
750
+ // no defined resources
751
+ if ty.defined_resources.is_empty() {
752
+ return;
753
+ }
754
+
755
+ let mut new_ty = ComponentInstanceType {
756
+ // Copied from the input verbatim
757
+ type_size: ty.type_size,
758
+
759
+ // Copied over as temporary storage for now, and both of these are
760
+ // filled out and expanded below.
761
+ exports: ty.exports.clone(),
762
+ explicit_resources: ty.explicit_resources.clone(),
763
+
764
+ // Explicitly discard this field since the
765
+ // defined resources are lifted into `self`
766
+ defined_resources: Default::default(),
767
+ };
768
+
769
+ // Create brand new resources for all defined ones in the instance.
770
+ let resources = (0..ty.defined_resources.len())
771
+ .map(|_| types.alloc_resource_id())
772
+ .collect::<IndexSet<_>>();
773
+
774
+ // Build a map from the defined resources in `ty` to those in `new_ty`.
775
+ //
776
+ // As part of this same loop the new resources, which were previously
777
+ // defined in `ty`, now become imported variables in `self`. Their
778
+ // path for where they're imported is updated as well with
779
+ // `self.next_import_index` as the import-to-be soon.
780
+ let mut mapping = Remapping::default();
781
+ let ty = types[*id].unwrap_component_instance();
782
+ for (old, new) in ty.defined_resources.iter().zip(&resources) {
783
+ let prev = mapping.resources.insert(*old, *new);
784
+ assert!(prev.is_none());
785
+
786
+ let mut base = vec![self.imports.len()];
787
+ base.extend(ty.explicit_resources[old].iter().copied());
788
+ self.imported_resources.insert(*new, base);
789
+ }
790
+
791
+ // Using the old-to-new resource mapping perform a substitution on
792
+ // the `exports` and `explicit_resources` fields of `new_ty`
793
+ for ty in new_ty.exports.values_mut() {
794
+ types.remap_component_entity(ty, &mut mapping);
795
+ }
796
+ for (id, path) in mem::take(&mut new_ty.explicit_resources) {
797
+ let id = *mapping.resources.get(&id).unwrap_or(&id);
798
+ new_ty.explicit_resources.insert(id, path);
799
+ }
800
+
801
+ // Now that `new_ty` is complete finish its registration and then
802
+ // update `id` on the way out.
803
+ *id = types.push_ty(Type::ComponentInstance(Box::new(new_ty)));
804
+ }
805
+
806
+ /// Prepares an instance type, pointed to `id`, for being exported as a
807
+ /// concrete instance from `self`.
808
+ ///
809
+ /// This will internally perform any resource "freshening" as required and
810
+ /// then additionally update metadata within `self` about resources being
811
+ /// exported or defined.
812
+ fn prepare_instance_export(&mut self, id: &mut TypeId, types: &mut TypeAlloc) {
813
+ // Exports of an instance mean that the enclosing context
814
+ // is inheriting the resources that the instance
815
+ // encapsulates. This means that the instance type
816
+ // recorded for this export will itself have no
817
+ // defined resources.
818
+ let ty = types[*id].unwrap_component_instance();
819
+
820
+ // Check to see if `defined_resources` is non-empty, and if so then
821
+ // "freshen" all the resources and inherit them to our own defined
822
+ // resources, updating `id` in the process.
823
+ //
824
+ // Note though that this specifically is not rewriting the resources of
825
+ // exported instances. The `defined_resources` set on instance types is
826
+ // a little subtle (see its documentation for more info), but the
827
+ // general idea is that for a concrete instance it's always empty. Only
828
+ // for instance type definitions does it ever have elements in it.
829
+ //
830
+ // That means that if this set is non-empty then what's happening is
831
+ // that we're in a type context an exporting an instance of a previously
832
+ // specified type. In this case all resources are required to be
833
+ // "freshened" to ensure that multiple exports of the same type all
834
+ // export different types of resources.
835
+ //
836
+ // And finally note that this operation empties out the
837
+ // `defined_resources` set of the type that is registered for the
838
+ // instance, as this export is modeled as producing a concrete instance.
839
+ if !ty.defined_resources.is_empty() {
840
+ let mut new_ty = ty.clone();
841
+ let mut mapping = Remapping::default();
842
+ for old in mem::take(&mut new_ty.defined_resources) {
843
+ let new = types.alloc_resource_id();
844
+ mapping.resources.insert(old, new);
845
+ self.defined_resources.insert(new, None);
846
+ }
847
+ for ty in new_ty.exports.values_mut() {
848
+ types.remap_component_entity(ty, &mut mapping);
849
+ }
850
+ for (id, path) in mem::take(&mut new_ty.explicit_resources) {
851
+ let id = mapping.resources.get(&id).copied().unwrap_or(id);
852
+ new_ty.explicit_resources.insert(id, path);
853
+ }
854
+ *id = types.push_ty(Type::ComponentInstance(Box::new(new_ty)));
855
+ }
856
+
857
+ // Any explicit resources in the instance are now additionally explicit
858
+ // in this component since it's exported.
859
+ //
860
+ // The path to each explicit resources gets one element prepended which
861
+ // is `self.next_export_index`, the index of the export about to be
862
+ // generated.
863
+ let ty = types[*id].unwrap_component_instance();
864
+ for (id, path) in ty.explicit_resources.iter() {
865
+ let mut new_path = vec![self.exports.len()];
866
+ new_path.extend(path);
867
+ self.explicit_resources.insert(*id, new_path);
868
+ }
869
+ }
870
+
871
+ pub fn add_export(
872
+ &mut self,
873
+ name: ComponentExternName<'_>,
874
+ mut ty: ComponentEntityType,
875
+ features: &WasmFeatures,
876
+ types: &mut TypeAlloc,
877
+ offset: usize,
878
+ check_limit: bool,
879
+ ) -> Result<()> {
880
+ if check_limit {
881
+ check_max(self.exports.len(), 1, MAX_WASM_EXPORTS, "exports", offset)?;
882
+ }
883
+ self.add_entity(
884
+ &mut ty,
885
+ Some((name.as_str(), ExternKind::Export)),
886
+ features,
887
+ types,
888
+ offset,
889
+ )?;
890
+ self.toplevel_exported_resources.validate_extern(
891
+ name.into(),
892
+ "export",
893
+ &ty,
894
+ types,
895
+ offset,
896
+ &mut self.kebab_named_externs,
897
+ &mut self.exports,
898
+ &mut self.type_size,
899
+ )?;
900
+ Ok(())
901
+ }
902
+
903
+ pub fn lift_function(
904
+ &mut self,
905
+ core_func_index: u32,
906
+ type_index: u32,
907
+ options: Vec<CanonicalOption>,
908
+ types: &TypeList,
909
+ offset: usize,
910
+ ) -> Result<()> {
911
+ let ty = self.function_type_at(type_index, types, offset)?;
912
+ let core_ty = types[self.core_function_at(core_func_index, offset)?].unwrap_func();
913
+
914
+ // Lifting a function is for an export, so match the expected canonical ABI
915
+ // export signature
916
+ let info = ty.lower(types, false);
917
+ self.check_options(Some(core_ty), &info, &options, types, offset)?;
918
+
919
+ if core_ty.params() != info.params.as_slice() {
920
+ bail!(
921
+ offset,
922
+ "lowered parameter types `{:?}` do not match parameter types \
923
+ `{:?}` of core function {core_func_index}",
924
+ info.params.as_slice(),
925
+ core_ty.params(),
926
+ );
927
+ }
928
+
929
+ if core_ty.results() != info.results.as_slice() {
930
+ bail!(
931
+ offset,
932
+ "lowered result types `{:?}` do not match result types \
933
+ `{:?}` of core function {core_func_index}",
934
+ info.results.as_slice(),
935
+ core_ty.results()
936
+ );
937
+ }
938
+
939
+ self.funcs.push(self.types[type_index as usize]);
940
+
941
+ Ok(())
942
+ }
943
+
944
+ pub fn lower_function(
945
+ &mut self,
946
+ func_index: u32,
947
+ options: Vec<CanonicalOption>,
948
+ types: &mut TypeAlloc,
949
+ offset: usize,
950
+ ) -> Result<()> {
951
+ let ty = types[self.function_at(func_index, offset)?].unwrap_component_func();
952
+
953
+ // Lowering a function is for an import, so use a function type that matches
954
+ // the expected canonical ABI import signature.
955
+ let info = ty.lower(types, true);
956
+
957
+ self.check_options(None, &info, &options, types, offset)?;
958
+
959
+ let lowered_ty = Type::Sub(SubType {
960
+ is_final: false,
961
+ supertype_idx: None,
962
+ structural_type: StructuralType::Func(info.into_func_type()),
963
+ });
964
+
965
+ let id = types.push_ty(lowered_ty);
966
+ self.core_funcs.push(id);
967
+
968
+ Ok(())
969
+ }
970
+
971
+ pub fn resource_new(
972
+ &mut self,
973
+ resource: u32,
974
+ types: &mut TypeAlloc,
975
+ offset: usize,
976
+ ) -> Result<()> {
977
+ let rep = self.check_local_resource(resource, types, offset)?;
978
+ let core_ty = Type::Sub(SubType {
979
+ is_final: false,
980
+ supertype_idx: None,
981
+ structural_type: StructuralType::Func(FuncType::new([rep], [ValType::I32])),
982
+ });
983
+ self.core_funcs.push(types.push_ty(core_ty));
984
+ Ok(())
985
+ }
986
+
987
+ pub fn resource_drop(
988
+ &mut self,
989
+ resource: u32,
990
+ types: &mut TypeAlloc,
991
+ offset: usize,
992
+ ) -> Result<()> {
993
+ self.resource_at(resource, types, offset)?;
994
+ let core_ty = Type::Sub(SubType {
995
+ is_final: false,
996
+ supertype_idx: None,
997
+ structural_type: StructuralType::Func(FuncType::new([ValType::I32], [])),
998
+ });
999
+ self.core_funcs.push(types.push_ty(core_ty));
1000
+ Ok(())
1001
+ }
1002
+
1003
+ pub fn resource_rep(
1004
+ &mut self,
1005
+ resource: u32,
1006
+ types: &mut TypeAlloc,
1007
+ offset: usize,
1008
+ ) -> Result<()> {
1009
+ let rep = self.check_local_resource(resource, types, offset)?;
1010
+ let core_ty = Type::Sub(SubType {
1011
+ is_final: false,
1012
+ supertype_idx: None,
1013
+ structural_type: StructuralType::Func(FuncType::new([ValType::I32], [rep])),
1014
+ });
1015
+ self.core_funcs.push(types.push_ty(core_ty));
1016
+ Ok(())
1017
+ }
1018
+
1019
+ fn check_local_resource(&self, idx: u32, types: &TypeList, offset: usize) -> Result<ValType> {
1020
+ let id = self.resource_at(idx, types, offset)?;
1021
+ let resource = types[id].unwrap_resource();
1022
+ match self.defined_resources.get(&resource).and_then(|rep| *rep) {
1023
+ Some(ty) => Ok(ty),
1024
+ None => bail!(offset, "type {idx} is not a local resource"),
1025
+ }
1026
+ }
1027
+
1028
+ fn resource_at<'a>(&self, idx: u32, types: &'a TypeList, offset: usize) -> Result<TypeId> {
1029
+ let id = self.type_at(idx, false, offset)?;
1030
+ match &types[id] {
1031
+ Type::Resource(_) => Ok(id),
1032
+ _ => bail!(offset, "type index {} is not a resource type", idx),
1033
+ }
1034
+ }
1035
+
1036
+ pub fn add_component(&mut self, component: ComponentType, types: &mut TypeAlloc) -> Result<()> {
1037
+ let ty = Type::Component(Box::new(component));
1038
+ let id = types.push_ty(ty);
1039
+ self.components.push(id);
1040
+ Ok(())
1041
+ }
1042
+
1043
+ pub fn add_instance(
1044
+ &mut self,
1045
+ instance: crate::ComponentInstance,
1046
+ features: &WasmFeatures,
1047
+ types: &mut TypeAlloc,
1048
+ offset: usize,
1049
+ ) -> Result<()> {
1050
+ let instance = match instance {
1051
+ crate::ComponentInstance::Instantiate {
1052
+ component_index,
1053
+ args,
1054
+ } => self.instantiate_component(
1055
+ component_index,
1056
+ args.into_vec(),
1057
+ features,
1058
+ types,
1059
+ offset,
1060
+ )?,
1061
+ crate::ComponentInstance::FromExports(exports) => {
1062
+ self.instantiate_exports(exports.into_vec(), features, types, offset)?
1063
+ }
1064
+ };
1065
+
1066
+ self.instances.push(instance);
1067
+
1068
+ Ok(())
1069
+ }
1070
+
1071
+ pub fn add_alias(
1072
+ components: &mut [Self],
1073
+ alias: crate::ComponentAlias,
1074
+ features: &WasmFeatures,
1075
+ types: &mut TypeAlloc,
1076
+ offset: usize,
1077
+ ) -> Result<()> {
1078
+ match alias {
1079
+ crate::ComponentAlias::InstanceExport {
1080
+ instance_index,
1081
+ kind,
1082
+ name,
1083
+ } => components.last_mut().unwrap().alias_instance_export(
1084
+ instance_index,
1085
+ kind,
1086
+ name,
1087
+ features,
1088
+ types,
1089
+ offset,
1090
+ ),
1091
+ crate::ComponentAlias::CoreInstanceExport {
1092
+ instance_index,
1093
+ kind,
1094
+ name,
1095
+ } => components.last_mut().unwrap().alias_core_instance_export(
1096
+ instance_index,
1097
+ kind,
1098
+ name,
1099
+ types,
1100
+ offset,
1101
+ ),
1102
+ crate::ComponentAlias::Outer { kind, count, index } => match kind {
1103
+ ComponentOuterAliasKind::CoreModule => {
1104
+ Self::alias_module(components, count, index, offset)
1105
+ }
1106
+ ComponentOuterAliasKind::CoreType => {
1107
+ Self::alias_core_type(components, count, index, offset)
1108
+ }
1109
+ ComponentOuterAliasKind::Type => {
1110
+ Self::alias_type(components, count, index, types, offset)
1111
+ }
1112
+ ComponentOuterAliasKind::Component => {
1113
+ Self::alias_component(components, count, index, offset)
1114
+ }
1115
+ },
1116
+ }
1117
+ }
1118
+
1119
+ pub fn add_start(
1120
+ &mut self,
1121
+ func_index: u32,
1122
+ args: &[u32],
1123
+ results: u32,
1124
+ features: &WasmFeatures,
1125
+ types: &TypeList,
1126
+ offset: usize,
1127
+ ) -> Result<()> {
1128
+ if !features.component_model_values {
1129
+ bail!(
1130
+ offset,
1131
+ "support for component model `value`s is not enabled"
1132
+ );
1133
+ }
1134
+ if self.has_start {
1135
+ return Err(BinaryReaderError::new(
1136
+ "component cannot have more than one start function",
1137
+ offset,
1138
+ ));
1139
+ }
1140
+
1141
+ let ft = types[self.function_at(func_index, offset)?].unwrap_component_func();
1142
+
1143
+ if ft.params.len() != args.len() {
1144
+ bail!(
1145
+ offset,
1146
+ "component start function requires {} arguments but was given {}",
1147
+ ft.params.len(),
1148
+ args.len()
1149
+ );
1150
+ }
1151
+
1152
+ if ft.results.len() as u32 != results {
1153
+ bail!(
1154
+ offset,
1155
+ "component start function has a result count of {results} \
1156
+ but the function type has a result count of {type_results}",
1157
+ type_results = ft.results.len(),
1158
+ );
1159
+ }
1160
+
1161
+ let cx = SubtypeCx::new(types, types);
1162
+ for (i, ((_, ty), arg)) in ft.params.iter().zip(args).enumerate() {
1163
+ // Ensure the value's type is a subtype of the parameter type
1164
+ cx.component_val_type(self.value_at(*arg, offset)?, ty, offset)
1165
+ .with_context(|| {
1166
+ format!("value type mismatch for component start function argument {i}")
1167
+ })?;
1168
+ }
1169
+
1170
+ for (_, ty) in ft.results.iter() {
1171
+ self.values.push((*ty, false));
1172
+ }
1173
+
1174
+ self.has_start = true;
1175
+
1176
+ Ok(())
1177
+ }
1178
+
1179
+ fn check_options(
1180
+ &self,
1181
+ core_ty: Option<&FuncType>,
1182
+ info: &LoweringInfo,
1183
+ options: &[CanonicalOption],
1184
+ types: &TypeList,
1185
+ offset: usize,
1186
+ ) -> Result<()> {
1187
+ fn display(option: CanonicalOption) -> &'static str {
1188
+ match option {
1189
+ CanonicalOption::UTF8 => "utf8",
1190
+ CanonicalOption::UTF16 => "utf16",
1191
+ CanonicalOption::CompactUTF16 => "latin1-utf16",
1192
+ CanonicalOption::Memory(_) => "memory",
1193
+ CanonicalOption::Realloc(_) => "realloc",
1194
+ CanonicalOption::PostReturn(_) => "post-return",
1195
+ }
1196
+ }
1197
+
1198
+ let mut encoding = None;
1199
+ let mut memory = None;
1200
+ let mut realloc = None;
1201
+ let mut post_return = None;
1202
+
1203
+ for option in options {
1204
+ match option {
1205
+ CanonicalOption::UTF8 | CanonicalOption::UTF16 | CanonicalOption::CompactUTF16 => {
1206
+ match encoding {
1207
+ Some(existing) => {
1208
+ bail!(
1209
+ offset,
1210
+ "canonical encoding option `{}` conflicts with option `{}`",
1211
+ display(existing),
1212
+ display(*option),
1213
+ )
1214
+ }
1215
+ None => encoding = Some(*option),
1216
+ }
1217
+ }
1218
+ CanonicalOption::Memory(idx) => {
1219
+ memory = match memory {
1220
+ None => {
1221
+ self.memory_at(*idx, offset)?;
1222
+ Some(*idx)
1223
+ }
1224
+ Some(_) => {
1225
+ return Err(BinaryReaderError::new(
1226
+ "canonical option `memory` is specified more than once",
1227
+ offset,
1228
+ ))
1229
+ }
1230
+ }
1231
+ }
1232
+ CanonicalOption::Realloc(idx) => {
1233
+ realloc = match realloc {
1234
+ None => {
1235
+ let ty = types[self.core_function_at(*idx, offset)?].unwrap_func();
1236
+ if ty.params()
1237
+ != [ValType::I32, ValType::I32, ValType::I32, ValType::I32]
1238
+ || ty.results() != [ValType::I32]
1239
+ {
1240
+ return Err(BinaryReaderError::new(
1241
+ "canonical option `realloc` uses a core function with an incorrect signature",
1242
+ offset,
1243
+ ));
1244
+ }
1245
+ Some(*idx)
1246
+ }
1247
+ Some(_) => {
1248
+ return Err(BinaryReaderError::new(
1249
+ "canonical option `realloc` is specified more than once",
1250
+ offset,
1251
+ ))
1252
+ }
1253
+ }
1254
+ }
1255
+ CanonicalOption::PostReturn(idx) => {
1256
+ post_return = match post_return {
1257
+ None => {
1258
+ let core_ty = core_ty.ok_or_else(|| {
1259
+ BinaryReaderError::new(
1260
+ "canonical option `post-return` cannot be specified for lowerings",
1261
+ offset,
1262
+ )
1263
+ })?;
1264
+
1265
+ let ty = types[self.core_function_at(*idx, offset)?].unwrap_func();
1266
+
1267
+ if ty.params() != core_ty.results() || !ty.results().is_empty() {
1268
+ return Err(BinaryReaderError::new(
1269
+ "canonical option `post-return` uses a core function with an incorrect signature",
1270
+ offset,
1271
+ ));
1272
+ }
1273
+ Some(*idx)
1274
+ }
1275
+ Some(_) => {
1276
+ return Err(BinaryReaderError::new(
1277
+ "canonical option `post-return` is specified more than once",
1278
+ offset,
1279
+ ))
1280
+ }
1281
+ }
1282
+ }
1283
+ }
1284
+ }
1285
+
1286
+ if info.requires_memory && memory.is_none() {
1287
+ return Err(BinaryReaderError::new(
1288
+ "canonical option `memory` is required",
1289
+ offset,
1290
+ ));
1291
+ }
1292
+
1293
+ if info.requires_realloc && realloc.is_none() {
1294
+ return Err(BinaryReaderError::new(
1295
+ "canonical option `realloc` is required",
1296
+ offset,
1297
+ ));
1298
+ }
1299
+
1300
+ Ok(())
1301
+ }
1302
+
1303
+ fn check_type_ref(
1304
+ &mut self,
1305
+ ty: &ComponentTypeRef,
1306
+ features: &WasmFeatures,
1307
+ types: &mut TypeAlloc,
1308
+ offset: usize,
1309
+ ) -> Result<ComponentEntityType> {
1310
+ Ok(match ty {
1311
+ ComponentTypeRef::Module(index) => {
1312
+ let id = self.type_at(*index, true, offset)?;
1313
+ match &types[id] {
1314
+ Type::Module(_) => {}
1315
+ _ => bail!(offset, "core type index {index} is not a module type"),
1316
+ }
1317
+ ComponentEntityType::Module(id)
1318
+ }
1319
+ ComponentTypeRef::Func(index) => {
1320
+ let id = self.type_at(*index, false, offset)?;
1321
+ match &types[id] {
1322
+ Type::ComponentFunc(_) => {}
1323
+ _ => bail!(offset, "type index {index} is not a function type"),
1324
+ }
1325
+ ComponentEntityType::Func(id)
1326
+ }
1327
+ ComponentTypeRef::Value(ty) => {
1328
+ self.check_value_support(features, offset)?;
1329
+ let ty = match ty {
1330
+ crate::ComponentValType::Primitive(ty) => ComponentValType::Primitive(*ty),
1331
+ crate::ComponentValType::Type(index) => {
1332
+ ComponentValType::Type(self.defined_type_at(*index, types, offset)?)
1333
+ }
1334
+ };
1335
+ ComponentEntityType::Value(ty)
1336
+ }
1337
+ ComponentTypeRef::Type(TypeBounds::Eq(index)) => {
1338
+ let referenced = self.type_at(*index, false, offset)?;
1339
+ let created = types.with_unique(referenced);
1340
+ ComponentEntityType::Type {
1341
+ referenced,
1342
+ created,
1343
+ }
1344
+ }
1345
+ ComponentTypeRef::Type(TypeBounds::SubResource) => {
1346
+ let id = types.alloc_resource_id();
1347
+ let id = types.push_ty(Type::Resource(id));
1348
+ ComponentEntityType::Type {
1349
+ referenced: id,
1350
+ created: id,
1351
+ }
1352
+ }
1353
+ ComponentTypeRef::Instance(index) => {
1354
+ let id = self.type_at(*index, false, offset)?;
1355
+ match &types[id] {
1356
+ Type::ComponentInstance(_) => {}
1357
+ _ => bail!(offset, "type index {index} is not an instance type"),
1358
+ }
1359
+ ComponentEntityType::Instance(id)
1360
+ }
1361
+ ComponentTypeRef::Component(index) => {
1362
+ let id = self.type_at(*index, false, offset)?;
1363
+ match &types[id] {
1364
+ Type::Component(_) => {}
1365
+ _ => bail!(offset, "type index {index} is not a component type"),
1366
+ }
1367
+ ComponentEntityType::Component(id)
1368
+ }
1369
+ })
1370
+ }
1371
+
1372
+ pub fn export_to_entity_type(
1373
+ &mut self,
1374
+ export: &crate::ComponentExport,
1375
+ features: &WasmFeatures,
1376
+ types: &mut TypeAlloc,
1377
+ offset: usize,
1378
+ ) -> Result<ComponentEntityType> {
1379
+ let actual = match export.kind {
1380
+ ComponentExternalKind::Module => {
1381
+ ComponentEntityType::Module(self.module_at(export.index, offset)?)
1382
+ }
1383
+ ComponentExternalKind::Func => {
1384
+ ComponentEntityType::Func(self.function_at(export.index, offset)?)
1385
+ }
1386
+ ComponentExternalKind::Value => {
1387
+ self.check_value_support(features, offset)?;
1388
+ ComponentEntityType::Value(*self.value_at(export.index, offset)?)
1389
+ }
1390
+ ComponentExternalKind::Type => {
1391
+ let referenced = self.type_at(export.index, false, offset)?;
1392
+ let created = types.with_unique(referenced);
1393
+ ComponentEntityType::Type {
1394
+ referenced,
1395
+ created,
1396
+ }
1397
+ }
1398
+ ComponentExternalKind::Instance => {
1399
+ ComponentEntityType::Instance(self.instance_at(export.index, offset)?)
1400
+ }
1401
+ ComponentExternalKind::Component => {
1402
+ ComponentEntityType::Component(self.component_at(export.index, offset)?)
1403
+ }
1404
+ };
1405
+
1406
+ let ascribed = match &export.ty {
1407
+ Some(ty) => self.check_type_ref(ty, features, types, offset)?,
1408
+ None => return Ok(actual),
1409
+ };
1410
+
1411
+ SubtypeCx::new(types, types)
1412
+ .component_entity_type(&actual, &ascribed, offset)
1413
+ .with_context(|| "ascribed type of export is not compatible with item's type")?;
1414
+
1415
+ Ok(ascribed)
1416
+ }
1417
+
1418
+ fn create_module_type(
1419
+ components: &[Self],
1420
+ decls: Vec<crate::ModuleTypeDeclaration>,
1421
+ features: &WasmFeatures,
1422
+ types: &mut TypeAlloc,
1423
+ offset: usize,
1424
+ ) -> Result<ModuleType> {
1425
+ let mut state = Module::default();
1426
+
1427
+ for decl in decls {
1428
+ match decl {
1429
+ crate::ModuleTypeDeclaration::Type(ty) => {
1430
+ state.add_type(ty, features, types, offset, true)?;
1431
+ }
1432
+ crate::ModuleTypeDeclaration::Export { name, ty } => {
1433
+ let ty = state.check_type_ref(&ty, features, types, offset)?;
1434
+ state.add_export(name, ty, features, offset, true)?;
1435
+ }
1436
+ crate::ModuleTypeDeclaration::OuterAlias { kind, count, index } => {
1437
+ if count > 1 {
1438
+ return Err(BinaryReaderError::new(
1439
+ "outer type aliases in module type declarations are limited to a maximum count of 1",
1440
+ offset,
1441
+ ));
1442
+ }
1443
+ match kind {
1444
+ crate::OuterAliasKind::Type => {
1445
+ let ty = if count == 0 {
1446
+ // Local alias, check the local module state
1447
+ state.type_id_at(index, offset)?
1448
+ } else {
1449
+ // Otherwise, check the enclosing component state
1450
+ let component =
1451
+ Self::check_alias_count(components, count - 1, offset)?;
1452
+ component.type_at(index, true, offset)?
1453
+ };
1454
+
1455
+ check_max(state.types.len(), 1, MAX_WASM_TYPES, "types", offset)?;
1456
+
1457
+ state.types.push(ty);
1458
+ }
1459
+ }
1460
+ }
1461
+ crate::ModuleTypeDeclaration::Import(import) => {
1462
+ state.add_import(import, features, types, offset)?;
1463
+ }
1464
+ }
1465
+ }
1466
+
1467
+ let imports = state.imports_for_module_type(offset)?;
1468
+
1469
+ Ok(ModuleType {
1470
+ type_size: state.type_size,
1471
+ imports,
1472
+ exports: state.exports,
1473
+ })
1474
+ }
1475
+
1476
+ fn create_component_type(
1477
+ components: &mut Vec<Self>,
1478
+ decls: Vec<crate::ComponentTypeDeclaration>,
1479
+ features: &WasmFeatures,
1480
+ types: &mut TypeAlloc,
1481
+ offset: usize,
1482
+ ) -> Result<ComponentType> {
1483
+ components.push(ComponentState::new(ComponentKind::ComponentType));
1484
+
1485
+ for decl in decls {
1486
+ match decl {
1487
+ crate::ComponentTypeDeclaration::CoreType(ty) => {
1488
+ Self::add_core_type(components, ty, features, types, offset, true)?;
1489
+ }
1490
+ crate::ComponentTypeDeclaration::Type(ty) => {
1491
+ Self::add_type(components, ty, features, types, offset, true)?;
1492
+ }
1493
+ crate::ComponentTypeDeclaration::Export { name, ty } => {
1494
+ let current = components.last_mut().unwrap();
1495
+ let ty = current.check_type_ref(&ty, features, types, offset)?;
1496
+ current.add_export(name, ty, features, types, offset, true)?;
1497
+ }
1498
+ crate::ComponentTypeDeclaration::Import(import) => {
1499
+ components
1500
+ .last_mut()
1501
+ .unwrap()
1502
+ .add_import(import, features, types, offset)?;
1503
+ }
1504
+ crate::ComponentTypeDeclaration::Alias(alias) => {
1505
+ Self::add_alias(components, alias, features, types, offset)?;
1506
+ }
1507
+ };
1508
+ }
1509
+
1510
+ components.pop().unwrap().finish(types, offset)
1511
+ }
1512
+
1513
+ fn create_instance_type(
1514
+ components: &mut Vec<Self>,
1515
+ decls: Vec<crate::InstanceTypeDeclaration>,
1516
+ features: &WasmFeatures,
1517
+ types: &mut TypeAlloc,
1518
+ offset: usize,
1519
+ ) -> Result<ComponentInstanceType> {
1520
+ components.push(ComponentState::new(ComponentKind::InstanceType));
1521
+
1522
+ for decl in decls {
1523
+ match decl {
1524
+ crate::InstanceTypeDeclaration::CoreType(ty) => {
1525
+ Self::add_core_type(components, ty, features, types, offset, true)?;
1526
+ }
1527
+ crate::InstanceTypeDeclaration::Type(ty) => {
1528
+ Self::add_type(components, ty, features, types, offset, true)?;
1529
+ }
1530
+ crate::InstanceTypeDeclaration::Export { name, ty } => {
1531
+ let current = components.last_mut().unwrap();
1532
+ let ty = current.check_type_ref(&ty, features, types, offset)?;
1533
+ current.add_export(name, ty, features, types, offset, true)?;
1534
+ }
1535
+ crate::InstanceTypeDeclaration::Alias(alias) => {
1536
+ Self::add_alias(components, alias, features, types, offset)?;
1537
+ }
1538
+ };
1539
+ }
1540
+
1541
+ let mut state = components.pop().unwrap();
1542
+
1543
+ assert!(state.imported_resources.is_empty());
1544
+
1545
+ Ok(ComponentInstanceType {
1546
+ type_size: state.type_size,
1547
+
1548
+ // The defined resources for this instance type are those listed on
1549
+ // the component state. The path to each defined resource is
1550
+ // guaranteed to live within the `explicit_resources` map since,
1551
+ // when in the type context, the introduction of any defined
1552
+ // resource must have been done with `(export "x" (type (sub
1553
+ // resource)))` which, in a sense, "fuses" the introduction of the
1554
+ // variable with the export. This means that all defined resources,
1555
+ // if any, should be guaranteed to have an `explicit_resources` path
1556
+ // listed.
1557
+ defined_resources: mem::take(&mut state.defined_resources)
1558
+ .into_iter()
1559
+ .map(|(id, rep)| {
1560
+ assert!(rep.is_none());
1561
+ id
1562
+ })
1563
+ .collect(),
1564
+
1565
+ // The map of what resources are explicitly exported and where
1566
+ // they're exported is plumbed through as-is.
1567
+ explicit_resources: mem::take(&mut state.explicit_resources),
1568
+
1569
+ exports: mem::take(&mut state.exports),
1570
+ })
1571
+ }
1572
+
1573
+ fn create_function_type(
1574
+ &self,
1575
+ ty: crate::ComponentFuncType,
1576
+ types: &TypeList,
1577
+ offset: usize,
1578
+ ) -> Result<ComponentFuncType> {
1579
+ let mut type_size = 1;
1580
+
1581
+ let mut set =
1582
+ HashSet::with_capacity(std::cmp::max(ty.params.len(), ty.results.type_count()));
1583
+
1584
+ let params = ty
1585
+ .params
1586
+ .iter()
1587
+ .map(|(name, ty)| {
1588
+ let name = to_kebab_str(name, "function parameter", offset)?;
1589
+ if !set.insert(name) {
1590
+ bail!(
1591
+ offset,
1592
+ "function parameter name `{name}` conflicts with previous parameter name `{prev}`",
1593
+ prev = set.get(&name).unwrap(),
1594
+ );
1595
+ }
1596
+
1597
+ let ty = self.create_component_val_type(*ty, types, offset)?;
1598
+ type_size = combine_type_sizes(type_size, ty.type_size(), offset)?;
1599
+ Ok((name.to_owned(), ty))
1600
+ })
1601
+ .collect::<Result<_>>()?;
1602
+
1603
+ set.clear();
1604
+
1605
+ let results = ty
1606
+ .results
1607
+ .iter()
1608
+ .map(|(name, ty)| {
1609
+ let name = name
1610
+ .map(|name| {
1611
+ let name = to_kebab_str(name, "function result", offset)?;
1612
+ if !set.insert(name) {
1613
+ bail!(
1614
+ offset,
1615
+ "function result name `{name}` conflicts with previous result name `{prev}`",
1616
+ prev = set.get(name).unwrap(),
1617
+ );
1618
+ }
1619
+
1620
+ Ok(name.to_owned())
1621
+ })
1622
+ .transpose()?;
1623
+
1624
+ let ty = self.create_component_val_type(*ty, types, offset)?;
1625
+ type_size = combine_type_sizes(type_size, ty.type_size(), offset)?;
1626
+ Ok((name, ty))
1627
+ })
1628
+ .collect::<Result<_>>()?;
1629
+
1630
+ Ok(ComponentFuncType {
1631
+ type_size,
1632
+ params,
1633
+ results,
1634
+ })
1635
+ }
1636
+
1637
+ fn instantiate_module(
1638
+ &self,
1639
+ module_index: u32,
1640
+ module_args: Vec<crate::InstantiationArg>,
1641
+ types: &mut TypeAlloc,
1642
+ offset: usize,
1643
+ ) -> Result<TypeId> {
1644
+ fn insert_arg<'a>(
1645
+ name: &'a str,
1646
+ arg: &'a InstanceType,
1647
+ args: &mut IndexMap<&'a str, &'a InstanceType>,
1648
+ offset: usize,
1649
+ ) -> Result<()> {
1650
+ if args.insert(name, arg).is_some() {
1651
+ bail!(
1652
+ offset,
1653
+ "duplicate module instantiation argument named `{name}`"
1654
+ );
1655
+ }
1656
+
1657
+ Ok(())
1658
+ }
1659
+
1660
+ let module_type_id = self.module_at(module_index, offset)?;
1661
+ let mut args = IndexMap::new();
1662
+
1663
+ // Populate the arguments
1664
+ for module_arg in module_args {
1665
+ match module_arg.kind {
1666
+ InstantiationArgKind::Instance => {
1667
+ let instance_type =
1668
+ types[self.core_instance_at(module_arg.index, offset)?].unwrap_instance();
1669
+ insert_arg(module_arg.name, instance_type, &mut args, offset)?;
1670
+ }
1671
+ }
1672
+ }
1673
+
1674
+ // Validate the arguments
1675
+ let module_type = types[module_type_id].unwrap_module();
1676
+ let cx = SubtypeCx::new(types, types);
1677
+ for ((module, name), expected) in module_type.imports.iter() {
1678
+ let instance = args.get(module.as_str()).ok_or_else(|| {
1679
+ format_err!(
1680
+ offset,
1681
+ "missing module instantiation argument named `{module}`"
1682
+ )
1683
+ })?;
1684
+
1685
+ let arg = instance
1686
+ .internal_exports(types)
1687
+ .get(name.as_str())
1688
+ .ok_or_else(|| {
1689
+ format_err!(
1690
+ offset,
1691
+ "module instantiation argument `{module}` does not \
1692
+ export an item named `{name}`",
1693
+ )
1694
+ })?;
1695
+
1696
+ cx.entity_type(arg, expected, offset).with_context(|| {
1697
+ format!(
1698
+ "type mismatch for export `{name}` of module \
1699
+ instantiation argument `{module}`"
1700
+ )
1701
+ })?;
1702
+ }
1703
+
1704
+ let ty = Type::Instance(Box::new(InstanceType {
1705
+ type_size: module_type
1706
+ .exports
1707
+ .iter()
1708
+ .fold(1, |acc, (_, ty)| acc + ty.type_size()),
1709
+ kind: InstanceTypeKind::Instantiated(module_type_id),
1710
+ }));
1711
+
1712
+ Ok(types.push_ty(ty))
1713
+ }
1714
+
1715
+ fn instantiate_component(
1716
+ &mut self,
1717
+ component_index: u32,
1718
+ component_args: Vec<crate::ComponentInstantiationArg>,
1719
+ features: &WasmFeatures,
1720
+ types: &mut TypeAlloc,
1721
+ offset: usize,
1722
+ ) -> Result<TypeId> {
1723
+ let component_type_id = self.component_at(component_index, offset)?;
1724
+ let mut args = IndexMap::new();
1725
+
1726
+ // Populate the arguments
1727
+ for component_arg in component_args {
1728
+ let ty = match component_arg.kind {
1729
+ ComponentExternalKind::Module => {
1730
+ ComponentEntityType::Module(self.module_at(component_arg.index, offset)?)
1731
+ }
1732
+ ComponentExternalKind::Component => {
1733
+ ComponentEntityType::Component(self.component_at(component_arg.index, offset)?)
1734
+ }
1735
+ ComponentExternalKind::Instance => {
1736
+ ComponentEntityType::Instance(self.instance_at(component_arg.index, offset)?)
1737
+ }
1738
+ ComponentExternalKind::Func => {
1739
+ ComponentEntityType::Func(self.function_at(component_arg.index, offset)?)
1740
+ }
1741
+ ComponentExternalKind::Value => {
1742
+ self.check_value_support(features, offset)?;
1743
+ ComponentEntityType::Value(*self.value_at(component_arg.index, offset)?)
1744
+ }
1745
+ ComponentExternalKind::Type => {
1746
+ let ty = self.type_at(component_arg.index, false, offset)?;
1747
+ ComponentEntityType::Type {
1748
+ referenced: ty,
1749
+ created: ty,
1750
+ }
1751
+ }
1752
+ };
1753
+ match args.entry(component_arg.name.to_string()) {
1754
+ Entry::Occupied(e) => {
1755
+ bail!(
1756
+ offset,
1757
+ "instantiation argument `{name}` conflicts with previous argument `{prev}`",
1758
+ prev = e.key(),
1759
+ name = component_arg.name
1760
+ );
1761
+ }
1762
+ Entry::Vacant(e) => {
1763
+ e.insert(ty);
1764
+ }
1765
+ }
1766
+ }
1767
+
1768
+ // Here comes the fun part of the component model, we're instantiating
1769
+ // the component with type `component_type_id` with the `args`
1770
+ // specified. Easy enough!
1771
+ //
1772
+ // This operation, however, is one of the lynchpins of safety in the
1773
+ // component model. Additionally what this ends up implementing ranges
1774
+ // from "well just check the types are equal" to "let's have a
1775
+ // full-blown ML-style module type system in the component model". There
1776
+ // are primarily two major tricky pieces to the component model which
1777
+ // make this operation, instantiating components, hard:
1778
+ //
1779
+ // 1. Components can import and exports other components. This means
1780
+ // that arguments to instantiation are along the lines of functions
1781
+ // being passed to functions or similar. Effectively this means that
1782
+ // the term "variance" comes into play with either contravariance
1783
+ // or covariance depending on where you are in typechecking. This is
1784
+ // one of the main rationales, however, that this check below is a
1785
+ // check for subtyping as opposed to exact type equivalence. For
1786
+ // example an instance that exports something is a subtype of an
1787
+ // instance that exports nothing. Components get a bit trick since
1788
+ // they both have imports and exports. My way of thinking about it
1789
+ // is "who's asking for what". If you're asking for imports then
1790
+ // I need to at least supply those imports, but I can possibly
1791
+ // supply more. If you're asking for a thing which you'll give a set
1792
+ // of imports, then I can give you something which takes less imports
1793
+ // because what you give still suffices. (things like that). The
1794
+ // real complication with components, however, comes with...
1795
+ //
1796
+ // 2. Resources. Resources in the component model are akin to "abstract
1797
+ // types". They're not abstract in the sense that they have no
1798
+ // representation, they're always backed by a 32-bit integer right
1799
+ // now. Instead they're abstract in the sense that some components
1800
+ // aren't allowed to understand the representation of a resource.
1801
+ // For example if you import a resource you can't get the underlying
1802
+ // internals of it. Furthermore the resource is strictly tracked
1803
+ // within the component with `own` and `borrow` runtime semantics.
1804
+ // The hardest part about resources, though, is handling them as
1805
+ // part of instantiation and subtyping.
1806
+ //
1807
+ // For example one major aspect of resources is that if a component
1808
+ // exports a resource then each instantiation of the component
1809
+ // produces a fresh resource type. This means that the type recorded
1810
+ // for the instantiation here can't simply be "I instantiated
1811
+ // component X" since in such a situation the type of all
1812
+ // instantiations would be the same, which they aren't.
1813
+ //
1814
+ // This sort of subtelty comes up quite frequently for resources.
1815
+ // This file contains references to `imported_resources` and
1816
+ // `defined_resources` for example which refer to the formal
1817
+ // nature of components and their abstract variables. Specifically
1818
+ // for instantiation though we're eventually faced with the problem
1819
+ // of subtype checks where resource subtyping is defined as "does
1820
+ // your id equal mine". Naively implemented that means anything with
1821
+ // resources isn't subtypes of anything else since resource ids are
1822
+ // unique between components. Instead what actually needs to happen
1823
+ // is types need to be substituted.
1824
+ //
1825
+ // Much of the complexity here is not actually apparent here in this
1826
+ // literal one function. Instead it's spread out across validation
1827
+ // in this file and type-checking in the `types.rs` module. Note that
1828
+ // the "spread out" nature isn't because we're bad maintainers
1829
+ // (hopefully), but rather it's quite infectious how many parts need
1830
+ // to handle resources and account for defined/imported variables.
1831
+ //
1832
+ // For example only one subtyping method is called here where `args` is
1833
+ // passed in. This method is quite recursive in its nature though and
1834
+ // will internally touch all the fields that this file maintains to
1835
+ // end up putting into various bits and pieces of type information.
1836
+ //
1837
+ // Unfortunately there's probably not really a succinct way to read
1838
+ // this method and understand everything. If you've written ML module
1839
+ // type systems this will probably look quite familiar, but otherwise
1840
+ // the whole system is not really easily approachable at this time. It's
1841
+ // hoped in the future that there's a formalism to refer to which will
1842
+ // make things more clear as the code would be able to reference this
1843
+ // hypothetical formalism. Until that's the case, though, these
1844
+ // comments are hopefully enough when augmented with communication with
1845
+ // the authors.
1846
+
1847
+ let component_type = types[component_type_id].unwrap_component();
1848
+ let mut exports = component_type.exports.clone();
1849
+ let type_size = component_type
1850
+ .exports
1851
+ .iter()
1852
+ .fold(1, |acc, (_, ty)| acc + ty.type_size());
1853
+
1854
+ // Perform the subtype check that `args` matches the imports of
1855
+ // `component_type_id`. The result of this subtype check is the
1856
+ // production of a mapping of resource types from the imports to the
1857
+ // arguments provided. This is a substitution map which is then used
1858
+ // below to perform a substitution into the exports of the instance
1859
+ // since the types of the exports are now in terms of whatever was
1860
+ // supplied as imports.
1861
+ let mut mapping = SubtypeCx::new(types, types).open_instance_type(
1862
+ &args,
1863
+ component_type_id,
1864
+ ExternKind::Import,
1865
+ offset,
1866
+ )?;
1867
+
1868
+ // Part of the instantiation of a component is that all of its
1869
+ // defined resources become "fresh" on each instantiation. This
1870
+ // means that each instantiation of a component gets brand new type
1871
+ // variables representing its defined resources, modeling that each
1872
+ // instantiation produces distinct types. The freshening is performed
1873
+ // here by allocating new ids and inserting them into `mapping`.
1874
+ //
1875
+ // Note that technically the `mapping` from subtyping should be applied
1876
+ // first and then the mapping for freshening should be applied
1877
+ // afterwards. The keys of the map from subtyping are the imported
1878
+ // resources from this component which are disjoint from its defined
1879
+ // resources. That means it should be possible to place everything
1880
+ // into one large map which maps from:
1881
+ //
1882
+ // * the component's imported resources go to whatever was explicitly
1883
+ // supplied in the import map
1884
+ // * the component's defined resources go to fresh new resources
1885
+ //
1886
+ // These two remapping operations can then get folded into one by
1887
+ // placing everything in the same `mapping` and using that for a remap
1888
+ // only once.
1889
+ let fresh_defined_resources = (0..component_type.defined_resources.len())
1890
+ .map(|_| types.alloc_resource_id())
1891
+ .collect::<IndexSet<_>>();
1892
+ let component_type = types[component_type_id].unwrap_component();
1893
+ for ((old, _path), new) in component_type
1894
+ .defined_resources
1895
+ .iter()
1896
+ .zip(&fresh_defined_resources)
1897
+ {
1898
+ let prev = mapping.resources.insert(*old, *new);
1899
+ assert!(prev.is_none());
1900
+ }
1901
+
1902
+ // Perform the remapping operation over all the exports that will be
1903
+ // listed for the final instance type. Note that this is performed
1904
+ // both for all the export types in addition to the explicitly exported
1905
+ // resources list.
1906
+ //
1907
+ // Note that this is a crucial step of the instantiation process which
1908
+ // is intentionally transforming the type of a component based on the
1909
+ // variables provided by imports and additionally ensuring that all
1910
+ // references to the component's defined resources are rebound to the
1911
+ // fresh ones introduced just above.
1912
+ for entity in exports.values_mut() {
1913
+ types.remap_component_entity(entity, &mut mapping);
1914
+ }
1915
+ let component_type = types[component_type_id].unwrap_component();
1916
+ let explicit_resources = component_type
1917
+ .explicit_resources
1918
+ .iter()
1919
+ .map(|(id, path)| {
1920
+ (
1921
+ mapping.resources.get(id).copied().unwrap_or(*id),
1922
+ path.clone(),
1923
+ )
1924
+ })
1925
+ .collect::<IndexMap<_, _>>();
1926
+
1927
+ // Technically in the last formalism that was consulted in writing this
1928
+ // implementation there are two further steps that are part of the
1929
+ // instantiation process:
1930
+ //
1931
+ // 1. The set of defined resources from the instance created, which are
1932
+ // added to the outer component, is the subset of the instance's
1933
+ // original defined resources and the free variables of the exports.
1934
+ //
1935
+ // 2. Each element of this subset is required to be "explicit in" the
1936
+ // instance, or otherwise explicitly exported somewhere within the
1937
+ // instance.
1938
+ //
1939
+ // With the syntactic structure of the component model, however, neither
1940
+ // of these conditions should be necessary. The main reason for this is
1941
+ // that this function is specifically dealing with instantiation of
1942
+ // components which should already have these properties validated
1943
+ // about them. Subsequently we shouldn't have to re-check them.
1944
+ //
1945
+ // In debug mode, however, do a sanity check.
1946
+ if cfg!(debug_assertions) {
1947
+ let mut free = IndexSet::new();
1948
+ for ty in exports.values() {
1949
+ types.free_variables_component_entity(ty, &mut free);
1950
+ }
1951
+ assert!(fresh_defined_resources.is_subset(&free));
1952
+ for resource in fresh_defined_resources.iter() {
1953
+ assert!(explicit_resources.contains_key(resource));
1954
+ }
1955
+ }
1956
+
1957
+ // And as the final step of the instantiation process all of the
1958
+ // new defined resources from this component instantiation are moved
1959
+ // onto `self`. Note that concrete instances never have defined
1960
+ // resources (see more comments in `instantiate_exports`) so the
1961
+ // `defined_resources` listing in the final type is always empty. This
1962
+ // represents how by having a concrete instance the definitions
1963
+ // referred to in that instance are now problems for the outer
1964
+ // component rather than the inner instance since the instance is bound
1965
+ // to the component.
1966
+ //
1967
+ // All defined resources here have no known representation, so they're
1968
+ // all listed with `None`. Also note that none of the resources were
1969
+ // exported yet so `self.explicit_resources` is not updated yet. If
1970
+ // this instance is exported, however, it'll consult the type's
1971
+ // `explicit_resources` array and use that appropriately.
1972
+ for resource in fresh_defined_resources {
1973
+ self.defined_resources.insert(resource, None);
1974
+ }
1975
+
1976
+ let ty = Type::ComponentInstance(Box::new(ComponentInstanceType {
1977
+ type_size,
1978
+ defined_resources: Default::default(),
1979
+ explicit_resources,
1980
+ exports,
1981
+ }));
1982
+ Ok(types.push_ty(ty))
1983
+ }
1984
+
1985
+ fn instantiate_exports(
1986
+ &mut self,
1987
+ exports: Vec<crate::ComponentExport>,
1988
+ features: &WasmFeatures,
1989
+ types: &mut TypeAlloc,
1990
+ offset: usize,
1991
+ ) -> Result<TypeId> {
1992
+ let mut type_size = 1;
1993
+ let mut inst_exports = IndexMap::new();
1994
+ let mut explicit_resources = IndexMap::new();
1995
+ let mut kebab_names = IndexSet::new();
1996
+
1997
+ // NB: It's intentional that this context is empty since no indices are
1998
+ // introduced in the bag-of-exports construct which means there's no
1999
+ // way syntactically to register something inside of this.
2000
+ let names = KebabNameContext::default();
2001
+
2002
+ for export in exports {
2003
+ assert!(export.ty.is_none());
2004
+ let ty = match export.kind {
2005
+ ComponentExternalKind::Module => {
2006
+ ComponentEntityType::Module(self.module_at(export.index, offset)?)
2007
+ }
2008
+ ComponentExternalKind::Component => {
2009
+ ComponentEntityType::Component(self.component_at(export.index, offset)?)
2010
+ }
2011
+ ComponentExternalKind::Instance => {
2012
+ let ty = self.instance_at(export.index, offset)?;
2013
+
2014
+ // When an instance is exported from an instance then
2015
+ // all explicitly exported resources on the sub-instance are
2016
+ // now also listed as exported resources on the outer
2017
+ // instance, just with one more element in their path.
2018
+ explicit_resources.extend(
2019
+ types[ty]
2020
+ .unwrap_component_instance()
2021
+ .explicit_resources
2022
+ .iter()
2023
+ .map(|(id, path)| {
2024
+ let mut new_path = vec![inst_exports.len()];
2025
+ new_path.extend(path);
2026
+ (*id, new_path)
2027
+ }),
2028
+ );
2029
+ ComponentEntityType::Instance(ty)
2030
+ }
2031
+ ComponentExternalKind::Func => {
2032
+ ComponentEntityType::Func(self.function_at(export.index, offset)?)
2033
+ }
2034
+ ComponentExternalKind::Value => {
2035
+ self.check_value_support(features, offset)?;
2036
+ ComponentEntityType::Value(*self.value_at(export.index, offset)?)
2037
+ }
2038
+ ComponentExternalKind::Type => {
2039
+ let ty = self.type_at(export.index, false, offset)?;
2040
+ // If this is an export of a resource type be sure to
2041
+ // record that in the explicit list with the appropriate
2042
+ // path because if this instance ends up getting used
2043
+ // it'll count towards the "explicit in" check.
2044
+ if let Type::Resource(id) = &types[ty] {
2045
+ explicit_resources.insert(*id, vec![inst_exports.len()]);
2046
+ }
2047
+ ComponentEntityType::Type {
2048
+ referenced: ty,
2049
+ // The created type index here isn't used anywhere
2050
+ // in index spaces because a "bag of exports"
2051
+ // doesn't build up its own index spaces. Just fill
2052
+ // in the same index here in this case as what's
2053
+ // referenced.
2054
+ created: ty,
2055
+ }
2056
+ }
2057
+ };
2058
+
2059
+ names.validate_extern(
2060
+ export.name.into(),
2061
+ "instance export",
2062
+ &ty,
2063
+ types,
2064
+ offset,
2065
+ &mut kebab_names,
2066
+ &mut inst_exports,
2067
+ &mut type_size,
2068
+ )?;
2069
+ }
2070
+
2071
+ let ty = Type::ComponentInstance(Box::new(ComponentInstanceType {
2072
+ type_size,
2073
+ explicit_resources,
2074
+ exports: inst_exports,
2075
+
2076
+ // NB: the list of defined resources for this instance itself
2077
+ // is always empty. Even if this instance exports resources,
2078
+ // it's empty.
2079
+ //
2080
+ // The reason for this is a bit subtle. The general idea, though, is
2081
+ // that the defined resources list here is only used for instance
2082
+ // types that are sort of "floating around" and haven't actually
2083
+ // been attached to something yet. For example when an instance type
2084
+ // is simply declared it can have defined resources introduced
2085
+ // through `(export "name" (type (sub resource)))`. These
2086
+ // definitions, however, are local to the instance itself and aren't
2087
+ // defined elsewhere.
2088
+ //
2089
+ // Here, though, no new definitions were introduced. The instance
2090
+ // created here is a "bag of exports" which could only refer to
2091
+ // preexisting items. This means that inherently no new resources
2092
+ // were created so there's nothing to put in this list. Any
2093
+ // resources referenced by the instance must be bound by the outer
2094
+ // component context or further above.
2095
+ //
2096
+ // Furthermore, however, actual instances of instances, which this
2097
+ // is, aren't allowed to have defined resources. Instead the
2098
+ // resources would have to be injected into the outer component
2099
+ // enclosing the instance. That means that even if bag-of-exports
2100
+ // could declare a new resource then the resource would be moved
2101
+ // from here to `self.defined_resources`. This doesn't exist at this
2102
+ // time, though, so this still remains empty and
2103
+ // `self.defined_resources` remains unperturbed.
2104
+ defined_resources: Default::default(),
2105
+ }));
2106
+
2107
+ Ok(types.push_ty(ty))
2108
+ }
2109
+
2110
+ fn instantiate_core_exports(
2111
+ &mut self,
2112
+ exports: Vec<crate::Export>,
2113
+ types: &mut TypeAlloc,
2114
+ offset: usize,
2115
+ ) -> Result<TypeId> {
2116
+ fn insert_export(
2117
+ name: &str,
2118
+ export: EntityType,
2119
+ exports: &mut IndexMap<String, EntityType>,
2120
+ type_size: &mut u32,
2121
+ offset: usize,
2122
+ ) -> Result<()> {
2123
+ *type_size = combine_type_sizes(*type_size, export.type_size(), offset)?;
2124
+
2125
+ if exports.insert(name.to_string(), export).is_some() {
2126
+ bail!(
2127
+ offset,
2128
+ "duplicate instantiation export name `{name}` already defined",
2129
+ )
2130
+ }
2131
+
2132
+ Ok(())
2133
+ }
2134
+
2135
+ let mut type_size = 1;
2136
+ let mut inst_exports = IndexMap::new();
2137
+ for export in exports {
2138
+ match export.kind {
2139
+ ExternalKind::Func => {
2140
+ insert_export(
2141
+ export.name,
2142
+ EntityType::Func(self.core_function_at(export.index, offset)?),
2143
+ &mut inst_exports,
2144
+ &mut type_size,
2145
+ offset,
2146
+ )?;
2147
+ }
2148
+ ExternalKind::Table => insert_export(
2149
+ export.name,
2150
+ EntityType::Table(*self.table_at(export.index, offset)?),
2151
+ &mut inst_exports,
2152
+ &mut type_size,
2153
+ offset,
2154
+ )?,
2155
+ ExternalKind::Memory => insert_export(
2156
+ export.name,
2157
+ EntityType::Memory(*self.memory_at(export.index, offset)?),
2158
+ &mut inst_exports,
2159
+ &mut type_size,
2160
+ offset,
2161
+ )?,
2162
+ ExternalKind::Global => {
2163
+ insert_export(
2164
+ export.name,
2165
+ EntityType::Global(*self.global_at(export.index, offset)?),
2166
+ &mut inst_exports,
2167
+ &mut type_size,
2168
+ offset,
2169
+ )?;
2170
+ }
2171
+ ExternalKind::Tag => insert_export(
2172
+ export.name,
2173
+ EntityType::Tag(self.core_function_at(export.index, offset)?),
2174
+ &mut inst_exports,
2175
+ &mut type_size,
2176
+ offset,
2177
+ )?,
2178
+ }
2179
+ }
2180
+
2181
+ let ty = Type::Instance(Box::new(InstanceType {
2182
+ type_size,
2183
+ kind: InstanceTypeKind::Exports(inst_exports),
2184
+ }));
2185
+
2186
+ Ok(types.push_ty(ty))
2187
+ }
2188
+
2189
+ fn alias_core_instance_export(
2190
+ &mut self,
2191
+ instance_index: u32,
2192
+ kind: ExternalKind,
2193
+ name: &str,
2194
+ types: &TypeList,
2195
+ offset: usize,
2196
+ ) -> Result<()> {
2197
+ macro_rules! push_module_export {
2198
+ ($expected:path, $collection:ident, $ty:literal) => {{
2199
+ match self.core_instance_export(instance_index, name, types, offset)? {
2200
+ $expected(ty) => {
2201
+ self.$collection.push(*ty);
2202
+ Ok(())
2203
+ }
2204
+ _ => {
2205
+ bail!(
2206
+ offset,
2207
+ "export `{name}` for core instance {instance_index} is not a {}",
2208
+ $ty
2209
+ )
2210
+ }
2211
+ }
2212
+ }};
2213
+ }
2214
+
2215
+ match kind {
2216
+ ExternalKind::Func => {
2217
+ check_max(
2218
+ self.function_count(),
2219
+ 1,
2220
+ MAX_WASM_FUNCTIONS,
2221
+ "functions",
2222
+ offset,
2223
+ )?;
2224
+ push_module_export!(EntityType::Func, core_funcs, "function")
2225
+ }
2226
+ ExternalKind::Table => {
2227
+ check_max(self.core_tables.len(), 1, MAX_WASM_TABLES, "tables", offset)?;
2228
+ push_module_export!(EntityType::Table, core_tables, "table")
2229
+ }
2230
+ ExternalKind::Memory => {
2231
+ check_max(
2232
+ self.core_memories.len(),
2233
+ 1,
2234
+ MAX_WASM_MEMORIES,
2235
+ "memories",
2236
+ offset,
2237
+ )?;
2238
+ push_module_export!(EntityType::Memory, core_memories, "memory")
2239
+ }
2240
+ ExternalKind::Global => {
2241
+ check_max(
2242
+ self.core_globals.len(),
2243
+ 1,
2244
+ MAX_WASM_GLOBALS,
2245
+ "globals",
2246
+ offset,
2247
+ )?;
2248
+ push_module_export!(EntityType::Global, core_globals, "global")
2249
+ }
2250
+ ExternalKind::Tag => {
2251
+ check_max(self.core_tags.len(), 1, MAX_WASM_TAGS, "tags", offset)?;
2252
+ push_module_export!(EntityType::Tag, core_tags, "tag")
2253
+ }
2254
+ }
2255
+ }
2256
+
2257
+ fn alias_instance_export(
2258
+ &mut self,
2259
+ instance_index: u32,
2260
+ kind: ComponentExternalKind,
2261
+ name: &str,
2262
+ features: &WasmFeatures,
2263
+ types: &mut TypeAlloc,
2264
+ offset: usize,
2265
+ ) -> Result<()> {
2266
+ if let ComponentExternalKind::Value = kind {
2267
+ self.check_value_support(features, offset)?;
2268
+ }
2269
+ let mut ty = match types[self.instance_at(instance_index, offset)?]
2270
+ .unwrap_component_instance()
2271
+ .exports
2272
+ .get(name)
2273
+ {
2274
+ Some(ty) => *ty,
2275
+ None => bail!(
2276
+ offset,
2277
+ "instance {instance_index} has no export named `{name}`"
2278
+ ),
2279
+ };
2280
+
2281
+ let ok = match (&ty, kind) {
2282
+ (ComponentEntityType::Module(_), ComponentExternalKind::Module) => true,
2283
+ (ComponentEntityType::Module(_), _) => false,
2284
+ (ComponentEntityType::Component(_), ComponentExternalKind::Component) => true,
2285
+ (ComponentEntityType::Component(_), _) => false,
2286
+ (ComponentEntityType::Func(_), ComponentExternalKind::Func) => true,
2287
+ (ComponentEntityType::Func(_), _) => false,
2288
+ (ComponentEntityType::Instance(_), ComponentExternalKind::Instance) => true,
2289
+ (ComponentEntityType::Instance(_), _) => false,
2290
+ (ComponentEntityType::Value(_), ComponentExternalKind::Value) => true,
2291
+ (ComponentEntityType::Value(_), _) => false,
2292
+ (ComponentEntityType::Type { .. }, ComponentExternalKind::Type) => true,
2293
+ (ComponentEntityType::Type { .. }, _) => false,
2294
+ };
2295
+ if !ok {
2296
+ bail!(
2297
+ offset,
2298
+ "export `{name}` for instance {instance_index} is not a {}",
2299
+ kind.desc(),
2300
+ );
2301
+ }
2302
+
2303
+ self.add_entity(&mut ty, None, features, types, offset)?;
2304
+ Ok(())
2305
+ }
2306
+
2307
+ fn alias_module(components: &mut [Self], count: u32, index: u32, offset: usize) -> Result<()> {
2308
+ let component = Self::check_alias_count(components, count, offset)?;
2309
+ let ty = component.module_at(index, offset)?;
2310
+
2311
+ let current = components.last_mut().unwrap();
2312
+ check_max(
2313
+ current.core_modules.len(),
2314
+ 1,
2315
+ MAX_WASM_MODULES,
2316
+ "modules",
2317
+ offset,
2318
+ )?;
2319
+
2320
+ current.core_modules.push(ty);
2321
+ Ok(())
2322
+ }
2323
+
2324
+ fn alias_component(
2325
+ components: &mut [Self],
2326
+ count: u32,
2327
+ index: u32,
2328
+ offset: usize,
2329
+ ) -> Result<()> {
2330
+ let component = Self::check_alias_count(components, count, offset)?;
2331
+ let ty = component.component_at(index, offset)?;
2332
+
2333
+ let current = components.last_mut().unwrap();
2334
+ check_max(
2335
+ current.components.len(),
2336
+ 1,
2337
+ MAX_WASM_COMPONENTS,
2338
+ "components",
2339
+ offset,
2340
+ )?;
2341
+
2342
+ current.components.push(ty);
2343
+ Ok(())
2344
+ }
2345
+
2346
+ fn alias_core_type(
2347
+ components: &mut [Self],
2348
+ count: u32,
2349
+ index: u32,
2350
+ offset: usize,
2351
+ ) -> Result<()> {
2352
+ let component = Self::check_alias_count(components, count, offset)?;
2353
+ let ty = component.type_at(index, true, offset)?;
2354
+
2355
+ let current = components.last_mut().unwrap();
2356
+ check_max(current.type_count(), 1, MAX_WASM_TYPES, "types", offset)?;
2357
+
2358
+ current.core_types.push(ty);
2359
+
2360
+ Ok(())
2361
+ }
2362
+
2363
+ fn alias_type(
2364
+ components: &mut [Self],
2365
+ count: u32,
2366
+ index: u32,
2367
+ types: &mut TypeAlloc,
2368
+ offset: usize,
2369
+ ) -> Result<()> {
2370
+ let component = Self::check_alias_count(components, count, offset)?;
2371
+ let ty = component.type_at(index, false, offset)?;
2372
+
2373
+ // If `count` "crossed a component boundary", meaning that it went from
2374
+ // one component to another, then this must additionally verify that
2375
+ // `ty` has no free variables with respect to resources. This is
2376
+ // intended to preserve the property for components where each component
2377
+ // is an isolated unit that can theoretically be extracted from other
2378
+ // components. If resources from other components were allowed to leak
2379
+ // in then it would prevent that.
2380
+ //
2381
+ // This check is done by calculating the `pos` within `components` that
2382
+ // our target `component` above was selected at. Once this is acquired
2383
+ // the component to the "right" is checked, and if that's a component
2384
+ // then it's considered as crossing a component boundary meaning the
2385
+ // free variables check runs.
2386
+ //
2387
+ // The reason this works is that in the list of `ComponentState` types
2388
+ // it's guaranteed that any `is_type` components are contiguous at the
2389
+ // end of the array. This means that if state one level deeper than the
2390
+ // target of this alias is a `!is_type` component, then the target must
2391
+ // be a component as well. If the one-level deeper state `is_type` then
2392
+ // the target is either a type or a component, both of which are valid
2393
+ // (as aliases can reach the enclosing component and have as many free
2394
+ // variables as they want).
2395
+ let pos_after_component = components.len() - (count as usize);
2396
+ if let Some(component) = components.get(pos_after_component) {
2397
+ if component.kind == ComponentKind::Component {
2398
+ let mut free = IndexSet::new();
2399
+ types.free_variables_type_id(ty, &mut free);
2400
+ if !free.is_empty() {
2401
+ bail!(
2402
+ offset,
2403
+ "cannot alias outer type which transitively refers \
2404
+ to resources not defined in the current component"
2405
+ );
2406
+ }
2407
+ }
2408
+ }
2409
+
2410
+ let current = components.last_mut().unwrap();
2411
+ check_max(current.type_count(), 1, MAX_WASM_TYPES, "types", offset)?;
2412
+
2413
+ current.types.push(ty);
2414
+
2415
+ Ok(())
2416
+ }
2417
+
2418
+ fn check_alias_count(components: &[Self], count: u32, offset: usize) -> Result<&Self> {
2419
+ let count = count as usize;
2420
+ if count >= components.len() {
2421
+ bail!(offset, "invalid outer alias count of {count}");
2422
+ }
2423
+
2424
+ Ok(&components[components.len() - count - 1])
2425
+ }
2426
+
2427
+ fn create_defined_type(
2428
+ &self,
2429
+ ty: crate::ComponentDefinedType,
2430
+ types: &TypeList,
2431
+ offset: usize,
2432
+ ) -> Result<ComponentDefinedType> {
2433
+ match ty {
2434
+ crate::ComponentDefinedType::Primitive(ty) => Ok(ComponentDefinedType::Primitive(ty)),
2435
+ crate::ComponentDefinedType::Record(fields) => {
2436
+ self.create_record_type(fields.as_ref(), types, offset)
2437
+ }
2438
+ crate::ComponentDefinedType::Variant(cases) => {
2439
+ self.create_variant_type(cases.as_ref(), types, offset)
2440
+ }
2441
+ crate::ComponentDefinedType::List(ty) => Ok(ComponentDefinedType::List(
2442
+ self.create_component_val_type(ty, types, offset)?,
2443
+ )),
2444
+ crate::ComponentDefinedType::Tuple(tys) => {
2445
+ self.create_tuple_type(tys.as_ref(), types, offset)
2446
+ }
2447
+ crate::ComponentDefinedType::Flags(names) => {
2448
+ self.create_flags_type(names.as_ref(), offset)
2449
+ }
2450
+ crate::ComponentDefinedType::Enum(cases) => {
2451
+ self.create_enum_type(cases.as_ref(), offset)
2452
+ }
2453
+ crate::ComponentDefinedType::Union(tys) => {
2454
+ self.create_union_type(tys.as_ref(), types, offset)
2455
+ }
2456
+ crate::ComponentDefinedType::Option(ty) => Ok(ComponentDefinedType::Option(
2457
+ self.create_component_val_type(ty, types, offset)?,
2458
+ )),
2459
+ crate::ComponentDefinedType::Result { ok, err } => Ok(ComponentDefinedType::Result {
2460
+ ok: ok
2461
+ .map(|ty| self.create_component_val_type(ty, types, offset))
2462
+ .transpose()?,
2463
+ err: err
2464
+ .map(|ty| self.create_component_val_type(ty, types, offset))
2465
+ .transpose()?,
2466
+ }),
2467
+ crate::ComponentDefinedType::Own(idx) => Ok(ComponentDefinedType::Own(
2468
+ self.resource_at(idx, types, offset)?,
2469
+ )),
2470
+ crate::ComponentDefinedType::Borrow(idx) => Ok(ComponentDefinedType::Borrow(
2471
+ self.resource_at(idx, types, offset)?,
2472
+ )),
2473
+ }
2474
+ }
2475
+
2476
+ fn create_record_type(
2477
+ &self,
2478
+ fields: &[(&str, crate::ComponentValType)],
2479
+ types: &TypeList,
2480
+ offset: usize,
2481
+ ) -> Result<ComponentDefinedType> {
2482
+ let mut type_size = 1;
2483
+ let mut field_map = IndexMap::with_capacity(fields.len());
2484
+
2485
+ if fields.is_empty() {
2486
+ bail!(offset, "record type must have at least one field");
2487
+ }
2488
+
2489
+ for (name, ty) in fields {
2490
+ let name = to_kebab_str(name, "record field", offset)?;
2491
+ let ty = self.create_component_val_type(*ty, types, offset)?;
2492
+
2493
+ match field_map.entry(name.to_owned()) {
2494
+ Entry::Occupied(e) => bail!(
2495
+ offset,
2496
+ "record field name `{name}` conflicts with previous field name `{prev}`",
2497
+ prev = e.key()
2498
+ ),
2499
+ Entry::Vacant(e) => {
2500
+ type_size = combine_type_sizes(type_size, ty.type_size(), offset)?;
2501
+ e.insert(ty);
2502
+ }
2503
+ }
2504
+ }
2505
+
2506
+ Ok(ComponentDefinedType::Record(RecordType {
2507
+ type_size,
2508
+ fields: field_map,
2509
+ }))
2510
+ }
2511
+
2512
+ fn create_variant_type(
2513
+ &self,
2514
+ cases: &[crate::VariantCase],
2515
+ types: &TypeList,
2516
+ offset: usize,
2517
+ ) -> Result<ComponentDefinedType> {
2518
+ let mut type_size = 1;
2519
+ let mut case_map: IndexMap<KebabString, VariantCase> = IndexMap::with_capacity(cases.len());
2520
+
2521
+ if cases.is_empty() {
2522
+ bail!(offset, "variant type must have at least one case");
2523
+ }
2524
+
2525
+ if cases.len() > u32::MAX as usize {
2526
+ return Err(BinaryReaderError::new(
2527
+ "variant type cannot be represented with a 32-bit discriminant value",
2528
+ offset,
2529
+ ));
2530
+ }
2531
+
2532
+ for (i, case) in cases.iter().enumerate() {
2533
+ if let Some(refines) = case.refines {
2534
+ if refines >= i as u32 {
2535
+ return Err(BinaryReaderError::new(
2536
+ "variant case can only refine a previously defined case",
2537
+ offset,
2538
+ ));
2539
+ }
2540
+ }
2541
+
2542
+ let name = to_kebab_str(case.name, "variant case", offset)?;
2543
+
2544
+ let ty = case
2545
+ .ty
2546
+ .map(|ty| self.create_component_val_type(ty, types, offset))
2547
+ .transpose()?;
2548
+
2549
+ match case_map.entry(name.to_owned()) {
2550
+ Entry::Occupied(e) => bail!(
2551
+ offset,
2552
+ "variant case name `{name}` conflicts with previous case name `{prev}`",
2553
+ name = case.name,
2554
+ prev = e.key()
2555
+ ),
2556
+ Entry::Vacant(e) => {
2557
+ type_size = combine_type_sizes(
2558
+ type_size,
2559
+ ty.map(|ty| ty.type_size()).unwrap_or(1),
2560
+ offset,
2561
+ )?;
2562
+
2563
+ // Safety: the use of `KebabStr::new_unchecked` here is safe because the string
2564
+ // was already verified to be kebab case.
2565
+ e.insert(VariantCase {
2566
+ ty,
2567
+ refines: case
2568
+ .refines
2569
+ .map(|i| KebabStr::new_unchecked(cases[i as usize].name).to_owned()),
2570
+ });
2571
+ }
2572
+ }
2573
+ }
2574
+
2575
+ Ok(ComponentDefinedType::Variant(VariantType {
2576
+ type_size,
2577
+ cases: case_map,
2578
+ }))
2579
+ }
2580
+
2581
+ fn create_tuple_type(
2582
+ &self,
2583
+ tys: &[crate::ComponentValType],
2584
+ types: &TypeList,
2585
+ offset: usize,
2586
+ ) -> Result<ComponentDefinedType> {
2587
+ let mut type_size = 1;
2588
+ if tys.is_empty() {
2589
+ bail!(offset, "tuple type must have at least one type");
2590
+ }
2591
+ let types = tys
2592
+ .iter()
2593
+ .map(|ty| {
2594
+ let ty = self.create_component_val_type(*ty, types, offset)?;
2595
+ type_size = combine_type_sizes(type_size, ty.type_size(), offset)?;
2596
+ Ok(ty)
2597
+ })
2598
+ .collect::<Result<_>>()?;
2599
+
2600
+ Ok(ComponentDefinedType::Tuple(TupleType { type_size, types }))
2601
+ }
2602
+
2603
+ fn create_flags_type(&self, names: &[&str], offset: usize) -> Result<ComponentDefinedType> {
2604
+ let mut names_set = IndexSet::with_capacity(names.len());
2605
+
2606
+ if names.is_empty() {
2607
+ bail!(offset, "flags must have at least one entry");
2608
+ }
2609
+
2610
+ for name in names {
2611
+ let name = to_kebab_str(name, "flag", offset)?;
2612
+ if !names_set.insert(name.to_owned()) {
2613
+ bail!(
2614
+ offset,
2615
+ "flag name `{name}` conflicts with previous flag name `{prev}`",
2616
+ prev = names_set.get(name).unwrap()
2617
+ );
2618
+ }
2619
+ }
2620
+
2621
+ Ok(ComponentDefinedType::Flags(names_set))
2622
+ }
2623
+
2624
+ fn create_enum_type(&self, cases: &[&str], offset: usize) -> Result<ComponentDefinedType> {
2625
+ if cases.len() > u32::MAX as usize {
2626
+ return Err(BinaryReaderError::new(
2627
+ "enumeration type cannot be represented with a 32-bit discriminant value",
2628
+ offset,
2629
+ ));
2630
+ }
2631
+
2632
+ if cases.is_empty() {
2633
+ bail!(offset, "enum type must have at least one variant");
2634
+ }
2635
+
2636
+ let mut tags = IndexSet::with_capacity(cases.len());
2637
+
2638
+ for tag in cases {
2639
+ let tag = to_kebab_str(tag, "enum tag", offset)?;
2640
+ if !tags.insert(tag.to_owned()) {
2641
+ bail!(
2642
+ offset,
2643
+ "enum tag name `{tag}` conflicts with previous tag name `{prev}`",
2644
+ prev = tags.get(tag).unwrap()
2645
+ );
2646
+ }
2647
+ }
2648
+
2649
+ Ok(ComponentDefinedType::Enum(tags))
2650
+ }
2651
+
2652
+ fn create_union_type(
2653
+ &self,
2654
+ tys: &[crate::ComponentValType],
2655
+ types: &TypeList,
2656
+ offset: usize,
2657
+ ) -> Result<ComponentDefinedType> {
2658
+ let mut type_size = 1;
2659
+ if tys.is_empty() {
2660
+ bail!(offset, "union type must have at least one case");
2661
+ }
2662
+ let types = tys
2663
+ .iter()
2664
+ .map(|ty| {
2665
+ let ty = self.create_component_val_type(*ty, types, offset)?;
2666
+ type_size = combine_type_sizes(type_size, ty.type_size(), offset)?;
2667
+ Ok(ty)
2668
+ })
2669
+ .collect::<Result<_>>()?;
2670
+
2671
+ Ok(ComponentDefinedType::Union(UnionType { type_size, types }))
2672
+ }
2673
+
2674
+ fn create_component_val_type(
2675
+ &self,
2676
+ ty: crate::ComponentValType,
2677
+ types: &TypeList,
2678
+ offset: usize,
2679
+ ) -> Result<ComponentValType> {
2680
+ Ok(match ty {
2681
+ crate::ComponentValType::Primitive(pt) => ComponentValType::Primitive(pt),
2682
+ crate::ComponentValType::Type(idx) => {
2683
+ ComponentValType::Type(self.defined_type_at(idx, types, offset)?)
2684
+ }
2685
+ })
2686
+ }
2687
+
2688
+ pub fn type_at(&self, idx: u32, core: bool, offset: usize) -> Result<TypeId> {
2689
+ let types = if core { &self.core_types } else { &self.types };
2690
+ types
2691
+ .get(idx as usize)
2692
+ .copied()
2693
+ .ok_or_else(|| format_err!(offset, "unknown type {idx}: type index out of bounds"))
2694
+ }
2695
+
2696
+ fn function_type_at<'a>(
2697
+ &self,
2698
+ idx: u32,
2699
+ types: &'a TypeList,
2700
+ offset: usize,
2701
+ ) -> Result<&'a ComponentFuncType> {
2702
+ match &types[self.type_at(idx, false, offset)?] {
2703
+ Type::ComponentFunc(f) => Ok(f),
2704
+ _ => bail!(offset, "type index {idx} is not a function type"),
2705
+ }
2706
+ }
2707
+
2708
+ fn function_at(&self, idx: u32, offset: usize) -> Result<TypeId> {
2709
+ self.funcs.get(idx as usize).copied().ok_or_else(|| {
2710
+ format_err!(
2711
+ offset,
2712
+ "unknown function {idx}: function index out of bounds"
2713
+ )
2714
+ })
2715
+ }
2716
+
2717
+ fn component_at(&self, idx: u32, offset: usize) -> Result<TypeId> {
2718
+ self.components.get(idx as usize).copied().ok_or_else(|| {
2719
+ format_err!(
2720
+ offset,
2721
+ "unknown component {idx}: component index out of bounds"
2722
+ )
2723
+ })
2724
+ }
2725
+
2726
+ fn instance_at(&self, idx: u32, offset: usize) -> Result<TypeId> {
2727
+ self.instances.get(idx as usize).copied().ok_or_else(|| {
2728
+ format_err!(
2729
+ offset,
2730
+ "unknown instance {idx}: instance index out of bounds"
2731
+ )
2732
+ })
2733
+ }
2734
+
2735
+ fn value_at(&mut self, idx: u32, offset: usize) -> Result<&ComponentValType> {
2736
+ match self.values.get_mut(idx as usize) {
2737
+ Some((ty, used)) if !*used => {
2738
+ *used = true;
2739
+ Ok(ty)
2740
+ }
2741
+ Some(_) => bail!(offset, "value {idx} cannot be used more than once"),
2742
+ None => bail!(offset, "unknown value {idx}: value index out of bounds"),
2743
+ }
2744
+ }
2745
+
2746
+ fn defined_type_at(&self, idx: u32, types: &TypeList, offset: usize) -> Result<TypeId> {
2747
+ let id = self.type_at(idx, false, offset)?;
2748
+ match &types[id] {
2749
+ Type::Defined(_) => Ok(id),
2750
+ _ => bail!(offset, "type index {} is not a defined type", idx),
2751
+ }
2752
+ }
2753
+
2754
+ fn core_function_at(&self, idx: u32, offset: usize) -> Result<TypeId> {
2755
+ match self.core_funcs.get(idx as usize) {
2756
+ Some(id) => Ok(*id),
2757
+ None => bail!(
2758
+ offset,
2759
+ "unknown core function {idx}: function index out of bounds"
2760
+ ),
2761
+ }
2762
+ }
2763
+
2764
+ fn module_at(&self, idx: u32, offset: usize) -> Result<TypeId> {
2765
+ match self.core_modules.get(idx as usize) {
2766
+ Some(id) => Ok(*id),
2767
+ None => bail!(offset, "unknown module {idx}: module index out of bounds"),
2768
+ }
2769
+ }
2770
+
2771
+ fn core_instance_at(&self, idx: u32, offset: usize) -> Result<TypeId> {
2772
+ match self.core_instances.get(idx as usize) {
2773
+ Some(id) => Ok(*id),
2774
+ None => bail!(
2775
+ offset,
2776
+ "unknown core instance {idx}: instance index out of bounds"
2777
+ ),
2778
+ }
2779
+ }
2780
+
2781
+ fn core_instance_export<'a>(
2782
+ &self,
2783
+ instance_index: u32,
2784
+ name: &str,
2785
+ types: &'a TypeList,
2786
+ offset: usize,
2787
+ ) -> Result<&'a EntityType> {
2788
+ match types[self.core_instance_at(instance_index, offset)?]
2789
+ .unwrap_instance()
2790
+ .internal_exports(types)
2791
+ .get(name)
2792
+ {
2793
+ Some(export) => Ok(export),
2794
+ None => bail!(
2795
+ offset,
2796
+ "core instance {instance_index} has no export named `{name}`"
2797
+ ),
2798
+ }
2799
+ }
2800
+
2801
+ fn global_at(&self, idx: u32, offset: usize) -> Result<&GlobalType> {
2802
+ match self.core_globals.get(idx as usize) {
2803
+ Some(t) => Ok(t),
2804
+ None => bail!(offset, "unknown global {idx}: global index out of bounds"),
2805
+ }
2806
+ }
2807
+
2808
+ fn table_at(&self, idx: u32, offset: usize) -> Result<&TableType> {
2809
+ match self.core_tables.get(idx as usize) {
2810
+ Some(t) => Ok(t),
2811
+ None => bail!(offset, "unknown table {idx}: table index out of bounds"),
2812
+ }
2813
+ }
2814
+
2815
+ fn memory_at(&self, idx: u32, offset: usize) -> Result<&MemoryType> {
2816
+ match self.core_memories.get(idx as usize) {
2817
+ Some(t) => Ok(t),
2818
+ None => bail!(offset, "unknown memory {idx}: memory index out of bounds"),
2819
+ }
2820
+ }
2821
+
2822
+ /// Completes the translation of this component, performing final
2823
+ /// validation of its structure.
2824
+ ///
2825
+ /// This method is required to be called for translating all components.
2826
+ /// Internally this will convert local data structures into a
2827
+ /// `ComponentType` which is suitable to use to describe the type of this
2828
+ /// component.
2829
+ pub fn finish(&mut self, types: &TypeAlloc, offset: usize) -> Result<ComponentType> {
2830
+ let mut ty = ComponentType {
2831
+ // Inherit some fields based on translation of the component.
2832
+ type_size: self.type_size,
2833
+ imports: self.imports.clone(),
2834
+ exports: self.exports.clone(),
2835
+
2836
+ // This is filled in as a subset of `self.defined_resources`
2837
+ // depending on what's actually used by the exports. See the
2838
+ // bottom of this function.
2839
+ defined_resources: Default::default(),
2840
+
2841
+ // These are inherited directly from what was calculated for this
2842
+ // component.
2843
+ imported_resources: mem::take(&mut self.imported_resources)
2844
+ .into_iter()
2845
+ .collect(),
2846
+ explicit_resources: mem::take(&mut self.explicit_resources),
2847
+ };
2848
+
2849
+ // Collect all "free variables", or resources, from the imports of this
2850
+ // component. None of the resources defined within this component can
2851
+ // be used as part of the exports. This set is then used to reject any
2852
+ // of `self.defined_resources` which show up.
2853
+ let mut free = IndexSet::default();
2854
+ for ty in ty.imports.values() {
2855
+ types.free_variables_component_entity(ty, &mut free);
2856
+ }
2857
+ for (resource, _path) in self.defined_resources.iter() {
2858
+ // FIXME: this error message is quite opaque and doesn't indicate
2859
+ // more contextual information such as:
2860
+ //
2861
+ // * what was the exported resource found in the imports
2862
+ // * which import was the resource found within
2863
+ //
2864
+ // These are possible to calculate here if necessary, however.
2865
+ if free.contains(resource) {
2866
+ bail!(offset, "local resource type found in imports");
2867
+ }
2868
+ }
2869
+
2870
+ // The next step in validation a component, with respect to resources,
2871
+ // is to minimize the set of defined resources to only those that
2872
+ // are actually used by the exports. This weeds out resources that are
2873
+ // defined, used within a component, and never exported, for example.
2874
+ //
2875
+ // The free variables of all exports are inserted into the `free` set
2876
+ // (which is reused from the imports after clearing it). The defined
2877
+ // resources calculated for this component are then inserted into this
2878
+ // type's list of defined resources if it's contained somewhere in
2879
+ // the free variables.
2880
+ //
2881
+ // Note that at the same time all defined resources must be exported,
2882
+ // somehow, transitively from this component. The `explicit_resources`
2883
+ // map is consulted for this purpose which lists all explicitly
2884
+ // exported resources in the component, regardless from whence they
2885
+ // came. If not present in this map then it's not exported and an error
2886
+ // is returned.
2887
+ //
2888
+ // NB: the "types are exported" check is probably sufficient nowadays
2889
+ // that the check of the `explicit_resources` map is probably not
2890
+ // necessary, but it's left here for completeness and out of an
2891
+ // abundance of caution.
2892
+ free.clear();
2893
+ for ty in ty.exports.values() {
2894
+ types.free_variables_component_entity(ty, &mut free);
2895
+ }
2896
+ for (id, _rep) in mem::take(&mut self.defined_resources) {
2897
+ if !free.contains(&id) {
2898
+ continue;
2899
+ }
2900
+
2901
+ let path = match ty.explicit_resources.get(&id).cloned() {
2902
+ Some(path) => path,
2903
+ // FIXME: this error message is quite opaque and doesn't
2904
+ // indicate more contextual information such as:
2905
+ //
2906
+ // * which resource wasn't found in an export
2907
+ // * which export has a reference to the resource
2908
+ //
2909
+ // These are possible to calculate here if necessary, however.
2910
+ None => bail!(
2911
+ offset,
2912
+ "local resource type found in export but not exported itself"
2913
+ ),
2914
+ };
2915
+
2916
+ ty.defined_resources.push((id, path));
2917
+ }
2918
+
2919
+ Ok(ty)
2920
+ }
2921
+
2922
+ fn check_value_support(&self, features: &WasmFeatures, offset: usize) -> Result<()> {
2923
+ if !features.component_model_values {
2924
+ bail!(
2925
+ offset,
2926
+ "support for component model `value`s is not enabled"
2927
+ );
2928
+ }
2929
+ Ok(())
2930
+ }
2931
+ }
2932
+
2933
+ impl KebabNameContext {
2934
+ /// Registers that the resource `id` is named `name` within this context.
2935
+ fn register(&mut self, name: &str, id: TypeId) {
2936
+ let idx = self.all_resource_names.len();
2937
+ let prev = self.resource_name_map.insert(id, idx);
2938
+ assert!(prev.is_none());
2939
+ self.all_resource_names.insert(name.to_string());
2940
+ }
2941
+
2942
+ fn validate_extern(
2943
+ &self,
2944
+ name: ComponentExternName<'_>,
2945
+ desc: &str,
2946
+ ty: &ComponentEntityType,
2947
+ types: &TypeAlloc,
2948
+ offset: usize,
2949
+ kebab_names: &mut IndexSet<KebabName>,
2950
+ items: &mut IndexMap<String, ComponentEntityType>,
2951
+ type_size: &mut u32,
2952
+ ) -> Result<()> {
2953
+ // First validate that `name` is even a valid kebab name, meaning it's
2954
+ // in kebab-case, is an ID, etc.
2955
+ let kebab = KebabName::new(name, offset).with_context(|| {
2956
+ format!("{desc} name `{}` is not a valid extern name", name.as_str())
2957
+ })?;
2958
+
2959
+ // Validate that the kebab name, if it has structure such as
2960
+ // `[method]a.b`, is indeed valid with respect to known resources.
2961
+ self.validate(&kebab, ty, types, offset)
2962
+ .with_context(|| format!("{desc} name `{kebab}` is not valid"))?;
2963
+
2964
+ // Top-level kebab-names must all be unique, even between both imports
2965
+ // and exports ot a component. For those names consult the `kebab_names`
2966
+ // set.
2967
+ if let ComponentExternName::Kebab(_) = name {
2968
+ if let Some(prev) = kebab_names.replace(kebab.clone()) {
2969
+ bail!(
2970
+ offset,
2971
+ "{desc} name `{kebab}` conflicts with previous name `{prev}`",
2972
+ );
2973
+ }
2974
+ }
2975
+
2976
+ // Otherwise all strings must be unique, regardless of their name, so
2977
+ // consult the `items` set to ensure that we're not for example
2978
+ // importing the same interface ID twice.
2979
+ match items.entry(kebab.into()) {
2980
+ Entry::Occupied(e) => {
2981
+ bail!(
2982
+ offset,
2983
+ "{desc} name `{name}` conflicts with previous name `{prev}`",
2984
+ name = name.as_str(),
2985
+ prev = e.key(),
2986
+ );
2987
+ }
2988
+ Entry::Vacant(e) => {
2989
+ e.insert(*ty);
2990
+ *type_size = combine_type_sizes(*type_size, ty.type_size(), offset)?;
2991
+ }
2992
+ }
2993
+ Ok(())
2994
+ }
2995
+
2996
+ /// Validates that the `name` provided is allowed to have the type `ty`.
2997
+ fn validate(
2998
+ &self,
2999
+ name: &KebabName,
3000
+ ty: &ComponentEntityType,
3001
+ types: &TypeAlloc,
3002
+ offset: usize,
3003
+ ) -> Result<()> {
3004
+ let func = || {
3005
+ let id = match ty {
3006
+ ComponentEntityType::Func(id) => *id,
3007
+ _ => bail!(offset, "item is not a func"),
3008
+ };
3009
+ Ok(types[id].unwrap_component_func())
3010
+ };
3011
+ match name.kind() {
3012
+ // Normal kebab name or id? No validation necessary.
3013
+ KebabNameKind::Normal(_) | KebabNameKind::Id { .. } => {}
3014
+
3015
+ // Constructors must return `(own $resource)` and the `$resource`
3016
+ // must be named within this context to match `rname`
3017
+ KebabNameKind::Constructor(rname) => {
3018
+ let ty = func()?;
3019
+ if ty.results.len() != 1 {
3020
+ bail!(offset, "function should return one value");
3021
+ }
3022
+ let ty = ty.results[0].1;
3023
+ let resource = match ty {
3024
+ ComponentValType::Primitive(_) => None,
3025
+ ComponentValType::Type(ty) => match &types[ty] {
3026
+ Type::Defined(ComponentDefinedType::Own(id)) => Some(id),
3027
+ _ => None,
3028
+ },
3029
+ };
3030
+ let resource = match resource {
3031
+ Some(id) => id,
3032
+ None => bail!(offset, "function should return `(own $T)`"),
3033
+ };
3034
+ self.validate_resource_name(*resource, rname, offset)?;
3035
+ }
3036
+
3037
+ // Methods must take `(param "self" (borrow $resource))` as the
3038
+ // first argument where `$resources` matches the name `resource` as
3039
+ // named in this context.
3040
+ KebabNameKind::Method { resource, .. } => {
3041
+ let ty = func()?;
3042
+ if ty.params.len() == 0 {
3043
+ bail!(offset, "function should have at least one argument");
3044
+ }
3045
+ let (pname, pty) = &ty.params[0];
3046
+ if pname.as_str() != "self" {
3047
+ bail!(
3048
+ offset,
3049
+ "function should have a first argument called `self`",
3050
+ );
3051
+ }
3052
+ let id = match pty {
3053
+ ComponentValType::Primitive(_) => None,
3054
+ ComponentValType::Type(ty) => match &types[*ty] {
3055
+ Type::Defined(ComponentDefinedType::Borrow(id)) => Some(id),
3056
+ _ => None,
3057
+ },
3058
+ };
3059
+ let id = match id {
3060
+ Some(id) => id,
3061
+ None => bail!(
3062
+ offset,
3063
+ "function should take a first argument of `(borrow $T)`"
3064
+ ),
3065
+ };
3066
+ self.validate_resource_name(*id, resource, offset)?;
3067
+ }
3068
+
3069
+ // Static methods don't have much validation beyond that they must
3070
+ // be a function and the resource name referred to must already be
3071
+ // in this context.
3072
+ KebabNameKind::Static { resource, .. } => {
3073
+ func()?;
3074
+ if !self.all_resource_names.contains(resource.as_str()) {
3075
+ bail!(offset, "static resource name is not known in this context");
3076
+ }
3077
+ }
3078
+ }
3079
+
3080
+ Ok(())
3081
+ }
3082
+
3083
+ fn validate_resource_name(&self, id: TypeId, name: &KebabStr, offset: usize) -> Result<()> {
3084
+ let expected_name_idx = match self.resource_name_map.get(&id) {
3085
+ Some(idx) => *idx,
3086
+ None => {
3087
+ bail!(
3088
+ offset,
3089
+ "resource used in function does not have a name in this context"
3090
+ )
3091
+ }
3092
+ };
3093
+ let expected_name = &self.all_resource_names[expected_name_idx];
3094
+ if name.as_str() != expected_name {
3095
+ bail!(
3096
+ offset,
3097
+ "function does not match expected \
3098
+ resource name `{expected_name}`"
3099
+ );
3100
+ }
3101
+ Ok(())
3102
+ }
3103
+ }
3104
+
3105
+ use self::append_only::*;
3106
+
3107
+ mod append_only {
3108
+ use indexmap::IndexMap;
3109
+ use std::hash::Hash;
3110
+ use std::ops::Deref;
3111
+
3112
+ pub struct IndexMapAppendOnly<K, V>(IndexMap<K, V>);
3113
+
3114
+ impl<K, V> IndexMapAppendOnly<K, V>
3115
+ where
3116
+ K: Hash + Eq + PartialEq,
3117
+ {
3118
+ pub fn insert(&mut self, key: K, value: V) {
3119
+ let prev = self.0.insert(key, value);
3120
+ assert!(prev.is_none());
3121
+ }
3122
+ }
3123
+
3124
+ impl<K, V> Deref for IndexMapAppendOnly<K, V> {
3125
+ type Target = IndexMap<K, V>;
3126
+ fn deref(&self) -> &IndexMap<K, V> {
3127
+ &self.0
3128
+ }
3129
+ }
3130
+
3131
+ impl<K, V> Default for IndexMapAppendOnly<K, V> {
3132
+ fn default() -> Self {
3133
+ Self(Default::default())
3134
+ }
3135
+ }
3136
+
3137
+ impl<K, V> IntoIterator for IndexMapAppendOnly<K, V> {
3138
+ type IntoIter = <IndexMap<K, V> as IntoIterator>::IntoIter;
3139
+ type Item = <IndexMap<K, V> as IntoIterator>::Item;
3140
+ fn into_iter(self) -> Self::IntoIter {
3141
+ self.0.into_iter()
3142
+ }
3143
+ }
3144
+ }