html-to-markdown 2.23.4 → 2.24.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/Gemfile.lock +7 -7
- data/README.md +9 -7
- data/ext/html-to-markdown-rb/native/Cargo.lock +21 -21
- data/ext/html-to-markdown-rb/native/Cargo.toml +1 -3
- data/lib/html_to_markdown/cli_proxy.rb +5 -2
- data/lib/html_to_markdown/version.rb +1 -1
- data/rust-vendor/cc/.cargo-checksum.json +1 -1
- data/rust-vendor/cc/.cargo_vcs_info.json +1 -1
- data/rust-vendor/cc/CHANGELOG.md +7 -0
- data/rust-vendor/cc/Cargo.lock +1 -1
- data/rust-vendor/cc/Cargo.toml +1 -1
- data/rust-vendor/cc/Cargo.toml.orig +1 -1
- data/rust-vendor/cc/src/target/generated.rs +1 -0
- data/rust-vendor/cc/src/target/parser.rs +4 -0
- data/rust-vendor/html-to-markdown-rs/README.md +1 -1
- data/rust-vendor/html-to-markdown-rs/src/convert_api.rs +90 -15
- data/rust-vendor/html-to-markdown-rs/src/converter/block/preformatted.rs +15 -4
- data/rust-vendor/html-to-markdown-rs/src/converter/handlers/graphic.rs +5 -3
- data/rust-vendor/html-to-markdown-rs/src/converter/media/svg.rs +5 -1
- data/rust-vendor/html-to-markdown-rs/src/converter/text/processing.rs +15 -8
- data/rust-vendor/html-to-markdown-rs/src/converter/utility/preprocessing.rs +43 -18
- data/rust-vendor/html-to-markdown-rs/src/lib.rs +6 -6
- data/rust-vendor/html-to-markdown-rs/src/validation.rs +68 -29
- data/rust-vendor/html-to-markdown-rs/tests/issue_190_regressions.rs +121 -0
- data/rust-vendor/html-to-markdown-rs/tests/skip_images_test.rs +21 -0
- data/rust-vendor/proc-macro2/.cargo-checksum.json +1 -1
- data/rust-vendor/proc-macro2/.cargo_vcs_info.json +1 -1
- data/rust-vendor/proc-macro2/Cargo.lock +14 -89
- data/rust-vendor/proc-macro2/Cargo.toml +1 -1
- data/rust-vendor/proc-macro2/Cargo.toml.orig +1 -1
- data/rust-vendor/proc-macro2/src/fallback.rs +37 -23
- data/rust-vendor/proc-macro2/src/lib.rs +1 -1
- data/rust-vendor/quote/.cargo-checksum.json +1 -1
- data/rust-vendor/quote/.cargo_vcs_info.json +1 -1
- data/rust-vendor/quote/.github/workflows/ci.yml +1 -1
- data/rust-vendor/quote/Cargo.lock +17 -17
- data/rust-vendor/quote/Cargo.toml +1 -1
- data/rust-vendor/quote/Cargo.toml.orig +1 -1
- data/rust-vendor/quote/src/format.rs +2 -2
- data/rust-vendor/quote/src/lib.rs +1 -1
- data/rust-vendor/quote/src/runtime.rs +2 -2
- data/rust-vendor/quote/tests/test.rs +6 -0
- data/rust-vendor/quote/tests/ui/does-not-have-iter-interpolated-dup.stderr +2 -2
- data/rust-vendor/quote/tests/ui/does-not-have-iter-interpolated.stderr +2 -2
- data/rust-vendor/quote/tests/ui/does-not-have-iter-separated.stderr +2 -2
- data/rust-vendor/quote/tests/ui/does-not-have-iter.stderr +2 -2
- data/rust-vendor/quote/tests/ui/not-repeatable.stderr +8 -8
- data/rust-vendor/siphasher/.cargo-checksum.json +1 -1
- data/rust-vendor/siphasher/.cargo_vcs_info.json +1 -1
- data/rust-vendor/siphasher/.github/workflows/issues.yml +17 -0
- data/rust-vendor/siphasher/COPYING +1 -1
- data/rust-vendor/siphasher/Cargo.lock +89 -0
- data/rust-vendor/siphasher/Cargo.toml +23 -13
- data/rust-vendor/siphasher/Cargo.toml.orig +1 -1
- data/rust-vendor/siphasher/src/common.rs +65 -0
- data/rust-vendor/siphasher/src/lib.rs +1 -1
- data/rust-vendor/siphasher/src/sip.rs +2 -68
- data/rust-vendor/siphasher/src/sip128.rs +15 -74
- data/rust-vendor/siphasher/src/tests.rs +1 -1
- data/rust-vendor/siphasher/src/tests128.rs +1 -1
- data/rust-vendor/uuid/.cargo-checksum.json +1 -1
- data/rust-vendor/uuid/.cargo_vcs_info.json +1 -1
- data/rust-vendor/uuid/Cargo.lock +125 -96
- data/rust-vendor/uuid/Cargo.toml +4 -11
- data/rust-vendor/uuid/Cargo.toml.orig +5 -14
- data/rust-vendor/uuid/README.md +3 -3
- data/rust-vendor/uuid/src/builder.rs +2 -1
- data/rust-vendor/uuid/src/external/serde_support.rs +209 -142
- data/rust-vendor/uuid/src/lib.rs +9 -11
- data/rust-vendor/uuid/src/macros.rs +9 -54
- data/rust-vendor/uuid/src/non_nil.rs +49 -2
- data/rust-vendor/web_atoms/.cargo-checksum.json +1 -1
- data/rust-vendor/web_atoms/.cargo_vcs_info.json +1 -1
- data/rust-vendor/web_atoms/Cargo.lock +1 -1
- data/rust-vendor/web_atoms/Cargo.toml +1 -1
- data/rust-vendor/web_atoms/Cargo.toml.orig +1 -1
- data/rust-vendor/web_atoms/local_names.txt +3 -0
- data/rust-vendor/zerocopy/.cargo-checksum.json +1 -1
- data/rust-vendor/zerocopy/.cargo_vcs_info.json +1 -1
- data/rust-vendor/zerocopy/Cargo.lock +5 -9
- data/rust-vendor/zerocopy/Cargo.toml +10 -18
- data/rust-vendor/zerocopy/Cargo.toml.orig +6 -14
- data/rust-vendor/zerocopy/Cargo.toml.std +58 -0
- data/rust-vendor/zerocopy/agent_docs/ui_tests.md +5 -5
- data/rust-vendor/zerocopy/cargo.sh +1 -1
- data/rust-vendor/zerocopy/ci/check_fmt.sh +1 -1
- data/rust-vendor/zerocopy/ci/check_readme.sh +1 -1
- data/rust-vendor/zerocopy/ci/check_stale_stderr.sh +44 -0
- data/rust-vendor/zerocopy/githooks/pre-push +2 -0
- data/rust-vendor/zerocopy/src/byte_slice.rs +1 -1
- data/rust-vendor/zerocopy/src/byteorder.rs +0 -1
- data/rust-vendor/zerocopy/src/impls.rs +334 -118
- data/rust-vendor/zerocopy/src/layout.rs +9 -0
- data/rust-vendor/zerocopy/src/lib.rs +163 -74
- data/rust-vendor/zerocopy/src/macros.rs +4 -8
- data/rust-vendor/zerocopy/src/pointer/inner.rs +4 -4
- data/rust-vendor/zerocopy/src/pointer/invariant.rs +22 -5
- data/rust-vendor/zerocopy/src/pointer/mod.rs +155 -18
- data/rust-vendor/zerocopy/src/pointer/ptr.rs +133 -182
- data/rust-vendor/zerocopy/src/pointer/transmute.rs +99 -106
- data/rust-vendor/zerocopy/src/ref.rs +4 -4
- data/rust-vendor/zerocopy/src/util/macro_util.rs +73 -127
- data/rust-vendor/zerocopy/src/util/macros.rs +61 -150
- data/rust-vendor/zerocopy/src/wrappers.rs +249 -3
- data/rust-vendor/zerocopy/tests/include.rs +67 -0
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-from-bytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-from-bytes.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-from-zeros.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-from-zeros.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-immutable.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-immutable.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-into-bytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-into-bytes.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-issue-1296.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-issue-1296.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-known-layout.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-known-layout.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-try-from-bytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-try-from-bytes.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-unaligned.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/diagnostic-not-implemented-unaligned.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-msrv/include_value_not_from_bytes.rs +3 -5
- data/rust-vendor/zerocopy/tests/ui-msrv/include_value_not_from_bytes.stderr +10 -10
- data/rust-vendor/zerocopy/tests/ui-msrv/include_value_wrong_size.rs +1 -4
- data/rust-vendor/zerocopy/tests/ui-msrv/include_value_wrong_size.stderr +3 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/invalid-impls/invalid-impls.rs +0 -1
- data/rust-vendor/zerocopy/tests/ui-msrv/invalid-impls/invalid-impls.stderr +35 -35
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-dst-not-frombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-dst-not-frombytes.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-const.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-const.stderr +10 -10
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-dst-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-dst-not-a-reference.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-dst-not-frombytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-dst-not-frombytes.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-dst-not-intobytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-dst-not-intobytes.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-dst-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-dst-unsized.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-dst-not-references.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-dst-not-references.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-immutable.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-immutable.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-not-a-reference.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-not-frombytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-not-frombytes.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-not-intobytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-not-intobytes.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-mut-src-unsized.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ptr-to-usize.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ptr-to-usize.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-dst-mutable.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-dst-mutable.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-dst-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-dst-not-a-reference.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-dst-not-frombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-dst-not-frombytes.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-dst-not-nocell.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-dst-not-nocell.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-dst-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-dst-unsized.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-src-dst-not-references.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-src-dst-not-references.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-src-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-src-not-a-reference.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-src-not-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-src-not-intobytes.stderr +12 -12
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-src-not-nocell.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-src-not-nocell.stderr +12 -12
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-src-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-ref-src-unsized.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-size-decrease.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-size-increase-allow-shrink.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-size-increase-allow-shrink.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-size-increase.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-src-not-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/transmute-src-not-intobytes.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute-dst-not-tryfrombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute-dst-not-tryfrombytes.stderr +12 -12
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute-size-decrease.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute-size-increase.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute-src-not-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute-src-not-intobytes.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-alignment-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-alignment-increase.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-dst-not-tryfrombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-dst-not-tryfrombytes.stderr +16 -16
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-size-decrease.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-size-increase.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-src-not-frombytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-src-not-frombytes.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-src-not-intobytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_mut-src-not-intobytes.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-alignment-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-alignment-increase.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-dst-mutable.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-dst-mutable.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-dst-not-immutable-tryfrombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-dst-not-immutable-tryfrombytes.stderr +16 -16
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-size-decrease.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-size-increase.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-src-not-immutable-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-msrv/try_transmute_ref-src-not-immutable-intobytes.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-from-bytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-from-bytes.stderr +15 -15
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-from-zeros.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-from-zeros.stderr +12 -12
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-immutable.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-immutable.stderr +13 -13
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-into-bytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-into-bytes.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-issue-1296.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-issue-1296.stderr +16 -16
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-known-layout.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-known-layout.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-try-from-bytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-try-from-bytes.stderr +15 -15
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-unaligned.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/diagnostic-not-implemented-unaligned.stderr +5 -5
- data/rust-vendor/zerocopy/tests/ui-nightly/include_value_not_from_bytes.rs +3 -5
- data/rust-vendor/zerocopy/tests/ui-nightly/include_value_not_from_bytes.stderr +21 -21
- data/rust-vendor/zerocopy/tests/ui-nightly/include_value_wrong_size.rs +1 -4
- data/rust-vendor/zerocopy/tests/ui-nightly/include_value_wrong_size.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-nightly/invalid-impls/invalid-impls.rs +0 -1
- data/rust-vendor/zerocopy/tests/ui-nightly/invalid-impls/invalid-impls.stderr +35 -51
- data/rust-vendor/zerocopy/tests/ui-nightly/ptr-is-invariant-over-v.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-dst-not-frombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-dst-not-frombytes.stderr +15 -15
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-const.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-const.stderr +7 -7
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-dst-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-dst-not-a-reference.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-dst-not-frombytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-dst-not-frombytes.stderr +12 -12
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-dst-not-intobytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-dst-not-intobytes.stderr +5 -5
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-dst-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-dst-unsized.stderr +3 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-dst-not-references.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-dst-not-references.stderr +3 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-immutable.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-immutable.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-not-a-reference.stderr +3 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-not-frombytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-not-frombytes.stderr +12 -12
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-not-intobytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-not-intobytes.stderr +5 -5
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-mut-src-unsized.stderr +3 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ptr-to-usize.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ptr-to-usize.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-dst-mutable.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-dst-mutable.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-dst-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-dst-not-a-reference.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-dst-not-frombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-dst-not-frombytes.stderr +16 -16
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-dst-not-nocell.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-dst-not-nocell.stderr +14 -14
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-dst-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-dst-unsized.stderr +3 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-src-dst-not-references.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-src-dst-not-references.stderr +9 -9
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-src-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-src-not-a-reference.stderr +3 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-src-not-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-src-not-intobytes.stderr +18 -18
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-src-not-nocell.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-src-not-nocell.stderr +28 -28
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-src-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-ref-src-unsized.stderr +3 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-size-decrease.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-size-increase-allow-shrink.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-size-increase-allow-shrink.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-size-increase.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-src-not-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/transmute-src-not-intobytes.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute-dst-not-tryfrombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute-dst-not-tryfrombytes.stderr +43 -43
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute-size-decrease.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute-size-increase.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute-src-not-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute-src-not-intobytes.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-alignment-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-alignment-increase.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-dst-not-tryfrombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-dst-not-tryfrombytes.stderr +51 -51
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-size-decrease.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-size-increase.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-src-not-frombytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-src-not-frombytes.stderr +29 -29
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-src-not-intobytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_mut-src-not-intobytes.stderr +22 -22
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-alignment-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-alignment-increase.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-dst-mutable.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-dst-mutable.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-dst-not-immutable-tryfrombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-dst-not-immutable-tryfrombytes.stderr +56 -56
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-size-decrease.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-size-increase.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-src-not-immutable-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-nightly/try_transmute_ref-src-not-immutable-intobytes.stderr +21 -21
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-from-bytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-from-bytes.stderr +15 -15
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-from-zeros.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-from-zeros.stderr +12 -12
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-immutable.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-immutable.stderr +13 -13
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-into-bytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-into-bytes.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-issue-1296.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-issue-1296.stderr +16 -16
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-known-layout.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-known-layout.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-try-from-bytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-try-from-bytes.stderr +15 -15
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-unaligned.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/diagnostic-not-implemented-unaligned.stderr +5 -5
- data/rust-vendor/zerocopy/tests/ui-stable/include_value_not_from_bytes.rs +3 -5
- data/rust-vendor/zerocopy/tests/ui-stable/include_value_not_from_bytes.stderr +21 -21
- data/rust-vendor/zerocopy/tests/ui-stable/include_value_wrong_size.rs +1 -4
- data/rust-vendor/zerocopy/tests/ui-stable/include_value_wrong_size.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-stable/invalid-impls/invalid-impls.rs +0 -1
- data/rust-vendor/zerocopy/tests/ui-stable/invalid-impls/invalid-impls.stderr +37 -37
- data/rust-vendor/zerocopy/tests/ui-stable/ptr-is-invariant-over-v.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-dst-not-frombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-dst-not-frombytes.stderr +15 -15
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-const.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-const.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-dst-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-dst-not-a-reference.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-dst-not-frombytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-dst-not-frombytes.stderr +11 -11
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-dst-not-intobytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-dst-not-intobytes.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-dst-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-dst-unsized.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-dst-not-references.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-dst-not-references.stderr +3 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-immutable.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-immutable.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-not-a-reference.stderr +3 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-not-frombytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-not-frombytes.stderr +11 -11
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-not-intobytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-not-intobytes.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-unsized.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ptr-to-usize.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ptr-to-usize.stderr +9 -5
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-dst-mutable.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-dst-mutable.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-dst-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-dst-not-a-reference.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-dst-not-frombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-dst-not-frombytes.stderr +16 -16
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-dst-not-nocell.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-dst-not-nocell.stderr +14 -14
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-dst-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-dst-unsized.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-src-dst-not-references.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-src-dst-not-references.stderr +9 -9
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-src-not-a-reference.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-src-not-a-reference.stderr +3 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-src-not-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-src-not-intobytes.stderr +18 -18
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-src-not-nocell.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-src-not-nocell.stderr +28 -28
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-src-unsized.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-src-unsized.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-size-decrease.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-size-increase-allow-shrink.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-size-increase-allow-shrink.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-size-increase.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-src-not-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-src-not-intobytes.stderr +8 -8
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute-dst-not-tryfrombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute-dst-not-tryfrombytes.stderr +42 -42
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute-size-decrease.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute-size-increase.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute-src-not-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute-src-not-intobytes.stderr +7 -7
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-alignment-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-alignment-increase.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-dst-not-tryfrombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-dst-not-tryfrombytes.stderr +49 -49
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-size-decrease.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-size-increase.stderr +4 -4
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-src-not-frombytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-src-not-frombytes.stderr +26 -26
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-src-not-intobytes.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_mut-src-not-intobytes.stderr +19 -19
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-alignment-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-alignment-increase.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-dst-mutable.rs +0 -2
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-dst-mutable.stderr +6 -6
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-dst-not-immutable-tryfrombytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-dst-not-immutable-tryfrombytes.stderr +54 -54
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-size-decrease.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-size-decrease.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-size-increase.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-size-increase.stderr +2 -2
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-src-not-immutable-intobytes.rs +1 -3
- data/rust-vendor/zerocopy/tests/ui-stable/try_transmute_ref-src-not-immutable-intobytes.stderr +19 -19
- data/rust-vendor/zerocopy-derive/.cargo-checksum.json +1 -1
- data/rust-vendor/zerocopy-derive/.cargo_vcs_info.json +1 -1
- data/rust-vendor/zerocopy-derive/Cargo.lock +3 -11
- data/rust-vendor/zerocopy-derive/Cargo.toml +13 -11
- data/rust-vendor/zerocopy-derive/Cargo.toml.orig +7 -10
- data/rust-vendor/zerocopy-derive/src/derive/from_bytes.rs +188 -0
- data/rust-vendor/zerocopy-derive/src/derive/into_bytes.rs +158 -0
- data/rust-vendor/zerocopy-derive/src/derive/known_layout.rs +348 -0
- data/rust-vendor/zerocopy-derive/src/derive/mod.rs +130 -0
- data/rust-vendor/zerocopy-derive/src/derive/try_from_bytes.rs +729 -0
- data/rust-vendor/zerocopy-derive/src/derive/unaligned.rs +78 -0
- data/rust-vendor/zerocopy-derive/src/lib.rs +31 -1893
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/eq.expected.rs +17 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/from_bytes_enum.expected.rs +64 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/from_bytes_struct.expected.rs +64 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/from_bytes_union.expected.rs +144 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/from_zeros.expected.rs +39 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/hash.expected.rs +24 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/immutable.expected.rs +17 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/into_bytes_enum.expected.rs +17 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/into_bytes_struct_basic.expected.rs +25 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/into_bytes_struct_empty.expected.rs +17 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/into_bytes_struct_trailing.expected.rs +25 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/into_bytes_struct_trailing_generic.expected.rs +21 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/known_layout_repr_c_struct.expected.rs +135 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/known_layout_struct.expected.rs +34 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/split_at_repr_c.expected.rs +22 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/split_at_repr_transparent.expected.rs +22 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/try_from_bytes.expected.rs +22 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/try_from_bytes_enum_1.expected.rs +2802 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/try_from_bytes_enum_2.expected.rs +2802 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/try_from_bytes_enum_3.expected.rs +2802 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/try_from_bytes_trivial_is_bit_valid_enum.expected.rs +22 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/expected/unaligned.expected.rs +17 -0
- data/rust-vendor/zerocopy-derive/src/output_tests/mod.rs +960 -0
- data/rust-vendor/zerocopy-derive/src/util.rs +757 -0
- data/rust-vendor/zerocopy-derive/tests/deprecated.rs +6 -0
- data/rust-vendor/zerocopy-derive/tests/enum_from_zeros.rs +9 -0
- data/rust-vendor/zerocopy-derive/tests/enum_known_layout.rs +4 -0
- data/rust-vendor/zerocopy-derive/tests/enum_no_cell.rs +4 -0
- data/rust-vendor/zerocopy-derive/tests/enum_to_bytes.rs +14 -0
- data/rust-vendor/zerocopy-derive/tests/enum_try_from_bytes.rs +37 -15
- data/rust-vendor/zerocopy-derive/tests/enum_unaligned.rs +4 -0
- data/rust-vendor/zerocopy-derive/tests/eq.rs +1 -0
- data/rust-vendor/zerocopy-derive/tests/hash.rs +1 -0
- data/rust-vendor/zerocopy-derive/tests/hygiene.rs +3 -1
- data/rust-vendor/zerocopy-derive/tests/include.rs +26 -4
- data/rust-vendor/zerocopy-derive/tests/issue_2117.rs +1 -0
- data/rust-vendor/zerocopy-derive/tests/issue_2835.rs +2 -1
- data/rust-vendor/zerocopy-derive/tests/issue_2880.rs +292 -0
- data/rust-vendor/zerocopy-derive/tests/issue_2915.rs +78 -0
- data/rust-vendor/zerocopy-derive/tests/paths_and_modules.rs +3 -0
- data/rust-vendor/zerocopy-derive/tests/priv_in_pub.rs +2 -0
- data/rust-vendor/zerocopy-derive/tests/struct_from_bytes.rs +6 -0
- data/rust-vendor/zerocopy-derive/tests/struct_from_zeros.rs +6 -0
- data/rust-vendor/zerocopy-derive/tests/struct_known_layout.rs +9 -0
- data/rust-vendor/zerocopy-derive/tests/struct_no_cell.rs +8 -0
- data/rust-vendor/zerocopy-derive/tests/struct_to_bytes.rs +17 -0
- data/rust-vendor/zerocopy-derive/tests/struct_try_from_bytes.rs +29 -65
- data/rust-vendor/zerocopy-derive/tests/struct_unaligned.rs +7 -0
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/derive_transparent.rs +3 -2
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/derive_transparent.stderr +32 -32
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/enum.rs +48 -1
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/enum.stderr +129 -126
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/enum_from_bytes_u8_too_few.rs +2 -1
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/enum_from_bytes_u8_too_few.stderr +6 -6
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/late_compile_pass.rs +9 -2
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/late_compile_pass.stderr +37 -37
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/mid_compile_pass.rs +6 -2
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/mid_compile_pass.stderr +26 -26
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/msrv_specific.rs +3 -2
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/msrv_specific.stderr +7 -7
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/privacy.rs +66 -29
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/privacy.stderr +78 -78
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/struct.rs +34 -2
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/struct.stderr +79 -79
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/union.rs +12 -1
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/union.stderr +29 -29
- data/rust-vendor/zerocopy-derive/tests/ui-msrv/union_into_bytes_cfg/union_into_bytes_cfg.rs +3 -2
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/absence_of_deprecated_warning.rs +3 -2
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/absence_of_deprecated_warning.stderr +2 -2
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/derive_transparent.rs +3 -2
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/derive_transparent.stderr +57 -57
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/enum.rs +48 -1
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/enum.stderr +200 -192
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/enum_from_bytes_u8_too_few.rs +2 -1
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/enum_from_bytes_u8_too_few.stderr +6 -6
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/late_compile_pass.rs +9 -2
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/late_compile_pass.stderr +105 -105
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/mid_compile_pass.rs +6 -2
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/mid_compile_pass.stderr +29 -29
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/privacy.rs +66 -29
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/privacy.stderr +15 -15
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/struct.rs +34 -2
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/struct.stderr +130 -129
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/union.rs +12 -1
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/union.stderr +42 -42
- data/rust-vendor/zerocopy-derive/tests/ui-nightly/union_into_bytes_cfg/union_into_bytes_cfg.rs +3 -2
- data/rust-vendor/zerocopy-derive/tests/ui-stable/derive_transparent.rs +3 -2
- data/rust-vendor/zerocopy-derive/tests/ui-stable/derive_transparent.stderr +57 -57
- data/rust-vendor/zerocopy-derive/tests/ui-stable/enum.rs +48 -1
- data/rust-vendor/zerocopy-derive/tests/ui-stable/enum.stderr +201 -186
- data/rust-vendor/zerocopy-derive/tests/ui-stable/enum_from_bytes_u8_too_few.rs +2 -1
- data/rust-vendor/zerocopy-derive/tests/ui-stable/enum_from_bytes_u8_too_few.stderr +6 -6
- data/rust-vendor/zerocopy-derive/tests/ui-stable/late_compile_pass.rs +9 -2
- data/rust-vendor/zerocopy-derive/tests/ui-stable/late_compile_pass.stderr +105 -105
- data/rust-vendor/zerocopy-derive/tests/ui-stable/mid_compile_pass.rs +6 -2
- data/rust-vendor/zerocopy-derive/tests/ui-stable/mid_compile_pass.stderr +29 -29
- data/rust-vendor/zerocopy-derive/tests/ui-stable/privacy.rs +66 -29
- data/rust-vendor/zerocopy-derive/tests/ui-stable/privacy.stderr +15 -15
- data/rust-vendor/zerocopy-derive/tests/ui-stable/struct.rs +34 -2
- data/rust-vendor/zerocopy-derive/tests/ui-stable/struct.stderr +158 -129
- data/rust-vendor/zerocopy-derive/tests/ui-stable/union.rs +12 -1
- data/rust-vendor/zerocopy-derive/tests/ui-stable/union.stderr +48 -44
- data/rust-vendor/zerocopy-derive/tests/ui-stable/union_into_bytes_cfg/union_into_bytes_cfg.rs +3 -2
- data/rust-vendor/zerocopy-derive/tests/union_from_bytes.rs +15 -0
- data/rust-vendor/zerocopy-derive/tests/union_from_zeros.rs +14 -0
- data/rust-vendor/zerocopy-derive/tests/union_known_layout.rs +5 -0
- data/rust-vendor/zerocopy-derive/tests/union_no_cell.rs +5 -0
- data/rust-vendor/zerocopy-derive/tests/union_to_bytes.rs +5 -0
- data/rust-vendor/zerocopy-derive/tests/union_try_from_bytes.rs +34 -74
- data/rust-vendor/zerocopy-derive/tests/union_unaligned.rs +4 -1
- data/rust-vendor/zerocopy-derive/tests/unsafe_cell.rs +3 -0
- data/rust-vendor/zmij/.cargo-checksum.json +1 -1
- data/rust-vendor/zmij/.cargo_vcs_info.json +1 -1
- data/rust-vendor/zmij/Cargo.lock +10 -10
- data/rust-vendor/zmij/Cargo.toml +1 -1
- data/rust-vendor/zmij/Cargo.toml.orig +1 -1
- data/rust-vendor/zmij/README.md +1 -1
- data/rust-vendor/zmij/src/lib.rs +132 -158
- data/rust-vendor/zune-jpeg/.cargo-checksum.json +1 -1
- data/rust-vendor/zune-jpeg/.cargo_vcs_info.json +1 -1
- data/rust-vendor/zune-jpeg/Cargo.lock +1 -1
- data/rust-vendor/zune-jpeg/Cargo.toml +1 -1
- data/rust-vendor/zune-jpeg/Cargo.toml.orig +1 -1
- data/rust-vendor/zune-jpeg/src/bitstream.rs +1 -1
- data/rust-vendor/zune-jpeg/src/components.rs +2 -1
- data/rust-vendor/zune-jpeg/src/decoder.rs +3 -23
- data/rust-vendor/zune-jpeg/src/headers.rs +19 -1
- data/rust-vendor/zune-jpeg/src/lib.rs +1 -0
- data/rust-vendor/zune-jpeg/src/mcu.rs +6 -6
- data/rust-vendor/zune-jpeg/src/mcu_prog.rs +22 -34
- data/rust-vendor/zune-jpeg/src/upsampler/avx2.rs +3 -1
- data/rust-vendor/zune-jpeg/src/upsampler/neon.rs +13 -23
- data/rust-vendor/zune-jpeg/src/upsampler/portable_simd.rs +4 -1
- data/rust-vendor/zune-jpeg/src/upsampler/scalar.rs +4 -1
- metadata +41 -8
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-mut-src-dst-unsized.stderr +0 -183
- data/rust-vendor/zerocopy/tests/ui-stable/transmute-ref-src-dst-unsized.stderr +0 -183
- data/rust-vendor/zerocopy-derive/src/enum.rs +0 -456
- data/rust-vendor/zerocopy-derive/src/ext.rs +0 -123
- data/rust-vendor/zerocopy-derive/src/output_tests.rs +0 -5608
- data/rust-vendor/zerocopy-derive/tests/crate_path.rs +0 -189
|
@@ -26,6 +26,7 @@ macro_rules! test {
|
|
|
26
26
|
|
|
27
27
|
#[deprecated = "do not use"]
|
|
28
28
|
#[derive(imp::$trait)]
|
|
29
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
29
30
|
$ty
|
|
30
31
|
|
|
31
32
|
#[allow(deprecated)]
|
|
@@ -53,6 +54,7 @@ mod enum_hash_eq {
|
|
|
53
54
|
use super::super::*;
|
|
54
55
|
#[deprecated = "do not use"]
|
|
55
56
|
#[derive(imp::ByteHash, imp::IntoBytes, imp::Immutable)]
|
|
57
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
56
58
|
#[repr(u8)]
|
|
57
59
|
enum Enum {
|
|
58
60
|
A,
|
|
@@ -67,6 +69,7 @@ mod enum_hash_eq {
|
|
|
67
69
|
use super::super::*;
|
|
68
70
|
#[deprecated = "do not use"]
|
|
69
71
|
#[derive(imp::ByteEq, imp::IntoBytes, imp::Immutable)]
|
|
72
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
70
73
|
#[repr(u8)]
|
|
71
74
|
enum Enum {
|
|
72
75
|
A,
|
|
@@ -84,6 +87,7 @@ mod struct_hash_eq {
|
|
|
84
87
|
use super::super::*;
|
|
85
88
|
#[deprecated = "do not use"]
|
|
86
89
|
#[derive(imp::ByteHash, imp::IntoBytes, imp::Immutable)]
|
|
90
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
87
91
|
#[repr(C)]
|
|
88
92
|
struct Struct;
|
|
89
93
|
|
|
@@ -96,6 +100,7 @@ mod struct_hash_eq {
|
|
|
96
100
|
use super::super::*;
|
|
97
101
|
#[deprecated = "do not use"]
|
|
98
102
|
#[derive(imp::ByteEq, imp::IntoBytes, imp::Immutable)]
|
|
103
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
99
104
|
#[repr(C)]
|
|
100
105
|
struct Struct;
|
|
101
106
|
|
|
@@ -112,6 +117,7 @@ mod split_at_test {
|
|
|
112
117
|
use super::super::*;
|
|
113
118
|
#[deprecated = "do not use"]
|
|
114
119
|
#[derive(imp::SplitAt, imp::KnownLayout)]
|
|
120
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
115
121
|
#[repr(C)]
|
|
116
122
|
struct Struct {
|
|
117
123
|
a: [u8],
|
|
@@ -13,6 +13,7 @@
|
|
|
13
13
|
include!("include.rs");
|
|
14
14
|
|
|
15
15
|
#[derive(imp::FromZeros)]
|
|
16
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
16
17
|
#[repr(C)]
|
|
17
18
|
enum Foo {
|
|
18
19
|
A,
|
|
@@ -21,6 +22,7 @@ enum Foo {
|
|
|
21
22
|
util_assert_impl_all!(Foo: imp::FromZeros);
|
|
22
23
|
|
|
23
24
|
#[derive(imp::FromZeros)]
|
|
25
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
24
26
|
#[repr(C)]
|
|
25
27
|
enum Bar {
|
|
26
28
|
A = 0,
|
|
@@ -29,6 +31,7 @@ enum Bar {
|
|
|
29
31
|
util_assert_impl_all!(Bar: imp::FromZeros);
|
|
30
32
|
|
|
31
33
|
#[derive(imp::FromZeros)]
|
|
34
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
32
35
|
#[repr(C)]
|
|
33
36
|
enum TwoVariantsHasExplicitZero {
|
|
34
37
|
A = 1,
|
|
@@ -38,6 +41,7 @@ enum TwoVariantsHasExplicitZero {
|
|
|
38
41
|
util_assert_impl_all!(TwoVariantsHasExplicitZero: imp::FromZeros);
|
|
39
42
|
|
|
40
43
|
#[derive(imp::FromZeros)]
|
|
44
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
41
45
|
#[repr(i8)]
|
|
42
46
|
enum ImplicitNonFirstVariantIsZero {
|
|
43
47
|
A = -1,
|
|
@@ -47,6 +51,7 @@ enum ImplicitNonFirstVariantIsZero {
|
|
|
47
51
|
util_assert_impl_all!(ImplicitNonFirstVariantIsZero: imp::FromZeros);
|
|
48
52
|
|
|
49
53
|
#[derive(imp::FromZeros)]
|
|
54
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
50
55
|
#[repr(u64)]
|
|
51
56
|
enum LargeDiscriminant {
|
|
52
57
|
A = 0xFFFF_FFFF_FFFF_FFFF,
|
|
@@ -56,6 +61,7 @@ enum LargeDiscriminant {
|
|
|
56
61
|
util_assert_impl_all!(LargeDiscriminant: imp::FromZeros);
|
|
57
62
|
|
|
58
63
|
#[derive(imp::FromZeros)]
|
|
64
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
59
65
|
#[repr(C)]
|
|
60
66
|
enum FirstVariantIsZeroable {
|
|
61
67
|
A(u32),
|
|
@@ -65,6 +71,7 @@ enum FirstVariantIsZeroable {
|
|
|
65
71
|
util_assert_impl_all!(FirstVariantIsZeroable: imp::FromZeros);
|
|
66
72
|
|
|
67
73
|
#[derive(imp::FromZeros)]
|
|
74
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
68
75
|
#[repr(u8)]
|
|
69
76
|
enum FirstVariantIsZeroableSecondIsNot {
|
|
70
77
|
A(bool),
|
|
@@ -79,6 +86,7 @@ mod msrv_only {
|
|
|
79
86
|
use super::*;
|
|
80
87
|
|
|
81
88
|
#[derive(imp::FromZeros)]
|
|
89
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
82
90
|
#[repr(u8)]
|
|
83
91
|
enum ImplicitFirstVariantIsZeroable {
|
|
84
92
|
A(bool),
|
|
@@ -88,6 +96,7 @@ mod msrv_only {
|
|
|
88
96
|
util_assert_impl_all!(ImplicitFirstVariantIsZeroable: imp::FromZeros);
|
|
89
97
|
|
|
90
98
|
#[derive(imp::FromZeros)]
|
|
99
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
91
100
|
#[repr(i8)]
|
|
92
101
|
enum ImplicitNonFirstVariantIsZeroable {
|
|
93
102
|
A(::core::num::NonZeroU8) = 1,
|
|
@@ -13,6 +13,7 @@
|
|
|
13
13
|
include!("include.rs");
|
|
14
14
|
|
|
15
15
|
#[derive(imp::KnownLayout)]
|
|
16
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
16
17
|
enum Foo {
|
|
17
18
|
A,
|
|
18
19
|
}
|
|
@@ -20,6 +21,7 @@ enum Foo {
|
|
|
20
21
|
util_assert_impl_all!(Foo: imp::KnownLayout);
|
|
21
22
|
|
|
22
23
|
#[derive(imp::KnownLayout)]
|
|
24
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
23
25
|
enum Bar {
|
|
24
26
|
A = 0,
|
|
25
27
|
}
|
|
@@ -27,6 +29,7 @@ enum Bar {
|
|
|
27
29
|
util_assert_impl_all!(Bar: imp::KnownLayout);
|
|
28
30
|
|
|
29
31
|
#[derive(imp::KnownLayout)]
|
|
32
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
30
33
|
enum Baz {
|
|
31
34
|
A = 1,
|
|
32
35
|
B = 0,
|
|
@@ -37,6 +40,7 @@ util_assert_impl_all!(Baz: imp::KnownLayout);
|
|
|
37
40
|
// Deriving `KnownLayout` should work if the enum has bounded parameters.
|
|
38
41
|
|
|
39
42
|
#[derive(imp::KnownLayout)]
|
|
43
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
40
44
|
#[repr(C)]
|
|
41
45
|
enum WithParams<'a: 'b, 'b: 'a, T: 'a + 'b + imp::KnownLayout, const N: usize>
|
|
42
46
|
where
|
|
@@ -13,6 +13,7 @@
|
|
|
13
13
|
include!("include.rs");
|
|
14
14
|
|
|
15
15
|
#[derive(imp::Immutable)]
|
|
16
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
16
17
|
enum Foo {
|
|
17
18
|
A,
|
|
18
19
|
}
|
|
@@ -20,6 +21,7 @@ enum Foo {
|
|
|
20
21
|
util_assert_impl_all!(Foo: imp::Immutable);
|
|
21
22
|
|
|
22
23
|
#[derive(imp::Immutable)]
|
|
24
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
23
25
|
enum Bar {
|
|
24
26
|
A = 0,
|
|
25
27
|
}
|
|
@@ -27,6 +29,7 @@ enum Bar {
|
|
|
27
29
|
util_assert_impl_all!(Bar: imp::Immutable);
|
|
28
30
|
|
|
29
31
|
#[derive(imp::Immutable)]
|
|
32
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
30
33
|
enum Baz {
|
|
31
34
|
A = 1,
|
|
32
35
|
B = 0,
|
|
@@ -37,6 +40,7 @@ util_assert_impl_all!(Baz: imp::Immutable);
|
|
|
37
40
|
// Deriving `Immutable` should work if the enum has bounded parameters.
|
|
38
41
|
|
|
39
42
|
#[derive(imp::Immutable)]
|
|
43
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
40
44
|
#[repr(C)]
|
|
41
45
|
enum WithParams<'a: 'b, 'b: 'a, T: 'a + 'b + imp::Immutable, const N: ::core::primitive::usize>
|
|
42
46
|
where
|
|
@@ -15,6 +15,7 @@ include!("include.rs");
|
|
|
15
15
|
// An enum is `IntoBytes` if if has a defined repr.
|
|
16
16
|
|
|
17
17
|
#[derive(imp::IntoBytes)]
|
|
18
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
18
19
|
#[repr(C)]
|
|
19
20
|
enum C {
|
|
20
21
|
A,
|
|
@@ -23,6 +24,7 @@ enum C {
|
|
|
23
24
|
util_assert_impl_all!(C: imp::IntoBytes);
|
|
24
25
|
|
|
25
26
|
#[derive(imp::IntoBytes)]
|
|
27
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
26
28
|
#[repr(u8)]
|
|
27
29
|
enum U8 {
|
|
28
30
|
A,
|
|
@@ -31,6 +33,7 @@ enum U8 {
|
|
|
31
33
|
util_assert_impl_all!(U8: imp::IntoBytes);
|
|
32
34
|
|
|
33
35
|
#[derive(imp::IntoBytes)]
|
|
36
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
34
37
|
#[repr(u16)]
|
|
35
38
|
enum U16 {
|
|
36
39
|
A,
|
|
@@ -39,6 +42,7 @@ enum U16 {
|
|
|
39
42
|
util_assert_impl_all!(U16: imp::IntoBytes);
|
|
40
43
|
|
|
41
44
|
#[derive(imp::IntoBytes)]
|
|
45
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
42
46
|
#[repr(u32)]
|
|
43
47
|
enum U32 {
|
|
44
48
|
A,
|
|
@@ -47,6 +51,7 @@ enum U32 {
|
|
|
47
51
|
util_assert_impl_all!(U32: imp::IntoBytes);
|
|
48
52
|
|
|
49
53
|
#[derive(imp::IntoBytes)]
|
|
54
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
50
55
|
#[repr(u64)]
|
|
51
56
|
enum U64 {
|
|
52
57
|
A,
|
|
@@ -55,6 +60,7 @@ enum U64 {
|
|
|
55
60
|
util_assert_impl_all!(U64: imp::IntoBytes);
|
|
56
61
|
|
|
57
62
|
#[derive(imp::IntoBytes)]
|
|
63
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
58
64
|
#[repr(usize)]
|
|
59
65
|
enum Usize {
|
|
60
66
|
A,
|
|
@@ -63,6 +69,7 @@ enum Usize {
|
|
|
63
69
|
util_assert_impl_all!(Usize: imp::IntoBytes);
|
|
64
70
|
|
|
65
71
|
#[derive(imp::IntoBytes)]
|
|
72
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
66
73
|
#[repr(i8)]
|
|
67
74
|
enum I8 {
|
|
68
75
|
A,
|
|
@@ -71,6 +78,7 @@ enum I8 {
|
|
|
71
78
|
util_assert_impl_all!(I8: imp::IntoBytes);
|
|
72
79
|
|
|
73
80
|
#[derive(imp::IntoBytes)]
|
|
81
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
74
82
|
#[repr(i16)]
|
|
75
83
|
enum I16 {
|
|
76
84
|
A,
|
|
@@ -79,6 +87,7 @@ enum I16 {
|
|
|
79
87
|
util_assert_impl_all!(I16: imp::IntoBytes);
|
|
80
88
|
|
|
81
89
|
#[derive(imp::IntoBytes)]
|
|
90
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
82
91
|
#[repr(i32)]
|
|
83
92
|
enum I32 {
|
|
84
93
|
A,
|
|
@@ -87,6 +96,7 @@ enum I32 {
|
|
|
87
96
|
util_assert_impl_all!(I32: imp::IntoBytes);
|
|
88
97
|
|
|
89
98
|
#[derive(imp::IntoBytes)]
|
|
99
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
90
100
|
#[repr(i64)]
|
|
91
101
|
enum I64 {
|
|
92
102
|
A,
|
|
@@ -95,6 +105,7 @@ enum I64 {
|
|
|
95
105
|
util_assert_impl_all!(I64: imp::IntoBytes);
|
|
96
106
|
|
|
97
107
|
#[derive(imp::IntoBytes)]
|
|
108
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
98
109
|
#[repr(isize)]
|
|
99
110
|
enum Isize {
|
|
100
111
|
A,
|
|
@@ -103,6 +114,7 @@ enum Isize {
|
|
|
103
114
|
util_assert_impl_all!(Isize: imp::IntoBytes);
|
|
104
115
|
|
|
105
116
|
#[derive(imp::IntoBytes)]
|
|
117
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
106
118
|
#[repr(u8)]
|
|
107
119
|
enum HasData {
|
|
108
120
|
A(u8),
|
|
@@ -112,6 +124,7 @@ enum HasData {
|
|
|
112
124
|
util_assert_impl_all!(HasData: imp::IntoBytes);
|
|
113
125
|
|
|
114
126
|
#[derive(imp::IntoBytes)]
|
|
127
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
115
128
|
#[repr(u32)]
|
|
116
129
|
enum HasData32 {
|
|
117
130
|
A(u32),
|
|
@@ -127,6 +140,7 @@ util_assert_impl_all!(HasData: imp::IntoBytes);
|
|
|
127
140
|
// Tag { A }`, which is two bytes long, rather than the correct `#[repr(u8)]
|
|
128
141
|
// struct Tag { A }`, which is one byte long.
|
|
129
142
|
#[derive(imp::IntoBytes)]
|
|
143
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
130
144
|
#[repr(u8, align(2))]
|
|
131
145
|
enum BadTagWouldHavePadding {
|
|
132
146
|
A(u8, u16),
|
|
@@ -13,6 +13,7 @@
|
|
|
13
13
|
include!("include.rs");
|
|
14
14
|
|
|
15
15
|
#[derive(Eq, PartialEq, Debug, imp::Immutable, imp::KnownLayout, imp::TryFromBytes)]
|
|
16
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
16
17
|
#[repr(u8)]
|
|
17
18
|
enum Foo {
|
|
18
19
|
A,
|
|
@@ -29,6 +30,7 @@ fn test_foo() {
|
|
|
29
30
|
}
|
|
30
31
|
|
|
31
32
|
#[derive(Eq, PartialEq, Debug, imp::KnownLayout, imp::Immutable, imp::TryFromBytes)]
|
|
33
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
32
34
|
#[repr(u16)]
|
|
33
35
|
enum Bar {
|
|
34
36
|
A = 0,
|
|
@@ -46,6 +48,7 @@ fn test_bar() {
|
|
|
46
48
|
}
|
|
47
49
|
|
|
48
50
|
#[derive(Eq, PartialEq, Debug, imp::KnownLayout, imp::Immutable, imp::TryFromBytes)]
|
|
51
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
49
52
|
#[repr(u32)]
|
|
50
53
|
enum Baz {
|
|
51
54
|
A = 1,
|
|
@@ -78,6 +81,7 @@ type i8 = bool;
|
|
|
78
81
|
const THREE: ::core::primitive::i8 = 3;
|
|
79
82
|
|
|
80
83
|
#[derive(Eq, PartialEq, Debug, imp::KnownLayout, imp::Immutable, imp::TryFromBytes)]
|
|
84
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
81
85
|
#[repr(i8)]
|
|
82
86
|
enum Blah {
|
|
83
87
|
A = 1,
|
|
@@ -114,6 +118,7 @@ fn test_blah() {
|
|
|
114
118
|
#[derive(
|
|
115
119
|
Eq, PartialEq, Debug, imp::KnownLayout, imp::Immutable, imp::TryFromBytes, imp::IntoBytes,
|
|
116
120
|
)]
|
|
121
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
117
122
|
#[repr(C)]
|
|
118
123
|
enum FieldlessButNotUnitOnly {
|
|
119
124
|
A,
|
|
@@ -124,17 +129,17 @@ enum FieldlessButNotUnitOnly {
|
|
|
124
129
|
#[test]
|
|
125
130
|
fn test_fieldless_but_not_unit_only() {
|
|
126
131
|
const SIZE: usize = ::core::mem::size_of::<FieldlessButNotUnitOnly>();
|
|
127
|
-
let disc: [u8; SIZE] = ::
|
|
132
|
+
let disc: [u8; SIZE] = ::zerocopy_renamed::transmute!(FieldlessButNotUnitOnly::A);
|
|
128
133
|
imp::assert_eq!(
|
|
129
134
|
<FieldlessButNotUnitOnly as imp::TryFromBytes>::try_read_from_bytes(&disc[..]),
|
|
130
135
|
imp::Ok(FieldlessButNotUnitOnly::A)
|
|
131
136
|
);
|
|
132
|
-
let disc: [u8; SIZE] = ::
|
|
137
|
+
let disc: [u8; SIZE] = ::zerocopy_renamed::transmute!(FieldlessButNotUnitOnly::B());
|
|
133
138
|
imp::assert_eq!(
|
|
134
139
|
<FieldlessButNotUnitOnly as imp::TryFromBytes>::try_read_from_bytes(&disc[..]),
|
|
135
140
|
imp::Ok(FieldlessButNotUnitOnly::B())
|
|
136
141
|
);
|
|
137
|
-
let disc: [u8; SIZE] = ::
|
|
142
|
+
let disc: [u8; SIZE] = ::zerocopy_renamed::transmute!(FieldlessButNotUnitOnly::C {});
|
|
138
143
|
imp::assert_eq!(
|
|
139
144
|
<FieldlessButNotUnitOnly as imp::TryFromBytes>::try_read_from_bytes(&disc[..]),
|
|
140
145
|
imp::Ok(FieldlessButNotUnitOnly::C {})
|
|
@@ -148,6 +153,7 @@ fn test_fieldless_but_not_unit_only() {
|
|
|
148
153
|
#[derive(
|
|
149
154
|
Eq, PartialEq, Debug, imp::KnownLayout, imp::Immutable, imp::TryFromBytes, imp::IntoBytes,
|
|
150
155
|
)]
|
|
156
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
151
157
|
#[repr(C)]
|
|
152
158
|
enum WeirdDiscriminants {
|
|
153
159
|
A = -7,
|
|
@@ -158,17 +164,17 @@ enum WeirdDiscriminants {
|
|
|
158
164
|
#[test]
|
|
159
165
|
fn test_weird_discriminants() {
|
|
160
166
|
const SIZE: usize = ::core::mem::size_of::<WeirdDiscriminants>();
|
|
161
|
-
let disc: [u8; SIZE] = ::
|
|
167
|
+
let disc: [u8; SIZE] = ::zerocopy_renamed::transmute!(WeirdDiscriminants::A);
|
|
162
168
|
imp::assert_eq!(
|
|
163
169
|
<WeirdDiscriminants as imp::TryFromBytes>::try_read_from_bytes(&disc[..]),
|
|
164
170
|
imp::Ok(WeirdDiscriminants::A)
|
|
165
171
|
);
|
|
166
|
-
let disc: [u8; SIZE] = ::
|
|
172
|
+
let disc: [u8; SIZE] = ::zerocopy_renamed::transmute!(WeirdDiscriminants::B);
|
|
167
173
|
imp::assert_eq!(
|
|
168
174
|
<WeirdDiscriminants as imp::TryFromBytes>::try_read_from_bytes(&disc[..]),
|
|
169
175
|
imp::Ok(WeirdDiscriminants::B)
|
|
170
176
|
);
|
|
171
|
-
let disc: [u8; SIZE] = ::
|
|
177
|
+
let disc: [u8; SIZE] = ::zerocopy_renamed::transmute!(WeirdDiscriminants::C);
|
|
172
178
|
imp::assert_eq!(
|
|
173
179
|
<WeirdDiscriminants as imp::TryFromBytes>::try_read_from_bytes(&disc[..]),
|
|
174
180
|
imp::Ok(WeirdDiscriminants::C)
|
|
@@ -183,6 +189,7 @@ fn test_weird_discriminants() {
|
|
|
183
189
|
#[derive(
|
|
184
190
|
Eq, PartialEq, Debug, imp::KnownLayout, imp::Immutable, imp::TryFromBytes, imp::IntoBytes,
|
|
185
191
|
)]
|
|
192
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
186
193
|
#[repr(C)]
|
|
187
194
|
enum HasFields {
|
|
188
195
|
A(u32),
|
|
@@ -193,14 +200,15 @@ enum HasFields {
|
|
|
193
200
|
fn test_has_fields() {
|
|
194
201
|
const SIZE: usize = ::core::mem::size_of::<HasFields>();
|
|
195
202
|
|
|
196
|
-
let bytes: [u8; SIZE] = ::
|
|
203
|
+
let bytes: [u8; SIZE] = ::zerocopy_renamed::transmute!(HasFields::A(10));
|
|
197
204
|
imp::assert_eq!(
|
|
198
205
|
<HasFields as imp::TryFromBytes>::try_read_from_bytes(&bytes[..]),
|
|
199
206
|
imp::Ok(HasFields::A(10)),
|
|
200
207
|
);
|
|
201
208
|
|
|
202
|
-
let bytes: [u8; SIZE] =
|
|
203
|
-
|
|
209
|
+
let bytes: [u8; SIZE] = ::zerocopy_renamed::transmute!(HasFields::B {
|
|
210
|
+
foo: ::core::num::NonZeroU32::new(123456).unwrap()
|
|
211
|
+
});
|
|
204
212
|
imp::assert_eq!(
|
|
205
213
|
<HasFields as imp::TryFromBytes>::try_read_from_bytes(&bytes[..]),
|
|
206
214
|
imp::Ok(HasFields::B { foo: ::core::num::NonZeroU32::new(123456).unwrap() }),
|
|
@@ -208,6 +216,7 @@ fn test_has_fields() {
|
|
|
208
216
|
}
|
|
209
217
|
|
|
210
218
|
#[derive(Eq, PartialEq, Debug, imp::KnownLayout, imp::Immutable, imp::TryFromBytes)]
|
|
219
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
211
220
|
#[repr(C, align(16))]
|
|
212
221
|
enum HasFieldsAligned {
|
|
213
222
|
A(u32),
|
|
@@ -221,6 +230,7 @@ fn test_has_fields_aligned() {
|
|
|
221
230
|
const SIZE: usize = ::core::mem::size_of::<HasFieldsAligned>();
|
|
222
231
|
|
|
223
232
|
#[derive(imp::IntoBytes)]
|
|
233
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
224
234
|
#[repr(C)]
|
|
225
235
|
struct BytesOfHasFieldsAligned {
|
|
226
236
|
has_fields: HasFields,
|
|
@@ -229,13 +239,13 @@ fn test_has_fields_aligned() {
|
|
|
229
239
|
|
|
230
240
|
let wrap = |has_fields| BytesOfHasFieldsAligned { has_fields, padding: [0; 8] };
|
|
231
241
|
|
|
232
|
-
let bytes: [u8; SIZE] = ::
|
|
242
|
+
let bytes: [u8; SIZE] = ::zerocopy_renamed::transmute!(wrap(HasFields::A(10)));
|
|
233
243
|
imp::assert_eq!(
|
|
234
244
|
<HasFieldsAligned as imp::TryFromBytes>::try_read_from_bytes(&bytes[..]),
|
|
235
245
|
imp::Ok(HasFieldsAligned::A(10)),
|
|
236
246
|
);
|
|
237
247
|
|
|
238
|
-
let bytes: [u8; SIZE] = ::
|
|
248
|
+
let bytes: [u8; SIZE] = ::zerocopy_renamed::transmute!(wrap(HasFields::B {
|
|
239
249
|
foo: ::core::num::NonZeroU32::new(123456).unwrap()
|
|
240
250
|
}));
|
|
241
251
|
imp::assert_eq!(
|
|
@@ -247,6 +257,7 @@ fn test_has_fields_aligned() {
|
|
|
247
257
|
#[derive(
|
|
248
258
|
Eq, PartialEq, Debug, imp::KnownLayout, imp::Immutable, imp::TryFromBytes, imp::IntoBytes,
|
|
249
259
|
)]
|
|
260
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
250
261
|
#[repr(u32)]
|
|
251
262
|
enum HasFieldsPrimitive {
|
|
252
263
|
A(u32),
|
|
@@ -257,13 +268,13 @@ enum HasFieldsPrimitive {
|
|
|
257
268
|
fn test_has_fields_primitive() {
|
|
258
269
|
const SIZE: usize = ::core::mem::size_of::<HasFieldsPrimitive>();
|
|
259
270
|
|
|
260
|
-
let bytes: [u8; SIZE] = ::
|
|
271
|
+
let bytes: [u8; SIZE] = ::zerocopy_renamed::transmute!(HasFieldsPrimitive::A(10));
|
|
261
272
|
imp::assert_eq!(
|
|
262
273
|
<HasFieldsPrimitive as imp::TryFromBytes>::try_read_from_bytes(&bytes[..]),
|
|
263
274
|
imp::Ok(HasFieldsPrimitive::A(10)),
|
|
264
275
|
);
|
|
265
276
|
|
|
266
|
-
let bytes: [u8; SIZE] = ::
|
|
277
|
+
let bytes: [u8; SIZE] = ::zerocopy_renamed::transmute!(HasFieldsPrimitive::B {
|
|
267
278
|
foo: ::core::num::NonZeroU32::new(123456).unwrap(),
|
|
268
279
|
});
|
|
269
280
|
imp::assert_eq!(
|
|
@@ -273,6 +284,7 @@ fn test_has_fields_primitive() {
|
|
|
273
284
|
}
|
|
274
285
|
|
|
275
286
|
#[derive(Eq, PartialEq, Debug, imp::KnownLayout, imp::Immutable, imp::TryFromBytes)]
|
|
287
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
276
288
|
#[repr(u32, align(16))]
|
|
277
289
|
enum HasFieldsPrimitiveAligned {
|
|
278
290
|
A(u32),
|
|
@@ -286,6 +298,7 @@ fn test_has_fields_primitive_aligned() {
|
|
|
286
298
|
const SIZE: usize = ::core::mem::size_of::<HasFieldsPrimitiveAligned>();
|
|
287
299
|
|
|
288
300
|
#[derive(imp::IntoBytes)]
|
|
301
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
289
302
|
#[repr(C)]
|
|
290
303
|
struct BytesOfHasFieldsPrimitiveAligned {
|
|
291
304
|
has_fields: HasFieldsPrimitive,
|
|
@@ -294,13 +307,13 @@ fn test_has_fields_primitive_aligned() {
|
|
|
294
307
|
|
|
295
308
|
let wrap = |has_fields| BytesOfHasFieldsPrimitiveAligned { has_fields, padding: [0; 8] };
|
|
296
309
|
|
|
297
|
-
let bytes: [u8; SIZE] = ::
|
|
310
|
+
let bytes: [u8; SIZE] = ::zerocopy_renamed::transmute!(wrap(HasFieldsPrimitive::A(10)));
|
|
298
311
|
imp::assert_eq!(
|
|
299
312
|
<HasFieldsPrimitiveAligned as imp::TryFromBytes>::try_read_from_bytes(&bytes[..]),
|
|
300
313
|
imp::Ok(HasFieldsPrimitiveAligned::A(10)),
|
|
301
314
|
);
|
|
302
315
|
|
|
303
|
-
let bytes: [u8; SIZE] = ::
|
|
316
|
+
let bytes: [u8; SIZE] = ::zerocopy_renamed::transmute!(wrap(HasFieldsPrimitive::B {
|
|
304
317
|
foo: ::core::num::NonZeroU32::new(123456).unwrap()
|
|
305
318
|
}));
|
|
306
319
|
imp::assert_eq!(
|
|
@@ -312,6 +325,7 @@ fn test_has_fields_primitive_aligned() {
|
|
|
312
325
|
}
|
|
313
326
|
|
|
314
327
|
#[derive(imp::TryFromBytes)]
|
|
328
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
315
329
|
#[repr(align(4), u32)]
|
|
316
330
|
enum HasReprAlignFirst {
|
|
317
331
|
A,
|
|
@@ -321,6 +335,7 @@ enum HasReprAlignFirst {
|
|
|
321
335
|
util_assert_impl_all!(HasReprAlignFirst: imp::TryFromBytes);
|
|
322
336
|
|
|
323
337
|
#[derive(imp::KnownLayout, imp::TryFromBytes, imp::Immutable)]
|
|
338
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
324
339
|
#[repr(u8)]
|
|
325
340
|
enum Complex {
|
|
326
341
|
UnitLike,
|
|
@@ -331,6 +346,7 @@ enum Complex {
|
|
|
331
346
|
util_assert_impl_all!(Complex: imp::TryFromBytes);
|
|
332
347
|
|
|
333
348
|
#[derive(imp::KnownLayout, imp::TryFromBytes, imp::Immutable)]
|
|
349
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
334
350
|
#[repr(u8)]
|
|
335
351
|
enum ComplexWithGenerics<X, Y> {
|
|
336
352
|
UnitLike,
|
|
@@ -341,6 +357,7 @@ enum ComplexWithGenerics<X, Y> {
|
|
|
341
357
|
util_assert_impl_all!(ComplexWithGenerics<u16, char>: imp::TryFromBytes);
|
|
342
358
|
|
|
343
359
|
#[derive(imp::KnownLayout, imp::TryFromBytes, imp::Immutable)]
|
|
360
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
344
361
|
#[repr(C)]
|
|
345
362
|
enum GenericWithLifetimes<'a, 'b, X: 'a, Y: 'b> {
|
|
346
363
|
Foo(::core::marker::PhantomData<&'a X>),
|
|
@@ -348,9 +365,11 @@ enum GenericWithLifetimes<'a, 'b, X: 'a, Y: 'b> {
|
|
|
348
365
|
}
|
|
349
366
|
|
|
350
367
|
#[derive(Clone, Copy, imp::TryFromBytes)]
|
|
368
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
351
369
|
struct A;
|
|
352
370
|
|
|
353
371
|
#[derive(imp::TryFromBytes)]
|
|
372
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
354
373
|
#[repr(C)]
|
|
355
374
|
enum B {
|
|
356
375
|
A(A),
|
|
@@ -358,6 +377,7 @@ enum B {
|
|
|
358
377
|
}
|
|
359
378
|
|
|
360
379
|
#[derive(imp::TryFromBytes)]
|
|
380
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
361
381
|
#[repr(u8)]
|
|
362
382
|
enum FooU8 {
|
|
363
383
|
Variant0,
|
|
@@ -636,6 +656,7 @@ mod issue_2051 {
|
|
|
636
656
|
// Prevents regressions of #2051.
|
|
637
657
|
#[repr(u32)]
|
|
638
658
|
#[derive(imp::TryFromBytes)]
|
|
659
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
639
660
|
#[allow(non_camel_case_types)]
|
|
640
661
|
pub enum Code {
|
|
641
662
|
I32_ADD,
|
|
@@ -645,6 +666,7 @@ mod issue_2051 {
|
|
|
645
666
|
}
|
|
646
667
|
|
|
647
668
|
#[derive(imp::TryFromBytes)]
|
|
669
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
648
670
|
#[repr(u8)]
|
|
649
671
|
enum RawIdentifierVariant {
|
|
650
672
|
r#type,
|
|
@@ -17,6 +17,7 @@ include!("include.rs");
|
|
|
17
17
|
// - `repr(u8)` or `repr(i8)`
|
|
18
18
|
|
|
19
19
|
#[derive(imp::Unaligned)]
|
|
20
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
20
21
|
#[repr(u8)]
|
|
21
22
|
enum Foo {
|
|
22
23
|
A,
|
|
@@ -25,6 +26,7 @@ enum Foo {
|
|
|
25
26
|
util_assert_impl_all!(Foo: imp::Unaligned);
|
|
26
27
|
|
|
27
28
|
#[derive(imp::Unaligned)]
|
|
29
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
28
30
|
#[repr(i8)]
|
|
29
31
|
enum Bar {
|
|
30
32
|
A,
|
|
@@ -33,6 +35,7 @@ enum Bar {
|
|
|
33
35
|
util_assert_impl_all!(Bar: imp::Unaligned);
|
|
34
36
|
|
|
35
37
|
#[derive(imp::Unaligned)]
|
|
38
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
36
39
|
#[repr(u8, align(1))]
|
|
37
40
|
enum Baz {
|
|
38
41
|
A,
|
|
@@ -41,6 +44,7 @@ enum Baz {
|
|
|
41
44
|
util_assert_impl_all!(Baz: imp::Unaligned);
|
|
42
45
|
|
|
43
46
|
#[derive(imp::Unaligned)]
|
|
47
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
44
48
|
#[repr(i8, align(1))]
|
|
45
49
|
enum Blah {
|
|
46
50
|
B,
|
|
@@ -16,9 +16,10 @@
|
|
|
16
16
|
|
|
17
17
|
include!("include.rs");
|
|
18
18
|
|
|
19
|
-
extern crate
|
|
19
|
+
extern crate zerocopy_renamed as _zerocopy;
|
|
20
20
|
|
|
21
21
|
#[derive(_zerocopy::KnownLayout, _zerocopy::FromBytes, _zerocopy::Unaligned)]
|
|
22
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
22
23
|
#[repr(C)]
|
|
23
24
|
struct TypeParams<'a, T, I: imp::Iterator> {
|
|
24
25
|
a: T,
|
|
@@ -49,6 +50,7 @@ mod issue_2177 {
|
|
|
49
50
|
macro_rules! define {
|
|
50
51
|
($name:ident, $repr:ty) => {
|
|
51
52
|
#[derive(_zerocopy::KnownLayout)]
|
|
53
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
52
54
|
#[repr(C)]
|
|
53
55
|
pub struct $name($repr);
|
|
54
56
|
};
|
|
@@ -37,7 +37,7 @@ mod imp {
|
|
|
37
37
|
primitive::*,
|
|
38
38
|
},
|
|
39
39
|
::std::{collections::hash_map::DefaultHasher, prelude::v1::*},
|
|
40
|
-
::
|
|
40
|
+
::zerocopy_renamed::*,
|
|
41
41
|
};
|
|
42
42
|
}
|
|
43
43
|
|
|
@@ -59,6 +59,7 @@ pub mod util {
|
|
|
59
59
|
Copy,
|
|
60
60
|
Clone,
|
|
61
61
|
)]
|
|
62
|
+
#[zerocopy(crate = "zerocopy_renamed")]
|
|
62
63
|
#[repr(C, align(2))]
|
|
63
64
|
pub struct AU16(pub u16);
|
|
64
65
|
|
|
@@ -107,6 +108,8 @@ pub mod util {
|
|
|
107
108
|
// As of this writing, this happens when deriving `TryFromBytes` thanks to a
|
|
108
109
|
// top-level `#[derive(FromBytes)]`.
|
|
109
110
|
pub fn test_trivial_is_bit_valid<T: super::imp::TryFromBytes>() {
|
|
111
|
+
use super::imp::{MaybeUninit, Ptr, ReadOnly};
|
|
112
|
+
|
|
110
113
|
// This test works based on the insight that a trivial `is_bit_valid`
|
|
111
114
|
// impl should never load any bytes from memory. Thus, while it is
|
|
112
115
|
// technically a violation of `is_bit_valid`'s safety precondition to
|
|
@@ -116,12 +119,31 @@ pub mod util {
|
|
|
116
119
|
// spuriously generating non-trivial `is_bit_valid` impls, this should
|
|
117
120
|
// cause UB which may be caught by Miri.
|
|
118
121
|
|
|
119
|
-
let mut buf =
|
|
120
|
-
let ptr =
|
|
122
|
+
let mut buf = MaybeUninit::<T>::uninit();
|
|
123
|
+
let ptr = Ptr::from_mut(&mut buf);
|
|
121
124
|
// SAFETY: This is intentionally unsound; see the preceding comment.
|
|
122
125
|
let ptr = unsafe { ptr.assume_initialized() };
|
|
126
|
+
let mut ptr = ptr.transmute::<ReadOnly<MaybeUninit<T>>, _, _>();
|
|
127
|
+
let ptr = ptr.reborrow_shared();
|
|
123
128
|
|
|
124
|
-
let ptr = ptr.cast::<_, ::
|
|
129
|
+
let ptr = ptr.cast::<_, ::zerocopy_renamed::pointer::cast::CastSized, _>();
|
|
125
130
|
assert!(<T as super::imp::TryFromBytes>::is_bit_valid(ptr));
|
|
126
131
|
}
|
|
132
|
+
|
|
133
|
+
pub fn test_is_bit_valid<T: super::imp::TryFromBytes, V: super::imp::IntoBytes>(
|
|
134
|
+
val: V,
|
|
135
|
+
is_bit_valid: bool,
|
|
136
|
+
) {
|
|
137
|
+
use super::imp::{
|
|
138
|
+
pointer::{cast::CastSized, BecauseImmutable},
|
|
139
|
+
ReadOnly,
|
|
140
|
+
};
|
|
141
|
+
|
|
142
|
+
let ro = ReadOnly::new(val);
|
|
143
|
+
let candidate = ::zerocopy_renamed::Ptr::from_ref(&ro);
|
|
144
|
+
let candidate = candidate.recall_validity();
|
|
145
|
+
let candidate = candidate.cast::<ReadOnly<T>, CastSized, (_, BecauseImmutable)>();
|
|
146
|
+
|
|
147
|
+
super::imp::assert_eq!(T::is_bit_valid(candidate), is_bit_valid);
|
|
148
|
+
}
|
|
127
149
|
}
|