wasmtime 20.0.2 → 21.0.1
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.
- checksums.yaml +4 -4
- data/Cargo.lock +129 -124
- data/ext/Cargo.toml +8 -6
- data/ext/cargo-vendor/cobs-0.2.3/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/cobs-0.2.3/Cargo.toml +39 -0
- data/ext/cargo-vendor/cobs-0.2.3/LICENSE-APACHE +202 -0
- data/ext/cargo-vendor/cobs-0.2.3/LICENSE-MIT +19 -0
- data/ext/cargo-vendor/cobs-0.2.3/README.md +23 -0
- data/ext/cargo-vendor/cobs-0.2.3/src/dec.rs +360 -0
- data/ext/cargo-vendor/cobs-0.2.3/src/enc.rs +216 -0
- data/ext/cargo-vendor/cobs-0.2.3/src/lib.rs +14 -0
- data/ext/cargo-vendor/cobs-0.2.3/tests/test.rs +265 -0
- data/ext/cargo-vendor/cranelift-bforest-0.108.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/cranelift-bforest-0.108.1/Cargo.toml +40 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/Cargo.toml +189 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/build.rs +266 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/alias_analysis.rs +403 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/context.rs +395 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/ctxhash.rs +167 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/egraph/elaborate.rs +835 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/egraph.rs +839 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/incremental_cache.rs +256 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/ir/instructions.rs +1020 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/abi.rs +1580 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/args.rs +721 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/emit.rs +3846 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/emit_tests.rs +7902 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/imms.rs +1213 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/mod.rs +3094 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/regs.rs +288 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst.isle +4225 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/lower/isle.rs +810 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/pcc.rs +568 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/mod.rs +449 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/abi.rs +1051 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/args.rs +1938 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/emit.rs +2681 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/emit_tests.rs +2197 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/mod.rs +1975 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/regs.rs +168 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/vector.rs +1144 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst.isle +2969 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/lower/isle.rs +625 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/lower.isle +2883 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/abi.rs +1037 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/inst/args.rs +314 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/inst/emit.rs +3646 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/inst/imms.rs +202 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/inst/mod.rs +3421 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/inst/regs.rs +180 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/abi.rs +1410 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst/args.rs +2256 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst/emit.rs +4311 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst/emit_tests.rs +5171 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst/mod.rs +2838 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst/regs.rs +276 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst.isle +5294 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/lower/isle.rs +1064 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/lower.isle +4808 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/lower.rs +337 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/pcc.rs +1014 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/lib.rs +106 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/abi.rs +2506 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/blockorder.rs +465 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/isle.rs +903 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/lower.rs +1432 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/mod.rs +555 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/reg.rs +522 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/valueregs.rs +138 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/vcode.rs +1741 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/nan_canonicalization.rs +130 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/opts/arithmetic.isle +240 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/opts/icmp.isle +215 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/ranges.rs +131 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/remove_constant_phis.rs +419 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/scoped_hash_map.rs +310 -0
- data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/settings.rs +590 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/Cargo.toml +35 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/gen_inst.rs +1278 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/gen_isle.rs +519 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/gen_settings.rs +508 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/gen_types.rs +75 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/isa/riscv64.rs +168 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/isa/x86.rs +414 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/isle.rs +126 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/lib.rs +98 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/shared/settings.rs +348 -0
- data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/srcgen.rs +464 -0
- data/ext/cargo-vendor/cranelift-codegen-shared-0.108.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/cranelift-codegen-shared-0.108.1/Cargo.toml +22 -0
- data/ext/cargo-vendor/cranelift-control-0.108.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/cranelift-control-0.108.1/Cargo.toml +30 -0
- data/ext/cargo-vendor/cranelift-entity-0.108.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/cranelift-entity-0.108.1/Cargo.toml +52 -0
- data/ext/cargo-vendor/cranelift-entity-0.108.1/src/lib.rs +381 -0
- data/ext/cargo-vendor/cranelift-frontend-0.108.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/cranelift-frontend-0.108.1/Cargo.toml +67 -0
- data/ext/cargo-vendor/cranelift-frontend-0.108.1/src/switch.rs +696 -0
- data/ext/cargo-vendor/cranelift-isle-0.108.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/cranelift-isle-0.108.1/Cargo.toml +46 -0
- data/ext/cargo-vendor/cranelift-isle-0.108.1/src/codegen.rs +886 -0
- data/ext/cargo-vendor/cranelift-isle-0.108.1/src/disjointsets.rs +169 -0
- data/ext/cargo-vendor/cranelift-isle-0.108.1/src/lib.rs +33 -0
- data/ext/cargo-vendor/cranelift-isle-0.108.1/src/sema.rs +2492 -0
- data/ext/cargo-vendor/cranelift-isle-0.108.1/src/serialize.rs +846 -0
- data/ext/cargo-vendor/cranelift-isle-0.108.1/src/stablemapset.rs +79 -0
- data/ext/cargo-vendor/cranelift-isle-0.108.1/src/trie_again.rs +684 -0
- data/ext/cargo-vendor/cranelift-native-0.108.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/cranelift-native-0.108.1/Cargo.toml +43 -0
- data/ext/cargo-vendor/cranelift-wasm-0.108.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/cranelift-wasm-0.108.1/Cargo.toml +109 -0
- data/ext/cargo-vendor/cranelift-wasm-0.108.1/src/code_translator.rs +3687 -0
- data/ext/cargo-vendor/cranelift-wasm-0.108.1/src/environ/dummy.rs +906 -0
- data/ext/cargo-vendor/cranelift-wasm-0.108.1/src/environ/spec.rs +945 -0
- data/ext/cargo-vendor/cranelift-wasm-0.108.1/src/sections_translator.rs +389 -0
- data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.22/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.22/Cargo.toml +48 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/CHANGELOG.md +28 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/Cargo.toml +73 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/LICENSE-APACHE +201 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/LICENSE-MIT +25 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/README.md +33 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/ci.sh +21 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/rust-toolchain.toml +3 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/src/adapters/futures_io.rs +65 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/src/adapters/mod.rs +40 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/src/adapters/std_io.rs +107 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/src/adapters/tokio.rs +108 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/src/asynch.rs +230 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/src/blocking.rs +309 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/src/fmt.rs +228 -0
- data/ext/cargo-vendor/embedded-io-0.4.0/src/lib.rs +125 -0
- data/ext/cargo-vendor/libm-0.2.8/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/libm-0.2.8/CHANGELOG.md +123 -0
- data/ext/cargo-vendor/libm-0.2.8/CONTRIBUTING.md +95 -0
- data/ext/cargo-vendor/libm-0.2.8/Cargo.toml +45 -0
- data/ext/cargo-vendor/libm-0.2.8/LICENSE-APACHE +201 -0
- data/ext/cargo-vendor/libm-0.2.8/LICENSE-MIT +25 -0
- data/ext/cargo-vendor/libm-0.2.8/README.md +51 -0
- data/ext/cargo-vendor/libm-0.2.8/build.rs +463 -0
- data/ext/cargo-vendor/libm-0.2.8/src/lib.rs +59 -0
- data/ext/cargo-vendor/libm-0.2.8/src/libm_helper.rs +171 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/acos.rs +112 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/acosf.rs +79 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/acosh.rs +27 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/acoshf.rs +26 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/asin.rs +119 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/asinf.rs +72 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/asinh.rs +40 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/asinhf.rs +39 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/atan.rs +184 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/atan2.rs +126 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/atan2f.rs +91 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/atanf.rs +112 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/atanh.rs +37 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/atanhf.rs +37 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/cbrt.rs +113 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/cbrtf.rs +75 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/ceil.rs +82 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/ceilf.rs +65 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/copysign.rs +12 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/copysignf.rs +12 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/cos.rs +73 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/cosf.rs +83 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/cosh.rs +38 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/coshf.rs +38 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/erf.rs +318 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/erff.rs +230 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/exp.rs +154 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/exp10.rs +22 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/exp10f.rs +22 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/exp2.rs +394 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/exp2f.rs +135 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/expf.rs +101 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/expm1.rs +144 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/expm1f.rs +134 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/expo2.rs +14 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fabs.rs +41 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fabsf.rs +41 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fdim.rs +22 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fdimf.rs +22 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fenv.rs +27 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/floor.rs +81 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/floorf.rs +66 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fma.rs +232 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fmaf.rs +117 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fmax.rs +12 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fmaxf.rs +12 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fmin.rs +12 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fminf.rs +12 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fmod.rs +80 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/fmodf.rs +89 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/frexp.rs +20 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/frexpf.rs +21 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/hypot.rs +74 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/hypotf.rs +43 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/ilogb.rs +32 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/ilogbf.rs +32 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/j0.rs +422 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/j0f.rs +359 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/j1.rs +414 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/j1f.rs +380 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/jn.rs +343 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/jnf.rs +259 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/k_cos.rs +62 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/k_cosf.rs +29 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/k_expo2.rs +14 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/k_expo2f.rs +14 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/k_sin.rs +57 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/k_sinf.rs +30 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/k_tan.rs +105 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/k_tanf.rs +46 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/ldexp.rs +4 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/ldexpf.rs +4 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/lgamma.rs +6 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/lgamma_r.rs +320 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/lgammaf.rs +6 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/lgammaf_r.rs +255 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/log.rs +117 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/log10.rs +117 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/log10f.rs +91 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/log1p.rs +143 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/log1pf.rs +98 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/log2.rs +106 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/log2f.rs +87 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/logf.rs +65 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/mod.rs +370 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/modf.rs +34 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/modff.rs +33 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/nextafter.rs +37 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/nextafterf.rs +37 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/pow.rs +637 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/powf.rs +342 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/rem_pio2.rs +233 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/rem_pio2_large.rs +470 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/rem_pio2f.rs +67 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/remainder.rs +5 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/remainderf.rs +5 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/remquo.rs +110 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/remquof.rs +97 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/rint.rs +58 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/rintf.rs +58 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/round.rs +28 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/roundf.rs +30 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/scalbn.rs +33 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/scalbnf.rs +29 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/sin.rs +88 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/sincos.rs +134 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/sincosf.rs +185 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/sinf.rs +93 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/sinh.rs +49 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/sinhf.rs +30 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/sqrt.rs +280 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/sqrtf.rs +170 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/tan.rs +70 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/tanf.rs +78 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/tanh.rs +53 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/tanhf.rs +39 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/tgamma.rs +208 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/tgammaf.rs +6 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/trunc.rs +40 -0
- data/ext/cargo-vendor/libm-0.2.8/src/math/truncf.rs +42 -0
- data/ext/cargo-vendor/postcard-1.0.8/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/postcard-1.0.8/CHANGELOG.md +141 -0
- data/ext/cargo-vendor/postcard-1.0.8/Cargo.toml +100 -0
- data/ext/cargo-vendor/postcard-1.0.8/LICENSE-APACHE +201 -0
- data/ext/cargo-vendor/postcard-1.0.8/LICENSE-MIT +25 -0
- data/ext/cargo-vendor/postcard-1.0.8/README.md +146 -0
- data/ext/cargo-vendor/postcard-1.0.8/spec/LICENSE-CC-BY-SA +427 -0
- data/ext/cargo-vendor/postcard-1.0.8/spec/book.toml +6 -0
- data/ext/cargo-vendor/postcard-1.0.8/spec/src/SUMMARY.md +6 -0
- data/ext/cargo-vendor/postcard-1.0.8/spec/src/glossary.md +17 -0
- data/ext/cargo-vendor/postcard-1.0.8/spec/src/intro.md +12 -0
- data/ext/cargo-vendor/postcard-1.0.8/spec/src/serde-data-model.md +190 -0
- data/ext/cargo-vendor/postcard-1.0.8/spec/src/wire-format.md +327 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/accumulator.rs +367 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/de/deserializer.rs +599 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/de/flavors.rs +468 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/de/mod.rs +568 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/error.rs +95 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/fixint.rs +189 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/lib.rs +143 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/max_size.rs +233 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/schema.rs +282 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/ser/flavors.rs +722 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/ser/mod.rs +866 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/ser/serializer.rs +564 -0
- data/ext/cargo-vendor/postcard-1.0.8/src/varint.rs +103 -0
- data/ext/cargo-vendor/postcard-1.0.8/tests/accumulator.rs +57 -0
- data/ext/cargo-vendor/postcard-1.0.8/tests/crc.rs +60 -0
- data/ext/cargo-vendor/postcard-1.0.8/tests/loopback.rs +248 -0
- data/ext/cargo-vendor/postcard-1.0.8/tests/max_size.rs +101 -0
- data/ext/cargo-vendor/postcard-1.0.8/tests/schema.rs +107 -0
- data/ext/cargo-vendor/rb-sys-0.9.100/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/rb-sys-0.9.100/Cargo.toml +58 -0
- data/ext/cargo-vendor/rb-sys-0.9.100/build/main.rs +267 -0
- data/ext/cargo-vendor/rb-sys-0.9.100/build/stable_api_config.rs +139 -0
- data/ext/cargo-vendor/rb-sys-0.9.100/src/bindings.rs +21 -0
- data/ext/cargo-vendor/rb-sys-0.9.100/src/tracking_allocator.rs +266 -0
- data/ext/cargo-vendor/rb-sys-build-0.9.100/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/rb-sys-build-0.9.100/Cargo.toml +62 -0
- data/ext/cargo-vendor/rb-sys-build-0.9.100/src/bindings/stable_api.rs +203 -0
- data/ext/cargo-vendor/rb-sys-build-0.9.100/src/bindings.rs +254 -0
- data/ext/cargo-vendor/rb-sys-build-0.9.100/src/cc.rs +374 -0
- data/ext/cargo-vendor/rb-sys-build-0.9.100/src/utils.rs +52 -0
- data/ext/cargo-vendor/wasi-common-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasi-common-21.0.1/Cargo.toml +223 -0
- data/ext/cargo-vendor/wasi-common-21.0.1/tests/all/async_.rs +293 -0
- data/ext/cargo-vendor/wasi-common-21.0.1/tests/all/main.rs +21 -0
- data/ext/cargo-vendor/wasi-common-21.0.1/tests/all/sync.rs +279 -0
- data/ext/cargo-vendor/wasm-encoder-0.207.0/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasm-encoder-0.207.0/Cargo.toml +45 -0
- data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/code.rs +3502 -0
- data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/data.rs +186 -0
- data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/elements.rs +221 -0
- data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/globals.rs +112 -0
- data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/imports.rs +157 -0
- data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/memories.rs +128 -0
- data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/tables.rs +134 -0
- data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/types.rs +678 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/Cargo.lock +659 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/Cargo.toml +95 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/binary_reader.rs +1867 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/lib.rs +805 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/limits.rs +78 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/map.rs +137 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/parser.rs +1636 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/component/canonicals.rs +121 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/component/instances.rs +164 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/component/names.rs +102 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/component/start.rs +31 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/component/types.rs +551 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/code.rs +146 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/coredumps.rs +244 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/custom.rs +64 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/data.rs +96 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/dylink0.rs +110 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/elements.rs +152 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/globals.rs +51 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/linking.rs +450 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/memories.rs +57 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/names.rs +159 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/operators.rs +430 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/reloc.rs +301 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/tables.rs +93 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/types/matches.rs +277 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/types.rs +1773 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core.rs +43 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/readers.rs +316 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/resources.rs +235 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/component.rs +3242 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/core/canonical.rs +233 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/core.rs +1450 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/func.rs +331 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/names.rs +947 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/operators.rs +4117 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/types.rs +4492 -0
- data/ext/cargo-vendor/wasmparser-0.207.0/src/validator.rs +1786 -0
- data/ext/cargo-vendor/wasmprinter-0.207.0/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmprinter-0.207.0/Cargo.toml +50 -0
- data/ext/cargo-vendor/wasmprinter-0.207.0/src/lib.rs +3226 -0
- data/ext/cargo-vendor/wasmprinter-0.207.0/src/operator.rs +1164 -0
- data/ext/cargo-vendor/wasmprinter-0.207.0/tests/all.rs +293 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/Cargo.toml +386 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/build.rs +37 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/compile/code_builder.rs +275 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/compile/runtime.rs +176 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/compile.rs +910 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/config.rs +2904 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/engine/serialization.rs +887 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/engine.rs +728 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/lib.rs +328 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/profiling_agent/jitdump.rs +67 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/profiling_agent/perfmap.rs +48 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/profiling_agent/vtune.rs +81 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/profiling_agent.rs +106 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/code.rs +102 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/code_memory.rs +337 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/component.rs +661 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/func/host.rs +440 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/func/options.rs +555 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/func/typed.rs +2498 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/func.rs +746 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/instance.rs +814 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/linker.rs +783 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/matching.rs +217 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/mod.rs +783 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/resource_table.rs +355 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/resources.rs +1133 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/storage.rs +43 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/store.rs +29 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/types.rs +892 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/values.rs +980 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/coredump.rs +342 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/debug.rs +166 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/externals/global.rs +310 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/externals/table.rs +477 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/externals.rs +236 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/func/typed.rs +899 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/func.rs +2627 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/disabled/anyref.rs +46 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/disabled/externref.rs +50 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/disabled/rooting.rs +224 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/enabled/anyref.rs +473 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/enabled/externref.rs +650 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/enabled/i31.rs +346 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/enabled/rooting.rs +1588 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc.rs +89 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/instance.rs +992 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/instantiate.rs +346 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/limits.rs +399 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/linker.rs +1506 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/memory.rs +998 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/module/registry.rs +353 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/module.rs +1295 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/profiling.rs +221 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/resources.rs +33 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/signatures.rs +216 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/stack.rs +73 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/store/context.rs +243 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/store/data.rs +301 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/store/func_refs.rs +90 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/store.rs +2820 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trampoline/func.rs +139 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trampoline/global.rs +68 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trampoline/memory.rs +287 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trampoline/table.rs +29 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trampoline.rs +78 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trap.rs +642 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/type_registry.rs +807 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/types/matching.rs +421 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/types.rs +2239 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/unix.rs +40 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/v128.rs +131 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/values.rs +966 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/arch/aarch64.rs +76 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/arch/x86_64.rs +41 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/async_yield.rs +35 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/component/libcalls.rs +571 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/component/resources.rs +352 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/component.rs +860 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/const_expr.rs +102 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/cow.rs +893 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/debug_builtins.rs +59 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/export.rs +108 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/disabled.rs +24 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/enabled/drc.rs +968 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/enabled/externref.rs +116 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/enabled/free_list.rs +771 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/enabled.rs +18 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/gc_ref.rs +491 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/gc_runtime.rs +506 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/host_data.rs +82 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/i31.rs +87 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc.rs +245 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/imports.rs +29 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/on_demand.rs +218 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/gc_heap_pool.rs +93 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/generic_stack_pool.rs +66 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/index_allocator.rs +705 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/memory_pool.rs +1000 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/table_pool.rs +233 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/unix_stack_pool.rs +245 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling.rs +656 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator.rs +798 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance.rs +1519 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/libcalls.rs +834 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/memory.rs +744 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mmap.rs +220 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mmap_vec.rs +162 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/module_id.rs +43 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mpk/enabled.rs +214 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mpk/mod.rs +54 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mpk/pkru.rs +104 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mpk/sys.rs +114 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/send_sync_ptr.rs +106 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/store_box.rs +37 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/custom/capi.rs +200 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/custom/mmap.rs +112 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/custom/mod.rs +34 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/custom/traphandlers.rs +55 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/custom/vm.rs +109 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/miri/mmap.rs +95 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/miri/mod.rs +24 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/miri/traphandlers.rs +47 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/mod.rs +25 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/machports.rs +416 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/mmap.rs +162 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/mod.rs +35 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/signals.rs +401 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/unwind.rs +150 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/vm.rs +215 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/windows/mmap.rs +221 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/windows/mod.rs +20 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/windows/traphandlers.rs +104 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/table.rs +847 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/threads/parking_spot.rs +623 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/threads/shared_memory.rs +233 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/threads/shared_memory_disabled.rs +101 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/traphandlers/backtrace.rs +267 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/traphandlers/coredump_disabled.rs +16 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/traphandlers/coredump_enabled.rs +42 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/traphandlers.rs +768 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/vmcontext/vm_host_func_context.rs +138 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/vmcontext.rs +1337 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm.rs +287 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/windows.rs +35 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime.rs +110 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/sync_nostd.rs +255 -0
- data/ext/cargo-vendor/wasmtime-21.0.1/src/sync_std.rs +52 -0
- data/ext/cargo-vendor/wasmtime-asm-macros-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-asm-macros-21.0.1/Cargo.toml +22 -0
- data/ext/cargo-vendor/wasmtime-asm-macros-21.0.1/src/lib.rs +83 -0
- data/ext/cargo-vendor/wasmtime-cache-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-cache-21.0.1/Cargo.toml +88 -0
- data/ext/cargo-vendor/wasmtime-cache-21.0.1/src/lib.rs +235 -0
- data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/Cargo.toml +79 -0
- data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/src/bindgen.rs +436 -0
- data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/src/component.rs +1295 -0
- data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/tests/codegen.rs +576 -0
- data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/tests/codegen_no_std.rs +16 -0
- data/ext/cargo-vendor/wasmtime-component-util-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-component-util-21.0.1/Cargo.toml +25 -0
- data/ext/cargo-vendor/wasmtime-component-util-21.0.1/src/lib.rs +182 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/Cargo.toml +114 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/compiler/component.rs +968 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/compiler.rs +1383 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/gc.rs +252 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/attr.rs +320 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/expression.rs +1248 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/line_program.rs +287 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/mod.rs +256 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/unit.rs +529 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/utils.rs +186 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/write_debuginfo.rs +196 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug.rs +18 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/func_environ.rs +2888 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/gc/enabled.rs +648 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/gc.rs +198 -0
- data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/lib.rs +511 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/Cargo.lock +772 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/Cargo.toml +154 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/examples/factc.rs +198 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/address_map.rs +73 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/mod.rs +419 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/module_artifacts.rs +315 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/module_environ.rs +1337 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/module_types.rs +362 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/trap_encoding.rs +70 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/compiler.rs +20 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/dfg.rs +691 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/info.rs +672 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/translate/adapt.rs +455 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/translate.rs +978 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/types.rs +1029 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/types_builder/resources.rs +233 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/types_builder.rs +997 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component.rs +107 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/demangling.rs +28 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact/core_types.rs +25 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact/signature.rs +119 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact/trampoline.rs +3234 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact/transcode.rs +90 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact/traps.rs +116 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact.rs +714 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/lib.rs +161 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/module.rs +697 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/module_artifacts.rs +146 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/module_types.rs +91 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/scopevec.rs +80 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/stack_map.rs +37 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/trap_encoding.rs +189 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/tunables.rs +168 -0
- data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/vmoffsets.rs +1015 -0
- data/ext/cargo-vendor/wasmtime-fiber-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-fiber-21.0.1/Cargo.toml +64 -0
- data/ext/cargo-vendor/wasmtime-fiber-21.0.1/build.rs +38 -0
- data/ext/cargo-vendor/wasmtime-fiber-21.0.1/src/lib.rs +328 -0
- data/ext/cargo-vendor/wasmtime-fiber-21.0.1/src/unix.rs +490 -0
- data/ext/cargo-vendor/wasmtime-fiber-21.0.1/src/windows.rs +166 -0
- data/ext/cargo-vendor/wasmtime-jit-debug-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-jit-debug-21.0.1/Cargo.toml +67 -0
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/Cargo.toml +51 -0
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/src/lib.rs +109 -0
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/src/libc.rs +163 -0
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/src/miri.rs +10 -0
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/src/win.rs +49 -0
- data/ext/cargo-vendor/wasmtime-slab-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-slab-21.0.1/Cargo.toml +21 -0
- data/ext/cargo-vendor/wasmtime-slab-21.0.1/src/lib.rs +498 -0
- data/ext/cargo-vendor/wasmtime-types-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-types-21.0.1/Cargo.toml +55 -0
- data/ext/cargo-vendor/wasmtime-types-21.0.1/src/error.rs +81 -0
- data/ext/cargo-vendor/wasmtime-types-21.0.1/src/lib.rs +1572 -0
- data/ext/cargo-vendor/wasmtime-versioned-export-macros-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-versioned-export-macros-21.0.1/Cargo.toml +32 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/Cargo.toml +200 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/bindings.rs +280 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/ctx.rs +667 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/filesystem.rs +446 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/lib.rs +426 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/preview0.rs +877 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/preview1.rs +2660 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/tests/all/api.rs +198 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/tests/all/async_.rs +397 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/tests/all/main.rs +91 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/tests/all/preview1.rs +251 -0
- data/ext/cargo-vendor/wasmtime-wasi-21.0.1/tests/all/sync.rs +331 -0
- data/ext/cargo-vendor/wasmtime-winch-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-winch-21.0.1/Cargo.toml +81 -0
- data/ext/cargo-vendor/wasmtime-winch-21.0.1/src/compiler.rs +261 -0
- data/ext/cargo-vendor/wasmtime-wit-bindgen-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wasmtime-wit-bindgen-21.0.1/Cargo.toml +46 -0
- data/ext/cargo-vendor/wasmtime-wit-bindgen-21.0.1/src/lib.rs +2541 -0
- data/ext/cargo-vendor/wasmtime-wit-bindgen-21.0.1/src/rust.rs +421 -0
- data/ext/cargo-vendor/wiggle-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wiggle-21.0.1/Cargo.toml +123 -0
- data/ext/cargo-vendor/wiggle-generate-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wiggle-generate-21.0.1/Cargo.toml +66 -0
- data/ext/cargo-vendor/wiggle-macro-21.0.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wiggle-macro-21.0.1/Cargo.toml +55 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/Cargo.toml +76 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/codegen/context.rs +534 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/codegen/env.rs +440 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/codegen/mod.rs +882 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/abi.rs +291 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/address.rs +143 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/asm.rs +380 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/masm.rs +566 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/mod.rs +158 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/regs.rs +161 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/reg.rs +73 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/x64/asm.rs +1423 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/x64/masm.rs +1120 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/masm.rs +941 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/regalloc.rs +65 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/regset.rs +194 -0
- data/ext/cargo-vendor/winch-codegen-0.19.1/src/visitor.rs +2144 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/Cargo.toml +109 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/src/ast/resolve.rs +1442 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/src/decoding.rs +1764 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/src/lib.rs +777 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/src/live.rs +126 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/src/resolve.rs +2337 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/resources-multiple-returns-borrow.wit.result +5 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/resources-return-borrow.wit.result +5 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow1.wit +7 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow1.wit.result +5 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow2.wit +8 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow2.wit.result +5 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow3.wit +7 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow3.wit.result +5 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow4.wit +7 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow4.wit.result +5 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow5.wit +7 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow5.wit.result +5 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow6.wit +7 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow6.wit.result +5 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow7.wit +11 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow7.wit.result +5 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow8/deps/baz.wit +9 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow8/foo.wit +7 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow8.wit.result +8 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/world-top-level-resources.wit +24 -0
- data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/world-top-level-resources.wit.json +231 -0
- data/ext/src/lib.rs +1 -0
- data/ext/src/ruby_api/config.rs +1 -12
- data/ext/src/ruby_api/engine.rs +3 -6
- data/ext/src/ruby_api/store.rs +68 -5
- data/lib/wasmtime/version.rb +1 -1
- metadata +1601 -1408
- data/ext/cargo-vendor/bincode-1.3.3/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/bincode-1.3.3/Cargo.toml +0 -37
- data/ext/cargo-vendor/bincode-1.3.3/LICENSE.md +0 -21
- data/ext/cargo-vendor/bincode-1.3.3/readme.md +0 -112
- data/ext/cargo-vendor/bincode-1.3.3/src/byteorder.rs +0 -385
- data/ext/cargo-vendor/bincode-1.3.3/src/config/endian.rs +0 -27
- data/ext/cargo-vendor/bincode-1.3.3/src/config/int.rs +0 -682
- data/ext/cargo-vendor/bincode-1.3.3/src/config/legacy.rs +0 -253
- data/ext/cargo-vendor/bincode-1.3.3/src/config/limit.rs +0 -49
- data/ext/cargo-vendor/bincode-1.3.3/src/config/mod.rs +0 -408
- data/ext/cargo-vendor/bincode-1.3.3/src/config/trailing.rs +0 -37
- data/ext/cargo-vendor/bincode-1.3.3/src/de/mod.rs +0 -515
- data/ext/cargo-vendor/bincode-1.3.3/src/de/read.rs +0 -202
- data/ext/cargo-vendor/bincode-1.3.3/src/error.rs +0 -115
- data/ext/cargo-vendor/bincode-1.3.3/src/internal.rs +0 -124
- data/ext/cargo-vendor/bincode-1.3.3/src/lib.rs +0 -201
- data/ext/cargo-vendor/bincode-1.3.3/src/ser/mod.rs +0 -772
- data/ext/cargo-vendor/bincode-1.3.3/tests/test.rs +0 -899
- data/ext/cargo-vendor/cranelift-bforest-0.107.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/cranelift-bforest-0.107.2/Cargo.toml +0 -40
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/Cargo.toml +0 -178
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/build.rs +0 -396
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/alias_analysis.rs +0 -403
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/context.rs +0 -386
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ctxhash.rs +0 -167
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/egraph/elaborate.rs +0 -835
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/egraph.rs +0 -838
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/fx.rs +0 -105
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/incremental_cache.rs +0 -256
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ir/instructions.rs +0 -1019
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/abi.rs +0 -1707
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/args.rs +0 -779
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/emit.rs +0 -3932
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/emit_tests.rs +0 -7919
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/imms.rs +0 -1218
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/mod.rs +0 -3083
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/regs.rs +0 -292
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst.isle +0 -4218
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/lower/isle.rs +0 -884
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/pcc.rs +0 -565
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/mod.rs +0 -432
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/abi.rs +0 -1109
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/args.rs +0 -1968
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/emit.rs +0 -3466
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/emit_tests.rs +0 -2146
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/mod.rs +0 -2041
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/regs.rs +0 -175
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/vector.rs +0 -1162
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst.isle +0 -2944
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/lower/isle.rs +0 -625
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/lower.isle +0 -2872
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/abi.rs +0 -1047
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/args.rs +0 -347
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/emit.rs +0 -3646
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/imms.rs +0 -202
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/mod.rs +0 -3423
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/regs.rs +0 -187
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/abi.rs +0 -1369
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/args.rs +0 -2289
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/emit.rs +0 -4383
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/emit_tests.rs +0 -5131
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/mod.rs +0 -2798
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/regs.rs +0 -276
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst.isle +0 -5304
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/lower/isle.rs +0 -1066
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/lower.isle +0 -4809
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/lower.rs +0 -339
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/pcc.rs +0 -1003
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/lib.rs +0 -106
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/abi.rs +0 -2594
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/blockorder.rs +0 -465
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/isle.rs +0 -914
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/lower.rs +0 -1452
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/mod.rs +0 -555
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/reg.rs +0 -562
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/valueregs.rs +0 -132
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/vcode.rs +0 -1807
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/nan_canonicalization.rs +0 -110
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/opts/arithmetic.isle +0 -179
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/opts/icmp.isle +0 -197
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/remove_constant_phis.rs +0 -420
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/scoped_hash_map.rs +0 -310
- data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/settings.rs +0 -591
- data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/Cargo.toml +0 -35
- data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/gen_inst.rs +0 -1784
- data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/gen_settings.rs +0 -508
- data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/gen_types.rs +0 -75
- data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/isa/riscv64.rs +0 -160
- data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/isa/x86.rs +0 -402
- data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/lib.rs +0 -59
- data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/shared/settings.rs +0 -355
- data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/srcgen.rs +0 -470
- data/ext/cargo-vendor/cranelift-codegen-shared-0.107.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/cranelift-codegen-shared-0.107.2/Cargo.toml +0 -22
- data/ext/cargo-vendor/cranelift-control-0.107.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/cranelift-control-0.107.2/Cargo.toml +0 -30
- data/ext/cargo-vendor/cranelift-entity-0.107.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/cranelift-entity-0.107.2/Cargo.toml +0 -50
- data/ext/cargo-vendor/cranelift-entity-0.107.2/src/lib.rs +0 -317
- data/ext/cargo-vendor/cranelift-frontend-0.107.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/cranelift-frontend-0.107.2/Cargo.toml +0 -69
- data/ext/cargo-vendor/cranelift-frontend-0.107.2/src/switch.rs +0 -654
- data/ext/cargo-vendor/cranelift-isle-0.107.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/cranelift-isle-0.107.2/Cargo.toml +0 -46
- data/ext/cargo-vendor/cranelift-isle-0.107.2/src/codegen.rs +0 -886
- data/ext/cargo-vendor/cranelift-isle-0.107.2/src/lib.rs +0 -271
- data/ext/cargo-vendor/cranelift-isle-0.107.2/src/sema.rs +0 -2492
- data/ext/cargo-vendor/cranelift-isle-0.107.2/src/serialize.rs +0 -846
- data/ext/cargo-vendor/cranelift-isle-0.107.2/src/trie_again.rs +0 -683
- data/ext/cargo-vendor/cranelift-native-0.107.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/cranelift-native-0.107.2/Cargo.toml +0 -45
- data/ext/cargo-vendor/cranelift-wasm-0.107.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/cranelift-wasm-0.107.2/Cargo.toml +0 -107
- data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/code_translator.rs +0 -3683
- data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/environ/dummy.rs +0 -912
- data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/environ/spec.rs +0 -945
- data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/sections_translator.rs +0 -409
- data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.21/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.21/Cargo.toml +0 -48
- data/ext/cargo-vendor/rb-sys-0.9.97/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/rb-sys-0.9.97/Cargo.toml +0 -54
- data/ext/cargo-vendor/rb-sys-0.9.97/build/main.rs +0 -238
- data/ext/cargo-vendor/rb-sys-0.9.97/build/stable_api_config.rs +0 -133
- data/ext/cargo-vendor/rb-sys-0.9.97/src/bindings.rs +0 -20
- data/ext/cargo-vendor/rb-sys-0.9.97/src/tracking_allocator.rs +0 -265
- data/ext/cargo-vendor/rb-sys-build-0.9.97/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/rb-sys-build-0.9.97/Cargo.toml +0 -62
- data/ext/cargo-vendor/rb-sys-build-0.9.97/src/bindings/stable_api.rs +0 -202
- data/ext/cargo-vendor/rb-sys-build-0.9.97/src/bindings.rs +0 -250
- data/ext/cargo-vendor/rb-sys-build-0.9.97/src/cc.rs +0 -365
- data/ext/cargo-vendor/rb-sys-build-0.9.97/src/utils.rs +0 -52
- data/ext/cargo-vendor/wasi-common-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasi-common-20.0.2/Cargo.toml +0 -220
- data/ext/cargo-vendor/wasi-common-20.0.2/tests/all/async_.rs +0 -293
- data/ext/cargo-vendor/wasi-common-20.0.2/tests/all/main.rs +0 -21
- data/ext/cargo-vendor/wasi-common-20.0.2/tests/all/sync.rs +0 -279
- data/ext/cargo-vendor/wasm-encoder-0.202.0/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasm-encoder-0.202.0/Cargo.toml +0 -43
- data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/code.rs +0 -3444
- data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/data.rs +0 -185
- data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/elements.rs +0 -220
- data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/globals.rs +0 -101
- data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/imports.rs +0 -156
- data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/memories.rs +0 -111
- data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/tables.rs +0 -116
- data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/types.rs +0 -673
- data/ext/cargo-vendor/wasmparser-0.202.0/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmparser-0.202.0/Cargo.lock +0 -744
- data/ext/cargo-vendor/wasmparser-0.202.0/Cargo.toml +0 -66
- data/ext/cargo-vendor/wasmparser-0.202.0/src/binary_reader.rs +0 -1849
- data/ext/cargo-vendor/wasmparser-0.202.0/src/lib.rs +0 -766
- data/ext/cargo-vendor/wasmparser-0.202.0/src/limits.rs +0 -64
- data/ext/cargo-vendor/wasmparser-0.202.0/src/parser.rs +0 -1611
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/component/canonicals.rs +0 -120
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/component/instances.rs +0 -163
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/component/names.rs +0 -102
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/component/start.rs +0 -30
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/component/types.rs +0 -549
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/code.rs +0 -146
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/coredumps.rs +0 -243
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/custom.rs +0 -63
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/data.rs +0 -96
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/dylink0.rs +0 -109
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/elements.rs +0 -152
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/globals.rs +0 -49
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/linking.rs +0 -449
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/memories.rs +0 -56
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/names.rs +0 -156
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/operators.rs +0 -411
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/tables.rs +0 -87
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/types/matches.rs +0 -277
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/types.rs +0 -1680
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core.rs +0 -41
- data/ext/cargo-vendor/wasmparser-0.202.0/src/readers.rs +0 -316
- data/ext/cargo-vendor/wasmparser-0.202.0/src/resources.rs +0 -235
- data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/component.rs +0 -3238
- data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/core/canonical.rs +0 -233
- data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/core.rs +0 -1400
- data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/func.rs +0 -338
- data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/names.rs +0 -929
- data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/operators.rs +0 -4076
- data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/types.rs +0 -4449
- data/ext/cargo-vendor/wasmparser-0.202.0/src/validator.rs +0 -1619
- data/ext/cargo-vendor/wasmprinter-0.202.0/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmprinter-0.202.0/Cargo.toml +0 -45
- data/ext/cargo-vendor/wasmprinter-0.202.0/src/lib.rs +0 -3202
- data/ext/cargo-vendor/wasmprinter-0.202.0/src/operator.rs +0 -1131
- data/ext/cargo-vendor/wasmprinter-0.202.0/tests/all.rs +0 -279
- data/ext/cargo-vendor/wasmtime-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-20.0.2/Cargo.toml +0 -268
- data/ext/cargo-vendor/wasmtime-20.0.2/src/compile/code_builder.rs +0 -201
- data/ext/cargo-vendor/wasmtime-20.0.2/src/compile/runtime.rs +0 -175
- data/ext/cargo-vendor/wasmtime-20.0.2/src/compile.rs +0 -897
- data/ext/cargo-vendor/wasmtime-20.0.2/src/config.rs +0 -2695
- data/ext/cargo-vendor/wasmtime-20.0.2/src/engine/serialization.rs +0 -849
- data/ext/cargo-vendor/wasmtime-20.0.2/src/engine.rs +0 -741
- data/ext/cargo-vendor/wasmtime-20.0.2/src/lib.rs +0 -303
- data/ext/cargo-vendor/wasmtime-20.0.2/src/profiling_agent/jitdump.rs +0 -66
- data/ext/cargo-vendor/wasmtime-20.0.2/src/profiling_agent/perfmap.rs +0 -47
- data/ext/cargo-vendor/wasmtime-20.0.2/src/profiling_agent/vtune.rs +0 -80
- data/ext/cargo-vendor/wasmtime-20.0.2/src/profiling_agent.rs +0 -105
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/code.rs +0 -102
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/code_memory.rs +0 -335
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/component.rs +0 -661
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/func/host.rs +0 -439
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/func/options.rs +0 -554
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/func/typed.rs +0 -2484
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/func.rs +0 -747
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/instance.rs +0 -804
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/linker.rs +0 -786
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/matching.rs +0 -217
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/mod.rs +0 -756
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/resource_table.rs +0 -350
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/resources.rs +0 -1133
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/storage.rs +0 -43
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/store.rs +0 -28
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/types.rs +0 -892
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/values.rs +0 -978
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/coredump.rs +0 -336
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/debug.rs +0 -165
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/externals/global.rs +0 -300
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/externals/table.rs +0 -480
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/externals.rs +0 -236
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/func/typed.rs +0 -898
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/func.rs +0 -2633
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/disabled/anyref.rs +0 -46
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/disabled/externref.rs +0 -50
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/disabled/rooting.rs +0 -222
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/enabled/anyref.rs +0 -472
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/enabled/externref.rs +0 -644
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/enabled/i31.rs +0 -345
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/enabled/rooting.rs +0 -1543
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc.rs +0 -87
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/instance.rs +0 -992
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/instantiate.rs +0 -345
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/limits.rs +0 -398
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/linker.rs +0 -1521
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/memory.rs +0 -999
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/module/registry.rs +0 -354
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/module.rs +0 -1295
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/profiling.rs +0 -224
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/resources.rs +0 -33
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/signatures.rs +0 -216
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/stack.rs +0 -73
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/store/context.rs +0 -243
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/store/data.rs +0 -289
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/store/func_refs.rs +0 -85
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/store.rs +0 -2796
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trampoline/func.rs +0 -138
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trampoline/global.rs +0 -68
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trampoline/memory.rs +0 -286
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trampoline/table.rs +0 -34
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trampoline.rs +0 -77
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trap.rs +0 -641
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/type_registry.rs +0 -632
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/types/matching.rs +0 -367
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/types.rs +0 -1378
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/unix.rs +0 -39
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/v128.rs +0 -131
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/values.rs +0 -945
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/windows.rs +0 -34
- data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime.rs +0 -112
- data/ext/cargo-vendor/wasmtime-asm-macros-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-asm-macros-20.0.2/Cargo.toml +0 -22
- data/ext/cargo-vendor/wasmtime-asm-macros-20.0.2/src/lib.rs +0 -81
- data/ext/cargo-vendor/wasmtime-cache-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-cache-20.0.2/Cargo.toml +0 -81
- data/ext/cargo-vendor/wasmtime-cache-20.0.2/src/lib.rs +0 -235
- data/ext/cargo-vendor/wasmtime-component-macro-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-component-macro-20.0.2/Cargo.toml +0 -67
- data/ext/cargo-vendor/wasmtime-component-macro-20.0.2/src/bindgen.rs +0 -390
- data/ext/cargo-vendor/wasmtime-component-macro-20.0.2/src/component.rs +0 -1295
- data/ext/cargo-vendor/wasmtime-component-macro-20.0.2/tests/codegen.rs +0 -342
- data/ext/cargo-vendor/wasmtime-component-util-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-component-util-20.0.2/Cargo.toml +0 -25
- data/ext/cargo-vendor/wasmtime-component-util-20.0.2/src/lib.rs +0 -180
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/Cargo.toml +0 -114
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/compiler/component.rs +0 -962
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/compiler.rs +0 -1369
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/gc.rs +0 -239
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/attr.rs +0 -345
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/expression.rs +0 -1252
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/line_program.rs +0 -282
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/mod.rs +0 -126
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/unit.rs +0 -522
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/utils.rs +0 -187
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/write_debuginfo.rs +0 -187
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug.rs +0 -18
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/func_environ.rs +0 -2672
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/gc/enabled.rs +0 -649
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/gc.rs +0 -198
- data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/lib.rs +0 -505
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/Cargo.lock +0 -782
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/Cargo.toml +0 -144
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/examples/factc.rs +0 -205
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/compile/address_map.rs +0 -72
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/compile/mod.rs +0 -389
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/compile/module_artifacts.rs +0 -300
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/compile/trap_encoding.rs +0 -69
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/compiler.rs +0 -19
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/dfg.rs +0 -690
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/info.rs +0 -672
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/translate/adapt.rs +0 -459
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/translate.rs +0 -965
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/types/resources.rs +0 -234
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/types.rs +0 -1972
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component.rs +0 -103
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/demangling.rs +0 -28
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact/core_types.rs +0 -24
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact/signature.rs +0 -135
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact/trampoline.rs +0 -3233
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact/transcode.rs +0 -89
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact/traps.rs +0 -115
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact.rs +0 -711
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/lib.rs +0 -70
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/module.rs +0 -780
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/module_artifacts.rs +0 -145
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/module_environ.rs +0 -1288
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/module_types.rs +0 -122
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/scopevec.rs +0 -78
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/stack_map.rs +0 -36
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/trap_encoding.rs +0 -188
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/tunables.rs +0 -158
- data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/vmoffsets.rs +0 -952
- data/ext/cargo-vendor/wasmtime-fiber-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-fiber-20.0.2/Cargo.toml +0 -63
- data/ext/cargo-vendor/wasmtime-fiber-20.0.2/build.rs +0 -26
- data/ext/cargo-vendor/wasmtime-fiber-20.0.2/src/lib.rs +0 -328
- data/ext/cargo-vendor/wasmtime-fiber-20.0.2/src/unix.rs +0 -265
- data/ext/cargo-vendor/wasmtime-fiber-20.0.2/src/windows.rs +0 -166
- data/ext/cargo-vendor/wasmtime-jit-debug-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-jit-debug-20.0.2/Cargo.toml +0 -67
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/Cargo.toml +0 -47
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/src/lib.rs +0 -108
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/src/libc.rs +0 -149
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/src/miri.rs +0 -10
- data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/src/win.rs +0 -45
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/Cargo.toml +0 -147
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/build.rs +0 -24
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/arch/aarch64.rs +0 -76
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/arch/x86_64.rs +0 -41
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/async_yield.rs +0 -35
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/component/libcalls.rs +0 -571
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/component/resources.rs +0 -351
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/component.rs +0 -860
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/cow.rs +0 -888
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/debug_builtins.rs +0 -59
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/export.rs +0 -108
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/disabled.rs +0 -23
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/enabled/drc.rs +0 -963
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/enabled/externref.rs +0 -115
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/enabled/free_list.rs +0 -767
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/enabled.rs +0 -18
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/gc_ref.rs +0 -486
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/gc_runtime.rs +0 -503
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/host_data.rs +0 -81
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/i31.rs +0 -86
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc.rs +0 -244
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/imports.rs +0 -27
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/on_demand.rs +0 -217
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling/gc_heap_pool.rs +0 -92
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling/index_allocator.rs +0 -704
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling/memory_pool.rs +0 -996
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling/stack_pool.rs +0 -242
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling/table_pool.rs +0 -231
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling.rs +0 -699
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator.rs +0 -780
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance.rs +0 -1566
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/lib.rs +0 -289
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/libcalls.rs +0 -777
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/memory.rs +0 -751
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mmap.rs +0 -214
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mmap_vec.rs +0 -201
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/module_id.rs +0 -43
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mpk/enabled.rs +0 -213
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mpk/mod.rs +0 -54
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mpk/pkru.rs +0 -104
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mpk/sys.rs +0 -113
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/send_sync_ptr.rs +0 -106
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/store_box.rs +0 -35
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/custom/capi.rs +0 -189
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/custom/mmap.rs +0 -111
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/custom/mod.rs +0 -24
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/custom/traphandlers.rs +0 -55
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/custom/vm.rs +0 -108
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/miri/mmap.rs +0 -94
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/miri/mod.rs +0 -10
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/miri/traphandlers.rs +0 -47
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/mod.rs +0 -33
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/machports.rs +0 -416
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/mmap.rs +0 -151
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/mod.rs +0 -21
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/signals.rs +0 -401
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/unwind.rs +0 -149
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/vm.rs +0 -208
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/windows/mmap.rs +0 -216
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/windows/mod.rs +0 -6
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/windows/traphandlers.rs +0 -104
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/table.rs +0 -851
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/threads/parking_spot.rs +0 -621
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/threads/shared_memory.rs +0 -230
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/threads/shared_memory_disabled.rs +0 -100
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/traphandlers/backtrace.rs +0 -265
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/traphandlers/coredump_disabled.rs +0 -16
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/traphandlers/coredump_enabled.rs +0 -40
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/traphandlers.rs +0 -785
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/vmcontext/vm_host_func_context.rs +0 -137
- data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/vmcontext.rs +0 -1293
- data/ext/cargo-vendor/wasmtime-slab-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-slab-20.0.2/Cargo.toml +0 -21
- data/ext/cargo-vendor/wasmtime-slab-20.0.2/src/lib.rs +0 -493
- data/ext/cargo-vendor/wasmtime-types-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-types-20.0.2/Cargo.toml +0 -36
- data/ext/cargo-vendor/wasmtime-types-20.0.2/src/error.rs +0 -59
- data/ext/cargo-vendor/wasmtime-types-20.0.2/src/lib.rs +0 -832
- data/ext/cargo-vendor/wasmtime-versioned-export-macros-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-versioned-export-macros-20.0.2/Cargo.toml +0 -32
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/Cargo.toml +0 -194
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/bindings.rs +0 -283
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/ctx.rs +0 -659
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/filesystem.rs +0 -433
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/lib.rs +0 -404
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/preview0.rs +0 -879
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/preview1.rs +0 -2601
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/tests/all/api.rs +0 -194
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/tests/all/async_.rs +0 -397
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/tests/all/main.rs +0 -91
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/tests/all/preview1.rs +0 -251
- data/ext/cargo-vendor/wasmtime-wasi-20.0.2/tests/all/sync.rs +0 -333
- data/ext/cargo-vendor/wasmtime-winch-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-winch-20.0.2/Cargo.toml +0 -81
- data/ext/cargo-vendor/wasmtime-winch-20.0.2/src/compiler.rs +0 -257
- data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.2/Cargo.toml +0 -41
- data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.2/src/lib.rs +0 -2213
- data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.2/src/rust.rs +0 -421
- data/ext/cargo-vendor/wiggle-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wiggle-20.0.2/Cargo.toml +0 -122
- data/ext/cargo-vendor/wiggle-generate-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wiggle-generate-20.0.2/Cargo.toml +0 -65
- data/ext/cargo-vendor/wiggle-generate-20.0.2/LICENSE +0 -220
- data/ext/cargo-vendor/wiggle-macro-20.0.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wiggle-macro-20.0.2/Cargo.toml +0 -55
- data/ext/cargo-vendor/wiggle-macro-20.0.2/LICENSE +0 -220
- data/ext/cargo-vendor/winch-codegen-0.18.2/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/winch-codegen-0.18.2/Cargo.toml +0 -81
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/codegen/context.rs +0 -534
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/codegen/env.rs +0 -435
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/codegen/mod.rs +0 -756
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/abi.rs +0 -291
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/address.rs +0 -144
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/asm.rs +0 -252
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/masm.rs +0 -573
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/mod.rs +0 -154
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/regs.rs +0 -149
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/reg.rs +0 -86
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/x64/asm.rs +0 -1423
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/x64/masm.rs +0 -1256
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/masm.rs +0 -947
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/regalloc.rs +0 -65
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/regset.rs +0 -194
- data/ext/cargo-vendor/winch-codegen-0.18.2/src/visitor.rs +0 -2149
- data/ext/cargo-vendor/wit-parser-0.202.0/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/wit-parser-0.202.0/Cargo.toml +0 -101
- data/ext/cargo-vendor/wit-parser-0.202.0/src/ast/resolve.rs +0 -1443
- data/ext/cargo-vendor/wit-parser-0.202.0/src/decoding.rs +0 -1764
- data/ext/cargo-vendor/wit-parser-0.202.0/src/lib.rs +0 -765
- data/ext/cargo-vendor/wit-parser-0.202.0/src/live.rs +0 -111
- data/ext/cargo-vendor/wit-parser-0.202.0/src/resolve.rs +0 -2240
- data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/resources-multiple-returns-borrow.wit.json +0 -74
- data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/resources-return-borrow.wit.json +0 -69
- data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/world-top-level-resources.wit +0 -24
- data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/world-top-level-resources.wit.json +0 -240
- data/ext/src/ruby_api/config/tracked_memory_creator.rs +0 -82
- /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/README.md +0 -0
- /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/map.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/node.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/path.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/pool.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/set.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/README.md +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/benches/x64-evex-encoding.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/binemit/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/binemit/stack_map.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/bitset.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/cfg_printer.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/constant_hash.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/cursor.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/data_value.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/dbg.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/dce.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/dominator_tree.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/egraph/cost.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/flowgraph.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/inst_predicates.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/atomic_rmw_op.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/builder.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/condcodes.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/constant.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/dfg.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/dynamic_type.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/entities.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/extfunc.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/extname.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/function.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/globalvalue.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/immediates.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/jumptable.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/known_symbol.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/layout.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/libcall.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/memflags.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/memtype.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/pcc.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/progpoint.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/sourceloc.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/stackslot.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/trapcode.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/types.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/inst/unwind/systemv.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/inst/unwind.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/inst_neon.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/lower/isle/generated_code.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/lower.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/lower.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/lower_dynamic_neon.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/settings.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/call_conv.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/inst/encode.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/inst/imms.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/inst/unwind/systemv.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/inst/unwind.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/inst_vector.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/lower/isle/generated_code.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/lower.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/settings.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/inst/emit_tests.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/inst/unwind/systemv.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/inst/unwind.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/inst.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/lower/isle/generated_code.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/lower/isle.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/lower.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/lower.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/settings.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/unwind/systemv.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/unwind/winx64.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/unwind.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/encoding/evex.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/encoding/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/encoding/rex.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/encoding/vex.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/inst/emit_state.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/inst/unwind/systemv.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/inst/unwind/winx64.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/inst/unwind.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/lower/isle/generated_code.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/settings.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isle_prelude.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/iterators.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/legalizer/globalvalue.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/legalizer/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/loop_analysis.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/machinst/buffer.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/machinst/compile.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/machinst/helpers.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/machinst/inst_common.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/machinst/pcc.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/README.md +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/bitops.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/cprop.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/extends.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/generated_code.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/remat.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/selects.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/shifts.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/spaceship.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/spectre.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/vector.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/prelude.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/prelude_lower.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/prelude_opt.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/print_errors.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/result.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/souper_harvest.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/timing.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/unionfind.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/unreachable_code.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/value_label.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/verifier/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/write.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/README.md +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/formats.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/instructions.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/isa.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/operands.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/settings.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/types.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/typevar.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/constant_hash.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/error.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/isa/arm64.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/isa/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/isa/s390x.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/entities.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/formats.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/immediates.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/instructions.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/types.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/unique_table.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-shared-0.107.2 → cranelift-codegen-shared-0.108.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-shared-0.107.2 → cranelift-codegen-shared-0.108.1}/README.md +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-shared-0.107.2 → cranelift-codegen-shared-0.108.1}/src/constant_hash.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-shared-0.107.2 → cranelift-codegen-shared-0.108.1}/src/constants.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-codegen-shared-0.107.2 → cranelift-codegen-shared-0.108.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-control-0.107.2 → cranelift-control-0.108.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{cranelift-control-0.107.2 → cranelift-control-0.108.1}/README.md +0 -0
- /data/ext/cargo-vendor/{cranelift-control-0.107.2 → cranelift-control-0.108.1}/src/chaos.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-control-0.107.2 → cranelift-control-0.108.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-control-0.107.2 → cranelift-control-0.108.1}/src/zero_sized.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/README.md +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/boxed_slice.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/iter.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/keys.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/list.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/map.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/packed_option.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/primary.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/set.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/sparse.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/unsigned.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/README.md +0 -0
- /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/src/frontend.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/src/ssa.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/src/variable.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/README.md +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/build.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/bad_converters.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/bound_var_type_mismatch.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/converter_extractor_constructor.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/error1.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/extra_parens.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/impure_expression.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/impure_rhs.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/multi_internal_etor.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/multi_prio.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/borrows.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/borrows_main.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/iflets.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/iflets_main.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/multi_constructor.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/multi_constructor_main.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/multi_extractor.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/multi_extractor_main.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/test.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/test_main.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/bound_var.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/construct_and_extract.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/conversions.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/conversions_extern.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/let.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/nodebug.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/prio_trie_bug.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/test2.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/test3.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/test4.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/tutorial.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/run/iconst.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/run/iconst_main.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/run/let_shadowing.isle +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/run/let_shadowing_main.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/ast.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/compile.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/error.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/lexer.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/log.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/overlap.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/parser.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/tests/run_tests.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-native-0.107.2 → cranelift-native-0.108.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{cranelift-native-0.107.2 → cranelift-native-0.108.1}/README.md +0 -0
- /data/ext/cargo-vendor/{cranelift-native-0.107.2 → cranelift-native-0.108.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-native-0.107.2 → cranelift-native-0.108.1}/src/riscv.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/README.md +0 -0
- /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/code_translator/bounds_checks.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/environ/mod.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/func_translator.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/heap.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/module_translator.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/state.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/table.rs +0 -0
- /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/translation_utils.rs +0 -0
- /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/README.md +0 -0
- /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/src/clocks.rs +0 -0
- /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/src/noop_scheduler.rs +0 -0
- /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/tests/clocks.rs +0 -0
- /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/tests/common/mod.rs +0 -0
- /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/tests/random.rs +0 -0
- /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/tests/scheduler.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/LICENSE-APACHE +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/LICENSE-MIT +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/bin/release.sh +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/build/features.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/build/version.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/readme.md +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/hidden.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/macros.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/memory.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/ruby_abi_version.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/special_consts.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/compiled.c +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/compiled.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_2_6.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_2_7.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_3_0.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_3_1.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_3_2.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_3_3.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/symbol.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/utils.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/value_type.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/LICENSE-APACHE +0 -0
- /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/LICENSE-MIT +0 -0
- /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/bindings/sanitizer.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/bindings/wrapper.h +0 -0
- /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/rb_config/flags.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/rb_config/library.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/rb_config/search_path.rs +0 -0
- /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/rb_config.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/README.md +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/clocks.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/ctx.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/dir.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/error.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/file.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/pipe.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/random.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sched/subscription.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sched.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/snapshots/mod.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/snapshots/preview_0.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/snapshots/preview_1/error.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/snapshots/preview_1.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/string_array.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/clocks.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/dir.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/file.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/mod.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/net.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/sched/unix.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/sched/windows.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/sched.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/stdio.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/table.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/dir.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/file.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/mod.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/net.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/sched/unix.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/sched/windows.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/sched.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/stdio.rs +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/witx/preview0/typenames.witx +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/witx/preview0/wasi_unstable.witx +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/witx/preview1/typenames.witx +0 -0
- /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/witx/preview1/wasi_snapshot_preview1.witx +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/README.md +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/aliases.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/builder.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/canonicals.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/components.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/exports.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/imports.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/instances.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/modules.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/names.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/start.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/types.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/custom.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/dump.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/exports.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/functions.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/linking.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/names.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/producers.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/start.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/tags.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/raw.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/README.md +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/benches/benchmark.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/examples/simple.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/component/aliases.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/component/exports.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/component/imports.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/component.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/branch_hinting.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/exports.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/functions.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/imports.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/init.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/producers.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/tags.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/tests/big-module.rs +0 -0
- /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmprinter-0.207.0}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wasmprinter-0.202.0 → wasmprinter-0.207.0}/README.md +0 -0
- /data/ext/cargo-vendor/{wasmprinter-0.202.0 → wasmtime-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-21.0.1}/README.md +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/proptest-regressions → wasmtime-21.0.1/proptest-regressions/runtime/vm}/instance/allocator/pooling/memory_pool.txt +0 -0
- /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-21.0.1}/src/runtime/gc/disabled/i31.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-21.0.1}/src/runtime/gc/disabled.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-21.0.1}/src/runtime/gc/enabled.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-21.0.1}/src/runtime/uninhabited.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/arch/mod.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/arch/riscv64.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/arch/s390x.S +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/arch/s390x.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/helpers.c +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/mpk/disabled.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/custom/unwind.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/miri/unwind.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/miri/vm.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/unix/macos_traphandlers.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/windows/unwind.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/windows/vm.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/threads/mod.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-cache-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/build.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/config/tests.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/config.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/tests.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/worker/tests/system_time_stub.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/worker/tests.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/worker.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/tests/cache_write_default_config.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/build.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/char.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/conventions.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/dead-code.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/direct-import.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/empty.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/flags.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/floats.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/function-new.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/integers.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/lists.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/many-arguments.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/multi-return.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/multiversion/deps/v1/root.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/multiversion/deps/v2/root.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/multiversion/root.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/records.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/rename.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/resources-export.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/resources-import.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/share-types.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/simple-functions.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/simple-lists.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/simple-wasi.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/small-anonymous.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/smoke-default.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/smoke-export.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/smoke.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/strings.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/unversioned-foo.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/use-paths.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/variants.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/wat.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/worlds-with-types.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cranelift-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/SECURITY.md +0 -0
- /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/builder.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/compiled_function.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/debug/transform/address_transform.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/debug/transform/range_info_builder.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/debug/transform/refs.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/debug/transform/simulate.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/gc/disabled.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/isa_builder.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/obj.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-environ-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/address_map.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/builtin.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/component/artifacts.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/component/translate/inline.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/component/vmcomponent_offsets.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/gc.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/obj.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/ref_bits.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-fiber-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/aarch64.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/arm.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/riscv64.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/s390x.S +0 -0
- /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/x86.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/x86_64.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/windows.c +0 -0
- /data/ext/cargo-vendor/{wasmtime-jit-debug-20.0.2 → wasmtime-jit-debug-21.0.1}/README.md +0 -0
- /data/ext/cargo-vendor/{wasmtime-jit-debug-20.0.2 → wasmtime-jit-debug-21.0.1}/src/gdb_jit_int.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-jit-debug-20.0.2 → wasmtime-jit-debug-21.0.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-jit-debug-20.0.2 → wasmtime-jit-debug-21.0.1}/src/perf_jitdump.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-types-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wasmtime-versioned-export-macros-20.0.2 → wasmtime-versioned-export-macros-21.0.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2 → wasmtime-wasi-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/README.md +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/clocks/host.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/clocks.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/error.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/clocks.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/env.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/exit.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/filesystem/sync.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/filesystem.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/instance_network.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/io.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/mod.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/network.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/random.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/tcp.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/tcp_create_socket.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/udp.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/udp_create_socket.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/ip_name_lookup.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/network.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/pipe.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/poll.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/random.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/runtime.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/stdio/worker_thread_stdin.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/stdio.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/stream.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/tcp.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/udp.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/write_stream.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/tests/process_stdin.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/command-extended.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/command.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/environment.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/exit.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/imports.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/run.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/stdio.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/terminal.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/clocks/monotonic-clock.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/clocks/wall-clock.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/clocks/world.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/filesystem/preopens.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/filesystem/types.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/filesystem/world.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/http/handler.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/http/proxy.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/http/types.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/io/error.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/io/poll.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/io/streams.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/io/world.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/random/insecure-seed.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/random/insecure.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/random/random.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/random/world.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/instance-network.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/ip-name-lookup.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/network.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/tcp-create-socket.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/tcp.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/udp-create-socket.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/udp.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/world.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/test.wit +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/witx/preview0/typenames.witx +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/witx/preview0/wasi_unstable.witx +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/witx/preview1/typenames.witx +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/witx/preview1/wasi_snapshot_preview1.witx +0 -0
- /data/ext/cargo-vendor/{wasmtime-winch-20.0.2 → wasmtime-winch-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wasmtime-winch-20.0.2 → wasmtime-winch-21.0.1}/src/builder.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-winch-20.0.2 → wasmtime-winch-21.0.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wit-bindgen-20.0.2 → wasmtime-wit-bindgen-21.0.1}/src/source.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wit-bindgen-20.0.2 → wasmtime-wit-bindgen-21.0.1}/src/types.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-types-20.0.2 → wiggle-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/README.md +0 -0
- /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/borrow.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/error.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/guest_type.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/region.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/wasmtime.rs +0 -0
- /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wiggle-generate-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/README.md +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/codegen_settings.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/config.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/funcs.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/lifetimes.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/module_trait.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/names.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/error.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/flags.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/handle.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/mod.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/record.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/variant.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/wasmtime.rs +0 -0
- /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-macro-21.0.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{wiggle-macro-20.0.2 → wiggle-macro-21.0.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/LICENSE +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/build.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/abi/local.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/abi/mod.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/codegen/bounds.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/codegen/builtin.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/codegen/call.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/codegen/control.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/frame/mod.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/isa/mod.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/isa/x64/abi.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/isa/x64/address.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/isa/x64/mod.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/isa/x64/regs.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/stack.rs +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/README.md +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/abi.rs +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/ast/lex.rs +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/ast/toposort.rs +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/ast.rs +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/docs.rs +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/serde_.rs +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/sizealign.rs +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/all.rs +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/comments.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/comments.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/complex-include/deps/bar/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/complex-include/deps/baz/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/complex-include/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/complex-include.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/cross-package-resource/deps/foo/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/cross-package-resource/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/cross-package-resource.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/diamond1/deps/dep1/types.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/diamond1/deps/dep2/types.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/diamond1/join.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/diamond1.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/disambiguate-diamond/shared1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/disambiguate-diamond/shared2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/disambiguate-diamond/world.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/disambiguate-diamond.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/empty.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/empty.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/another-pkg/other-doc.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/corp/saas.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/different-pkg/the-doc.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/foreign-pkg/the-doc.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/some-pkg/some-doc.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/wasi/clocks.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/wasi/filesystem.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/another-pkg/other-doc.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/corp/saas.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/different-pkg/the-doc.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/foreign-pkg/the-doc.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/some-pkg/some-doc.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/wasi/clocks.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/wasi/filesystem.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/wasi/wasi.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/functions.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/functions.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/ignore-files-deps/deps/bar/types.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/ignore-files-deps/deps/ignore-me.txt +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/ignore-files-deps/world.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/ignore-files-deps.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/import-export-overlap1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/import-export-overlap1.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/import-export-overlap2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/import-export-overlap2.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/include-reps.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/include-reps.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kebab-name-include-with.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kebab-name-include-with.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps/a.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps/deps/b/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps/deps/c.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps/deps/d.wat +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps/deps/e.wasm +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/many-names/a.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/many-names/b.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/many-names.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/multi-file/bar.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/multi-file/cycle-a.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/multi-file/cycle-b.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/multi-file/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/multi-file.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/name-both-resource-and-type/deps/dep/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/name-both-resource-and-type/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/name-both-resource-and-type.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax1.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax3.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax3.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax4.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax4.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/alias-no-type.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/alias-no-type.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/async.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/async1.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-function.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-function.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-function2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-function2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include1.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include3.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include3.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-list.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-list.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg1/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg1.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg2/deps/bar/empty.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg2/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg3/deps/bar/baz.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg3/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg3.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg4/deps/bar/baz.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg4/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg4.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg5/deps/bar/baz.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg5/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg5.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg6/deps/bar/baz.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg6/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg6.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource1.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource10.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource10.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource11.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource11.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource12.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource12.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource13.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource13.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource14.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource14.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource15/deps/foo/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource15/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource15.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource3.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource3.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource4.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource4.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource5.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource5.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource6.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource6.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource7.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource7.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource8.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource8.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource9.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource9.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-world-type1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-world-type1.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/conflicting-package/a.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/conflicting-package/b.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/conflicting-package.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle3.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle3.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle4.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle4.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle5.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle5.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/dangling-type.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/dangling-type.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-function-params.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-function-params.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-functions.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-functions.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-interface.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-interface.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-interface2/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-interface2/foo2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-interface2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-type.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-type.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/empty-enum.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/empty-enum.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/empty-variant1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/empty-variant1.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/export-twice.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/export-twice.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export1.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export3.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export3.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export4.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export4.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export5.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export5.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-twice.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-twice.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-cycle.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-cycle.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-foreign/deps/bar/empty.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-foreign/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-foreign.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-with-id.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-with-id.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-with-on-id.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-with-on-id.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-toplevel.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-toplevel.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-type-reference.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-type-reference.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-type-reference2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-type-reference2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/kebab-name-include-not-found.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/kebab-name-include-not-found.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/kebab-name-include.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/kebab-name-include.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/keyword.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/keyword.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/missing-package.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/missing-package.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/multiple-package-docs/a.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/multiple-package-docs/b.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/multiple-package-docs.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/no-access-to-sibling-use/bar.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/no-access-to-sibling-use/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/no-access-to-sibling-use.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/non-existance-world-include/deps/bar/baz.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/non-existance-world-include/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/non-existance-world-include.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle/deps/a1/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle2/deps/a1/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle2/deps/a2/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle2/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0/tests/ui → wit-parser-0.207.0/tests/ui/parse-fail}/resources-multiple-returns-borrow.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0/tests/ui → wit-parser-0.207.0/tests/ui/parse-fail}/resources-return-borrow.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/type-and-resource-same-name/deps/dep/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/type-and-resource-same-name/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/type-and-resource-same-name.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/undefined-typed.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/undefined-typed.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unknown-interface.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unknown-interface.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface1.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface3.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface3.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface4.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface4.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use1.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use10/bar.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use10/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use10.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use3.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use3.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use7.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use7.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use8.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use8.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use9.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use9.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unterminated-string.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-and-include-world/deps/bar/baz.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-and-include-world/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-and-include-world.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict3.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict3.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-cycle1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-cycle1.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-cycle4.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-cycle4.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-shadow1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-shadow1.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-world/deps/bar/baz.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-world/root.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-world.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-interface-clash.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-interface-clash.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-same-fields2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-same-fields2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-same-fields3.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-same-fields3.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-top-level-func.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-top-level-func.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-top-level-func2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-top-level-func2.wit.result +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/random.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/random.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-empty.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-empty.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-multiple-returns-own.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-multiple-returns-own.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-multiple.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-multiple.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-return-own.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-return-own.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources1.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/same-name-import-export.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/same-name-import-export.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/shared-types.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/shared-types.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/simple-wasm-text.wat +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/simple-wasm-text.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/stress-export-elaborate.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/stress-export-elaborate.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/type-then-eof.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/type-then-eof.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/types.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/types.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/union-fuzz-1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/union-fuzz-1.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/union-fuzz-2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/union-fuzz-2.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/use-chain.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/use-chain.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/use.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/use.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/versions/deps/a1/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/versions/deps/a2/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/versions/foo.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/versions.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/wasi.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/wasi.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-diamond.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-diamond.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-iface-no-collide.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-iface-no-collide.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import1.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import1.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import2.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import2.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import3.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import3.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-same-fields4.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-same-fields4.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-top-level-funcs.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-top-level-funcs.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/worlds-union-dedup.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/worlds-union-dedup.wit.json +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/worlds-with-types.wit +0 -0
- /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/worlds-with-types.wit.json +0 -0
@@ -1,2484 +0,0 @@
|
|
1
|
-
use crate::component::func::{Func, LiftContext, LowerContext, Options};
|
2
|
-
use crate::component::matching::InstanceType;
|
3
|
-
use crate::component::storage::{storage_as_slice, storage_as_slice_mut};
|
4
|
-
use crate::{AsContextMut, StoreContext, StoreContextMut, ValRaw};
|
5
|
-
use anyhow::{anyhow, bail, Context, Result};
|
6
|
-
use std::borrow::Cow;
|
7
|
-
use std::fmt;
|
8
|
-
use std::marker;
|
9
|
-
use std::mem::{self, MaybeUninit};
|
10
|
-
use std::ptr::NonNull;
|
11
|
-
use std::str;
|
12
|
-
use std::sync::Arc;
|
13
|
-
use wasmtime_environ::component::{
|
14
|
-
CanonicalAbiInfo, ComponentTypes, InterfaceType, StringEncoding, VariantInfo, MAX_FLAT_PARAMS,
|
15
|
-
MAX_FLAT_RESULTS,
|
16
|
-
};
|
17
|
-
use wasmtime_runtime::component::ComponentInstance;
|
18
|
-
use wasmtime_runtime::SendSyncPtr;
|
19
|
-
|
20
|
-
/// A statically-typed version of [`Func`] which takes `Params` as input and
|
21
|
-
/// returns `Return`.
|
22
|
-
///
|
23
|
-
/// This is an efficient way to invoke a WebAssembly component where if the
|
24
|
-
/// inputs and output are statically known this can eschew the vast majority of
|
25
|
-
/// machinery and checks when calling WebAssembly. This is the most optimized
|
26
|
-
/// way to call a WebAssembly component.
|
27
|
-
///
|
28
|
-
/// Note that like [`Func`] this is a pointer within a [`Store`](crate::Store)
|
29
|
-
/// and usage will panic if used with the wrong store.
|
30
|
-
///
|
31
|
-
/// This type is primarily created with the [`Func::typed`] API.
|
32
|
-
///
|
33
|
-
/// See [`ComponentType`] for more information about supported types.
|
34
|
-
pub struct TypedFunc<Params, Return> {
|
35
|
-
func: Func,
|
36
|
-
|
37
|
-
// The definition of this field is somewhat subtle and may be surprising.
|
38
|
-
// Naively one might expect something like
|
39
|
-
//
|
40
|
-
// _marker: marker::PhantomData<fn(Params) -> Return>,
|
41
|
-
//
|
42
|
-
// Since this is a function pointer after all. The problem with this
|
43
|
-
// definition though is that it imposes the wrong variance on `Params` from
|
44
|
-
// what we want. Abstractly a `fn(Params)` is able to store `Params` within
|
45
|
-
// it meaning you can only give it `Params` that live longer than the
|
46
|
-
// function pointer.
|
47
|
-
//
|
48
|
-
// With a component model function, however, we're always copying data from
|
49
|
-
// the host into the guest, so we are never storing pointers to `Params`
|
50
|
-
// into the guest outside the duration of a `call`, meaning we can actually
|
51
|
-
// accept values in `TypedFunc::call` which live for a shorter duration
|
52
|
-
// than the `Params` argument on the struct.
|
53
|
-
//
|
54
|
-
// This all means that we don't use a phantom function pointer, but instead
|
55
|
-
// feign phantom storage here to get the variance desired.
|
56
|
-
_marker: marker::PhantomData<(Params, Return)>,
|
57
|
-
}
|
58
|
-
|
59
|
-
impl<Params, Return> Copy for TypedFunc<Params, Return> {}
|
60
|
-
|
61
|
-
impl<Params, Return> Clone for TypedFunc<Params, Return> {
|
62
|
-
fn clone(&self) -> TypedFunc<Params, Return> {
|
63
|
-
*self
|
64
|
-
}
|
65
|
-
}
|
66
|
-
|
67
|
-
impl<Params, Return> TypedFunc<Params, Return>
|
68
|
-
where
|
69
|
-
Params: ComponentNamedList + Lower,
|
70
|
-
Return: ComponentNamedList + Lift,
|
71
|
-
{
|
72
|
-
/// Creates a new [`TypedFunc`] from the provided component [`Func`],
|
73
|
-
/// unsafely asserting that the underlying function takes `Params` as
|
74
|
-
/// input and returns `Return`.
|
75
|
-
///
|
76
|
-
/// # Unsafety
|
77
|
-
///
|
78
|
-
/// This is an unsafe function because it does not verify that the [`Func`]
|
79
|
-
/// provided actually implements this signature. It's up to the caller to
|
80
|
-
/// have performed some other sort of check to ensure that the signature is
|
81
|
-
/// correct.
|
82
|
-
pub unsafe fn new_unchecked(func: Func) -> TypedFunc<Params, Return> {
|
83
|
-
TypedFunc {
|
84
|
-
_marker: marker::PhantomData,
|
85
|
-
func,
|
86
|
-
}
|
87
|
-
}
|
88
|
-
|
89
|
-
/// Returns the underlying un-typed [`Func`] that this [`TypedFunc`]
|
90
|
-
/// references.
|
91
|
-
pub fn func(&self) -> &Func {
|
92
|
-
&self.func
|
93
|
-
}
|
94
|
-
|
95
|
-
/// Calls the underlying WebAssembly component function using the provided
|
96
|
-
/// `params` as input.
|
97
|
-
///
|
98
|
-
/// This method is used to enter into a component. Execution happens within
|
99
|
-
/// the `store` provided. The `params` are copied into WebAssembly memory
|
100
|
-
/// as appropriate and a core wasm function is invoked.
|
101
|
-
///
|
102
|
-
/// # Post-return
|
103
|
-
///
|
104
|
-
/// In the component model each function can have a "post return" specified
|
105
|
-
/// which allows cleaning up the arguments returned to the host. For example
|
106
|
-
/// if WebAssembly returns a string to the host then it might be a uniquely
|
107
|
-
/// allocated string which, after the host finishes processing it, needs to
|
108
|
-
/// be deallocated in the wasm instance's own linear memory to prevent
|
109
|
-
/// memory leaks in wasm itself. The `post-return` canonical abi option is
|
110
|
-
/// used to configured this.
|
111
|
-
///
|
112
|
-
/// To accommodate this feature of the component model after invoking a
|
113
|
-
/// function via [`TypedFunc::call`] you must next invoke
|
114
|
-
/// [`TypedFunc::post_return`]. Note that the return value of the function
|
115
|
-
/// should be processed between these two function calls. The return value
|
116
|
-
/// continues to be usable from an embedder's perspective after
|
117
|
-
/// `post_return` is called, but after `post_return` is invoked it may no
|
118
|
-
/// longer retain the same value that the wasm module originally returned.
|
119
|
-
///
|
120
|
-
/// Also note that [`TypedFunc::post_return`] must be invoked irrespective
|
121
|
-
/// of whether the canonical ABI option `post-return` was configured or not.
|
122
|
-
/// This means that embedders must unconditionally call
|
123
|
-
/// [`TypedFunc::post_return`] when a function returns. If this function
|
124
|
-
/// call returns an error, however, then [`TypedFunc::post_return`] is not
|
125
|
-
/// required.
|
126
|
-
///
|
127
|
-
/// # Errors
|
128
|
-
///
|
129
|
-
/// This function can return an error for a number of reasons:
|
130
|
-
///
|
131
|
-
/// * If the wasm itself traps during execution.
|
132
|
-
/// * If the wasm traps while copying arguments into memory.
|
133
|
-
/// * If the wasm provides bad allocation pointers when copying arguments
|
134
|
-
/// into memory.
|
135
|
-
/// * If the wasm returns a value which violates the canonical ABI.
|
136
|
-
/// * If this function's instances cannot be entered, for example if the
|
137
|
-
/// instance is currently calling a host function.
|
138
|
-
/// * If a previous function call occurred and the corresponding
|
139
|
-
/// `post_return` hasn't been invoked yet.
|
140
|
-
///
|
141
|
-
/// In general there are many ways that things could go wrong when copying
|
142
|
-
/// types in and out of a wasm module with the canonical ABI, and certain
|
143
|
-
/// error conditions are specific to certain types. For example a
|
144
|
-
/// WebAssembly module can't return an invalid `char`. When allocating space
|
145
|
-
/// for this host to copy a string into the returned pointer must be
|
146
|
-
/// in-bounds in memory.
|
147
|
-
///
|
148
|
-
/// If an error happens then the error should contain detailed enough
|
149
|
-
/// information to understand which part of the canonical ABI went wrong
|
150
|
-
/// and what to inspect.
|
151
|
-
///
|
152
|
-
/// # Panics
|
153
|
-
///
|
154
|
-
/// Panics if this is called on a function in an asynchronous store. This
|
155
|
-
/// only works with functions defined within a synchonous store. Also
|
156
|
-
/// panics if `store` does not own this function.
|
157
|
-
pub fn call(&self, store: impl AsContextMut, params: Params) -> Result<Return> {
|
158
|
-
assert!(
|
159
|
-
!store.as_context().async_support(),
|
160
|
-
"must use `call_async` when async support is enabled on the config"
|
161
|
-
);
|
162
|
-
self.call_impl(store, params)
|
163
|
-
}
|
164
|
-
|
165
|
-
/// Exactly like [`Self::call`], except for use on asynchronous stores.
|
166
|
-
///
|
167
|
-
/// # Panics
|
168
|
-
///
|
169
|
-
/// Panics if this is called on a function in a synchronous store. This
|
170
|
-
/// only works with functions defined within an asynchronous store. Also
|
171
|
-
/// panics if `store` does not own this function.
|
172
|
-
#[cfg(feature = "async")]
|
173
|
-
#[cfg_attr(docsrs, doc(cfg(feature = "async")))]
|
174
|
-
pub async fn call_async<T>(
|
175
|
-
&self,
|
176
|
-
mut store: impl AsContextMut<Data = T>,
|
177
|
-
params: Params,
|
178
|
-
) -> Result<Return>
|
179
|
-
where
|
180
|
-
T: Send,
|
181
|
-
Params: Send + Sync,
|
182
|
-
Return: Send + Sync,
|
183
|
-
{
|
184
|
-
let mut store = store.as_context_mut();
|
185
|
-
assert!(
|
186
|
-
store.0.async_support(),
|
187
|
-
"cannot use `call_async` when async support is not enabled on the config"
|
188
|
-
);
|
189
|
-
store
|
190
|
-
.on_fiber(|store| self.call_impl(store, params))
|
191
|
-
.await?
|
192
|
-
}
|
193
|
-
|
194
|
-
fn call_impl(&self, mut store: impl AsContextMut, params: Params) -> Result<Return> {
|
195
|
-
let store = &mut store.as_context_mut();
|
196
|
-
// Note that this is in theory simpler than it might read at this time.
|
197
|
-
// Here we're doing a runtime dispatch on the `flatten_count` for the
|
198
|
-
// params/results to see whether they're inbounds. This creates 4 cases
|
199
|
-
// to handle. In reality this is a highly optimizable branch where LLVM
|
200
|
-
// will easily figure out that only one branch here is taken.
|
201
|
-
//
|
202
|
-
// Otherwise this current construction is done to ensure that the stack
|
203
|
-
// space reserved for the params/results is always of the appropriate
|
204
|
-
// size (as the params/results needed differ depending on the "flatten"
|
205
|
-
// count)
|
206
|
-
if Params::flatten_count() <= MAX_FLAT_PARAMS {
|
207
|
-
if Return::flatten_count() <= MAX_FLAT_RESULTS {
|
208
|
-
self.func.call_raw(
|
209
|
-
store,
|
210
|
-
¶ms,
|
211
|
-
Self::lower_stack_args,
|
212
|
-
Self::lift_stack_result,
|
213
|
-
)
|
214
|
-
} else {
|
215
|
-
self.func.call_raw(
|
216
|
-
store,
|
217
|
-
¶ms,
|
218
|
-
Self::lower_stack_args,
|
219
|
-
Self::lift_heap_result,
|
220
|
-
)
|
221
|
-
}
|
222
|
-
} else {
|
223
|
-
if Return::flatten_count() <= MAX_FLAT_RESULTS {
|
224
|
-
self.func.call_raw(
|
225
|
-
store,
|
226
|
-
¶ms,
|
227
|
-
Self::lower_heap_args,
|
228
|
-
Self::lift_stack_result,
|
229
|
-
)
|
230
|
-
} else {
|
231
|
-
self.func.call_raw(
|
232
|
-
store,
|
233
|
-
¶ms,
|
234
|
-
Self::lower_heap_args,
|
235
|
-
Self::lift_heap_result,
|
236
|
-
)
|
237
|
-
}
|
238
|
-
}
|
239
|
-
}
|
240
|
-
|
241
|
-
/// Lower parameters directly onto the stack specified by the `dst`
|
242
|
-
/// location.
|
243
|
-
///
|
244
|
-
/// This is only valid to call when the "flatten count" is small enough, or
|
245
|
-
/// when the canonical ABI says arguments go through the stack rather than
|
246
|
-
/// the heap.
|
247
|
-
fn lower_stack_args<T>(
|
248
|
-
cx: &mut LowerContext<'_, T>,
|
249
|
-
params: &Params,
|
250
|
-
ty: InterfaceType,
|
251
|
-
dst: &mut MaybeUninit<Params::Lower>,
|
252
|
-
) -> Result<()> {
|
253
|
-
assert!(Params::flatten_count() <= MAX_FLAT_PARAMS);
|
254
|
-
params.lower(cx, ty, dst)?;
|
255
|
-
Ok(())
|
256
|
-
}
|
257
|
-
|
258
|
-
/// Lower parameters onto a heap-allocated location.
|
259
|
-
///
|
260
|
-
/// This is used when the stack space to be used for the arguments is above
|
261
|
-
/// the `MAX_FLAT_PARAMS` threshold. Here the wasm's `realloc` function is
|
262
|
-
/// invoked to allocate space and then parameters are stored at that heap
|
263
|
-
/// pointer location.
|
264
|
-
fn lower_heap_args<T>(
|
265
|
-
cx: &mut LowerContext<'_, T>,
|
266
|
-
params: &Params,
|
267
|
-
ty: InterfaceType,
|
268
|
-
dst: &mut MaybeUninit<ValRaw>,
|
269
|
-
) -> Result<()> {
|
270
|
-
assert!(Params::flatten_count() > MAX_FLAT_PARAMS);
|
271
|
-
|
272
|
-
// Memory must exist via validation if the arguments are stored on the
|
273
|
-
// heap, so we can create a `MemoryMut` at this point. Afterwards
|
274
|
-
// `realloc` is used to allocate space for all the arguments and then
|
275
|
-
// they're all stored in linear memory.
|
276
|
-
//
|
277
|
-
// Note that `realloc` will bake in a check that the returned pointer is
|
278
|
-
// in-bounds.
|
279
|
-
let ptr = cx.realloc(0, 0, Params::ALIGN32, Params::SIZE32)?;
|
280
|
-
params.store(cx, ty, ptr)?;
|
281
|
-
|
282
|
-
// Note that the pointer here is stored as a 64-bit integer. This allows
|
283
|
-
// this to work with either 32 or 64-bit memories. For a 32-bit memory
|
284
|
-
// it'll just ignore the upper 32 zero bits, and for 64-bit memories
|
285
|
-
// this'll have the full 64-bits. Note that for 32-bit memories the call
|
286
|
-
// to `realloc` above guarantees that the `ptr` is in-bounds meaning
|
287
|
-
// that we will know that the zero-extended upper bits of `ptr` are
|
288
|
-
// guaranteed to be zero.
|
289
|
-
//
|
290
|
-
// This comment about 64-bit integers is also referred to below with
|
291
|
-
// "WRITEPTR64".
|
292
|
-
dst.write(ValRaw::i64(ptr as i64));
|
293
|
-
|
294
|
-
Ok(())
|
295
|
-
}
|
296
|
-
|
297
|
-
/// Lift the result of a function directly from the stack result.
|
298
|
-
///
|
299
|
-
/// This is only used when the result fits in the maximum number of stack
|
300
|
-
/// slots.
|
301
|
-
fn lift_stack_result(
|
302
|
-
cx: &mut LiftContext<'_>,
|
303
|
-
ty: InterfaceType,
|
304
|
-
dst: &Return::Lower,
|
305
|
-
) -> Result<Return> {
|
306
|
-
assert!(Return::flatten_count() <= MAX_FLAT_RESULTS);
|
307
|
-
Return::lift(cx, ty, dst)
|
308
|
-
}
|
309
|
-
|
310
|
-
/// Lift the result of a function where the result is stored indirectly on
|
311
|
-
/// the heap.
|
312
|
-
fn lift_heap_result(
|
313
|
-
cx: &mut LiftContext<'_>,
|
314
|
-
ty: InterfaceType,
|
315
|
-
dst: &ValRaw,
|
316
|
-
) -> Result<Return> {
|
317
|
-
assert!(Return::flatten_count() > MAX_FLAT_RESULTS);
|
318
|
-
// FIXME: needs to read an i64 for memory64
|
319
|
-
let ptr = usize::try_from(dst.get_u32())?;
|
320
|
-
if ptr % usize::try_from(Return::ALIGN32)? != 0 {
|
321
|
-
bail!("return pointer not aligned");
|
322
|
-
}
|
323
|
-
|
324
|
-
let bytes = cx
|
325
|
-
.memory()
|
326
|
-
.get(ptr..)
|
327
|
-
.and_then(|b| b.get(..Return::SIZE32))
|
328
|
-
.ok_or_else(|| anyhow::anyhow!("pointer out of bounds of memory"))?;
|
329
|
-
Return::load(cx, ty, bytes)
|
330
|
-
}
|
331
|
-
|
332
|
-
/// See [`Func::post_return`]
|
333
|
-
pub fn post_return(&self, store: impl AsContextMut) -> Result<()> {
|
334
|
-
self.func.post_return(store)
|
335
|
-
}
|
336
|
-
|
337
|
-
/// See [`Func::post_return_async`]
|
338
|
-
#[cfg(feature = "async")]
|
339
|
-
#[cfg_attr(docsrs, doc(cfg(feature = "async")))]
|
340
|
-
pub async fn post_return_async<T: Send>(
|
341
|
-
&self,
|
342
|
-
store: impl AsContextMut<Data = T>,
|
343
|
-
) -> Result<()> {
|
344
|
-
self.func.post_return_async(store).await
|
345
|
-
}
|
346
|
-
}
|
347
|
-
|
348
|
-
/// A trait representing a static list of named types that can be passed to or
|
349
|
-
/// returned from a [`TypedFunc`].
|
350
|
-
///
|
351
|
-
/// This trait is implemented for a number of tuple types and is not expected
|
352
|
-
/// to be implemented externally. The contents of this trait are hidden as it's
|
353
|
-
/// intended to be an implementation detail of Wasmtime. The contents of this
|
354
|
-
/// trait are not covered by Wasmtime's stability guarantees.
|
355
|
-
///
|
356
|
-
/// For more information about this trait see [`Func::typed`] and
|
357
|
-
/// [`TypedFunc`].
|
358
|
-
//
|
359
|
-
// Note that this is an `unsafe` trait, and the unsafety means that
|
360
|
-
// implementations of this trait must be correct or otherwise [`TypedFunc`]
|
361
|
-
// would not be memory safe. The main reason this is `unsafe` is the
|
362
|
-
// `typecheck` function which must operate correctly relative to the `AsTuple`
|
363
|
-
// interpretation of the implementor.
|
364
|
-
pub unsafe trait ComponentNamedList: ComponentType {}
|
365
|
-
|
366
|
-
/// A trait representing types which can be passed to and read from components
|
367
|
-
/// with the canonical ABI.
|
368
|
-
///
|
369
|
-
/// This trait is implemented for Rust types which can be communicated to
|
370
|
-
/// components. The [`Func::typed`] and [`TypedFunc`] Rust items are the main
|
371
|
-
/// consumers of this trait.
|
372
|
-
///
|
373
|
-
/// Supported Rust types include:
|
374
|
-
///
|
375
|
-
/// | Component Model Type | Rust Type |
|
376
|
-
/// |-----------------------------------|--------------------------------------|
|
377
|
-
/// | `{s,u}{8,16,32,64}` | `{i,u}{8,16,32,64}` |
|
378
|
-
/// | `f{32,64}` | `f{32,64}` |
|
379
|
-
/// | `bool` | `bool` |
|
380
|
-
/// | `char` | `char` |
|
381
|
-
/// | `tuple<A, B>` | `(A, B)` |
|
382
|
-
/// | `option<T>` | `Option<T>` |
|
383
|
-
/// | `result` | `Result<(), ()>` |
|
384
|
-
/// | `result<T>` | `Result<T, ()>` |
|
385
|
-
/// | `result<_, E>` | `Result<(), E>` |
|
386
|
-
/// | `result<T, E>` | `Result<T, E>` |
|
387
|
-
/// | `string` | `String`, `&str`, or [`WasmStr`] |
|
388
|
-
/// | `list<T>` | `Vec<T>`, `&[T]`, or [`WasmList`] |
|
389
|
-
/// | `own<T>`, `borrow<T>` | [`Resource<T>`] or [`ResourceAny`] |
|
390
|
-
/// | `record` | [`#[derive(ComponentType)]`][d-cm] |
|
391
|
-
/// | `variant` | [`#[derive(ComponentType)]`][d-cm] |
|
392
|
-
/// | `enum` | [`#[derive(ComponentType)]`][d-cm] |
|
393
|
-
/// | `flags` | [`flags!`][f-m] |
|
394
|
-
///
|
395
|
-
/// [`Resource<T>`]: crate::component::Resource
|
396
|
-
/// [`ResourceAny`]: crate::component::ResourceAny
|
397
|
-
/// [d-cm]: macro@crate::component::ComponentType
|
398
|
-
/// [f-m]: crate::component::flags
|
399
|
-
///
|
400
|
-
/// Rust standard library pointers such as `&T`, `Box<T>`, `Rc<T>`, and `Arc<T>`
|
401
|
-
/// additionally represent whatever type `T` represents in the component model.
|
402
|
-
/// Note that types such as `record`, `variant`, `enum`, and `flags` are
|
403
|
-
/// generated by the embedder at compile time. These macros derive
|
404
|
-
/// implementation of this trait for custom types to map to custom types in the
|
405
|
-
/// component model. Note that for `record`, `variant`, `enum`, and `flags`
|
406
|
-
/// those types are often generated by the
|
407
|
-
/// [`bindgen!`](crate::component::bindgen) macro from WIT definitions.
|
408
|
-
///
|
409
|
-
/// Types that implement [`ComponentType`] are used for `Params` and `Return`
|
410
|
-
/// in [`TypedFunc`] and [`Func::typed`].
|
411
|
-
///
|
412
|
-
/// The contents of this trait are hidden as it's intended to be an
|
413
|
-
/// implementation detail of Wasmtime. The contents of this trait are not
|
414
|
-
/// covered by Wasmtime's stability guarantees.
|
415
|
-
//
|
416
|
-
// Note that this is an `unsafe` trait as `TypedFunc`'s safety heavily relies on
|
417
|
-
// the correctness of the implementations of this trait. Some ways in which this
|
418
|
-
// trait must be correct to be safe are:
|
419
|
-
//
|
420
|
-
// * The `Lower` associated type must be a `ValRaw` sequence. It doesn't have to
|
421
|
-
// literally be `[ValRaw; N]` but when laid out in memory it must be adjacent
|
422
|
-
// `ValRaw` values and have a multiple of the size of `ValRaw` and the same
|
423
|
-
// alignment.
|
424
|
-
//
|
425
|
-
// * The `lower` function must initialize the bits within `Lower` that are going
|
426
|
-
// to be read by the trampoline that's used to enter core wasm. A trampoline
|
427
|
-
// is passed `*mut Lower` and will read the canonical abi arguments in
|
428
|
-
// sequence, so all of the bits must be correctly initialized.
|
429
|
-
//
|
430
|
-
// * The `size` and `align` functions must be correct for this value stored in
|
431
|
-
// the canonical ABI. The `Cursor<T>` iteration of these bytes rely on this
|
432
|
-
// for correctness as they otherwise eschew bounds-checking.
|
433
|
-
//
|
434
|
-
// There are likely some other correctness issues which aren't documented as
|
435
|
-
// well, this isn't intended to be an exhaustive list. It suffices to say,
|
436
|
-
// though, that correctness bugs in this trait implementation are highly likely
|
437
|
-
// to lead to security bugs, which again leads to the `unsafe` in the trait.
|
438
|
-
//
|
439
|
-
// Also note that this trait specifically is not sealed because we have a proc
|
440
|
-
// macro that generates implementations of this trait for external types in a
|
441
|
-
// `#[derive]`-like fashion.
|
442
|
-
pub unsafe trait ComponentType {
|
443
|
-
/// Representation of the "lowered" form of this component value.
|
444
|
-
///
|
445
|
-
/// Lowerings lower into core wasm values which are represented by `ValRaw`.
|
446
|
-
/// This `Lower` type must be a list of `ValRaw` as either a literal array
|
447
|
-
/// or a struct where every field is a `ValRaw`. This must be `Copy` (as
|
448
|
-
/// `ValRaw` is `Copy`) and support all byte patterns. This being correct is
|
449
|
-
/// one reason why the trait is unsafe.
|
450
|
-
#[doc(hidden)]
|
451
|
-
type Lower: Copy;
|
452
|
-
|
453
|
-
/// The information about this type's canonical ABI (size/align/etc).
|
454
|
-
#[doc(hidden)]
|
455
|
-
const ABI: CanonicalAbiInfo;
|
456
|
-
|
457
|
-
#[doc(hidden)]
|
458
|
-
const SIZE32: usize = Self::ABI.size32 as usize;
|
459
|
-
#[doc(hidden)]
|
460
|
-
const ALIGN32: u32 = Self::ABI.align32;
|
461
|
-
|
462
|
-
#[doc(hidden)]
|
463
|
-
const IS_RUST_UNIT_TYPE: bool = false;
|
464
|
-
|
465
|
-
/// Returns the number of core wasm abi values will be used to represent
|
466
|
-
/// this type in its lowered form.
|
467
|
-
///
|
468
|
-
/// This divides the size of `Self::Lower` by the size of `ValRaw`.
|
469
|
-
#[doc(hidden)]
|
470
|
-
fn flatten_count() -> usize {
|
471
|
-
assert!(mem::size_of::<Self::Lower>() % mem::size_of::<ValRaw>() == 0);
|
472
|
-
assert!(mem::align_of::<Self::Lower>() == mem::align_of::<ValRaw>());
|
473
|
-
mem::size_of::<Self::Lower>() / mem::size_of::<ValRaw>()
|
474
|
-
}
|
475
|
-
|
476
|
-
/// Performs a type-check to see whether this component value type matches
|
477
|
-
/// the interface type `ty` provided.
|
478
|
-
#[doc(hidden)]
|
479
|
-
fn typecheck(ty: &InterfaceType, types: &InstanceType<'_>) -> Result<()>;
|
480
|
-
}
|
481
|
-
|
482
|
-
#[doc(hidden)]
|
483
|
-
pub unsafe trait ComponentVariant: ComponentType {
|
484
|
-
const CASES: &'static [Option<CanonicalAbiInfo>];
|
485
|
-
const INFO: VariantInfo = VariantInfo::new_static(Self::CASES);
|
486
|
-
const PAYLOAD_OFFSET32: usize = Self::INFO.payload_offset32 as usize;
|
487
|
-
}
|
488
|
-
|
489
|
-
/// Host types which can be passed to WebAssembly components.
|
490
|
-
///
|
491
|
-
/// This trait is implemented for all types that can be passed to components
|
492
|
-
/// either as parameters of component exports or returns of component imports.
|
493
|
-
/// This trait represents the ability to convert from the native host
|
494
|
-
/// representation to the canonical ABI.
|
495
|
-
///
|
496
|
-
/// Built-in types to Rust such as `Option<T>` implement this trait as
|
497
|
-
/// appropriate. For a mapping of component model to Rust types see
|
498
|
-
/// [`ComponentType`].
|
499
|
-
///
|
500
|
-
/// For user-defined types, for example `record` types mapped to Rust `struct`s,
|
501
|
-
/// this crate additionally has
|
502
|
-
/// [`#[derive(Lower)]`](macro@crate::component::Lower).
|
503
|
-
///
|
504
|
-
/// Note that like [`ComponentType`] the definition of this trait is intended to
|
505
|
-
/// be an internal implementation detail of Wasmtime at this time. It's
|
506
|
-
/// recommended to use the `#[derive(Lower)]` implementation instead.
|
507
|
-
pub unsafe trait Lower: ComponentType {
|
508
|
-
/// Performs the "lower" function in the canonical ABI.
|
509
|
-
///
|
510
|
-
/// This method will lower the current value into a component. The `lower`
|
511
|
-
/// function performs a "flat" lowering into the `dst` specified which is
|
512
|
-
/// allowed to be uninitialized entering this method but is guaranteed to be
|
513
|
-
/// fully initialized if the method returns `Ok(())`.
|
514
|
-
///
|
515
|
-
/// The `cx` context provided is the context within which this lowering is
|
516
|
-
/// happening. This contains information such as canonical options specified
|
517
|
-
/// (e.g. string encodings, memories, etc), the store itself, along with
|
518
|
-
/// type information.
|
519
|
-
///
|
520
|
-
/// The `ty` parameter is the destination type that is being lowered into.
|
521
|
-
/// For example this is the component's "view" of the type that is being
|
522
|
-
/// lowered. This is guaranteed to have passed a `typecheck` earlier.
|
523
|
-
///
|
524
|
-
/// This will only be called if `typecheck` passes for `Op::Lower`.
|
525
|
-
#[doc(hidden)]
|
526
|
-
fn lower<T>(
|
527
|
-
&self,
|
528
|
-
cx: &mut LowerContext<'_, T>,
|
529
|
-
ty: InterfaceType,
|
530
|
-
dst: &mut MaybeUninit<Self::Lower>,
|
531
|
-
) -> Result<()>;
|
532
|
-
|
533
|
-
/// Performs the "store" operation in the canonical ABI.
|
534
|
-
///
|
535
|
-
/// This function will store `self` into the linear memory described by
|
536
|
-
/// `cx` at the `offset` provided.
|
537
|
-
///
|
538
|
-
/// It is expected that `offset` is a valid offset in memory for
|
539
|
-
/// `Self::SIZE32` bytes. At this time that's not an unsafe contract as it's
|
540
|
-
/// always re-checked on all stores, but this is something that will need to
|
541
|
-
/// be improved in the future to remove extra bounds checks. For now this
|
542
|
-
/// function will panic if there's a bug and `offset` isn't valid within
|
543
|
-
/// memory.
|
544
|
-
///
|
545
|
-
/// The `ty` type information passed here is the same as the type
|
546
|
-
/// information passed to `lower` above, and is the component's own view of
|
547
|
-
/// what the resulting type should be.
|
548
|
-
///
|
549
|
-
/// This will only be called if `typecheck` passes for `Op::Lower`.
|
550
|
-
#[doc(hidden)]
|
551
|
-
fn store<T>(
|
552
|
-
&self,
|
553
|
-
cx: &mut LowerContext<'_, T>,
|
554
|
-
ty: InterfaceType,
|
555
|
-
offset: usize,
|
556
|
-
) -> Result<()>;
|
557
|
-
|
558
|
-
/// Provided method to lower a list of `Self` into memory.
|
559
|
-
///
|
560
|
-
/// Requires that `offset` has already been checked for alignment and
|
561
|
-
/// validity in terms of being in-bounds, otherwise this may panic.
|
562
|
-
///
|
563
|
-
/// This is primarily here to get overridden for implementations of integers
|
564
|
-
/// which can avoid some extra fluff and use a pattern that's more easily
|
565
|
-
/// optimizable by LLVM.
|
566
|
-
#[doc(hidden)]
|
567
|
-
fn store_list<T>(
|
568
|
-
cx: &mut LowerContext<'_, T>,
|
569
|
-
ty: InterfaceType,
|
570
|
-
mut offset: usize,
|
571
|
-
items: &[Self],
|
572
|
-
) -> Result<()>
|
573
|
-
where
|
574
|
-
Self: Sized,
|
575
|
-
{
|
576
|
-
for item in items {
|
577
|
-
item.store(cx, ty, offset)?;
|
578
|
-
offset += Self::SIZE32;
|
579
|
-
}
|
580
|
-
Ok(())
|
581
|
-
}
|
582
|
-
}
|
583
|
-
|
584
|
-
/// Host types which can be created from the canonical ABI.
|
585
|
-
///
|
586
|
-
/// This is the mirror of the [`Lower`] trait where it represents the capability
|
587
|
-
/// of acquiring items from WebAssembly and passing them to the host.
|
588
|
-
///
|
589
|
-
/// Built-in types to Rust such as `Option<T>` implement this trait as
|
590
|
-
/// appropriate. For a mapping of component model to Rust types see
|
591
|
-
/// [`ComponentType`].
|
592
|
-
///
|
593
|
-
/// For user-defined types, for example `record` types mapped to Rust `struct`s,
|
594
|
-
/// this crate additionally has
|
595
|
-
/// [`#[derive(Lift)]`](macro@crate::component::Lift).
|
596
|
-
///
|
597
|
-
/// Note that like [`ComponentType`] the definition of this trait is intended to
|
598
|
-
/// be an internal implementation detail of Wasmtime at this time. It's
|
599
|
-
/// recommended to use the `#[derive(Lift)]` implementation instead.
|
600
|
-
pub unsafe trait Lift: Sized + ComponentType {
|
601
|
-
/// Performs the "lift" operation in the canonical ABI.
|
602
|
-
///
|
603
|
-
/// This function performs a "flat" lift operation from the `src` specified
|
604
|
-
/// which is a sequence of core wasm values. The lifting operation will
|
605
|
-
/// validate core wasm values and produce a `Self` on success.
|
606
|
-
///
|
607
|
-
/// The `cx` provided contains contextual information such as the store
|
608
|
-
/// that's being loaded from, canonical options, and type information.
|
609
|
-
///
|
610
|
-
/// The `ty` parameter is the origin component's specification for what the
|
611
|
-
/// type that is being lifted is. For example this is the record type or the
|
612
|
-
/// resource type that is being lifted.
|
613
|
-
///
|
614
|
-
/// Note that this has a default implementation but if `typecheck` passes
|
615
|
-
/// for `Op::Lift` this needs to be overridden.
|
616
|
-
#[doc(hidden)]
|
617
|
-
fn lift(cx: &mut LiftContext<'_>, ty: InterfaceType, src: &Self::Lower) -> Result<Self>;
|
618
|
-
|
619
|
-
/// Performs the "load" operation in the canonical ABI.
|
620
|
-
///
|
621
|
-
/// This will read the `bytes` provided, which are a sub-slice into the
|
622
|
-
/// linear memory described by `cx`. The `bytes` array provided is
|
623
|
-
/// guaranteed to be `Self::SIZE32` bytes large. All of memory is then also
|
624
|
-
/// available through `cx` for bounds-checks and such as necessary for
|
625
|
-
/// strings/lists.
|
626
|
-
///
|
627
|
-
/// The `ty` argument is the type that's being loaded, as described by the
|
628
|
-
/// original component.
|
629
|
-
///
|
630
|
-
/// Note that this has a default implementation but if `typecheck` passes
|
631
|
-
/// for `Op::Lift` this needs to be overridden.
|
632
|
-
#[doc(hidden)]
|
633
|
-
fn load(cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self>;
|
634
|
-
|
635
|
-
/// Converts `list` into a `Vec<T>`, used in `Lift for Vec<T>`.
|
636
|
-
///
|
637
|
-
/// This is primarily here to get overridden for implementations of integers
|
638
|
-
/// which can avoid some extra fluff and use a pattern that's more easily
|
639
|
-
/// optimizable by LLVM.
|
640
|
-
#[doc(hidden)]
|
641
|
-
fn load_list(cx: &mut LiftContext<'_>, list: &WasmList<Self>) -> Result<Vec<Self>>
|
642
|
-
where
|
643
|
-
Self: Sized,
|
644
|
-
{
|
645
|
-
(0..list.len)
|
646
|
-
.map(|index| list.get_from_store(cx, index).unwrap())
|
647
|
-
.collect()
|
648
|
-
}
|
649
|
-
}
|
650
|
-
|
651
|
-
// Macro to help generate "forwarding implementations" of `ComponentType` to
|
652
|
-
// another type, used for wrappers in Rust like `&T`, `Box<T>`, etc. Note that
|
653
|
-
// these wrappers only implement lowering because lifting native Rust types
|
654
|
-
// cannot be done.
|
655
|
-
macro_rules! forward_type_impls {
|
656
|
-
($(($($generics:tt)*) $a:ty => $b:ty,)*) => ($(
|
657
|
-
unsafe impl <$($generics)*> ComponentType for $a {
|
658
|
-
type Lower = <$b as ComponentType>::Lower;
|
659
|
-
|
660
|
-
const ABI: CanonicalAbiInfo = <$b as ComponentType>::ABI;
|
661
|
-
|
662
|
-
#[inline]
|
663
|
-
fn typecheck(ty: &InterfaceType, types: &InstanceType<'_>) -> Result<()> {
|
664
|
-
<$b as ComponentType>::typecheck(ty, types)
|
665
|
-
}
|
666
|
-
}
|
667
|
-
)*)
|
668
|
-
}
|
669
|
-
|
670
|
-
forward_type_impls! {
|
671
|
-
(T: ComponentType + ?Sized) &'_ T => T,
|
672
|
-
(T: ComponentType + ?Sized) Box<T> => T,
|
673
|
-
(T: ComponentType + ?Sized) std::rc::Rc<T> => T,
|
674
|
-
(T: ComponentType + ?Sized) std::sync::Arc<T> => T,
|
675
|
-
() String => str,
|
676
|
-
(T: ComponentType) Vec<T> => [T],
|
677
|
-
}
|
678
|
-
|
679
|
-
macro_rules! forward_lowers {
|
680
|
-
($(($($generics:tt)*) $a:ty => $b:ty,)*) => ($(
|
681
|
-
unsafe impl <$($generics)*> Lower for $a {
|
682
|
-
fn lower<U>(
|
683
|
-
&self,
|
684
|
-
cx: &mut LowerContext<'_, U>,
|
685
|
-
ty: InterfaceType,
|
686
|
-
dst: &mut MaybeUninit<Self::Lower>,
|
687
|
-
) -> Result<()> {
|
688
|
-
<$b as Lower>::lower(self, cx, ty, dst)
|
689
|
-
}
|
690
|
-
|
691
|
-
fn store<U>(
|
692
|
-
&self,
|
693
|
-
cx: &mut LowerContext<'_, U>,
|
694
|
-
ty: InterfaceType,
|
695
|
-
offset: usize,
|
696
|
-
) -> Result<()> {
|
697
|
-
<$b as Lower>::store(self, cx, ty, offset)
|
698
|
-
}
|
699
|
-
}
|
700
|
-
)*)
|
701
|
-
}
|
702
|
-
|
703
|
-
forward_lowers! {
|
704
|
-
(T: Lower + ?Sized) &'_ T => T,
|
705
|
-
(T: Lower + ?Sized) Box<T> => T,
|
706
|
-
(T: Lower + ?Sized) std::rc::Rc<T> => T,
|
707
|
-
(T: Lower + ?Sized) std::sync::Arc<T> => T,
|
708
|
-
() String => str,
|
709
|
-
(T: Lower) Vec<T> => [T],
|
710
|
-
}
|
711
|
-
|
712
|
-
macro_rules! forward_string_lifts {
|
713
|
-
($($a:ty,)*) => ($(
|
714
|
-
unsafe impl Lift for $a {
|
715
|
-
#[inline]
|
716
|
-
fn lift(cx: &mut LiftContext<'_>, ty: InterfaceType, src: &Self::Lower) -> Result<Self> {
|
717
|
-
Ok(<WasmStr as Lift>::lift(cx, ty, src)?.to_str_from_memory(cx.memory())?.into())
|
718
|
-
}
|
719
|
-
|
720
|
-
#[inline]
|
721
|
-
fn load(cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self> {
|
722
|
-
Ok(<WasmStr as Lift>::load(cx, ty, bytes)?.to_str_from_memory(cx.memory())?.into())
|
723
|
-
}
|
724
|
-
}
|
725
|
-
)*)
|
726
|
-
}
|
727
|
-
|
728
|
-
forward_string_lifts! {
|
729
|
-
Box<str>,
|
730
|
-
std::rc::Rc<str>,
|
731
|
-
std::sync::Arc<str>,
|
732
|
-
String,
|
733
|
-
}
|
734
|
-
|
735
|
-
macro_rules! forward_list_lifts {
|
736
|
-
($($a:ty,)*) => ($(
|
737
|
-
unsafe impl <T: Lift> Lift for $a {
|
738
|
-
fn lift(cx: &mut LiftContext<'_>, ty: InterfaceType, src: &Self::Lower) -> Result<Self> {
|
739
|
-
let list = <WasmList::<T> as Lift>::lift(cx, ty, src)?;
|
740
|
-
Ok(T::load_list(cx, &list)?.into())
|
741
|
-
}
|
742
|
-
|
743
|
-
fn load(cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self> {
|
744
|
-
let list = <WasmList::<T> as Lift>::load(cx, ty, bytes)?;
|
745
|
-
Ok(T::load_list(cx, &list)?.into())
|
746
|
-
}
|
747
|
-
}
|
748
|
-
)*)
|
749
|
-
}
|
750
|
-
|
751
|
-
forward_list_lifts! {
|
752
|
-
Box<[T]>,
|
753
|
-
std::rc::Rc<[T]>,
|
754
|
-
std::sync::Arc<[T]>,
|
755
|
-
Vec<T>,
|
756
|
-
}
|
757
|
-
|
758
|
-
// Macro to help generate `ComponentType` implementations for primitive types
|
759
|
-
// such as integers, char, bool, etc.
|
760
|
-
macro_rules! integers {
|
761
|
-
($($primitive:ident = $ty:ident in $field:ident/$get:ident with abi:$abi:ident,)*) => ($(
|
762
|
-
unsafe impl ComponentType for $primitive {
|
763
|
-
type Lower = ValRaw;
|
764
|
-
|
765
|
-
const ABI: CanonicalAbiInfo = CanonicalAbiInfo::$abi;
|
766
|
-
|
767
|
-
fn typecheck(ty: &InterfaceType, _types: &InstanceType<'_>) -> Result<()> {
|
768
|
-
match ty {
|
769
|
-
InterfaceType::$ty => Ok(()),
|
770
|
-
other => bail!("expected `{}` found `{}`", desc(&InterfaceType::$ty), desc(other))
|
771
|
-
}
|
772
|
-
}
|
773
|
-
}
|
774
|
-
|
775
|
-
unsafe impl Lower for $primitive {
|
776
|
-
#[inline]
|
777
|
-
#[allow(trivial_numeric_casts)]
|
778
|
-
fn lower<T>(
|
779
|
-
&self,
|
780
|
-
_cx: &mut LowerContext<'_, T>,
|
781
|
-
ty: InterfaceType,
|
782
|
-
dst: &mut MaybeUninit<Self::Lower>,
|
783
|
-
) -> Result<()> {
|
784
|
-
debug_assert!(matches!(ty, InterfaceType::$ty));
|
785
|
-
dst.write(ValRaw::$field(*self as $field));
|
786
|
-
Ok(())
|
787
|
-
}
|
788
|
-
|
789
|
-
#[inline]
|
790
|
-
fn store<T>(
|
791
|
-
&self,
|
792
|
-
cx: &mut LowerContext<'_, T>,
|
793
|
-
ty: InterfaceType,
|
794
|
-
offset: usize,
|
795
|
-
) -> Result<()> {
|
796
|
-
debug_assert!(matches!(ty, InterfaceType::$ty));
|
797
|
-
debug_assert!(offset % Self::SIZE32 == 0);
|
798
|
-
*cx.get(offset) = self.to_le_bytes();
|
799
|
-
Ok(())
|
800
|
-
}
|
801
|
-
|
802
|
-
fn store_list<T>(
|
803
|
-
cx: &mut LowerContext<'_, T>,
|
804
|
-
ty: InterfaceType,
|
805
|
-
offset: usize,
|
806
|
-
items: &[Self],
|
807
|
-
) -> Result<()> {
|
808
|
-
debug_assert!(matches!(ty, InterfaceType::$ty));
|
809
|
-
|
810
|
-
// Double-check that the CM alignment is at least the host's
|
811
|
-
// alignment for this type which should be true for all
|
812
|
-
// platforms.
|
813
|
-
assert!((Self::ALIGN32 as usize) >= mem::align_of::<Self>());
|
814
|
-
|
815
|
-
// Slice `cx`'s memory to the window that we'll be modifying.
|
816
|
-
// This should all have already been verified in terms of
|
817
|
-
// alignment and sizing meaning that these assertions here are
|
818
|
-
// not truly necessary but are instead double-checks.
|
819
|
-
//
|
820
|
-
// Note that we're casting a `[u8]` slice to `[Self]` with
|
821
|
-
// `align_to_mut` which is not safe in general but is safe in
|
822
|
-
// our specific case as all `u8` patterns are valid `Self`
|
823
|
-
// patterns since `Self` is an integral type.
|
824
|
-
let dst = &mut cx.as_slice_mut()[offset..][..items.len() * Self::SIZE32];
|
825
|
-
let (before, middle, end) = unsafe { dst.align_to_mut::<Self>() };
|
826
|
-
assert!(before.is_empty() && end.is_empty());
|
827
|
-
assert_eq!(middle.len(), items.len());
|
828
|
-
|
829
|
-
// And with all that out of the way perform the copying loop.
|
830
|
-
// This is not a `copy_from_slice` because endianness needs to
|
831
|
-
// be handled here, but LLVM should pretty easily transform this
|
832
|
-
// into a memcpy on little-endian platforms.
|
833
|
-
for (dst, src) in middle.iter_mut().zip(items) {
|
834
|
-
*dst = src.to_le();
|
835
|
-
}
|
836
|
-
Ok(())
|
837
|
-
}
|
838
|
-
}
|
839
|
-
|
840
|
-
unsafe impl Lift for $primitive {
|
841
|
-
#[inline]
|
842
|
-
#[allow(trivial_numeric_casts)]
|
843
|
-
fn lift(_cx: &mut LiftContext<'_>, ty: InterfaceType, src: &Self::Lower) -> Result<Self> {
|
844
|
-
debug_assert!(matches!(ty, InterfaceType::$ty));
|
845
|
-
Ok(src.$get() as $primitive)
|
846
|
-
}
|
847
|
-
|
848
|
-
#[inline]
|
849
|
-
fn load(_cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self> {
|
850
|
-
debug_assert!(matches!(ty, InterfaceType::$ty));
|
851
|
-
debug_assert!((bytes.as_ptr() as usize) % Self::SIZE32 == 0);
|
852
|
-
Ok($primitive::from_le_bytes(bytes.try_into().unwrap()))
|
853
|
-
}
|
854
|
-
|
855
|
-
fn load_list(cx: &mut LiftContext<'_>, list: &WasmList<Self>) -> Result<Vec<Self>> {
|
856
|
-
Ok(
|
857
|
-
list._as_le_slice(cx.memory())
|
858
|
-
.iter()
|
859
|
-
.map(|i| Self::from_le(*i))
|
860
|
-
.collect(),
|
861
|
-
)
|
862
|
-
}
|
863
|
-
}
|
864
|
-
)*)
|
865
|
-
}
|
866
|
-
|
867
|
-
integers! {
|
868
|
-
i8 = S8 in i32/get_i32 with abi:SCALAR1,
|
869
|
-
u8 = U8 in u32/get_u32 with abi:SCALAR1,
|
870
|
-
i16 = S16 in i32/get_i32 with abi:SCALAR2,
|
871
|
-
u16 = U16 in u32/get_u32 with abi:SCALAR2,
|
872
|
-
i32 = S32 in i32/get_i32 with abi:SCALAR4,
|
873
|
-
u32 = U32 in u32/get_u32 with abi:SCALAR4,
|
874
|
-
i64 = S64 in i64/get_i64 with abi:SCALAR8,
|
875
|
-
u64 = U64 in u64/get_u64 with abi:SCALAR8,
|
876
|
-
}
|
877
|
-
|
878
|
-
macro_rules! floats {
|
879
|
-
($($float:ident/$get_float:ident = $ty:ident with abi:$abi:ident)*) => ($(const _: () = {
|
880
|
-
/// All floats in-and-out of the canonical abi always have their nan
|
881
|
-
/// payloads canonicalized. conveniently the `NAN` constant in rust has
|
882
|
-
/// the same representation as canonical nan, so we can use that for the
|
883
|
-
/// nan value.
|
884
|
-
#[inline]
|
885
|
-
fn canonicalize(float: $float) -> $float {
|
886
|
-
if float.is_nan() {
|
887
|
-
$float::NAN
|
888
|
-
} else {
|
889
|
-
float
|
890
|
-
}
|
891
|
-
}
|
892
|
-
|
893
|
-
unsafe impl ComponentType for $float {
|
894
|
-
type Lower = ValRaw;
|
895
|
-
|
896
|
-
const ABI: CanonicalAbiInfo = CanonicalAbiInfo::$abi;
|
897
|
-
|
898
|
-
fn typecheck(ty: &InterfaceType, _types: &InstanceType<'_>) -> Result<()> {
|
899
|
-
match ty {
|
900
|
-
InterfaceType::$ty => Ok(()),
|
901
|
-
other => bail!("expected `{}` found `{}`", desc(&InterfaceType::$ty), desc(other))
|
902
|
-
}
|
903
|
-
}
|
904
|
-
}
|
905
|
-
|
906
|
-
unsafe impl Lower for $float {
|
907
|
-
#[inline]
|
908
|
-
fn lower<T>(
|
909
|
-
&self,
|
910
|
-
_cx: &mut LowerContext<'_, T>,
|
911
|
-
ty: InterfaceType,
|
912
|
-
dst: &mut MaybeUninit<Self::Lower>,
|
913
|
-
) -> Result<()> {
|
914
|
-
debug_assert!(matches!(ty, InterfaceType::$ty));
|
915
|
-
dst.write(ValRaw::$float(canonicalize(*self).to_bits()));
|
916
|
-
Ok(())
|
917
|
-
}
|
918
|
-
|
919
|
-
#[inline]
|
920
|
-
fn store<T>(
|
921
|
-
&self,
|
922
|
-
cx: &mut LowerContext<'_, T>,
|
923
|
-
ty: InterfaceType,
|
924
|
-
offset: usize,
|
925
|
-
) -> Result<()> {
|
926
|
-
debug_assert!(matches!(ty, InterfaceType::$ty));
|
927
|
-
debug_assert!(offset % Self::SIZE32 == 0);
|
928
|
-
let ptr = cx.get(offset);
|
929
|
-
*ptr = canonicalize(*self).to_bits().to_le_bytes();
|
930
|
-
Ok(())
|
931
|
-
}
|
932
|
-
}
|
933
|
-
|
934
|
-
unsafe impl Lift for $float {
|
935
|
-
#[inline]
|
936
|
-
fn lift(_cx: &mut LiftContext<'_>, ty: InterfaceType, src: &Self::Lower) -> Result<Self> {
|
937
|
-
debug_assert!(matches!(ty, InterfaceType::$ty));
|
938
|
-
Ok(canonicalize($float::from_bits(src.$get_float())))
|
939
|
-
}
|
940
|
-
|
941
|
-
#[inline]
|
942
|
-
fn load(_cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self> {
|
943
|
-
debug_assert!(matches!(ty, InterfaceType::$ty));
|
944
|
-
debug_assert!((bytes.as_ptr() as usize) % Self::SIZE32 == 0);
|
945
|
-
Ok(canonicalize($float::from_le_bytes(bytes.try_into().unwrap())))
|
946
|
-
}
|
947
|
-
}
|
948
|
-
};)*)
|
949
|
-
}
|
950
|
-
|
951
|
-
floats! {
|
952
|
-
f32/get_f32 = Float32 with abi:SCALAR4
|
953
|
-
f64/get_f64 = Float64 with abi:SCALAR8
|
954
|
-
}
|
955
|
-
|
956
|
-
unsafe impl ComponentType for bool {
|
957
|
-
type Lower = ValRaw;
|
958
|
-
|
959
|
-
const ABI: CanonicalAbiInfo = CanonicalAbiInfo::SCALAR1;
|
960
|
-
|
961
|
-
fn typecheck(ty: &InterfaceType, _types: &InstanceType<'_>) -> Result<()> {
|
962
|
-
match ty {
|
963
|
-
InterfaceType::Bool => Ok(()),
|
964
|
-
other => bail!("expected `bool` found `{}`", desc(other)),
|
965
|
-
}
|
966
|
-
}
|
967
|
-
}
|
968
|
-
|
969
|
-
unsafe impl Lower for bool {
|
970
|
-
fn lower<T>(
|
971
|
-
&self,
|
972
|
-
_cx: &mut LowerContext<'_, T>,
|
973
|
-
ty: InterfaceType,
|
974
|
-
dst: &mut MaybeUninit<Self::Lower>,
|
975
|
-
) -> Result<()> {
|
976
|
-
debug_assert!(matches!(ty, InterfaceType::Bool));
|
977
|
-
dst.write(ValRaw::i32(*self as i32));
|
978
|
-
Ok(())
|
979
|
-
}
|
980
|
-
|
981
|
-
fn store<T>(
|
982
|
-
&self,
|
983
|
-
cx: &mut LowerContext<'_, T>,
|
984
|
-
ty: InterfaceType,
|
985
|
-
offset: usize,
|
986
|
-
) -> Result<()> {
|
987
|
-
debug_assert!(matches!(ty, InterfaceType::Bool));
|
988
|
-
debug_assert!(offset % Self::SIZE32 == 0);
|
989
|
-
cx.get::<1>(offset)[0] = *self as u8;
|
990
|
-
Ok(())
|
991
|
-
}
|
992
|
-
}
|
993
|
-
|
994
|
-
unsafe impl Lift for bool {
|
995
|
-
#[inline]
|
996
|
-
fn lift(_cx: &mut LiftContext<'_>, ty: InterfaceType, src: &Self::Lower) -> Result<Self> {
|
997
|
-
debug_assert!(matches!(ty, InterfaceType::Bool));
|
998
|
-
match src.get_i32() {
|
999
|
-
0 => Ok(false),
|
1000
|
-
_ => Ok(true),
|
1001
|
-
}
|
1002
|
-
}
|
1003
|
-
|
1004
|
-
#[inline]
|
1005
|
-
fn load(_cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self> {
|
1006
|
-
debug_assert!(matches!(ty, InterfaceType::Bool));
|
1007
|
-
match bytes[0] {
|
1008
|
-
0 => Ok(false),
|
1009
|
-
_ => Ok(true),
|
1010
|
-
}
|
1011
|
-
}
|
1012
|
-
}
|
1013
|
-
|
1014
|
-
unsafe impl ComponentType for char {
|
1015
|
-
type Lower = ValRaw;
|
1016
|
-
|
1017
|
-
const ABI: CanonicalAbiInfo = CanonicalAbiInfo::SCALAR4;
|
1018
|
-
|
1019
|
-
fn typecheck(ty: &InterfaceType, _types: &InstanceType<'_>) -> Result<()> {
|
1020
|
-
match ty {
|
1021
|
-
InterfaceType::Char => Ok(()),
|
1022
|
-
other => bail!("expected `char` found `{}`", desc(other)),
|
1023
|
-
}
|
1024
|
-
}
|
1025
|
-
}
|
1026
|
-
|
1027
|
-
unsafe impl Lower for char {
|
1028
|
-
#[inline]
|
1029
|
-
fn lower<T>(
|
1030
|
-
&self,
|
1031
|
-
_cx: &mut LowerContext<'_, T>,
|
1032
|
-
ty: InterfaceType,
|
1033
|
-
dst: &mut MaybeUninit<Self::Lower>,
|
1034
|
-
) -> Result<()> {
|
1035
|
-
debug_assert!(matches!(ty, InterfaceType::Char));
|
1036
|
-
dst.write(ValRaw::u32(u32::from(*self)));
|
1037
|
-
Ok(())
|
1038
|
-
}
|
1039
|
-
|
1040
|
-
#[inline]
|
1041
|
-
fn store<T>(
|
1042
|
-
&self,
|
1043
|
-
cx: &mut LowerContext<'_, T>,
|
1044
|
-
ty: InterfaceType,
|
1045
|
-
offset: usize,
|
1046
|
-
) -> Result<()> {
|
1047
|
-
debug_assert!(matches!(ty, InterfaceType::Char));
|
1048
|
-
debug_assert!(offset % Self::SIZE32 == 0);
|
1049
|
-
*cx.get::<4>(offset) = u32::from(*self).to_le_bytes();
|
1050
|
-
Ok(())
|
1051
|
-
}
|
1052
|
-
}
|
1053
|
-
|
1054
|
-
unsafe impl Lift for char {
|
1055
|
-
#[inline]
|
1056
|
-
fn lift(_cx: &mut LiftContext<'_>, ty: InterfaceType, src: &Self::Lower) -> Result<Self> {
|
1057
|
-
debug_assert!(matches!(ty, InterfaceType::Char));
|
1058
|
-
Ok(char::try_from(src.get_u32())?)
|
1059
|
-
}
|
1060
|
-
|
1061
|
-
#[inline]
|
1062
|
-
fn load(_cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self> {
|
1063
|
-
debug_assert!(matches!(ty, InterfaceType::Char));
|
1064
|
-
debug_assert!((bytes.as_ptr() as usize) % Self::SIZE32 == 0);
|
1065
|
-
let bits = u32::from_le_bytes(bytes.try_into().unwrap());
|
1066
|
-
Ok(char::try_from(bits)?)
|
1067
|
-
}
|
1068
|
-
}
|
1069
|
-
|
1070
|
-
// TODO: these probably need different constants for memory64
|
1071
|
-
const UTF16_TAG: usize = 1 << 31;
|
1072
|
-
const MAX_STRING_BYTE_LENGTH: usize = (1 << 31) - 1;
|
1073
|
-
|
1074
|
-
// Note that this is similar to `ComponentType for WasmStr` except it can only
|
1075
|
-
// be used for lowering, not lifting.
|
1076
|
-
unsafe impl ComponentType for str {
|
1077
|
-
type Lower = [ValRaw; 2];
|
1078
|
-
|
1079
|
-
const ABI: CanonicalAbiInfo = CanonicalAbiInfo::POINTER_PAIR;
|
1080
|
-
|
1081
|
-
fn typecheck(ty: &InterfaceType, _types: &InstanceType<'_>) -> Result<()> {
|
1082
|
-
match ty {
|
1083
|
-
InterfaceType::String => Ok(()),
|
1084
|
-
other => bail!("expected `string` found `{}`", desc(other)),
|
1085
|
-
}
|
1086
|
-
}
|
1087
|
-
}
|
1088
|
-
|
1089
|
-
unsafe impl Lower for str {
|
1090
|
-
fn lower<T>(
|
1091
|
-
&self,
|
1092
|
-
cx: &mut LowerContext<'_, T>,
|
1093
|
-
ty: InterfaceType,
|
1094
|
-
dst: &mut MaybeUninit<[ValRaw; 2]>,
|
1095
|
-
) -> Result<()> {
|
1096
|
-
debug_assert!(matches!(ty, InterfaceType::String));
|
1097
|
-
let (ptr, len) = lower_string(cx, self)?;
|
1098
|
-
// See "WRITEPTR64" above for why this is always storing a 64-bit
|
1099
|
-
// integer.
|
1100
|
-
map_maybe_uninit!(dst[0]).write(ValRaw::i64(ptr as i64));
|
1101
|
-
map_maybe_uninit!(dst[1]).write(ValRaw::i64(len as i64));
|
1102
|
-
Ok(())
|
1103
|
-
}
|
1104
|
-
|
1105
|
-
fn store<T>(
|
1106
|
-
&self,
|
1107
|
-
cx: &mut LowerContext<'_, T>,
|
1108
|
-
ty: InterfaceType,
|
1109
|
-
offset: usize,
|
1110
|
-
) -> Result<()> {
|
1111
|
-
debug_assert!(matches!(ty, InterfaceType::String));
|
1112
|
-
debug_assert!(offset % (Self::ALIGN32 as usize) == 0);
|
1113
|
-
let (ptr, len) = lower_string(cx, self)?;
|
1114
|
-
// FIXME: needs memory64 handling
|
1115
|
-
*cx.get(offset + 0) = (ptr as i32).to_le_bytes();
|
1116
|
-
*cx.get(offset + 4) = (len as i32).to_le_bytes();
|
1117
|
-
Ok(())
|
1118
|
-
}
|
1119
|
-
}
|
1120
|
-
|
1121
|
-
fn lower_string<T>(cx: &mut LowerContext<'_, T>, string: &str) -> Result<(usize, usize)> {
|
1122
|
-
// Note that in general the wasm module can't assume anything about what the
|
1123
|
-
// host strings are encoded as. Additionally hosts are allowed to have
|
1124
|
-
// differently-encoded strings at runtime. Finally when copying a string
|
1125
|
-
// into wasm it's somewhat strict in the sense that the various patterns of
|
1126
|
-
// allocation and such are already dictated for us.
|
1127
|
-
//
|
1128
|
-
// In general what this means is that when copying a string from the host
|
1129
|
-
// into the destination we need to follow one of the cases of copying into
|
1130
|
-
// WebAssembly. It doesn't particularly matter which case as long as it ends
|
1131
|
-
// up in the right encoding. For example a destination encoding of
|
1132
|
-
// latin1+utf16 has a number of ways to get copied into and we do something
|
1133
|
-
// here that isn't the default "utf8 to latin1+utf16" since we have access
|
1134
|
-
// to simd-accelerated helpers in the `encoding_rs` crate. This is ok though
|
1135
|
-
// because we can fake that the host string was already stored in latin1
|
1136
|
-
// format and follow that copy pattern instead.
|
1137
|
-
match cx.options.string_encoding() {
|
1138
|
-
// This corresponds to `store_string_copy` in the canonical ABI where
|
1139
|
-
// the host's representation is utf-8 and the wasm module wants utf-8 so
|
1140
|
-
// a copy is all that's needed (and the `realloc` can be precise for the
|
1141
|
-
// initial memory allocation).
|
1142
|
-
StringEncoding::Utf8 => {
|
1143
|
-
if string.len() > MAX_STRING_BYTE_LENGTH {
|
1144
|
-
bail!(
|
1145
|
-
"string length of {} too large to copy into wasm",
|
1146
|
-
string.len()
|
1147
|
-
);
|
1148
|
-
}
|
1149
|
-
let ptr = cx.realloc(0, 0, 1, string.len())?;
|
1150
|
-
cx.as_slice_mut()[ptr..][..string.len()].copy_from_slice(string.as_bytes());
|
1151
|
-
Ok((ptr, string.len()))
|
1152
|
-
}
|
1153
|
-
|
1154
|
-
// This corresponds to `store_utf8_to_utf16` in the canonical ABI. Here
|
1155
|
-
// an over-large allocation is performed and then shrunk afterwards if
|
1156
|
-
// necessary.
|
1157
|
-
StringEncoding::Utf16 => {
|
1158
|
-
let size = string.len() * 2;
|
1159
|
-
if size > MAX_STRING_BYTE_LENGTH {
|
1160
|
-
bail!(
|
1161
|
-
"string length of {} too large to copy into wasm",
|
1162
|
-
string.len()
|
1163
|
-
);
|
1164
|
-
}
|
1165
|
-
let mut ptr = cx.realloc(0, 0, 2, size)?;
|
1166
|
-
let mut copied = 0;
|
1167
|
-
let bytes = &mut cx.as_slice_mut()[ptr..][..size];
|
1168
|
-
for (u, bytes) in string.encode_utf16().zip(bytes.chunks_mut(2)) {
|
1169
|
-
let u_bytes = u.to_le_bytes();
|
1170
|
-
bytes[0] = u_bytes[0];
|
1171
|
-
bytes[1] = u_bytes[1];
|
1172
|
-
copied += 1;
|
1173
|
-
}
|
1174
|
-
if (copied * 2) < size {
|
1175
|
-
ptr = cx.realloc(ptr, size, 2, copied * 2)?;
|
1176
|
-
}
|
1177
|
-
Ok((ptr, copied))
|
1178
|
-
}
|
1179
|
-
|
1180
|
-
StringEncoding::CompactUtf16 => {
|
1181
|
-
// This corresponds to `store_string_to_latin1_or_utf16`
|
1182
|
-
let bytes = string.as_bytes();
|
1183
|
-
let mut iter = string.char_indices();
|
1184
|
-
let mut ptr = cx.realloc(0, 0, 2, bytes.len())?;
|
1185
|
-
let mut dst = &mut cx.as_slice_mut()[ptr..][..bytes.len()];
|
1186
|
-
let mut result = 0;
|
1187
|
-
while let Some((i, ch)) = iter.next() {
|
1188
|
-
// Test if this `char` fits into the latin1 encoding.
|
1189
|
-
if let Ok(byte) = u8::try_from(u32::from(ch)) {
|
1190
|
-
dst[result] = byte;
|
1191
|
-
result += 1;
|
1192
|
-
continue;
|
1193
|
-
}
|
1194
|
-
|
1195
|
-
// .. if utf16 is forced to be used then the allocation is
|
1196
|
-
// bumped up to the maximum size.
|
1197
|
-
let worst_case = bytes
|
1198
|
-
.len()
|
1199
|
-
.checked_mul(2)
|
1200
|
-
.ok_or_else(|| anyhow!("byte length overflow"))?;
|
1201
|
-
if worst_case > MAX_STRING_BYTE_LENGTH {
|
1202
|
-
bail!("byte length too large");
|
1203
|
-
}
|
1204
|
-
ptr = cx.realloc(ptr, bytes.len(), 2, worst_case)?;
|
1205
|
-
dst = &mut cx.as_slice_mut()[ptr..][..worst_case];
|
1206
|
-
|
1207
|
-
// Previously encoded latin1 bytes are inflated to their 16-bit
|
1208
|
-
// size for utf16
|
1209
|
-
for i in (0..result).rev() {
|
1210
|
-
dst[2 * i] = dst[i];
|
1211
|
-
dst[2 * i + 1] = 0;
|
1212
|
-
}
|
1213
|
-
|
1214
|
-
// and then the remainder of the string is encoded.
|
1215
|
-
for (u, bytes) in string[i..]
|
1216
|
-
.encode_utf16()
|
1217
|
-
.zip(dst[2 * result..].chunks_mut(2))
|
1218
|
-
{
|
1219
|
-
let u_bytes = u.to_le_bytes();
|
1220
|
-
bytes[0] = u_bytes[0];
|
1221
|
-
bytes[1] = u_bytes[1];
|
1222
|
-
result += 1;
|
1223
|
-
}
|
1224
|
-
if worst_case > 2 * result {
|
1225
|
-
ptr = cx.realloc(ptr, worst_case, 2, 2 * result)?;
|
1226
|
-
}
|
1227
|
-
return Ok((ptr, result | UTF16_TAG));
|
1228
|
-
}
|
1229
|
-
if result < bytes.len() {
|
1230
|
-
ptr = cx.realloc(ptr, bytes.len(), 2, result)?;
|
1231
|
-
}
|
1232
|
-
Ok((ptr, result))
|
1233
|
-
}
|
1234
|
-
}
|
1235
|
-
}
|
1236
|
-
|
1237
|
-
/// Representation of a string located in linear memory in a WebAssembly
|
1238
|
-
/// instance.
|
1239
|
-
///
|
1240
|
-
/// This type can be used in place of `String` and `str` for string-taking APIs
|
1241
|
-
/// in some situations. The purpose of this type is to represent a range of
|
1242
|
-
/// validated bytes within a component but does not actually copy the bytes. The
|
1243
|
-
/// primary method, [`WasmStr::to_str`], attempts to return a reference to the
|
1244
|
-
/// string directly located in the component's memory, avoiding a copy into the
|
1245
|
-
/// host if possible.
|
1246
|
-
///
|
1247
|
-
/// The downside of this type, however, is that accessing a string requires a
|
1248
|
-
/// [`Store`](crate::Store) pointer (via [`StoreContext`]). Bindings generated
|
1249
|
-
/// by [`bindgen!`](crate::component::bindgen), for example, do not have access
|
1250
|
-
/// to [`StoreContext`] and thus can't use this type.
|
1251
|
-
///
|
1252
|
-
/// This is intended for more advanced use cases such as defining functions
|
1253
|
-
/// directly in a [`Linker`](crate::component::Linker). It's expected that in
|
1254
|
-
/// the future [`bindgen!`](crate::component::bindgen) will also have a way to
|
1255
|
-
/// use this type.
|
1256
|
-
///
|
1257
|
-
/// This type is used with [`TypedFunc`], for example, when WebAssembly returns
|
1258
|
-
/// a string. This type cannot be used to give a string to WebAssembly, instead
|
1259
|
-
/// `&str` should be used for that (since it's coming from the host).
|
1260
|
-
///
|
1261
|
-
/// Note that this type represents an in-bounds string in linear memory, but it
|
1262
|
-
/// does not represent a valid string (e.g. valid utf-8). Validation happens
|
1263
|
-
/// when [`WasmStr::to_str`] is called.
|
1264
|
-
///
|
1265
|
-
/// Also note that this type does not implement [`Lower`], it only implements
|
1266
|
-
/// [`Lift`].
|
1267
|
-
pub struct WasmStr {
|
1268
|
-
ptr: usize,
|
1269
|
-
len: usize,
|
1270
|
-
options: Options,
|
1271
|
-
}
|
1272
|
-
|
1273
|
-
impl WasmStr {
|
1274
|
-
fn new(ptr: usize, len: usize, cx: &mut LiftContext<'_>) -> Result<WasmStr> {
|
1275
|
-
let byte_len = match cx.options.string_encoding() {
|
1276
|
-
StringEncoding::Utf8 => Some(len),
|
1277
|
-
StringEncoding::Utf16 => len.checked_mul(2),
|
1278
|
-
StringEncoding::CompactUtf16 => {
|
1279
|
-
if len & UTF16_TAG == 0 {
|
1280
|
-
Some(len)
|
1281
|
-
} else {
|
1282
|
-
(len ^ UTF16_TAG).checked_mul(2)
|
1283
|
-
}
|
1284
|
-
}
|
1285
|
-
};
|
1286
|
-
match byte_len.and_then(|len| ptr.checked_add(len)) {
|
1287
|
-
Some(n) if n <= cx.memory().len() => {}
|
1288
|
-
_ => bail!("string pointer/length out of bounds of memory"),
|
1289
|
-
}
|
1290
|
-
Ok(WasmStr {
|
1291
|
-
ptr,
|
1292
|
-
len,
|
1293
|
-
options: *cx.options,
|
1294
|
-
})
|
1295
|
-
}
|
1296
|
-
|
1297
|
-
/// Returns the underlying string that this cursor points to.
|
1298
|
-
///
|
1299
|
-
/// Note that this will internally decode the string from the wasm's
|
1300
|
-
/// encoding to utf-8 and additionally perform validation.
|
1301
|
-
///
|
1302
|
-
/// The `store` provided must be the store where this string lives to
|
1303
|
-
/// access the correct memory.
|
1304
|
-
///
|
1305
|
-
/// # Errors
|
1306
|
-
///
|
1307
|
-
/// Returns an error if the string wasn't encoded correctly (e.g. invalid
|
1308
|
-
/// utf-8).
|
1309
|
-
///
|
1310
|
-
/// # Panics
|
1311
|
-
///
|
1312
|
-
/// Panics if this string is not owned by `store`.
|
1313
|
-
//
|
1314
|
-
// TODO: should add accessors for specifically utf-8 and utf-16 that perhaps
|
1315
|
-
// in an opt-in basis don't do validation. Additionally there should be some
|
1316
|
-
// method that returns `[u16]` after validating to avoid the utf16-to-utf8
|
1317
|
-
// transcode.
|
1318
|
-
pub fn to_str<'a, T: 'a>(&self, store: impl Into<StoreContext<'a, T>>) -> Result<Cow<'a, str>> {
|
1319
|
-
let store = store.into().0;
|
1320
|
-
let memory = self.options.memory(store);
|
1321
|
-
self.to_str_from_memory(memory)
|
1322
|
-
}
|
1323
|
-
|
1324
|
-
fn to_str_from_memory<'a>(&self, memory: &'a [u8]) -> Result<Cow<'a, str>> {
|
1325
|
-
match self.options.string_encoding() {
|
1326
|
-
StringEncoding::Utf8 => self.decode_utf8(memory),
|
1327
|
-
StringEncoding::Utf16 => self.decode_utf16(memory, self.len),
|
1328
|
-
StringEncoding::CompactUtf16 => {
|
1329
|
-
if self.len & UTF16_TAG == 0 {
|
1330
|
-
self.decode_latin1(memory)
|
1331
|
-
} else {
|
1332
|
-
self.decode_utf16(memory, self.len ^ UTF16_TAG)
|
1333
|
-
}
|
1334
|
-
}
|
1335
|
-
}
|
1336
|
-
}
|
1337
|
-
|
1338
|
-
fn decode_utf8<'a>(&self, memory: &'a [u8]) -> Result<Cow<'a, str>> {
|
1339
|
-
// Note that bounds-checking already happen in construction of `WasmStr`
|
1340
|
-
// so this is never expected to panic. This could theoretically be
|
1341
|
-
// unchecked indexing if we're feeling wild enough.
|
1342
|
-
Ok(str::from_utf8(&memory[self.ptr..][..self.len])?.into())
|
1343
|
-
}
|
1344
|
-
|
1345
|
-
fn decode_utf16<'a>(&self, memory: &'a [u8], len: usize) -> Result<Cow<'a, str>> {
|
1346
|
-
// See notes in `decode_utf8` for why this is panicking indexing.
|
1347
|
-
let memory = &memory[self.ptr..][..len * 2];
|
1348
|
-
Ok(std::char::decode_utf16(
|
1349
|
-
memory
|
1350
|
-
.chunks(2)
|
1351
|
-
.map(|chunk| u16::from_le_bytes(chunk.try_into().unwrap())),
|
1352
|
-
)
|
1353
|
-
.collect::<Result<String, _>>()?
|
1354
|
-
.into())
|
1355
|
-
}
|
1356
|
-
|
1357
|
-
fn decode_latin1<'a>(&self, memory: &'a [u8]) -> Result<Cow<'a, str>> {
|
1358
|
-
// See notes in `decode_utf8` for why this is panicking indexing.
|
1359
|
-
Ok(encoding_rs::mem::decode_latin1(
|
1360
|
-
&memory[self.ptr..][..self.len],
|
1361
|
-
))
|
1362
|
-
}
|
1363
|
-
}
|
1364
|
-
|
1365
|
-
// Note that this is similar to `ComponentType for str` except it can only be
|
1366
|
-
// used for lifting, not lowering.
|
1367
|
-
unsafe impl ComponentType for WasmStr {
|
1368
|
-
type Lower = <str as ComponentType>::Lower;
|
1369
|
-
|
1370
|
-
const ABI: CanonicalAbiInfo = CanonicalAbiInfo::POINTER_PAIR;
|
1371
|
-
|
1372
|
-
fn typecheck(ty: &InterfaceType, _types: &InstanceType<'_>) -> Result<()> {
|
1373
|
-
match ty {
|
1374
|
-
InterfaceType::String => Ok(()),
|
1375
|
-
other => bail!("expected `string` found `{}`", desc(other)),
|
1376
|
-
}
|
1377
|
-
}
|
1378
|
-
}
|
1379
|
-
|
1380
|
-
unsafe impl Lift for WasmStr {
|
1381
|
-
#[inline]
|
1382
|
-
fn lift(cx: &mut LiftContext<'_>, ty: InterfaceType, src: &Self::Lower) -> Result<Self> {
|
1383
|
-
debug_assert!(matches!(ty, InterfaceType::String));
|
1384
|
-
// FIXME: needs memory64 treatment
|
1385
|
-
let ptr = src[0].get_u32();
|
1386
|
-
let len = src[1].get_u32();
|
1387
|
-
let (ptr, len) = (usize::try_from(ptr)?, usize::try_from(len)?);
|
1388
|
-
WasmStr::new(ptr, len, cx)
|
1389
|
-
}
|
1390
|
-
|
1391
|
-
#[inline]
|
1392
|
-
fn load(cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self> {
|
1393
|
-
debug_assert!(matches!(ty, InterfaceType::String));
|
1394
|
-
debug_assert!((bytes.as_ptr() as usize) % (Self::ALIGN32 as usize) == 0);
|
1395
|
-
// FIXME: needs memory64 treatment
|
1396
|
-
let ptr = u32::from_le_bytes(bytes[..4].try_into().unwrap());
|
1397
|
-
let len = u32::from_le_bytes(bytes[4..].try_into().unwrap());
|
1398
|
-
let (ptr, len) = (usize::try_from(ptr)?, usize::try_from(len)?);
|
1399
|
-
WasmStr::new(ptr, len, cx)
|
1400
|
-
}
|
1401
|
-
}
|
1402
|
-
|
1403
|
-
unsafe impl<T> ComponentType for [T]
|
1404
|
-
where
|
1405
|
-
T: ComponentType,
|
1406
|
-
{
|
1407
|
-
type Lower = [ValRaw; 2];
|
1408
|
-
|
1409
|
-
const ABI: CanonicalAbiInfo = CanonicalAbiInfo::POINTER_PAIR;
|
1410
|
-
|
1411
|
-
fn typecheck(ty: &InterfaceType, types: &InstanceType<'_>) -> Result<()> {
|
1412
|
-
match ty {
|
1413
|
-
InterfaceType::List(t) => T::typecheck(&types.types[*t].element, types),
|
1414
|
-
other => bail!("expected `list` found `{}`", desc(other)),
|
1415
|
-
}
|
1416
|
-
}
|
1417
|
-
}
|
1418
|
-
|
1419
|
-
unsafe impl<T> Lower for [T]
|
1420
|
-
where
|
1421
|
-
T: Lower,
|
1422
|
-
{
|
1423
|
-
fn lower<U>(
|
1424
|
-
&self,
|
1425
|
-
cx: &mut LowerContext<'_, U>,
|
1426
|
-
ty: InterfaceType,
|
1427
|
-
dst: &mut MaybeUninit<[ValRaw; 2]>,
|
1428
|
-
) -> Result<()> {
|
1429
|
-
let elem = match ty {
|
1430
|
-
InterfaceType::List(i) => cx.types[i].element,
|
1431
|
-
_ => bad_type_info(),
|
1432
|
-
};
|
1433
|
-
let (ptr, len) = lower_list(cx, elem, self)?;
|
1434
|
-
// See "WRITEPTR64" above for why this is always storing a 64-bit
|
1435
|
-
// integer.
|
1436
|
-
map_maybe_uninit!(dst[0]).write(ValRaw::i64(ptr as i64));
|
1437
|
-
map_maybe_uninit!(dst[1]).write(ValRaw::i64(len as i64));
|
1438
|
-
Ok(())
|
1439
|
-
}
|
1440
|
-
|
1441
|
-
fn store<U>(
|
1442
|
-
&self,
|
1443
|
-
cx: &mut LowerContext<'_, U>,
|
1444
|
-
ty: InterfaceType,
|
1445
|
-
offset: usize,
|
1446
|
-
) -> Result<()> {
|
1447
|
-
let elem = match ty {
|
1448
|
-
InterfaceType::List(i) => cx.types[i].element,
|
1449
|
-
_ => bad_type_info(),
|
1450
|
-
};
|
1451
|
-
debug_assert!(offset % (Self::ALIGN32 as usize) == 0);
|
1452
|
-
let (ptr, len) = lower_list(cx, elem, self)?;
|
1453
|
-
*cx.get(offset + 0) = (ptr as i32).to_le_bytes();
|
1454
|
-
*cx.get(offset + 4) = (len as i32).to_le_bytes();
|
1455
|
-
Ok(())
|
1456
|
-
}
|
1457
|
-
}
|
1458
|
-
|
1459
|
-
// FIXME: this is not a memcpy for `T` where `T` is something like `u8`.
|
1460
|
-
//
|
1461
|
-
// Some attempts to fix this have proved not fruitful. In isolation an attempt
|
1462
|
-
// was made where:
|
1463
|
-
//
|
1464
|
-
// * `MemoryMut` stored a `*mut [u8]` as its "last view" of memory to avoid
|
1465
|
-
// reloading the base pointer constantly. This view is reset on `realloc`.
|
1466
|
-
// * The bounds-checks in `MemoryMut::get` were removed (replaced with unsafe
|
1467
|
-
// indexing)
|
1468
|
-
//
|
1469
|
-
// Even then though this didn't correctly vectorized for `Vec<u8>`. It's not
|
1470
|
-
// entirely clear why but it appeared that it's related to reloading the base
|
1471
|
-
// pointer fo memory (I guess from `MemoryMut` itself?). Overall I'm not really
|
1472
|
-
// clear on what's happening there, but this is surely going to be a performance
|
1473
|
-
// bottleneck in the future.
|
1474
|
-
fn lower_list<T, U>(
|
1475
|
-
cx: &mut LowerContext<'_, U>,
|
1476
|
-
ty: InterfaceType,
|
1477
|
-
list: &[T],
|
1478
|
-
) -> Result<(usize, usize)>
|
1479
|
-
where
|
1480
|
-
T: Lower,
|
1481
|
-
{
|
1482
|
-
let elem_size = T::SIZE32;
|
1483
|
-
let size = list
|
1484
|
-
.len()
|
1485
|
-
.checked_mul(elem_size)
|
1486
|
-
.ok_or_else(|| anyhow!("size overflow copying a list"))?;
|
1487
|
-
let ptr = cx.realloc(0, 0, T::ALIGN32, size)?;
|
1488
|
-
T::store_list(cx, ty, ptr, list)?;
|
1489
|
-
Ok((ptr, list.len()))
|
1490
|
-
}
|
1491
|
-
|
1492
|
-
/// Representation of a list of values that are owned by a WebAssembly instance.
|
1493
|
-
///
|
1494
|
-
/// For some more commentary about the rationale for this type see the
|
1495
|
-
/// documentation of [`WasmStr`]. In summary this type can avoid a copy when
|
1496
|
-
/// passing data to the host in some situations but is additionally more
|
1497
|
-
/// cumbersome to use by requiring a [`Store`](crate::Store) to be provided.
|
1498
|
-
///
|
1499
|
-
/// This type is used whenever a `(list T)` is returned from a [`TypedFunc`],
|
1500
|
-
/// for example. This type represents a list of values that are stored in linear
|
1501
|
-
/// memory which are waiting to be read.
|
1502
|
-
///
|
1503
|
-
/// Note that this type represents only a valid range of bytes for the list
|
1504
|
-
/// itself, it does not represent validity of the elements themselves and that's
|
1505
|
-
/// performed when they're iterated.
|
1506
|
-
///
|
1507
|
-
/// Note that this type does not implement the [`Lower`] trait, only [`Lift`].
|
1508
|
-
pub struct WasmList<T> {
|
1509
|
-
ptr: usize,
|
1510
|
-
len: usize,
|
1511
|
-
options: Options,
|
1512
|
-
elem: InterfaceType,
|
1513
|
-
// NB: it would probably be more efficient to store a non-atomic index-style
|
1514
|
-
// reference to something inside a `StoreOpaque`, but that's not easily
|
1515
|
-
// available at this time, so it's left as a future exercise.
|
1516
|
-
types: Arc<ComponentTypes>,
|
1517
|
-
instance: SendSyncPtr<ComponentInstance>,
|
1518
|
-
_marker: marker::PhantomData<T>,
|
1519
|
-
}
|
1520
|
-
|
1521
|
-
impl<T: Lift> WasmList<T> {
|
1522
|
-
fn new(
|
1523
|
-
ptr: usize,
|
1524
|
-
len: usize,
|
1525
|
-
cx: &mut LiftContext<'_>,
|
1526
|
-
elem: InterfaceType,
|
1527
|
-
) -> Result<WasmList<T>> {
|
1528
|
-
match len
|
1529
|
-
.checked_mul(T::SIZE32)
|
1530
|
-
.and_then(|len| ptr.checked_add(len))
|
1531
|
-
{
|
1532
|
-
Some(n) if n <= cx.memory().len() => {}
|
1533
|
-
_ => bail!("list pointer/length out of bounds of memory"),
|
1534
|
-
}
|
1535
|
-
if ptr % usize::try_from(T::ALIGN32)? != 0 {
|
1536
|
-
bail!("list pointer is not aligned")
|
1537
|
-
}
|
1538
|
-
Ok(WasmList {
|
1539
|
-
ptr,
|
1540
|
-
len,
|
1541
|
-
options: *cx.options,
|
1542
|
-
elem,
|
1543
|
-
types: cx.types.clone(),
|
1544
|
-
instance: SendSyncPtr::new(NonNull::new(cx.instance_ptr()).unwrap()),
|
1545
|
-
_marker: marker::PhantomData,
|
1546
|
-
})
|
1547
|
-
}
|
1548
|
-
|
1549
|
-
/// Returns the item length of this vector
|
1550
|
-
#[inline]
|
1551
|
-
pub fn len(&self) -> usize {
|
1552
|
-
self.len
|
1553
|
-
}
|
1554
|
-
|
1555
|
-
/// Gets the `n`th element of this list.
|
1556
|
-
///
|
1557
|
-
/// Returns `None` if `index` is out of bounds. Returns `Some(Err(..))` if
|
1558
|
-
/// the value couldn't be decoded (it was invalid). Returns `Some(Ok(..))`
|
1559
|
-
/// if the value is valid.
|
1560
|
-
///
|
1561
|
-
/// # Panics
|
1562
|
-
///
|
1563
|
-
/// This function will panic if the string did not originally come from the
|
1564
|
-
/// `store` specified.
|
1565
|
-
//
|
1566
|
-
// TODO: given that interface values are intended to be consumed in one go
|
1567
|
-
// should we even expose a random access iteration API? In theory all
|
1568
|
-
// consumers should be validating through the iterator.
|
1569
|
-
pub fn get(&self, mut store: impl AsContextMut, index: usize) -> Option<Result<T>> {
|
1570
|
-
let store = store.as_context_mut().0;
|
1571
|
-
self.options.store_id().assert_belongs_to(store.id());
|
1572
|
-
// This should be safe because the unsafety lies in the `self.instance`
|
1573
|
-
// pointer passed in has previously been validated by the lifting
|
1574
|
-
// context this was originally created within and with the check above
|
1575
|
-
// this is guaranteed to be the same store. This means that this should
|
1576
|
-
// be carrying over the original assertion from the original creation of
|
1577
|
-
// the lifting context that created this type.
|
1578
|
-
let mut cx =
|
1579
|
-
unsafe { LiftContext::new(store, &self.options, &self.types, self.instance.as_ptr()) };
|
1580
|
-
self.get_from_store(&mut cx, index)
|
1581
|
-
}
|
1582
|
-
|
1583
|
-
fn get_from_store(&self, cx: &mut LiftContext<'_>, index: usize) -> Option<Result<T>> {
|
1584
|
-
if index >= self.len {
|
1585
|
-
return None;
|
1586
|
-
}
|
1587
|
-
// Note that this is using panicking indexing and this is expected to
|
1588
|
-
// never fail. The bounds-checking here happened during the construction
|
1589
|
-
// of the `WasmList` itself which means these should always be in-bounds
|
1590
|
-
// (and wasm memory can only grow). This could theoretically be
|
1591
|
-
// unchecked indexing if we're confident enough and it's actually a perf
|
1592
|
-
// issue one day.
|
1593
|
-
let bytes = &cx.memory()[self.ptr + index * T::SIZE32..][..T::SIZE32];
|
1594
|
-
Some(T::load(cx, self.elem, bytes))
|
1595
|
-
}
|
1596
|
-
|
1597
|
-
/// Returns an iterator over the elements of this list.
|
1598
|
-
///
|
1599
|
-
/// Each item of the list may fail to decode and is represented through the
|
1600
|
-
/// `Result` value of the iterator.
|
1601
|
-
pub fn iter<'a, U: 'a>(
|
1602
|
-
&'a self,
|
1603
|
-
store: impl Into<StoreContextMut<'a, U>>,
|
1604
|
-
) -> impl ExactSizeIterator<Item = Result<T>> + 'a {
|
1605
|
-
let store = store.into().0;
|
1606
|
-
self.options.store_id().assert_belongs_to(store.id());
|
1607
|
-
// See comments about unsafety in the `get` method.
|
1608
|
-
let mut cx =
|
1609
|
-
unsafe { LiftContext::new(store, &self.options, &self.types, self.instance.as_ptr()) };
|
1610
|
-
(0..self.len).map(move |i| self.get_from_store(&mut cx, i).unwrap())
|
1611
|
-
}
|
1612
|
-
}
|
1613
|
-
|
1614
|
-
macro_rules! raw_wasm_list_accessors {
|
1615
|
-
($($i:ident)*) => ($(
|
1616
|
-
impl WasmList<$i> {
|
1617
|
-
/// Get access to the raw underlying memory for this list.
|
1618
|
-
///
|
1619
|
-
/// This method will return a direct slice into the original wasm
|
1620
|
-
/// module's linear memory where the data for this slice is stored.
|
1621
|
-
/// This allows the embedder to have efficient access to the
|
1622
|
-
/// underlying memory if needed and avoid copies and such if
|
1623
|
-
/// desired.
|
1624
|
-
///
|
1625
|
-
/// Note that multi-byte integers are stored in little-endian format
|
1626
|
-
/// so portable processing of this slice must be aware of the host's
|
1627
|
-
/// byte-endianness. The `from_le` constructors in the Rust standard
|
1628
|
-
/// library should be suitable for converting from little-endian.
|
1629
|
-
///
|
1630
|
-
/// # Panics
|
1631
|
-
///
|
1632
|
-
/// Panics if the `store` provided is not the one from which this
|
1633
|
-
/// slice originated.
|
1634
|
-
pub fn as_le_slice<'a, T: 'a>(&self, store: impl Into<StoreContext<'a, T>>) -> &'a [$i] {
|
1635
|
-
let memory = self.options.memory(store.into().0);
|
1636
|
-
self._as_le_slice(memory)
|
1637
|
-
}
|
1638
|
-
|
1639
|
-
fn _as_le_slice<'a>(&self, all_of_memory: &'a [u8]) -> &'a [$i] {
|
1640
|
-
// See comments in `WasmList::get` for the panicking indexing
|
1641
|
-
let byte_size = self.len * mem::size_of::<$i>();
|
1642
|
-
let bytes = &all_of_memory[self.ptr..][..byte_size];
|
1643
|
-
|
1644
|
-
// The canonical ABI requires that everything is aligned to its
|
1645
|
-
// own size, so this should be an aligned array. Furthermore the
|
1646
|
-
// alignment of primitive integers for hosts should be smaller
|
1647
|
-
// than or equal to the size of the primitive itself, meaning
|
1648
|
-
// that a wasm canonical-abi-aligned list is also aligned for
|
1649
|
-
// the host. That should mean that the head/tail slices here are
|
1650
|
-
// empty.
|
1651
|
-
//
|
1652
|
-
// Also note that the `unsafe` here is needed since the type
|
1653
|
-
// we're aligning to isn't guaranteed to be valid, but in our
|
1654
|
-
// case it's just integers and bytes so this should be safe.
|
1655
|
-
unsafe {
|
1656
|
-
let (head, body, tail) = bytes.align_to::<$i>();
|
1657
|
-
assert!(head.is_empty() && tail.is_empty());
|
1658
|
-
body
|
1659
|
-
}
|
1660
|
-
}
|
1661
|
-
}
|
1662
|
-
)*)
|
1663
|
-
}
|
1664
|
-
|
1665
|
-
raw_wasm_list_accessors! {
|
1666
|
-
i8 i16 i32 i64
|
1667
|
-
u8 u16 u32 u64
|
1668
|
-
}
|
1669
|
-
|
1670
|
-
// Note that this is similar to `ComponentType for str` except it can only be
|
1671
|
-
// used for lifting, not lowering.
|
1672
|
-
unsafe impl<T: ComponentType> ComponentType for WasmList<T> {
|
1673
|
-
type Lower = <[T] as ComponentType>::Lower;
|
1674
|
-
|
1675
|
-
const ABI: CanonicalAbiInfo = CanonicalAbiInfo::POINTER_PAIR;
|
1676
|
-
|
1677
|
-
fn typecheck(ty: &InterfaceType, types: &InstanceType<'_>) -> Result<()> {
|
1678
|
-
<[T] as ComponentType>::typecheck(ty, types)
|
1679
|
-
}
|
1680
|
-
}
|
1681
|
-
|
1682
|
-
unsafe impl<T: Lift> Lift for WasmList<T> {
|
1683
|
-
fn lift(cx: &mut LiftContext<'_>, ty: InterfaceType, src: &Self::Lower) -> Result<Self> {
|
1684
|
-
let elem = match ty {
|
1685
|
-
InterfaceType::List(i) => cx.types[i].element,
|
1686
|
-
_ => bad_type_info(),
|
1687
|
-
};
|
1688
|
-
// FIXME: needs memory64 treatment
|
1689
|
-
let ptr = src[0].get_u32();
|
1690
|
-
let len = src[1].get_u32();
|
1691
|
-
let (ptr, len) = (usize::try_from(ptr)?, usize::try_from(len)?);
|
1692
|
-
WasmList::new(ptr, len, cx, elem)
|
1693
|
-
}
|
1694
|
-
|
1695
|
-
fn load(cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self> {
|
1696
|
-
let elem = match ty {
|
1697
|
-
InterfaceType::List(i) => cx.types[i].element,
|
1698
|
-
_ => bad_type_info(),
|
1699
|
-
};
|
1700
|
-
debug_assert!((bytes.as_ptr() as usize) % (Self::ALIGN32 as usize) == 0);
|
1701
|
-
// FIXME: needs memory64 treatment
|
1702
|
-
let ptr = u32::from_le_bytes(bytes[..4].try_into().unwrap());
|
1703
|
-
let len = u32::from_le_bytes(bytes[4..].try_into().unwrap());
|
1704
|
-
let (ptr, len) = (usize::try_from(ptr)?, usize::try_from(len)?);
|
1705
|
-
WasmList::new(ptr, len, cx, elem)
|
1706
|
-
}
|
1707
|
-
}
|
1708
|
-
|
1709
|
-
/// Verify that the given wasm type is a tuple with the expected fields in the right order.
|
1710
|
-
fn typecheck_tuple(
|
1711
|
-
ty: &InterfaceType,
|
1712
|
-
types: &InstanceType<'_>,
|
1713
|
-
expected: &[fn(&InterfaceType, &InstanceType<'_>) -> Result<()>],
|
1714
|
-
) -> Result<()> {
|
1715
|
-
match ty {
|
1716
|
-
InterfaceType::Tuple(t) => {
|
1717
|
-
let tuple = &types.types[*t];
|
1718
|
-
if tuple.types.len() != expected.len() {
|
1719
|
-
bail!(
|
1720
|
-
"expected {}-tuple, found {}-tuple",
|
1721
|
-
expected.len(),
|
1722
|
-
tuple.types.len()
|
1723
|
-
);
|
1724
|
-
}
|
1725
|
-
for (ty, check) in tuple.types.iter().zip(expected) {
|
1726
|
-
check(ty, types)?;
|
1727
|
-
}
|
1728
|
-
Ok(())
|
1729
|
-
}
|
1730
|
-
other => bail!("expected `tuple` found `{}`", desc(other)),
|
1731
|
-
}
|
1732
|
-
}
|
1733
|
-
|
1734
|
-
/// Verify that the given wasm type is a record with the expected fields in the right order and with the right
|
1735
|
-
/// names.
|
1736
|
-
pub fn typecheck_record(
|
1737
|
-
ty: &InterfaceType,
|
1738
|
-
types: &InstanceType<'_>,
|
1739
|
-
expected: &[(&str, fn(&InterfaceType, &InstanceType<'_>) -> Result<()>)],
|
1740
|
-
) -> Result<()> {
|
1741
|
-
match ty {
|
1742
|
-
InterfaceType::Record(index) => {
|
1743
|
-
let fields = &types.types[*index].fields;
|
1744
|
-
|
1745
|
-
if fields.len() != expected.len() {
|
1746
|
-
bail!(
|
1747
|
-
"expected record of {} fields, found {} fields",
|
1748
|
-
expected.len(),
|
1749
|
-
fields.len()
|
1750
|
-
);
|
1751
|
-
}
|
1752
|
-
|
1753
|
-
for (field, &(name, check)) in fields.iter().zip(expected) {
|
1754
|
-
check(&field.ty, types)
|
1755
|
-
.with_context(|| format!("type mismatch for field {}", name))?;
|
1756
|
-
|
1757
|
-
if field.name != name {
|
1758
|
-
bail!("expected record field named {}, found {}", name, field.name);
|
1759
|
-
}
|
1760
|
-
}
|
1761
|
-
|
1762
|
-
Ok(())
|
1763
|
-
}
|
1764
|
-
other => bail!("expected `record` found `{}`", desc(other)),
|
1765
|
-
}
|
1766
|
-
}
|
1767
|
-
|
1768
|
-
/// Verify that the given wasm type is a variant with the expected cases in the right order and with the right
|
1769
|
-
/// names.
|
1770
|
-
pub fn typecheck_variant(
|
1771
|
-
ty: &InterfaceType,
|
1772
|
-
types: &InstanceType<'_>,
|
1773
|
-
expected: &[(
|
1774
|
-
&str,
|
1775
|
-
Option<fn(&InterfaceType, &InstanceType<'_>) -> Result<()>>,
|
1776
|
-
)],
|
1777
|
-
) -> Result<()> {
|
1778
|
-
match ty {
|
1779
|
-
InterfaceType::Variant(index) => {
|
1780
|
-
let cases = &types.types[*index].cases;
|
1781
|
-
|
1782
|
-
if cases.len() != expected.len() {
|
1783
|
-
bail!(
|
1784
|
-
"expected variant of {} cases, found {} cases",
|
1785
|
-
expected.len(),
|
1786
|
-
cases.len()
|
1787
|
-
);
|
1788
|
-
}
|
1789
|
-
|
1790
|
-
for ((case_name, case_ty), &(name, check)) in cases.iter().zip(expected) {
|
1791
|
-
if *case_name != name {
|
1792
|
-
bail!("expected variant case named {name}, found {case_name}");
|
1793
|
-
}
|
1794
|
-
|
1795
|
-
match (check, case_ty) {
|
1796
|
-
(Some(check), Some(ty)) => check(ty, types)
|
1797
|
-
.with_context(|| format!("type mismatch for case {name}"))?,
|
1798
|
-
(None, None) => {}
|
1799
|
-
(Some(_), None) => {
|
1800
|
-
bail!("case `{name}` has no type but one was expected")
|
1801
|
-
}
|
1802
|
-
(None, Some(_)) => {
|
1803
|
-
bail!("case `{name}` has a type but none was expected")
|
1804
|
-
}
|
1805
|
-
}
|
1806
|
-
}
|
1807
|
-
|
1808
|
-
Ok(())
|
1809
|
-
}
|
1810
|
-
other => bail!("expected `variant` found `{}`", desc(other)),
|
1811
|
-
}
|
1812
|
-
}
|
1813
|
-
|
1814
|
-
/// Verify that the given wasm type is a enum with the expected cases in the right order and with the right
|
1815
|
-
/// names.
|
1816
|
-
pub fn typecheck_enum(
|
1817
|
-
ty: &InterfaceType,
|
1818
|
-
types: &InstanceType<'_>,
|
1819
|
-
expected: &[&str],
|
1820
|
-
) -> Result<()> {
|
1821
|
-
match ty {
|
1822
|
-
InterfaceType::Enum(index) => {
|
1823
|
-
let names = &types.types[*index].names;
|
1824
|
-
|
1825
|
-
if names.len() != expected.len() {
|
1826
|
-
bail!(
|
1827
|
-
"expected enum of {} names, found {} names",
|
1828
|
-
expected.len(),
|
1829
|
-
names.len()
|
1830
|
-
);
|
1831
|
-
}
|
1832
|
-
|
1833
|
-
for (name, expected) in names.iter().zip(expected) {
|
1834
|
-
if name != expected {
|
1835
|
-
bail!("expected enum case named {}, found {}", expected, name);
|
1836
|
-
}
|
1837
|
-
}
|
1838
|
-
|
1839
|
-
Ok(())
|
1840
|
-
}
|
1841
|
-
other => bail!("expected `enum` found `{}`", desc(other)),
|
1842
|
-
}
|
1843
|
-
}
|
1844
|
-
|
1845
|
-
/// Verify that the given wasm type is a flags type with the expected flags in the right order and with the right
|
1846
|
-
/// names.
|
1847
|
-
pub fn typecheck_flags(
|
1848
|
-
ty: &InterfaceType,
|
1849
|
-
types: &InstanceType<'_>,
|
1850
|
-
expected: &[&str],
|
1851
|
-
) -> Result<()> {
|
1852
|
-
match ty {
|
1853
|
-
InterfaceType::Flags(index) => {
|
1854
|
-
let names = &types.types[*index].names;
|
1855
|
-
|
1856
|
-
if names.len() != expected.len() {
|
1857
|
-
bail!(
|
1858
|
-
"expected flags type with {} names, found {} names",
|
1859
|
-
expected.len(),
|
1860
|
-
names.len()
|
1861
|
-
);
|
1862
|
-
}
|
1863
|
-
|
1864
|
-
for (name, expected) in names.iter().zip(expected) {
|
1865
|
-
if name != expected {
|
1866
|
-
bail!("expected flag named {}, found {}", expected, name);
|
1867
|
-
}
|
1868
|
-
}
|
1869
|
-
|
1870
|
-
Ok(())
|
1871
|
-
}
|
1872
|
-
other => bail!("expected `flags` found `{}`", desc(other)),
|
1873
|
-
}
|
1874
|
-
}
|
1875
|
-
|
1876
|
-
/// Format the specified bitflags using the specified names for debugging
|
1877
|
-
pub fn format_flags(bits: &[u32], names: &[&str], f: &mut fmt::Formatter) -> fmt::Result {
|
1878
|
-
f.write_str("(")?;
|
1879
|
-
let mut wrote = false;
|
1880
|
-
for (index, name) in names.iter().enumerate() {
|
1881
|
-
if ((bits[index / 32] >> (index % 32)) & 1) != 0 {
|
1882
|
-
if wrote {
|
1883
|
-
f.write_str("|")?;
|
1884
|
-
} else {
|
1885
|
-
wrote = true;
|
1886
|
-
}
|
1887
|
-
|
1888
|
-
f.write_str(name)?;
|
1889
|
-
}
|
1890
|
-
}
|
1891
|
-
f.write_str(")")
|
1892
|
-
}
|
1893
|
-
|
1894
|
-
unsafe impl<T> ComponentType for Option<T>
|
1895
|
-
where
|
1896
|
-
T: ComponentType,
|
1897
|
-
{
|
1898
|
-
type Lower = TupleLower2<<u32 as ComponentType>::Lower, T::Lower>;
|
1899
|
-
|
1900
|
-
const ABI: CanonicalAbiInfo = CanonicalAbiInfo::variant_static(&[None, Some(T::ABI)]);
|
1901
|
-
|
1902
|
-
fn typecheck(ty: &InterfaceType, types: &InstanceType<'_>) -> Result<()> {
|
1903
|
-
match ty {
|
1904
|
-
InterfaceType::Option(t) => T::typecheck(&types.types[*t].ty, types),
|
1905
|
-
other => bail!("expected `option` found `{}`", desc(other)),
|
1906
|
-
}
|
1907
|
-
}
|
1908
|
-
}
|
1909
|
-
|
1910
|
-
unsafe impl<T> ComponentVariant for Option<T>
|
1911
|
-
where
|
1912
|
-
T: ComponentType,
|
1913
|
-
{
|
1914
|
-
const CASES: &'static [Option<CanonicalAbiInfo>] = &[None, Some(T::ABI)];
|
1915
|
-
}
|
1916
|
-
|
1917
|
-
unsafe impl<T> Lower for Option<T>
|
1918
|
-
where
|
1919
|
-
T: Lower,
|
1920
|
-
{
|
1921
|
-
fn lower<U>(
|
1922
|
-
&self,
|
1923
|
-
cx: &mut LowerContext<'_, U>,
|
1924
|
-
ty: InterfaceType,
|
1925
|
-
dst: &mut MaybeUninit<Self::Lower>,
|
1926
|
-
) -> Result<()> {
|
1927
|
-
let payload = match ty {
|
1928
|
-
InterfaceType::Option(ty) => cx.types[ty].ty,
|
1929
|
-
_ => bad_type_info(),
|
1930
|
-
};
|
1931
|
-
match self {
|
1932
|
-
None => {
|
1933
|
-
map_maybe_uninit!(dst.A1).write(ValRaw::i32(0));
|
1934
|
-
// Note that this is unsafe as we're writing an arbitrary
|
1935
|
-
// bit-pattern to an arbitrary type, but part of the unsafe
|
1936
|
-
// contract of the `ComponentType` trait is that we can assign
|
1937
|
-
// any bit-pattern. By writing all zeros here we're ensuring
|
1938
|
-
// that the core wasm arguments this translates to will all be
|
1939
|
-
// zeros (as the canonical ABI requires).
|
1940
|
-
unsafe {
|
1941
|
-
map_maybe_uninit!(dst.A2).as_mut_ptr().write_bytes(0u8, 1);
|
1942
|
-
}
|
1943
|
-
}
|
1944
|
-
Some(val) => {
|
1945
|
-
map_maybe_uninit!(dst.A1).write(ValRaw::i32(1));
|
1946
|
-
val.lower(cx, payload, map_maybe_uninit!(dst.A2))?;
|
1947
|
-
}
|
1948
|
-
}
|
1949
|
-
Ok(())
|
1950
|
-
}
|
1951
|
-
|
1952
|
-
fn store<U>(
|
1953
|
-
&self,
|
1954
|
-
cx: &mut LowerContext<'_, U>,
|
1955
|
-
ty: InterfaceType,
|
1956
|
-
offset: usize,
|
1957
|
-
) -> Result<()> {
|
1958
|
-
debug_assert!(offset % (Self::ALIGN32 as usize) == 0);
|
1959
|
-
let payload = match ty {
|
1960
|
-
InterfaceType::Option(ty) => cx.types[ty].ty,
|
1961
|
-
_ => bad_type_info(),
|
1962
|
-
};
|
1963
|
-
match self {
|
1964
|
-
None => {
|
1965
|
-
cx.get::<1>(offset)[0] = 0;
|
1966
|
-
}
|
1967
|
-
Some(val) => {
|
1968
|
-
cx.get::<1>(offset)[0] = 1;
|
1969
|
-
val.store(cx, payload, offset + (Self::INFO.payload_offset32 as usize))?;
|
1970
|
-
}
|
1971
|
-
}
|
1972
|
-
Ok(())
|
1973
|
-
}
|
1974
|
-
}
|
1975
|
-
|
1976
|
-
unsafe impl<T> Lift for Option<T>
|
1977
|
-
where
|
1978
|
-
T: Lift,
|
1979
|
-
{
|
1980
|
-
fn lift(cx: &mut LiftContext<'_>, ty: InterfaceType, src: &Self::Lower) -> Result<Self> {
|
1981
|
-
let payload = match ty {
|
1982
|
-
InterfaceType::Option(ty) => cx.types[ty].ty,
|
1983
|
-
_ => bad_type_info(),
|
1984
|
-
};
|
1985
|
-
Ok(match src.A1.get_i32() {
|
1986
|
-
0 => None,
|
1987
|
-
1 => Some(T::lift(cx, payload, &src.A2)?),
|
1988
|
-
_ => bail!("invalid option discriminant"),
|
1989
|
-
})
|
1990
|
-
}
|
1991
|
-
|
1992
|
-
fn load(cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self> {
|
1993
|
-
debug_assert!((bytes.as_ptr() as usize) % (Self::ALIGN32 as usize) == 0);
|
1994
|
-
let payload_ty = match ty {
|
1995
|
-
InterfaceType::Option(ty) => cx.types[ty].ty,
|
1996
|
-
_ => bad_type_info(),
|
1997
|
-
};
|
1998
|
-
let discrim = bytes[0];
|
1999
|
-
let payload = &bytes[Self::INFO.payload_offset32 as usize..];
|
2000
|
-
match discrim {
|
2001
|
-
0 => Ok(None),
|
2002
|
-
1 => Ok(Some(T::load(cx, payload_ty, payload)?)),
|
2003
|
-
_ => bail!("invalid option discriminant"),
|
2004
|
-
}
|
2005
|
-
}
|
2006
|
-
}
|
2007
|
-
|
2008
|
-
#[derive(Clone, Copy)]
|
2009
|
-
#[repr(C)]
|
2010
|
-
pub struct ResultLower<T: Copy, E: Copy> {
|
2011
|
-
tag: ValRaw,
|
2012
|
-
payload: ResultLowerPayload<T, E>,
|
2013
|
-
}
|
2014
|
-
|
2015
|
-
#[derive(Clone, Copy)]
|
2016
|
-
#[repr(C)]
|
2017
|
-
union ResultLowerPayload<T: Copy, E: Copy> {
|
2018
|
-
ok: T,
|
2019
|
-
err: E,
|
2020
|
-
}
|
2021
|
-
|
2022
|
-
unsafe impl<T, E> ComponentType for Result<T, E>
|
2023
|
-
where
|
2024
|
-
T: ComponentType,
|
2025
|
-
E: ComponentType,
|
2026
|
-
{
|
2027
|
-
type Lower = ResultLower<T::Lower, E::Lower>;
|
2028
|
-
|
2029
|
-
const ABI: CanonicalAbiInfo = CanonicalAbiInfo::variant_static(&[Some(T::ABI), Some(E::ABI)]);
|
2030
|
-
|
2031
|
-
fn typecheck(ty: &InterfaceType, types: &InstanceType<'_>) -> Result<()> {
|
2032
|
-
match ty {
|
2033
|
-
InterfaceType::Result(r) => {
|
2034
|
-
let result = &types.types[*r];
|
2035
|
-
match &result.ok {
|
2036
|
-
Some(ty) => T::typecheck(ty, types)?,
|
2037
|
-
None if T::IS_RUST_UNIT_TYPE => {}
|
2038
|
-
None => bail!("expected no `ok` type"),
|
2039
|
-
}
|
2040
|
-
match &result.err {
|
2041
|
-
Some(ty) => E::typecheck(ty, types)?,
|
2042
|
-
None if E::IS_RUST_UNIT_TYPE => {}
|
2043
|
-
None => bail!("expected no `err` type"),
|
2044
|
-
}
|
2045
|
-
Ok(())
|
2046
|
-
}
|
2047
|
-
other => bail!("expected `result` found `{}`", desc(other)),
|
2048
|
-
}
|
2049
|
-
}
|
2050
|
-
}
|
2051
|
-
|
2052
|
-
/// Lowers the payload of a variant into the storage for the entire payload,
|
2053
|
-
/// handling writing zeros at the end of the representation if this payload is
|
2054
|
-
/// smaller than the entire flat representation.
|
2055
|
-
///
|
2056
|
-
/// * `payload` - the flat storage space for the entire payload of the variant
|
2057
|
-
/// * `typed_payload` - projection from the payload storage space to the
|
2058
|
-
/// individaul storage space for this variant.
|
2059
|
-
/// * `lower` - lowering operation used to initialize the `typed_payload` return
|
2060
|
-
/// value.
|
2061
|
-
///
|
2062
|
-
/// For more information on this se the comments in the `Lower for Result`
|
2063
|
-
/// implementation below.
|
2064
|
-
pub unsafe fn lower_payload<P, T>(
|
2065
|
-
payload: &mut MaybeUninit<P>,
|
2066
|
-
typed_payload: impl FnOnce(&mut MaybeUninit<P>) -> &mut MaybeUninit<T>,
|
2067
|
-
lower: impl FnOnce(&mut MaybeUninit<T>) -> Result<()>,
|
2068
|
-
) -> Result<()> {
|
2069
|
-
let typed = typed_payload(payload);
|
2070
|
-
lower(typed)?;
|
2071
|
-
|
2072
|
-
let typed_len = storage_as_slice(typed).len();
|
2073
|
-
let payload = storage_as_slice_mut(payload);
|
2074
|
-
for slot in payload[typed_len..].iter_mut() {
|
2075
|
-
*slot = ValRaw::u64(0);
|
2076
|
-
}
|
2077
|
-
Ok(())
|
2078
|
-
}
|
2079
|
-
|
2080
|
-
unsafe impl<T, E> ComponentVariant for Result<T, E>
|
2081
|
-
where
|
2082
|
-
T: ComponentType,
|
2083
|
-
E: ComponentType,
|
2084
|
-
{
|
2085
|
-
const CASES: &'static [Option<CanonicalAbiInfo>] = &[Some(T::ABI), Some(E::ABI)];
|
2086
|
-
}
|
2087
|
-
|
2088
|
-
unsafe impl<T, E> Lower for Result<T, E>
|
2089
|
-
where
|
2090
|
-
T: Lower,
|
2091
|
-
E: Lower,
|
2092
|
-
{
|
2093
|
-
fn lower<U>(
|
2094
|
-
&self,
|
2095
|
-
cx: &mut LowerContext<'_, U>,
|
2096
|
-
ty: InterfaceType,
|
2097
|
-
dst: &mut MaybeUninit<Self::Lower>,
|
2098
|
-
) -> Result<()> {
|
2099
|
-
let (ok, err) = match ty {
|
2100
|
-
InterfaceType::Result(ty) => {
|
2101
|
-
let ty = &cx.types[ty];
|
2102
|
-
(ty.ok, ty.err)
|
2103
|
-
}
|
2104
|
-
_ => bad_type_info(),
|
2105
|
-
};
|
2106
|
-
|
2107
|
-
// This implementation of `Lower::lower`, if you're reading these from
|
2108
|
-
// the top of this file, is the first location that the "join" logic of
|
2109
|
-
// the component model's canonical ABI encountered. The rough problem is
|
2110
|
-
// that let's say we have a component model type of the form:
|
2111
|
-
//
|
2112
|
-
// (result u64 (error (tuple f32 u16)))
|
2113
|
-
//
|
2114
|
-
// The flat representation of this is actually pretty tricky. Currently
|
2115
|
-
// it is:
|
2116
|
-
//
|
2117
|
-
// i32 i64 i32
|
2118
|
-
//
|
2119
|
-
// The first `i32` is the discriminant for the `result`, and the payload
|
2120
|
-
// is represented by `i64 i32`. The "ok" variant will only use the `i64`
|
2121
|
-
// and the "err" variant will use both `i64` and `i32`.
|
2122
|
-
//
|
2123
|
-
// In the "ok" variant the first issue is encountered. The size of one
|
2124
|
-
// variant may not match the size of the other variants. All variants
|
2125
|
-
// start at the "front" but when lowering a type we need to be sure to
|
2126
|
-
// initialize the later variants (lest we leak random host memory into
|
2127
|
-
// the guest module). Due to how the `Lower` type is represented as a
|
2128
|
-
// `union` of all the variants what ends up happening here is that
|
2129
|
-
// internally within the `lower_payload` after the typed payload is
|
2130
|
-
// lowered the remaining bits of the payload that weren't initialized
|
2131
|
-
// are all set to zero. This will guarantee that we'll write to all the
|
2132
|
-
// slots for each variant.
|
2133
|
-
//
|
2134
|
-
// The "err" variant encounters the second issue, however, which is that
|
2135
|
-
// the flat representation for each type may differ between payloads. In
|
2136
|
-
// the "ok" arm an `i64` is written, but the `lower` implementation for
|
2137
|
-
// the "err" arm will write an `f32` and then an `i32`. For this
|
2138
|
-
// implementation of `lower` to be valid the `f32` needs to get inflated
|
2139
|
-
// to an `i64` with zero-padding in the upper bits. What may be
|
2140
|
-
// surprising, however, is that none of this is handled in this file.
|
2141
|
-
// This implementation looks like it's blindly deferring to `E::lower`
|
2142
|
-
// and hoping it does the right thing.
|
2143
|
-
//
|
2144
|
-
// In reality, however, the correctness of variant lowering relies on
|
2145
|
-
// two subtle details of the `ValRaw` implementation in Wasmtime:
|
2146
|
-
//
|
2147
|
-
// 1. First the `ValRaw` value always contains little-endian values.
|
2148
|
-
// This means that if a `u32` is written, a `u64` is read, and then
|
2149
|
-
// the `u64` has its upper bits truncated the original value will
|
2150
|
-
// always be retained. This is primarily here for big-endian
|
2151
|
-
// platforms where if it weren't little endian then the opposite
|
2152
|
-
// would occur and the wrong value would be read.
|
2153
|
-
//
|
2154
|
-
// 2. Second, and perhaps even more subtly, the `ValRaw` constructors
|
2155
|
-
// for 32-bit types actually always initialize 64-bits of the
|
2156
|
-
// `ValRaw`. In the component model flat ABI only 32 and 64-bit types
|
2157
|
-
// are used so 64-bits is big enough to contain everything. This
|
2158
|
-
// means that when a `ValRaw` is written into the destination it will
|
2159
|
-
// always, whether it's needed or not, be "ready" to get extended up
|
2160
|
-
// to 64-bits.
|
2161
|
-
//
|
2162
|
-
// Put together these two subtle guarantees means that all `Lower`
|
2163
|
-
// implementations can be written "naturally" as one might naively
|
2164
|
-
// expect. Variants will, on each arm, zero out remaining fields and all
|
2165
|
-
// writes to the flat representation will automatically be 64-bit writes
|
2166
|
-
// meaning that if the value is read as a 64-bit value, which isn't
|
2167
|
-
// known at the time of the write, it'll still be correct.
|
2168
|
-
match self {
|
2169
|
-
Ok(e) => {
|
2170
|
-
map_maybe_uninit!(dst.tag).write(ValRaw::i32(0));
|
2171
|
-
unsafe {
|
2172
|
-
lower_payload(
|
2173
|
-
map_maybe_uninit!(dst.payload),
|
2174
|
-
|payload| map_maybe_uninit!(payload.ok),
|
2175
|
-
|dst| match ok {
|
2176
|
-
Some(ok) => e.lower(cx, ok, dst),
|
2177
|
-
None => Ok(()),
|
2178
|
-
},
|
2179
|
-
)
|
2180
|
-
}
|
2181
|
-
}
|
2182
|
-
Err(e) => {
|
2183
|
-
map_maybe_uninit!(dst.tag).write(ValRaw::i32(1));
|
2184
|
-
unsafe {
|
2185
|
-
lower_payload(
|
2186
|
-
map_maybe_uninit!(dst.payload),
|
2187
|
-
|payload| map_maybe_uninit!(payload.err),
|
2188
|
-
|dst| match err {
|
2189
|
-
Some(err) => e.lower(cx, err, dst),
|
2190
|
-
None => Ok(()),
|
2191
|
-
},
|
2192
|
-
)
|
2193
|
-
}
|
2194
|
-
}
|
2195
|
-
}
|
2196
|
-
}
|
2197
|
-
|
2198
|
-
fn store<U>(
|
2199
|
-
&self,
|
2200
|
-
cx: &mut LowerContext<'_, U>,
|
2201
|
-
ty: InterfaceType,
|
2202
|
-
offset: usize,
|
2203
|
-
) -> Result<()> {
|
2204
|
-
let (ok, err) = match ty {
|
2205
|
-
InterfaceType::Result(ty) => {
|
2206
|
-
let ty = &cx.types[ty];
|
2207
|
-
(ty.ok, ty.err)
|
2208
|
-
}
|
2209
|
-
_ => bad_type_info(),
|
2210
|
-
};
|
2211
|
-
debug_assert!(offset % (Self::ALIGN32 as usize) == 0);
|
2212
|
-
let payload_offset = Self::INFO.payload_offset32 as usize;
|
2213
|
-
match self {
|
2214
|
-
Ok(e) => {
|
2215
|
-
cx.get::<1>(offset)[0] = 0;
|
2216
|
-
if let Some(ok) = ok {
|
2217
|
-
e.store(cx, ok, offset + payload_offset)?;
|
2218
|
-
}
|
2219
|
-
}
|
2220
|
-
Err(e) => {
|
2221
|
-
cx.get::<1>(offset)[0] = 1;
|
2222
|
-
if let Some(err) = err {
|
2223
|
-
e.store(cx, err, offset + payload_offset)?;
|
2224
|
-
}
|
2225
|
-
}
|
2226
|
-
}
|
2227
|
-
Ok(())
|
2228
|
-
}
|
2229
|
-
}
|
2230
|
-
|
2231
|
-
unsafe impl<T, E> Lift for Result<T, E>
|
2232
|
-
where
|
2233
|
-
T: Lift,
|
2234
|
-
E: Lift,
|
2235
|
-
{
|
2236
|
-
#[inline]
|
2237
|
-
fn lift(cx: &mut LiftContext<'_>, ty: InterfaceType, src: &Self::Lower) -> Result<Self> {
|
2238
|
-
let (ok, err) = match ty {
|
2239
|
-
InterfaceType::Result(ty) => {
|
2240
|
-
let ty = &cx.types[ty];
|
2241
|
-
(ty.ok, ty.err)
|
2242
|
-
}
|
2243
|
-
_ => bad_type_info(),
|
2244
|
-
};
|
2245
|
-
// Note that this implementation specifically isn't trying to actually
|
2246
|
-
// reinterpret or alter the bits of `lower` depending on which variant
|
2247
|
-
// we're lifting. This ends up all working out because the value is
|
2248
|
-
// stored in little-endian format.
|
2249
|
-
//
|
2250
|
-
// When stored in little-endian format the `{T,E}::Lower`, when each
|
2251
|
-
// individual `ValRaw` is read, means that if an i64 value, extended
|
2252
|
-
// from an i32 value, was stored then when the i32 value is read it'll
|
2253
|
-
// automatically ignore the upper bits.
|
2254
|
-
//
|
2255
|
-
// This "trick" allows us to seamlessly pass through the `Self::Lower`
|
2256
|
-
// representation into the lifting/lowering without trying to handle
|
2257
|
-
// "join"ed types as per the canonical ABI. It just so happens that i64
|
2258
|
-
// bits will naturally be reinterpreted as f64. Additionally if the
|
2259
|
-
// joined type is i64 but only the lower bits are read that's ok and we
|
2260
|
-
// don't need to validate the upper bits.
|
2261
|
-
//
|
2262
|
-
// This is largely enabled by WebAssembly/component-model#35 where no
|
2263
|
-
// validation needs to be performed for ignored bits and bytes here.
|
2264
|
-
Ok(match src.tag.get_i32() {
|
2265
|
-
0 => Ok(unsafe { lift_option(cx, ok, &src.payload.ok)? }),
|
2266
|
-
1 => Err(unsafe { lift_option(cx, err, &src.payload.err)? }),
|
2267
|
-
_ => bail!("invalid expected discriminant"),
|
2268
|
-
})
|
2269
|
-
}
|
2270
|
-
|
2271
|
-
#[inline]
|
2272
|
-
fn load(cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self> {
|
2273
|
-
debug_assert!((bytes.as_ptr() as usize) % (Self::ALIGN32 as usize) == 0);
|
2274
|
-
let discrim = bytes[0];
|
2275
|
-
let payload = &bytes[Self::INFO.payload_offset32 as usize..];
|
2276
|
-
let (ok, err) = match ty {
|
2277
|
-
InterfaceType::Result(ty) => {
|
2278
|
-
let ty = &cx.types[ty];
|
2279
|
-
(ty.ok, ty.err)
|
2280
|
-
}
|
2281
|
-
_ => bad_type_info(),
|
2282
|
-
};
|
2283
|
-
match discrim {
|
2284
|
-
0 => Ok(Ok(load_option(cx, ok, &payload[..T::SIZE32])?)),
|
2285
|
-
1 => Ok(Err(load_option(cx, err, &payload[..E::SIZE32])?)),
|
2286
|
-
_ => bail!("invalid expected discriminant"),
|
2287
|
-
}
|
2288
|
-
}
|
2289
|
-
}
|
2290
|
-
|
2291
|
-
fn lift_option<T>(cx: &mut LiftContext<'_>, ty: Option<InterfaceType>, src: &T::Lower) -> Result<T>
|
2292
|
-
where
|
2293
|
-
T: Lift,
|
2294
|
-
{
|
2295
|
-
match ty {
|
2296
|
-
Some(ty) => T::lift(cx, ty, src),
|
2297
|
-
None => Ok(empty_lift()),
|
2298
|
-
}
|
2299
|
-
}
|
2300
|
-
|
2301
|
-
fn load_option<T>(cx: &mut LiftContext<'_>, ty: Option<InterfaceType>, bytes: &[u8]) -> Result<T>
|
2302
|
-
where
|
2303
|
-
T: Lift,
|
2304
|
-
{
|
2305
|
-
match ty {
|
2306
|
-
Some(ty) => T::load(cx, ty, bytes),
|
2307
|
-
None => Ok(empty_lift()),
|
2308
|
-
}
|
2309
|
-
}
|
2310
|
-
|
2311
|
-
fn empty_lift<T>() -> T
|
2312
|
-
where
|
2313
|
-
T: Lift,
|
2314
|
-
{
|
2315
|
-
assert!(T::IS_RUST_UNIT_TYPE);
|
2316
|
-
assert_eq!(mem::size_of::<T>(), 0);
|
2317
|
-
unsafe { MaybeUninit::uninit().assume_init() }
|
2318
|
-
}
|
2319
|
-
|
2320
|
-
macro_rules! impl_component_ty_for_tuples {
|
2321
|
-
($n:tt $($t:ident)*) => {paste::paste!{
|
2322
|
-
#[allow(non_snake_case)]
|
2323
|
-
#[doc(hidden)]
|
2324
|
-
#[derive(Clone, Copy)]
|
2325
|
-
#[repr(C)]
|
2326
|
-
pub struct [<TupleLower$n>]<$($t),*> {
|
2327
|
-
$($t: $t,)*
|
2328
|
-
_align_tuple_lower0_correctly: [ValRaw; 0],
|
2329
|
-
}
|
2330
|
-
|
2331
|
-
#[allow(non_snake_case)]
|
2332
|
-
unsafe impl<$($t,)*> ComponentType for ($($t,)*)
|
2333
|
-
where $($t: ComponentType),*
|
2334
|
-
{
|
2335
|
-
type Lower = [<TupleLower$n>]<$($t::Lower),*>;
|
2336
|
-
|
2337
|
-
const ABI: CanonicalAbiInfo = CanonicalAbiInfo::record_static(&[
|
2338
|
-
$($t::ABI),*
|
2339
|
-
]);
|
2340
|
-
|
2341
|
-
const IS_RUST_UNIT_TYPE: bool = {
|
2342
|
-
let mut _is_unit = true;
|
2343
|
-
$(
|
2344
|
-
let _anything_to_bind_the_macro_variable = $t::IS_RUST_UNIT_TYPE;
|
2345
|
-
_is_unit = false;
|
2346
|
-
)*
|
2347
|
-
_is_unit
|
2348
|
-
};
|
2349
|
-
|
2350
|
-
fn typecheck(
|
2351
|
-
ty: &InterfaceType,
|
2352
|
-
types: &InstanceType<'_>,
|
2353
|
-
) -> Result<()> {
|
2354
|
-
typecheck_tuple(ty, types, &[$($t::typecheck),*])
|
2355
|
-
}
|
2356
|
-
}
|
2357
|
-
|
2358
|
-
#[allow(non_snake_case)]
|
2359
|
-
unsafe impl<$($t,)*> Lower for ($($t,)*)
|
2360
|
-
where $($t: Lower),*
|
2361
|
-
{
|
2362
|
-
fn lower<U>(
|
2363
|
-
&self,
|
2364
|
-
cx: &mut LowerContext<'_, U>,
|
2365
|
-
ty: InterfaceType,
|
2366
|
-
_dst: &mut MaybeUninit<Self::Lower>,
|
2367
|
-
) -> Result<()> {
|
2368
|
-
let types = match ty {
|
2369
|
-
InterfaceType::Tuple(t) => &cx.types[t].types,
|
2370
|
-
_ => bad_type_info(),
|
2371
|
-
};
|
2372
|
-
let ($($t,)*) = self;
|
2373
|
-
let mut _types = types.iter();
|
2374
|
-
$(
|
2375
|
-
let ty = *_types.next().unwrap_or_else(bad_type_info);
|
2376
|
-
$t.lower(cx, ty, map_maybe_uninit!(_dst.$t))?;
|
2377
|
-
)*
|
2378
|
-
Ok(())
|
2379
|
-
}
|
2380
|
-
|
2381
|
-
fn store<U>(
|
2382
|
-
&self,
|
2383
|
-
cx: &mut LowerContext<'_, U>,
|
2384
|
-
ty: InterfaceType,
|
2385
|
-
mut _offset: usize,
|
2386
|
-
) -> Result<()> {
|
2387
|
-
debug_assert!(_offset % (Self::ALIGN32 as usize) == 0);
|
2388
|
-
let types = match ty {
|
2389
|
-
InterfaceType::Tuple(t) => &cx.types[t].types,
|
2390
|
-
_ => bad_type_info(),
|
2391
|
-
};
|
2392
|
-
let ($($t,)*) = self;
|
2393
|
-
let mut _types = types.iter();
|
2394
|
-
$(
|
2395
|
-
let ty = *_types.next().unwrap_or_else(bad_type_info);
|
2396
|
-
$t.store(cx, ty, $t::ABI.next_field32_size(&mut _offset))?;
|
2397
|
-
)*
|
2398
|
-
Ok(())
|
2399
|
-
}
|
2400
|
-
}
|
2401
|
-
|
2402
|
-
#[allow(non_snake_case)]
|
2403
|
-
unsafe impl<$($t,)*> Lift for ($($t,)*)
|
2404
|
-
where $($t: Lift),*
|
2405
|
-
{
|
2406
|
-
#[inline]
|
2407
|
-
fn lift(cx: &mut LiftContext<'_>, ty: InterfaceType, _src: &Self::Lower) -> Result<Self> {
|
2408
|
-
let types = match ty {
|
2409
|
-
InterfaceType::Tuple(t) => &cx.types[t].types,
|
2410
|
-
_ => bad_type_info(),
|
2411
|
-
};
|
2412
|
-
let mut _types = types.iter();
|
2413
|
-
Ok(($(
|
2414
|
-
$t::lift(
|
2415
|
-
cx,
|
2416
|
-
*_types.next().unwrap_or_else(bad_type_info),
|
2417
|
-
&_src.$t,
|
2418
|
-
)?,
|
2419
|
-
)*))
|
2420
|
-
}
|
2421
|
-
|
2422
|
-
#[inline]
|
2423
|
-
fn load(cx: &mut LiftContext<'_>, ty: InterfaceType, bytes: &[u8]) -> Result<Self> {
|
2424
|
-
debug_assert!((bytes.as_ptr() as usize) % (Self::ALIGN32 as usize) == 0);
|
2425
|
-
let types = match ty {
|
2426
|
-
InterfaceType::Tuple(t) => &cx.types[t].types,
|
2427
|
-
_ => bad_type_info(),
|
2428
|
-
};
|
2429
|
-
let mut _types = types.iter();
|
2430
|
-
let mut _offset = 0;
|
2431
|
-
$(
|
2432
|
-
let ty = *_types.next().unwrap_or_else(bad_type_info);
|
2433
|
-
let $t = $t::load(cx, ty, &bytes[$t::ABI.next_field32_size(&mut _offset)..][..$t::SIZE32])?;
|
2434
|
-
)*
|
2435
|
-
Ok(($($t,)*))
|
2436
|
-
}
|
2437
|
-
}
|
2438
|
-
|
2439
|
-
#[allow(non_snake_case)]
|
2440
|
-
unsafe impl<$($t,)*> ComponentNamedList for ($($t,)*)
|
2441
|
-
where $($t: ComponentType),*
|
2442
|
-
{}
|
2443
|
-
}};
|
2444
|
-
}
|
2445
|
-
|
2446
|
-
for_each_function_signature!(impl_component_ty_for_tuples);
|
2447
|
-
|
2448
|
-
pub fn desc(ty: &InterfaceType) -> &'static str {
|
2449
|
-
match ty {
|
2450
|
-
InterfaceType::U8 => "u8",
|
2451
|
-
InterfaceType::S8 => "s8",
|
2452
|
-
InterfaceType::U16 => "u16",
|
2453
|
-
InterfaceType::S16 => "s16",
|
2454
|
-
InterfaceType::U32 => "u32",
|
2455
|
-
InterfaceType::S32 => "s32",
|
2456
|
-
InterfaceType::U64 => "u64",
|
2457
|
-
InterfaceType::S64 => "s64",
|
2458
|
-
InterfaceType::Float32 => "f32",
|
2459
|
-
InterfaceType::Float64 => "f64",
|
2460
|
-
InterfaceType::Bool => "bool",
|
2461
|
-
InterfaceType::Char => "char",
|
2462
|
-
InterfaceType::String => "string",
|
2463
|
-
InterfaceType::List(_) => "list",
|
2464
|
-
InterfaceType::Tuple(_) => "tuple",
|
2465
|
-
InterfaceType::Option(_) => "option",
|
2466
|
-
InterfaceType::Result(_) => "result",
|
2467
|
-
|
2468
|
-
InterfaceType::Record(_) => "record",
|
2469
|
-
InterfaceType::Variant(_) => "variant",
|
2470
|
-
InterfaceType::Flags(_) => "flags",
|
2471
|
-
InterfaceType::Enum(_) => "enum",
|
2472
|
-
InterfaceType::Own(_) => "owned resource",
|
2473
|
-
InterfaceType::Borrow(_) => "borrowed resource",
|
2474
|
-
}
|
2475
|
-
}
|
2476
|
-
|
2477
|
-
#[cold]
|
2478
|
-
#[doc(hidden)]
|
2479
|
-
pub fn bad_type_info<T>() -> T {
|
2480
|
-
// NB: should consider something like `unreachable_unchecked` here if this
|
2481
|
-
// becomes a performance bottleneck at some point, but that also comes with
|
2482
|
-
// a tradeoff of propagating a lot of unsafety, so it may not be worth it.
|
2483
|
-
panic!("bad type information detected");
|
2484
|
-
}
|