[INFO] cloning repository https://github.com/jeremyBanks/you-can [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/jeremyBanks/you-can" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FjeremyBanks%2Fyou-can", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FjeremyBanks%2Fyou-can'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] d86ffb02abff2c3db121e220b99f32c06c6b0645 [INFO] testing jeremyBanks/you-can against master#9e136a30a965bf4e63f03095c57df7257bf96fd6 for pr-134530 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FjeremyBanks%2Fyou-can" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/jeremyBanks/you-can on toolchain 9e136a30a965bf4e63f03095c57df7257bf96fd6 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+9e136a30a965bf4e63f03095c57df7257bf96fd6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] removed /workspace/builds/worker-4-tc1/source/rust-toolchain.toml [INFO] started tweaking git repo https://github.com/jeremyBanks/you-can [INFO] finished tweaking git repo https://github.com/jeremyBanks/you-can [INFO] tweaked toml for git repo https://github.com/jeremyBanks/you-can written to /workspace/builds/worker-4-tc1/source/Cargo.toml [INFO] crate git repo https://github.com/jeremyBanks/you-can already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+9e136a30a965bf4e63f03095c57df7257bf96fd6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded rustfix v0.6.1 [INFO] [stderr] Downloaded compiletest_rs v0.8.0 [INFO] [stderr] Downloaded tester v0.9.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:f3a9d4ad9d972b27faf3965f35b62e55ba32bbce8f20bc8fe909558a86702fde" "/opt/rustwide/cargo-home/bin/cargo" "+9e136a30a965bf4e63f03095c57df7257bf96fd6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] cddc1edbba49e7f18e6f43f32077e7941f21a52f9942eba443ffdf66ca0d50c5 [INFO] running `Command { std: "docker" "start" "-a" "cddc1edbba49e7f18e6f43f32077e7941f21a52f9942eba443ffdf66ca0d50c5", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "cddc1edbba49e7f18e6f43f32077e7941f21a52f9942eba443ffdf66ca0d50c5", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "cddc1edbba49e7f18e6f43f32077e7941f21a52f9942eba443ffdf66ca0d50c5", kill_on_drop: false }` [INFO] [stdout] cddc1edbba49e7f18e6f43f32077e7941f21a52f9942eba443ffdf66ca0d50c5 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:f3a9d4ad9d972b27faf3965f35b62e55ba32bbce8f20bc8fe909558a86702fde" "/opt/rustwide/cargo-home/bin/cargo" "+9e136a30a965bf4e63f03095c57df7257bf96fd6" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] cf272b13df0b92278117cd98b62e3a3d5bd6e7aabd4bb9c90f2c55a8d07eff73 [INFO] running `Command { std: "docker" "start" "-a" "cf272b13df0b92278117cd98b62e3a3d5bd6e7aabd4bb9c90f2c55a8d07eff73", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.43 [INFO] [stderr] Compiling semver-parser v0.7.0 [INFO] [stderr] Compiling quote v1.0.21 [INFO] [stderr] Compiling unicode-ident v1.0.3 [INFO] [stderr] Compiling syn v1.0.99 [INFO] [stderr] Compiling semver v0.9.0 [INFO] [stderr] Compiling rustc_version v0.2.3 [INFO] [stderr] Compiling you-can-build-macros v0.0.14 (/opt/rustwide/workdir/macros) [INFO] [stdout] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stdout] --> macros/lib.rs:2:13 [INFO] [stdout] | [INFO] [stdout] 2 | #![cfg_attr(rustc_is_unstable, feature(proc_macro_diagnostic, proc_macro_span))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: expected names are: `clippy`, `debug_assertions`, `doc`, `docsrs`, `doctest`, `feature`, `fmt_debug`, `miri`, `overflow_checks`, `panic`, `proc_macro`, `relocation_model`, `rustfmt`, `sanitize`, `sanitizer_cfi_generalize_pointers`, `sanitizer_cfi_normalize_integers`, `target_abi`, `target_arch`, `target_endian`, `target_env`, `target_family`, `target_feature`, `target_has_atomic`, `target_has_atomic_equal_alignment`, `target_has_atomic_load_store`, `target_os`, `target_pointer_width`, `target_thread_local`, `target_vendor`, `test`, `ub_checks`, `unix`, and `windows` [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: `#[warn(unexpected_cfgs)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stdout] --> macros/lib.rs:17:23 [INFO] [stdout] | [INFO] [stdout] 17 | #[cfg(not(rustc_is_unstable))] { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 49 | / if_unstable! { [INFO] [stdout] 50 | | then { [INFO] [stdout] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stdout] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stdout] ... | [INFO] [stdout] 84 | | } [INFO] [stdout] | |_____- in this macro invocation [INFO] [stdout] | [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stdout] --> macros/lib.rs:20:19 [INFO] [stdout] | [INFO] [stdout] 20 | #[cfg(rustc_is_unstable)] { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 49 | / if_unstable! { [INFO] [stdout] 50 | | then { [INFO] [stdout] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stdout] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stdout] ... | [INFO] [stdout] 84 | | } [INFO] [stdout] | |_____- in this macro invocation [INFO] [stdout] | [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stdout] --> macros/lib.rs:16:17 [INFO] [stdout] | [INFO] [stdout] 16 | if cfg!(rustc_is_unstable) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 49 | / if_unstable! { [INFO] [stdout] 50 | | then { [INFO] [stdout] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stdout] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stdout] ... | [INFO] [stdout] 84 | | } [INFO] [stdout] | |_____- in this macro invocation [INFO] [stdout] | [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stdout] --> macros/lib.rs:24:19 [INFO] [stdout] | [INFO] [stdout] 24 | #[cfg(rustc_is_unstable)] { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 49 | / if_unstable! { [INFO] [stdout] 50 | | then { [INFO] [stdout] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stdout] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stdout] ... | [INFO] [stdout] 84 | | } [INFO] [stdout] | |_____- in this macro invocation [INFO] [stdout] | [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling you-can v0.0.14 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 8.30s [INFO] running `Command { std: "docker" "inspect" "cf272b13df0b92278117cd98b62e3a3d5bd6e7aabd4bb9c90f2c55a8d07eff73", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "cf272b13df0b92278117cd98b62e3a3d5bd6e7aabd4bb9c90f2c55a8d07eff73", kill_on_drop: false }` [INFO] [stdout] cf272b13df0b92278117cd98b62e3a3d5bd6e7aabd4bb9c90f2c55a8d07eff73 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:f3a9d4ad9d972b27faf3965f35b62e55ba32bbce8f20bc8fe909558a86702fde" "/opt/rustwide/cargo-home/bin/cargo" "+9e136a30a965bf4e63f03095c57df7257bf96fd6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 45b12d32d6179292f3781221fc30527d925ffeb4d011e278263093ea8d5ffabd [INFO] running `Command { std: "docker" "start" "-a" "45b12d32d6179292f3781221fc30527d925ffeb4d011e278263093ea8d5ffabd", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.43 [INFO] [stderr] Compiling libc v0.2.131 [INFO] [stderr] Compiling cfg-if v1.0.0 [INFO] [stderr] Compiling serde_derive v1.0.143 [INFO] [stderr] Compiling serde v1.0.143 [INFO] [stderr] Compiling memchr v2.5.0 [INFO] [stderr] Compiling log v0.4.17 [INFO] [stderr] Compiling anyhow v1.0.61 [INFO] [stderr] Compiling serde_json v1.0.83 [INFO] [stderr] Compiling semver v1.0.13 [INFO] [stderr] Compiling itoa v1.0.3 [INFO] [stderr] Compiling unicode-width v0.1.9 [INFO] [stderr] Compiling ryu v1.0.11 [INFO] [stderr] Compiling fastrand v1.8.0 [INFO] [stderr] Compiling regex-syntax v0.6.27 [INFO] [stderr] Compiling compiletest_rs v0.8.0 [INFO] [stderr] Compiling remove_dir_all v0.5.3 [INFO] [stderr] Compiling getopts v0.2.21 [INFO] [stderr] Compiling lazy_static v1.4.0 [INFO] [stderr] Compiling diff v0.1.13 [INFO] [stderr] Compiling rustc_version v0.4.0 [INFO] [stderr] Compiling dirs-sys-next v0.1.2 [INFO] [stderr] Compiling num_cpus v1.13.1 [INFO] [stderr] Compiling tempfile v3.3.0 [INFO] [stderr] Compiling filetime v0.2.17 [INFO] [stderr] Compiling aho-corasick v0.7.18 [INFO] [stderr] Compiling quote v1.0.21 [INFO] [stderr] Compiling syn v1.0.99 [INFO] [stderr] Compiling dirs-next v2.0.0 [INFO] [stderr] Compiling term v0.7.0 [INFO] [stderr] Compiling tester v0.9.0 [INFO] [stderr] Compiling regex v1.6.0 [INFO] [stderr] Compiling you-can-build-macros v0.0.14 (/opt/rustwide/workdir/macros) [INFO] [stdout] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stdout] --> macros/lib.rs:2:13 [INFO] [stdout] | [INFO] [stdout] 2 | #![cfg_attr(rustc_is_unstable, feature(proc_macro_diagnostic, proc_macro_span))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: expected names are: `clippy`, `debug_assertions`, `doc`, `docsrs`, `doctest`, `feature`, `fmt_debug`, `miri`, `overflow_checks`, `panic`, `proc_macro`, `relocation_model`, `rustfmt`, `sanitize`, `sanitizer_cfi_generalize_pointers`, `sanitizer_cfi_normalize_integers`, `target_abi`, `target_arch`, `target_endian`, `target_env`, `target_family`, `target_feature`, `target_has_atomic`, `target_has_atomic_equal_alignment`, `target_has_atomic_load_store`, `target_os`, `target_pointer_width`, `target_thread_local`, `target_vendor`, `test`, `ub_checks`, `unix`, and `windows` [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: `#[warn(unexpected_cfgs)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stdout] --> macros/lib.rs:17:23 [INFO] [stdout] | [INFO] [stdout] 17 | #[cfg(not(rustc_is_unstable))] { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 49 | / if_unstable! { [INFO] [stdout] 50 | | then { [INFO] [stdout] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stdout] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stdout] ... | [INFO] [stdout] 84 | | } [INFO] [stdout] | |_____- in this macro invocation [INFO] [stdout] | [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stdout] --> macros/lib.rs:20:19 [INFO] [stdout] | [INFO] [stdout] 20 | #[cfg(rustc_is_unstable)] { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 49 | / if_unstable! { [INFO] [stdout] 50 | | then { [INFO] [stdout] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stdout] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stdout] ... | [INFO] [stdout] 84 | | } [INFO] [stdout] | |_____- in this macro invocation [INFO] [stdout] | [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stdout] --> macros/lib.rs:16:17 [INFO] [stdout] | [INFO] [stdout] 16 | if cfg!(rustc_is_unstable) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 49 | / if_unstable! { [INFO] [stdout] 50 | | then { [INFO] [stdout] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stdout] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stdout] ... | [INFO] [stdout] 84 | | } [INFO] [stdout] | |_____- in this macro invocation [INFO] [stdout] | [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stdout] --> macros/lib.rs:24:19 [INFO] [stdout] | [INFO] [stdout] 24 | #[cfg(rustc_is_unstable)] { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 49 | / if_unstable! { [INFO] [stdout] 50 | | then { [INFO] [stdout] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stdout] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stdout] ... | [INFO] [stdout] 84 | | } [INFO] [stdout] | |_____- in this macro invocation [INFO] [stdout] | [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling you-can v0.0.14 (/opt/rustwide/workdir) [INFO] [stderr] Compiling rustfix v0.6.1 [INFO] [stdout] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] --> examples/in_fn.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | #![you_can::turn_off_the_borrow_checker] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the borrow checker is suppressed for these references. [INFO] [stdout] --> examples/in_fn.rs:9:17 [INFO] [stdout] | [INFO] [stdout] 9 | let mut_1 = &mut owned[0]; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 10 | let mut_2 = &mut owned[1]; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] --> examples/in_mod.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | #![you_can::turn_off_the_borrow_checker] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the borrow checker is suppressed for these references. [INFO] [stdout] --> examples/in_mod.rs:10:21 [INFO] [stdout] | [INFO] [stdout] 10 | let mut_1 = &mut owned[0]; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 11 | let mut_2 = &mut owned[1]; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] --> examples/on_block.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the borrow checker is suppressed for these references. [INFO] [stdout] --> examples/on_block.rs:9:21 [INFO] [stdout] | [INFO] [stdout] 9 | let mut_1 = &mut owned[0]; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 10 | let mut_2 = &mut owned[1]; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] --> examples/on_statement.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] --> examples/on_statement.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] --> examples/on_fn.rs:1:1 [INFO] [stdout] | [INFO] [stdout] 1 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the borrow checker is suppressed for these references. [INFO] [stdout] --> examples/on_fn.rs:6:17 [INFO] [stdout] | [INFO] [stdout] 6 | let mut_1 = &mut owned[0]; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 7 | let mut_2 = &mut owned[1]; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] --> examples/on_mod.rs:1:1 [INFO] [stdout] | [INFO] [stdout] 1 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the borrow checker is suppressed for these references. [INFO] [stdout] --> examples/on_mod.rs:7:21 [INFO] [stdout] | [INFO] [stdout] 7 | let mut_1 = &mut owned[0]; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 8 | let mut_2 = &mut owned[1]; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 25.87s [INFO] running `Command { std: "docker" "inspect" "45b12d32d6179292f3781221fc30527d925ffeb4d011e278263093ea8d5ffabd", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "45b12d32d6179292f3781221fc30527d925ffeb4d011e278263093ea8d5ffabd", kill_on_drop: false }` [INFO] [stdout] 45b12d32d6179292f3781221fc30527d925ffeb4d011e278263093ea8d5ffabd [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:f3a9d4ad9d972b27faf3965f35b62e55ba32bbce8f20bc8fe909558a86702fde" "/opt/rustwide/cargo-home/bin/cargo" "+9e136a30a965bf4e63f03095c57df7257bf96fd6" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 7dd47b92bb918ef81b671b8acd54e32e60cd55e2cc566e2d58e1c123e3691a3d [INFO] running `Command { std: "docker" "start" "-a" "7dd47b92bb918ef81b671b8acd54e32e60cd55e2cc566e2d58e1c123e3691a3d", kill_on_drop: false }` [INFO] [stderr] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stderr] --> macros/lib.rs:2:13 [INFO] [stderr] | [INFO] [stderr] 2 | #![cfg_attr(rustc_is_unstable, feature(proc_macro_diagnostic, proc_macro_span))] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: expected names are: `clippy`, `debug_assertions`, `doc`, `docsrs`, `doctest`, `feature`, `fmt_debug`, `miri`, `overflow_checks`, `panic`, `proc_macro`, `relocation_model`, `rustfmt`, `sanitize`, `sanitizer_cfi_generalize_pointers`, `sanitizer_cfi_normalize_integers`, `target_abi`, `target_arch`, `target_endian`, `target_env`, `target_family`, `target_feature`, `target_has_atomic`, `target_has_atomic_equal_alignment`, `target_has_atomic_load_store`, `target_os`, `target_pointer_width`, `target_thread_local`, `target_vendor`, `test`, `ub_checks`, `unix`, and `windows` [INFO] [stderr] = help: consider using a Cargo feature instead [INFO] [stderr] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stderr] [lints.rust] [INFO] [stderr] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stderr] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] = note: `#[warn(unexpected_cfgs)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stderr] --> macros/lib.rs:17:23 [INFO] [stderr] | [INFO] [stderr] 17 | #[cfg(not(rustc_is_unstable))] { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 49 | / if_unstable! { [INFO] [stderr] 50 | | then { [INFO] [stderr] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stderr] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stderr] ... | [INFO] [stderr] 84 | | } [INFO] [stderr] | |_____- in this macro invocation [INFO] [stderr] | [INFO] [stderr] = help: consider using a Cargo feature instead [INFO] [stderr] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stderr] [lints.rust] [INFO] [stderr] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stderr] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stderr] --> macros/lib.rs:20:19 [INFO] [stderr] | [INFO] [stderr] 20 | #[cfg(rustc_is_unstable)] { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 49 | / if_unstable! { [INFO] [stderr] 50 | | then { [INFO] [stderr] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stderr] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stderr] ... | [INFO] [stderr] 84 | | } [INFO] [stderr] | |_____- in this macro invocation [INFO] [stderr] | [INFO] [stderr] = help: consider using a Cargo feature instead [INFO] [stderr] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stderr] [lints.rust] [INFO] [stderr] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stderr] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stderr] --> macros/lib.rs:16:17 [INFO] [stderr] | [INFO] [stderr] 16 | if cfg!(rustc_is_unstable) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 49 | / if_unstable! { [INFO] [stderr] 50 | | then { [INFO] [stderr] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stderr] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stderr] ... | [INFO] [stderr] 84 | | } [INFO] [stderr] | |_____- in this macro invocation [INFO] [stderr] | [INFO] [stderr] = help: consider using a Cargo feature instead [INFO] [stderr] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stderr] [lints.rust] [INFO] [stderr] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stderr] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition name: `rustc_is_unstable` [INFO] [stderr] --> macros/lib.rs:24:19 [INFO] [stderr] | [INFO] [stderr] 24 | #[cfg(rustc_is_unstable)] { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 49 | / if_unstable! { [INFO] [stderr] 50 | | then { [INFO] [stderr] 51 | | proc_macro::Diagnostic::spanned( [INFO] [stderr] 52 | | vec![Span::call_site().parent().unwrap_or_else(Span::call_site)], [INFO] [stderr] ... | [INFO] [stderr] 84 | | } [INFO] [stderr] | |_____- in this macro invocation [INFO] [stderr] | [INFO] [stderr] = help: consider using a Cargo feature instead [INFO] [stderr] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stderr] [lints.rust] [INFO] [stderr] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(rustc_is_unstable)'] } [INFO] [stderr] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(rustc_is_unstable)");` to the top of the `build.rs` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] = note: this warning originates in the macro `if_unstable` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] warning: `you-can-build-macros` (lib) generated 5 warnings [INFO] [stderr] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stderr] --> examples/in_fn.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | #![you_can::turn_off_the_borrow_checker] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: the borrow checker is suppressed for these references. [INFO] [stderr] --> examples/in_fn.rs:9:17 [INFO] [stderr] | [INFO] [stderr] 9 | let mut_1 = &mut owned[0]; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] 10 | let mut_2 = &mut owned[1]; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stderr] --> examples/in_mod.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | #![you_can::turn_off_the_borrow_checker] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: the borrow checker is suppressed for these references. [INFO] [stderr] --> examples/in_mod.rs:10:21 [INFO] [stderr] | [INFO] [stderr] 10 | let mut_1 = &mut owned[0]; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] 11 | let mut_2 = &mut owned[1]; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stderr] --> examples/on_mod.rs:1:1 [INFO] [stderr] | [INFO] [stderr] 1 | #[you_can::turn_off_the_borrow_checker] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: the borrow checker is suppressed for these references. [INFO] [stderr] --> examples/on_mod.rs:7:21 [INFO] [stderr] | [INFO] [stderr] 7 | let mut_1 = &mut owned[0]; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] 8 | let mut_2 = &mut owned[1]; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stderr] --> examples/on_block.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | #[you_can::turn_off_the_borrow_checker] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: the borrow checker is suppressed for these references. [INFO] [stderr] --> examples/on_block.rs:9:21 [INFO] [stderr] | [INFO] [stderr] 9 | let mut_1 = &mut owned[0]; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] 10 | let mut_2 = &mut owned[1]; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stderr] --> examples/on_statement.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | #[you_can::turn_off_the_borrow_checker] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stderr] --> examples/on_statement.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | #[you_can::turn_off_the_borrow_checker] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stderr] --> examples/on_fn.rs:1:1 [INFO] [stderr] | [INFO] [stderr] 1 | #[you_can::turn_off_the_borrow_checker] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: the borrow checker is suppressed for these references. [INFO] [stderr] --> examples/on_fn.rs:6:17 [INFO] [stderr] | [INFO] [stderr] 6 | let mut_1 = &mut owned[0]; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] 7 | let mut_2 = &mut owned[1]; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `you-can` (example "in_fn") generated 2 warnings [INFO] [stderr] warning: `you-can` (example "in_mod") generated 2 warnings [INFO] [stderr] warning: `you-can` (example "on_mod") generated 2 warnings [INFO] [stderr] warning: `you-can` (example "on_block") generated 2 warnings [INFO] [stderr] warning: `you-can` (example "on_statement") generated 2 warnings [INFO] [stderr] warning: `you-can` (example "on_fn") generated 2 warnings [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.11s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/you_can-d8875c494ebda8f9) [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stderr] Running tests/compile_tests.rs (/opt/rustwide/target/debug/deps/compile_tests-36d4f8bc52623eb0) [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 2 tests [INFO] [stdout] [INFO] [stdout] running 1 test [INFO] [stdout] [INFO] [stdout] running 7 tests [INFO] [stdout] test [ui] unstable-pass/in_mod.rs ... FAILED [INFO] [stdout] test [ui] unstable-pass/on_fn_empty.rs ... FAILED [INFO] [stdout] test [ui] unstable-pass/on_statement.rs ... FAILED [INFO] [stdout] test [ui] unstable-pass/on_mod.rs ... FAILED [INFO] [stdout] test [ui] unstable-pass/on_block.rs ... FAILED [INFO] [stdout] test [ui] unstable-pass/on_fn.rs ... FAILED [INFO] [stdout] test [ui] unstable-pass/in_fn.rs ... FAILED [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [ui] unstable-pass/in_fn.rs [INFO] [stdout] [ui] unstable-pass/in_mod.rs [INFO] [stdout] [ui] unstable-pass/on_block.rs [INFO] [stdout] [ui] unstable-pass/on_fn.rs [INFO] [stdout] [ui] unstable-pass/on_fn_empty.rs [INFO] [stdout] [ui] unstable-pass/on_mod.rs [INFO] [stdout] [ui] unstable-pass/on_statement.rs [INFO] [stdout] [INFO] [stdout] test result: FAILED. 0 passed; 7 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.19s [INFO] [stdout] [INFO] [stdout] test [compile-fail] unstable-fail/not_on_fn.rs ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.20s [INFO] [stdout] [INFO] [stdout] test compile_fail ... ok [INFO] [stdout] test run_pass ... FAILED [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- run_pass stdout ---- [INFO] [stdout] diff of stderr: [INFO] [stdout] [INFO] [stdout] -warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] - --> $DIR/in_mod.rs:4:5 [INFO] [stdout] +error[E0464]: multiple candidates for `rlib` dependency `you_can` found [INFO] [stdout] + --> $DIR/in_mod.rs:4:8 [INFO] [stdout] | [INFO] [stdout] 4 | #![you_can::turn_off_the_borrow_checker] [INFO] [stdout] - | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] + | ^^^^^^^ [INFO] [stdout] + | [INFO] [stdout] + = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib [INFO] [stdout] + = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib [INFO] [stdout] [INFO] [stdout] -warning: the borrow checker is suppressed for these references. [INFO] [stdout] - --> $DIR/in_mod.rs:10:21 [INFO] [stdout] +error[E0499]: cannot borrow `owned` as mutable more than once at a time [INFO] [stdout] + --> $DIR/in_mod.rs:11:26 [INFO] [stdout] | [INFO] [stdout] 10 | let mut_1 = &mut owned[0]; [INFO] [stdout] - | ^^^^^^^^^^^^^ [INFO] [stdout] + | ----- first mutable borrow occurs here [INFO] [stdout] 11 | let mut_2 = &mut owned[1]; [INFO] [stdout] - | ^^^^^^^^^^^^^ [INFO] [stdout] + | ^^^^^ second mutable borrow occurs here [INFO] [stdout] +... [INFO] [stdout] +15 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ first borrow later used here [INFO] [stdout] + | [INFO] [stdout] + = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices [INFO] [stdout] [INFO] [stdout] -warning: 2 warnings emitted [INFO] [stdout] +error[E0505]: cannot move out of `owned` because it is borrowed [INFO] [stdout] + --> $DIR/in_mod.rs:14:14 [INFO] [stdout] + | [INFO] [stdout] +7 | let mut owned = vec![1, 32]; [INFO] [stdout] + | --------- binding `owned` declared here [INFO] [stdout] +... [INFO] [stdout] +10 | let mut_1 = &mut owned[0]; [INFO] [stdout] + | ----- borrow of `owned` occurs here [INFO] [stdout] +... [INFO] [stdout] +14 | drop(owned); [INFO] [stdout] + | ^^^^^ move out of `owned` occurs here [INFO] [stdout] +15 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ borrow later used here [INFO] [stdout] + | [INFO] [stdout] +help: consider cloning the value if the performance cost is acceptable [INFO] [stdout] + | [INFO] [stdout] +10 | let mut_1 = &mut owned.clone()[0]; [INFO] [stdout] + | ++++++++ [INFO] [stdout] [INFO] [stdout] +error: aborting due to 3 previous errors [INFO] [stdout] + [INFO] [stdout] +Some errors have detailed explanations: E0464, E0499, E0505. [INFO] [stdout] +For more information about an error, try `rustc --explain E0464`. [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] The actual stderr differed from the expected stderr. [INFO] [stdout] Actual stderr saved to /tmp/in_mod.stage-id.stderr [INFO] [stdout] To update references, rerun the tests and pass the `--bless` flag [INFO] [stdout] To only update this specific test, also pass `--test-args in_mod.rs` [INFO] [stdout] [INFO] [stdout] error: 1 errors occurred comparing output. [INFO] [stdout] status: exit status: 1 [INFO] [stdout] command: "rustc" "tests/unstable-pass/in_mod.rs" "-L" "/tmp" "--target=x86_64-unknown-linux-gnu" "--error-format" "json" "-C" "prefer-dynamic" "-o" "/tmp/in_mod.stage-id" "-A" "unused" "--extern" "you_can" "--extern" "unbounded" "-L" "target/debug/deps" "-L" "/opt/rustwide/target/debug/deps" "-L" "/opt/rustwide/target/debug" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib" "--edition=2021" "-L" "/tmp/in_mod.stage-id.aux" [INFO] [stdout] stdout: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] stderr: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] {"$message_type":"diagnostic","message":"multiple candidates for `rlib` dependency `you_can` found","code":{"code":"E0464","explanation":"The compiler found multiple library files with the requested crate name.\n\n```compile_fail\n// aux-build:crateresolve-1.rs\n// aux-build:crateresolve-2.rs\n// aux-build:crateresolve-3.rs\n\nextern crate crateresolve;\n//~^ ERROR multiple candidates for `rlib` dependency `crateresolve` found\n\nfn main() {}\n```\n\nThis error can occur in several different cases -- for example, when using\n`extern crate` or passing `--extern` options without crate paths. It can also be\ncaused by caching issues with the build directory, in which case `cargo clean`\nmay help.\n\nIn the above example, there are three different library files, all of which\ndefine the same crate name. Without providing a full path, there is no way for\nthe compiler to know which crate it should use.\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/in_mod.rs","byte_start":57,"byte_end":64,"line_start":4,"line_end":4,"column_start":8,"column_end":15,"is_primary":true,"text":[{"text":" #![you_can::turn_off_the_borrow_checker]","highlight_start":8,"highlight_end":15}],"label":null,"suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null},{"message":"candidate #2: /opt/rustwide/target/debug/libyou_can.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null}],"rendered":"error[E0464]: multiple candidates for `rlib` dependency `you_can` found\n --> tests/unstable-pass/in_mod.rs:4:8\n |\n4 | #![you_can::turn_off_the_borrow_checker]\n | ^^^^^^^\n |\n = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib\n = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot borrow `owned` as mutable more than once at a time","code":{"code":"E0499","explanation":"A variable was borrowed as mutable more than once.\n\nErroneous code example:\n\n```compile_fail,E0499\nlet mut i = 0;\nlet mut x = &mut i;\nlet mut a = &mut i;\nx;\n// error: cannot borrow `i` as mutable more than once at a time\n```\n\nPlease note that in Rust, you can either have many immutable references, or one\nmutable reference. For more details you may want to read the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n\nExample:\n\n```\nlet mut i = 0;\nlet mut x = &mut i; // ok!\n\n// or:\nlet mut i = 0;\nlet a = &i; // ok!\nlet b = &i; // still ok!\nlet c = &i; // still ok!\nb;\na;\n```\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/in_mod.rs","byte_start":215,"byte_end":220,"line_start":10,"line_end":10,"column_start":26,"column_end":31,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":26,"highlight_end":31}],"label":"first mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/in_mod.rs","byte_start":250,"byte_end":255,"line_start":11,"line_end":11,"column_start":26,"column_end":31,"is_primary":true,"text":[{"text":" let mut_2 = &mut owned[1];","highlight_start":26,"highlight_end":31}],"label":"second mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/in_mod.rs","byte_start":332,"byte_end":338,"line_start":15,"line_end":15,"column_start":25,"column_end":31,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":25,"highlight_end":31}],"label":"first borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices","code":null,"level":"help","spans":[],"children":[],"rendered":null}],"rendered":"error[E0499]: cannot borrow `owned` as mutable more than once at a time\n --> tests/unstable-pass/in_mod.rs:11:26\n |\n10 | let mut_1 = &mut owned[0];\n | ----- first mutable borrow occurs here\n11 | let mut_2 = &mut owned[1];\n | ^^^^^ second mutable borrow occurs here\n...\n15 | let undefined = *mut_1 + *mut_2;\n | ------ first borrow later used here\n |\n = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot move out of `owned` because it is borrowed","code":{"code":"E0505","explanation":"A value was moved out while it was still borrowed.\n\nErroneous code example:\n\n```compile_fail,E0505\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let _ref_to_val: &Value = &x;\n eat(x);\n borrow(_ref_to_val);\n}\n```\n\nHere, the function `eat` takes ownership of `x`. However,\n`x` cannot be moved because the borrow to `_ref_to_val`\nneeds to last till the function `borrow`.\nTo fix that you can do a few different things:\n\n* Try to avoid moving the variable.\n* Release borrow before move.\n* Implement the `Copy` trait on the type.\n\nExamples:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: &Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n eat(&x); // pass by reference, if it's possible\n borrow(ref_to_val);\n}\n```\n\nOr:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n borrow(ref_to_val);\n // ref_to_val is no longer used.\n eat(x);\n}\n```\n\nOr:\n\n```\n#[derive(Clone, Copy)] // implement Copy trait\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let ref_to_val: &Value = &x;\n eat(x); // it will be copied here.\n borrow(ref_to_val);\n}\n```\n\nFor more information on Rust's ownership system, take a look at the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/in_mod.rs","byte_start":300,"byte_end":305,"line_start":14,"line_end":14,"column_start":14,"column_end":19,"is_primary":true,"text":[{"text":" drop(owned);","highlight_start":14,"highlight_end":19}],"label":"move out of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/in_mod.rs","byte_start":215,"byte_end":220,"line_start":10,"line_end":10,"column_start":26,"column_end":31,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":26,"highlight_end":31}],"label":"borrow of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/in_mod.rs","byte_start":128,"byte_end":137,"line_start":7,"line_end":7,"column_start":13,"column_end":22,"is_primary":false,"text":[{"text":" let mut owned = vec![1, 32];","highlight_start":13,"highlight_end":22}],"label":"binding `owned` declared here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/in_mod.rs","byte_start":332,"byte_end":338,"line_start":15,"line_end":15,"column_start":25,"column_end":31,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":25,"highlight_end":31}],"label":"borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"consider cloning the value if the performance cost is acceptable","code":null,"level":"help","spans":[{"file_name":"tests/unstable-pass/in_mod.rs","byte_start":220,"byte_end":220,"line_start":10,"line_end":10,"column_start":31,"column_end":31,"is_primary":true,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":31,"highlight_end":31}],"label":null,"suggested_replacement":".clone()","suggestion_applicability":"MachineApplicable","expansion":null}],"children":[],"rendered":null}],"rendered":"error[E0505]: cannot move out of `owned` because it is borrowed\n --> tests/unstable-pass/in_mod.rs:14:14\n |\n7 | let mut owned = vec![1, 32];\n | --------- binding `owned` declared here\n...\n10 | let mut_1 = &mut owned[0];\n | ----- borrow of `owned` occurs here\n...\n14 | drop(owned);\n | ^^^^^ move out of `owned` occurs here\n15 | let undefined = *mut_1 + *mut_2;\n | ------ borrow later used here\n |\nhelp: consider cloning the value if the performance cost is acceptable\n |\n10 | let mut_1 = &mut owned.clone()[0];\n | ++++++++\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"aborting due to 3 previous errors","code":null,"level":"error","spans":[],"children":[],"rendered":"error: aborting due to 3 previous errors\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"Some errors have detailed explanations: E0464, E0499, E0505.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"Some errors have detailed explanations: E0464, E0499, E0505.\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"For more information about an error, try `rustc --explain E0464`.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"For more information about an error, try `rustc --explain E0464`.\n"} [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] diff of stderr: [INFO] [stdout] [INFO] [stdout] -warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] - --> $DIR/on_fn_empty.rs:1:1 [INFO] [stdout] +error[E0464]: multiple candidates for `rlib` dependency `you_can` found [INFO] [stdout] + --> $DIR/on_fn_empty.rs:1:3 [INFO] [stdout] | [INFO] [stdout] 1 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] - | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] + | ^^^^^^^ [INFO] [stdout] + | [INFO] [stdout] + = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib [INFO] [stdout] + = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib [INFO] [stdout] [INFO] [stdout] -warning: 1 warning emitted [INFO] [stdout] +error: aborting due to 1 previous error [INFO] [stdout] [INFO] [stdout] +For more information about this error, try `rustc --explain E0464`. [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] The actual stderr differed from the expected stderr. [INFO] [stdout] Actual stderr saved to /tmp/on_fn_empty.stage-id.stderr [INFO] [stdout] To update references, rerun the tests and pass the `--bless` flag [INFO] [stdout] To only update this specific test, also pass `--test-args on_fn_empty.rs` [INFO] [stdout] [INFO] [stdout] error: 1 errors occurred comparing output. [INFO] [stdout] status: exit status: 1 [INFO] [stdout] command: "rustc" "tests/unstable-pass/on_fn_empty.rs" "-L" "/tmp" "--target=x86_64-unknown-linux-gnu" "--error-format" "json" "-C" "prefer-dynamic" "-o" "/tmp/on_fn_empty.stage-id" "-A" "unused" "--extern" "you_can" "--extern" "unbounded" "-L" "target/debug/deps" "-L" "/opt/rustwide/target/debug/deps" "-L" "/opt/rustwide/target/debug" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib" "--edition=2021" "-L" "/tmp/on_fn_empty.stage-id.aux" [INFO] [stdout] stdout: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] stderr: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] {"$message_type":"diagnostic","message":"multiple candidates for `rlib` dependency `you_can` found","code":{"code":"E0464","explanation":"The compiler found multiple library files with the requested crate name.\n\n```compile_fail\n// aux-build:crateresolve-1.rs\n// aux-build:crateresolve-2.rs\n// aux-build:crateresolve-3.rs\n\nextern crate crateresolve;\n//~^ ERROR multiple candidates for `rlib` dependency `crateresolve` found\n\nfn main() {}\n```\n\nThis error can occur in several different cases -- for example, when using\n`extern crate` or passing `--extern` options without crate paths. It can also be\ncaused by caching issues with the build directory, in which case `cargo clean`\nmay help.\n\nIn the above example, there are three different library files, all of which\ndefine the same crate name. Without providing a full path, there is no way for\nthe compiler to know which crate it should use.\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_fn_empty.rs","byte_start":2,"byte_end":9,"line_start":1,"line_end":1,"column_start":3,"column_end":10,"is_primary":true,"text":[{"text":"#[you_can::turn_off_the_borrow_checker]","highlight_start":3,"highlight_end":10}],"label":null,"suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null},{"message":"candidate #2: /opt/rustwide/target/debug/libyou_can.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null}],"rendered":"error[E0464]: multiple candidates for `rlib` dependency `you_can` found\n --> tests/unstable-pass/on_fn_empty.rs:1:3\n |\n1 | #[you_can::turn_off_the_borrow_checker]\n | ^^^^^^^\n |\n = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib\n = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"aborting due to 1 previous error","code":null,"level":"error","spans":[],"children":[],"rendered":"error: aborting due to 1 previous error\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"For more information about this error, try `rustc --explain E0464`.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"For more information about this error, try `rustc --explain E0464`.\n"} [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] diff of stderr: [INFO] [stdout] [INFO] [stdout] -warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] - --> $DIR/on_statement.rs:6:5 [INFO] [stdout] +error[E0464]: multiple candidates for `rlib` dependency `you_can` found [INFO] [stdout] + --> $DIR/on_statement.rs:6:7 [INFO] [stdout] | [INFO] [stdout] 6 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] - | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] + | ^^^^^^^ [INFO] [stdout] + | [INFO] [stdout] + = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib [INFO] [stdout] + = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib [INFO] [stdout] [INFO] [stdout] -warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] - --> $DIR/on_statement.rs:8:5 [INFO] [stdout] +error[E0464]: multiple candidates for `rlib` dependency `you_can` found [INFO] [stdout] + --> $DIR/on_statement.rs:8:7 [INFO] [stdout] | [INFO] [stdout] 8 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] - | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] + | ^^^^^^^ [INFO] [stdout] + | [INFO] [stdout] + = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib [INFO] [stdout] + = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib [INFO] [stdout] [INFO] [stdout] -warning: 2 warnings emitted [INFO] [stdout] +error[E0499]: cannot borrow `owned` as mutable more than once at a time [INFO] [stdout] + --> $DIR/on_statement.rs:9:22 [INFO] [stdout] + | [INFO] [stdout] +7 | let mut_1 = &mut owned[0]; [INFO] [stdout] + | ----- first mutable borrow occurs here [INFO] [stdout] +8 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] +9 | let mut_2 = &mut owned[1]; [INFO] [stdout] + | ^^^^^ second mutable borrow occurs here [INFO] [stdout] +... [INFO] [stdout] +13 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ first borrow later used here [INFO] [stdout] + | [INFO] [stdout] + = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices [INFO] [stdout] [INFO] [stdout] +error[E0505]: cannot move out of `owned` because it is borrowed [INFO] [stdout] + --> $DIR/on_statement.rs:12:10 [INFO] [stdout] + | [INFO] [stdout] +4 | let mut owned = vec![1, 32]; [INFO] [stdout] + | --------- binding `owned` declared here [INFO] [stdout] +... [INFO] [stdout] +7 | let mut_1 = &mut owned[0]; [INFO] [stdout] + | ----- borrow of `owned` occurs here [INFO] [stdout] +... [INFO] [stdout] +12 | drop(owned); [INFO] [stdout] + | ^^^^^ move out of `owned` occurs here [INFO] [stdout] +13 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ borrow later used here [INFO] [stdout] + | [INFO] [stdout] +help: consider cloning the value if the performance cost is acceptable [INFO] [stdout] + | [INFO] [stdout] +7 | let mut_1 = &mut owned.clone()[0]; [INFO] [stdout] + | ++++++++ [INFO] [stdout] + [INFO] [stdout] +error: aborting due to 4 previous errors [INFO] [stdout] + [INFO] [stdout] +Some errors have detailed explanations: E0464, E0499, E0505. [INFO] [stdout] +For more information about an error, try `rustc --explain E0464`. [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] The actual stderr differed from the expected stderr. [INFO] [stdout] Actual stderr saved to /tmp/on_statement.stage-id.stderr [INFO] [stdout] To update references, rerun the tests and pass the `--bless` flag [INFO] [stdout] To only update this specific test, also pass `--test-args on_statement.rs` [INFO] [stdout] [INFO] [stdout] error: 1 errors occurred comparing output. [INFO] [stdout] status: exit status: 1 [INFO] [stdout] command: "rustc" "tests/unstable-pass/on_statement.rs" "-L" "/tmp" "--target=x86_64-unknown-linux-gnu" "--error-format" "json" "-C" "prefer-dynamic" "-o" "/tmp/on_statement.stage-id" "-A" "unused" "--extern" "you_can" "--extern" "unbounded" "-L" "target/debug/deps" "-L" "/opt/rustwide/target/debug/deps" "-L" "/opt/rustwide/target/debug" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib" "--edition=2021" "-L" "/tmp/on_statement.stage-id.aux" [INFO] [stdout] stdout: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] stderr: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] {"$message_type":"diagnostic","message":"multiple candidates for `rlib` dependency `you_can` found","code":{"code":"E0464","explanation":"The compiler found multiple library files with the requested crate name.\n\n```compile_fail\n// aux-build:crateresolve-1.rs\n// aux-build:crateresolve-2.rs\n// aux-build:crateresolve-3.rs\n\nextern crate crateresolve;\n//~^ ERROR multiple candidates for `rlib` dependency `crateresolve` found\n\nfn main() {}\n```\n\nThis error can occur in several different cases -- for example, when using\n`extern crate` or passing `--extern` options without crate paths. It can also be\ncaused by caching issues with the build directory, in which case `cargo clean`\nmay help.\n\nIn the above example, there are three different library files, all of which\ndefine the same crate name. Without providing a full path, there is no way for\nthe compiler to know which crate it should use.\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_statement.rs","byte_start":142,"byte_end":149,"line_start":6,"line_end":6,"column_start":7,"column_end":14,"is_primary":true,"text":[{"text":" #[you_can::turn_off_the_borrow_checker]","highlight_start":7,"highlight_end":14}],"label":null,"suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null},{"message":"candidate #2: /opt/rustwide/target/debug/libyou_can.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null}],"rendered":"error[E0464]: multiple candidates for `rlib` dependency `you_can` found\n --> tests/unstable-pass/on_statement.rs:6:7\n |\n6 | #[you_can::turn_off_the_borrow_checker]\n | ^^^^^^^\n |\n = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib\n = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"multiple candidates for `rlib` dependency `you_can` found","code":{"code":"E0464","explanation":"The compiler found multiple library files with the requested crate name.\n\n```compile_fail\n// aux-build:crateresolve-1.rs\n// aux-build:crateresolve-2.rs\n// aux-build:crateresolve-3.rs\n\nextern crate crateresolve;\n//~^ ERROR multiple candidates for `rlib` dependency `crateresolve` found\n\nfn main() {}\n```\n\nThis error can occur in several different cases -- for example, when using\n`extern crate` or passing `--extern` options without crate paths. It can also be\ncaused by caching issues with the build directory, in which case `cargo clean`\nmay help.\n\nIn the above example, there are three different library files, all of which\ndefine the same crate name. Without providing a full path, there is no way for\nthe compiler to know which crate it should use.\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_statement.rs","byte_start":217,"byte_end":224,"line_start":8,"line_end":8,"column_start":7,"column_end":14,"is_primary":true,"text":[{"text":" #[you_can::turn_off_the_borrow_checker]","highlight_start":7,"highlight_end":14}],"label":null,"suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null},{"message":"candidate #2: /opt/rustwide/target/debug/libyou_can.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null}],"rendered":"error[E0464]: multiple candidates for `rlib` dependency `you_can` found\n --> tests/unstable-pass/on_statement.rs:8:7\n |\n8 | #[you_can::turn_off_the_borrow_checker]\n | ^^^^^^^\n |\n = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib\n = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot borrow `owned` as mutable more than once at a time","code":{"code":"E0499","explanation":"A variable was borrowed as mutable more than once.\n\nErroneous code example:\n\n```compile_fail,E0499\nlet mut i = 0;\nlet mut x = &mut i;\nlet mut a = &mut i;\nx;\n// error: cannot borrow `i` as mutable more than once at a time\n```\n\nPlease note that in Rust, you can either have many immutable references, or one\nmutable reference. For more details you may want to read the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n\nExample:\n\n```\nlet mut i = 0;\nlet mut x = &mut i; // ok!\n\n// or:\nlet mut i = 0;\nlet a = &i; // ok!\nlet b = &i; // still ok!\nlet c = &i; // still ok!\nb;\na;\n```\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_statement.rs","byte_start":201,"byte_end":206,"line_start":7,"line_end":7,"column_start":22,"column_end":27,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":22,"highlight_end":27}],"label":"first mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_statement.rs","byte_start":276,"byte_end":281,"line_start":9,"line_end":9,"column_start":22,"column_end":27,"is_primary":true,"text":[{"text":" let mut_2 = &mut owned[1];","highlight_start":22,"highlight_end":27}],"label":"second mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_statement.rs","byte_start":346,"byte_end":352,"line_start":13,"line_end":13,"column_start":21,"column_end":27,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":21,"highlight_end":27}],"label":"first borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices","code":null,"level":"help","spans":[],"children":[],"rendered":null}],"rendered":"error[E0499]: cannot borrow `owned` as mutable more than once at a time\n --> tests/unstable-pass/on_statement.rs:9:22\n |\n7 | let mut_1 = &mut owned[0];\n | ----- first mutable borrow occurs here\n8 | #[you_can::turn_off_the_borrow_checker]\n9 | let mut_2 = &mut owned[1];\n | ^^^^^ second mutable borrow occurs here\n...\n13 | let undefined = *mut_1 + *mut_2;\n | ------ first borrow later used here\n |\n = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot move out of `owned` because it is borrowed","code":{"code":"E0505","explanation":"A value was moved out while it was still borrowed.\n\nErroneous code example:\n\n```compile_fail,E0505\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let _ref_to_val: &Value = &x;\n eat(x);\n borrow(_ref_to_val);\n}\n```\n\nHere, the function `eat` takes ownership of `x`. However,\n`x` cannot be moved because the borrow to `_ref_to_val`\nneeds to last till the function `borrow`.\nTo fix that you can do a few different things:\n\n* Try to avoid moving the variable.\n* Release borrow before move.\n* Implement the `Copy` trait on the type.\n\nExamples:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: &Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n eat(&x); // pass by reference, if it's possible\n borrow(ref_to_val);\n}\n```\n\nOr:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n borrow(ref_to_val);\n // ref_to_val is no longer used.\n eat(x);\n}\n```\n\nOr:\n\n```\n#[derive(Clone, Copy)] // implement Copy trait\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let ref_to_val: &Value = &x;\n eat(x); // it will be copied here.\n borrow(ref_to_val);\n}\n```\n\nFor more information on Rust's ownership system, take a look at the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_statement.rs","byte_start":318,"byte_end":323,"line_start":12,"line_end":12,"column_start":10,"column_end":15,"is_primary":true,"text":[{"text":" drop(owned);","highlight_start":10,"highlight_end":15}],"label":"move out of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_statement.rs","byte_start":201,"byte_end":206,"line_start":7,"line_end":7,"column_start":22,"column_end":27,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":22,"highlight_end":27}],"label":"borrow of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_statement.rs","byte_start":79,"byte_end":88,"line_start":4,"line_end":4,"column_start":9,"column_end":18,"is_primary":false,"text":[{"text":" let mut owned = vec![1, 32];","highlight_start":9,"highlight_end":18}],"label":"binding `owned` declared here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_statement.rs","byte_start":346,"byte_end":352,"line_start":13,"line_end":13,"column_start":21,"column_end":27,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":21,"highlight_end":27}],"label":"borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"consider cloning the value if the performance cost is acceptable","code":null,"level":"help","spans":[{"file_name":"tests/unstable-pass/on_statement.rs","byte_start":206,"byte_end":206,"line_start":7,"line_end":7,"column_start":27,"column_end":27,"is_primary":true,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":27,"highlight_end":27}],"label":null,"suggested_replacement":".clone()","suggestion_applicability":"MachineApplicable","expansion":null}],"children":[],"rendered":null}],"rendered":"error[E0505]: cannot move out of `owned` because it is borrowed\n --> tests/unstable-pass/on_statement.rs:12:10\n |\n4 | let mut owned = vec![1, 32];\n | --------- binding `owned` declared here\n...\n7 | let mut_1 = &mut owned[0];\n | ----- borrow of `owned` occurs here\n...\n12 | drop(owned);\n | ^^^^^ move out of `owned` occurs here\n13 | let undefined = *mut_1 + *mut_2;\n | ------ borrow later used here\n |\nhelp: consider cloning the value if the performance cost is acceptable\n |\n7 | let mut_1 = &mut owned.clone()[0];\n | ++++++++\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"aborting due to 4 previous errors","code":null,"level":"error","spans":[],"children":[],"rendered":"error: aborting due to 4 previous errors\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"Some errors have detailed explanations: E0464, E0499, E0505.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"Some errors have detailed explanations: E0464, E0499, E0505.\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"For more information about an error, try `rustc --explain E0464`.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"For more information about an error, try `rustc --explain E0464`.\n"} [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] diff of stderr: [INFO] [stdout] [INFO] [stdout] -warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] - --> $DIR/on_mod.rs:1:1 [INFO] [stdout] +error[E0464]: multiple candidates for `rlib` dependency `you_can` found [INFO] [stdout] + --> $DIR/on_mod.rs:1:3 [INFO] [stdout] | [INFO] [stdout] 1 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] - | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] - [INFO] [stdout] -warning: the borrow checker is suppressed for these references. [INFO] [stdout] - --> $DIR/on_mod.rs:7:21 [INFO] [stdout] + | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] -7 | let mut_1 = &mut owned[0]; [INFO] [stdout] - | ^^^^^^^^^^^^^ [INFO] [stdout] -8 | let mut_2 = &mut owned[1]; [INFO] [stdout] - | ^^^^^^^^^^^^^ [INFO] [stdout] + = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib [INFO] [stdout] + = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib [INFO] [stdout] [INFO] [stdout] -warning: 2 warnings emitted [INFO] [stdout] +error[E0499]: cannot borrow `owned` as mutable more than once at a time [INFO] [stdout] + --> $DIR/on_mod.rs:8:26 [INFO] [stdout] + | [INFO] [stdout] +7 | let mut_1 = &mut owned[0]; [INFO] [stdout] + | ----- first mutable borrow occurs here [INFO] [stdout] +8 | let mut_2 = &mut owned[1]; [INFO] [stdout] + | ^^^^^ second mutable borrow occurs here [INFO] [stdout] +... [INFO] [stdout] +12 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ first borrow later used here [INFO] [stdout] + | [INFO] [stdout] + = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices [INFO] [stdout] [INFO] [stdout] +error[E0505]: cannot move out of `owned` because it is borrowed [INFO] [stdout] + --> $DIR/on_mod.rs:11:14 [INFO] [stdout] + | [INFO] [stdout] +4 | let mut owned = vec![1, 32]; [INFO] [stdout] + | --------- binding `owned` declared here [INFO] [stdout] +... [INFO] [stdout] +7 | let mut_1 = &mut owned[0]; [INFO] [stdout] + | ----- borrow of `owned` occurs here [INFO] [stdout] +... [INFO] [stdout] +11 | drop(owned); [INFO] [stdout] + | ^^^^^ move out of `owned` occurs here [INFO] [stdout] +12 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ borrow later used here [INFO] [stdout] + | [INFO] [stdout] +help: consider cloning the value if the performance cost is acceptable [INFO] [stdout] + | [INFO] [stdout] +7 | let mut_1 = &mut owned.clone()[0]; [INFO] [stdout] + | ++++++++ [INFO] [stdout] + [INFO] [stdout] +error: aborting due to 3 previous errors [INFO] [stdout] + [INFO] [stdout] +Some errors have detailed explanations: E0464, E0499, E0505. [INFO] [stdout] +For more information about an error, try `rustc --explain E0464`. [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] The actual stderr differed from the expected stderr. [INFO] [stdout] Actual stderr saved to /tmp/on_mod.stage-id.stderr [INFO] [stdout] To update references, rerun the tests and pass the `--bless` flag [INFO] [stdout] To only update this specific test, also pass `--test-args on_mod.rs` [INFO] [stdout] [INFO] [stdout] error: 1 errors occurred comparing output. [INFO] [stdout] status: exit status: 1 [INFO] [stdout] command: "rustc" "tests/unstable-pass/on_mod.rs" "-L" "/tmp" "--target=x86_64-unknown-linux-gnu" "--error-format" "json" "-C" "prefer-dynamic" "-o" "/tmp/on_mod.stage-id" "-A" "unused" "--extern" "you_can" "--extern" "unbounded" "-L" "target/debug/deps" "-L" "/opt/rustwide/target/debug/deps" "-L" "/opt/rustwide/target/debug" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib" "--edition=2021" "-L" "/tmp/on_mod.stage-id.aux" [INFO] [stdout] stdout: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] stderr: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] {"$message_type":"diagnostic","message":"multiple candidates for `rlib` dependency `you_can` found","code":{"code":"E0464","explanation":"The compiler found multiple library files with the requested crate name.\n\n```compile_fail\n// aux-build:crateresolve-1.rs\n// aux-build:crateresolve-2.rs\n// aux-build:crateresolve-3.rs\n\nextern crate crateresolve;\n//~^ ERROR multiple candidates for `rlib` dependency `crateresolve` found\n\nfn main() {}\n```\n\nThis error can occur in several different cases -- for example, when using\n`extern crate` or passing `--extern` options without crate paths. It can also be\ncaused by caching issues with the build directory, in which case `cargo clean`\nmay help.\n\nIn the above example, there are three different library files, all of which\ndefine the same crate name. Without providing a full path, there is no way for\nthe compiler to know which crate it should use.\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_mod.rs","byte_start":2,"byte_end":9,"line_start":1,"line_end":1,"column_start":3,"column_end":10,"is_primary":true,"text":[{"text":"#[you_can::turn_off_the_borrow_checker]","highlight_start":3,"highlight_end":10}],"label":null,"suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null},{"message":"candidate #2: /opt/rustwide/target/debug/libyou_can.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null}],"rendered":"error[E0464]: multiple candidates for `rlib` dependency `you_can` found\n --> tests/unstable-pass/on_mod.rs:1:3\n |\n1 | #[you_can::turn_off_the_borrow_checker]\n | ^^^^^^^\n |\n = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib\n = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot borrow `owned` as mutable more than once at a time","code":{"code":"E0499","explanation":"A variable was borrowed as mutable more than once.\n\nErroneous code example:\n\n```compile_fail,E0499\nlet mut i = 0;\nlet mut x = &mut i;\nlet mut a = &mut i;\nx;\n// error: cannot borrow `i` as mutable more than once at a time\n```\n\nPlease note that in Rust, you can either have many immutable references, or one\nmutable reference. For more details you may want to read the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n\nExample:\n\n```\nlet mut i = 0;\nlet mut x = &mut i; // ok!\n\n// or:\nlet mut i = 0;\nlet a = &i; // ok!\nlet b = &i; // still ok!\nlet c = &i; // still ok!\nb;\na;\n```\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_mod.rs","byte_start":171,"byte_end":176,"line_start":7,"line_end":7,"column_start":26,"column_end":31,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":26,"highlight_end":31}],"label":"first mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_mod.rs","byte_start":206,"byte_end":211,"line_start":8,"line_end":8,"column_start":26,"column_end":31,"is_primary":true,"text":[{"text":" let mut_2 = &mut owned[1];","highlight_start":26,"highlight_end":31}],"label":"second mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_mod.rs","byte_start":288,"byte_end":294,"line_start":12,"line_end":12,"column_start":25,"column_end":31,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":25,"highlight_end":31}],"label":"first borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices","code":null,"level":"help","spans":[],"children":[],"rendered":null}],"rendered":"error[E0499]: cannot borrow `owned` as mutable more than once at a time\n --> tests/unstable-pass/on_mod.rs:8:26\n |\n7 | let mut_1 = &mut owned[0];\n | ----- first mutable borrow occurs here\n8 | let mut_2 = &mut owned[1];\n | ^^^^^ second mutable borrow occurs here\n...\n12 | let undefined = *mut_1 + *mut_2;\n | ------ first borrow later used here\n |\n = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot move out of `owned` because it is borrowed","code":{"code":"E0505","explanation":"A value was moved out while it was still borrowed.\n\nErroneous code example:\n\n```compile_fail,E0505\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let _ref_to_val: &Value = &x;\n eat(x);\n borrow(_ref_to_val);\n}\n```\n\nHere, the function `eat` takes ownership of `x`. However,\n`x` cannot be moved because the borrow to `_ref_to_val`\nneeds to last till the function `borrow`.\nTo fix that you can do a few different things:\n\n* Try to avoid moving the variable.\n* Release borrow before move.\n* Implement the `Copy` trait on the type.\n\nExamples:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: &Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n eat(&x); // pass by reference, if it's possible\n borrow(ref_to_val);\n}\n```\n\nOr:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n borrow(ref_to_val);\n // ref_to_val is no longer used.\n eat(x);\n}\n```\n\nOr:\n\n```\n#[derive(Clone, Copy)] // implement Copy trait\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let ref_to_val: &Value = &x;\n eat(x); // it will be copied here.\n borrow(ref_to_val);\n}\n```\n\nFor more information on Rust's ownership system, take a look at the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_mod.rs","byte_start":256,"byte_end":261,"line_start":11,"line_end":11,"column_start":14,"column_end":19,"is_primary":true,"text":[{"text":" drop(owned);","highlight_start":14,"highlight_end":19}],"label":"move out of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_mod.rs","byte_start":171,"byte_end":176,"line_start":7,"line_end":7,"column_start":26,"column_end":31,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":26,"highlight_end":31}],"label":"borrow of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_mod.rs","byte_start":84,"byte_end":93,"line_start":4,"line_end":4,"column_start":13,"column_end":22,"is_primary":false,"text":[{"text":" let mut owned = vec![1, 32];","highlight_start":13,"highlight_end":22}],"label":"binding `owned` declared here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_mod.rs","byte_start":288,"byte_end":294,"line_start":12,"line_end":12,"column_start":25,"column_end":31,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":25,"highlight_end":31}],"label":"borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"consider cloning the value if the performance cost is acceptable","code":null,"level":"help","spans":[{"file_name":"tests/unstable-pass/on_mod.rs","byte_start":176,"byte_end":176,"line_start":7,"line_end":7,"column_start":31,"column_end":31,"is_primary":true,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":31,"highlight_end":31}],"label":null,"suggested_replacement":".clone()","suggestion_applicability":"MachineApplicable","expansion":null}],"children":[],"rendered":null}],"rendered":"error[E0505]: cannot move out of `owned` because it is borrowed\n --> tests/unstable-pass/on_mod.rs:11:14\n |\n4 | let mut owned = vec![1, 32];\n | --------- binding `owned` declared here\n...\n7 | let mut_1 = &mut owned[0];\n | ----- borrow of `owned` occurs here\n...\n11 | drop(owned);\n | ^^^^^ move out of `owned` occurs here\n12 | let undefined = *mut_1 + *mut_2;\n | ------ borrow later used here\n |\nhelp: consider cloning the value if the performance cost is acceptable\n |\n7 | let mut_1 = &mut owned.clone()[0];\n | ++++++++\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"aborting due to 3 previous errors","code":null,"level":"error","spans":[],"children":[],"rendered":"error: aborting due to 3 previous errors\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"Some errors have detailed explanations: E0464, E0499, E0505.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"Some errors have detailed explanations: E0464, E0499, E0505.\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"For more information about an error, try `rustc --explain E0464`.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"For more information about an error, try `rustc --explain E0464`.\n"} [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] diff of stderr: [INFO] [stdout] [INFO] [stdout] -warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] - --> $DIR/on_block.rs:6:5 [INFO] [stdout] +error[E0464]: multiple candidates for `rlib` dependency `you_can` found [INFO] [stdout] + --> $DIR/on_block.rs:6:7 [INFO] [stdout] | [INFO] [stdout] 6 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] - | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] + | ^^^^^^^ [INFO] [stdout] + | [INFO] [stdout] + = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib [INFO] [stdout] + = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib [INFO] [stdout] [INFO] [stdout] -warning: the borrow checker is suppressed for these references. [INFO] [stdout] - --> $DIR/on_block.rs:9:21 [INFO] [stdout] +error[E0499]: cannot borrow `owned` as mutable more than once at a time [INFO] [stdout] + --> $DIR/on_block.rs:10:26 [INFO] [stdout] | [INFO] [stdout] 9 | let mut_1 = &mut owned[0]; [INFO] [stdout] - | ^^^^^^^^^^^^^ [INFO] [stdout] + | ----- first mutable borrow occurs here [INFO] [stdout] 10 | let mut_2 = &mut owned[1]; [INFO] [stdout] - | ^^^^^^^^^^^^^ [INFO] [stdout] + | ^^^^^ second mutable borrow occurs here [INFO] [stdout] +... [INFO] [stdout] +14 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ first borrow later used here [INFO] [stdout] + | [INFO] [stdout] + = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices [INFO] [stdout] [INFO] [stdout] -warning: 2 warnings emitted [INFO] [stdout] +error[E0505]: cannot move out of `owned` because it is borrowed [INFO] [stdout] + --> $DIR/on_block.rs:13:14 [INFO] [stdout] + | [INFO] [stdout] +4 | let mut owned = vec![1, 32]; [INFO] [stdout] + | --------- binding `owned` declared here [INFO] [stdout] +... [INFO] [stdout] +9 | let mut_1 = &mut owned[0]; [INFO] [stdout] + | ----- borrow of `owned` occurs here [INFO] [stdout] +... [INFO] [stdout] +13 | drop(owned); [INFO] [stdout] + | ^^^^^ move out of `owned` occurs here [INFO] [stdout] +14 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ borrow later used here [INFO] [stdout] + | [INFO] [stdout] +help: consider cloning the value if the performance cost is acceptable [INFO] [stdout] + | [INFO] [stdout] +9 | let mut_1 = &mut owned.clone()[0]; [INFO] [stdout] + | ++++++++ [INFO] [stdout] [INFO] [stdout] +error: aborting due to 3 previous errors [INFO] [stdout] + [INFO] [stdout] +Some errors have detailed explanations: E0464, E0499, E0505. [INFO] [stdout] +For more information about an error, try `rustc --explain E0464`. [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] The actual stderr differed from the expected stderr. [INFO] [stdout] Actual stderr saved to /tmp/on_block.stage-id.stderr [INFO] [stdout] To update references, rerun the tests and pass the `--bless` flag [INFO] [stdout] To only update this specific test, also pass `--test-args on_block.rs` [INFO] [stdout] [INFO] [stdout] error: 1 errors occurred comparing output. [INFO] [stdout] status: exit status: 1 [INFO] [stdout] command: "rustc" "tests/unstable-pass/on_block.rs" "-L" "/tmp" "--target=x86_64-unknown-linux-gnu" "--error-format" "json" "-C" "prefer-dynamic" "-o" "/tmp/on_block.stage-id" "-A" "unused" "--extern" "you_can" "--extern" "unbounded" "-L" "target/debug/deps" "-L" "/opt/rustwide/target/debug/deps" "-L" "/opt/rustwide/target/debug" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib" "--edition=2021" "-L" "/tmp/on_block.stage-id.aux" [INFO] [stdout] stdout: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] stderr: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] {"$message_type":"diagnostic","message":"multiple candidates for `rlib` dependency `you_can` found","code":{"code":"E0464","explanation":"The compiler found multiple library files with the requested crate name.\n\n```compile_fail\n// aux-build:crateresolve-1.rs\n// aux-build:crateresolve-2.rs\n// aux-build:crateresolve-3.rs\n\nextern crate crateresolve;\n//~^ ERROR multiple candidates for `rlib` dependency `crateresolve` found\n\nfn main() {}\n```\n\nThis error can occur in several different cases -- for example, when using\n`extern crate` or passing `--extern` options without crate paths. It can also be\ncaused by caching issues with the build directory, in which case `cargo clean`\nmay help.\n\nIn the above example, there are three different library files, all of which\ndefine the same crate name. Without providing a full path, there is no way for\nthe compiler to know which crate it should use.\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_block.rs","byte_start":111,"byte_end":118,"line_start":6,"line_end":6,"column_start":7,"column_end":14,"is_primary":true,"text":[{"text":" #[you_can::turn_off_the_borrow_checker]","highlight_start":7,"highlight_end":14}],"label":null,"suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null},{"message":"candidate #2: /opt/rustwide/target/debug/libyou_can.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null}],"rendered":"error[E0464]: multiple candidates for `rlib` dependency `you_can` found\n --> tests/unstable-pass/on_block.rs:6:7\n |\n6 | #[you_can::turn_off_the_borrow_checker]\n | ^^^^^^^\n |\n = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib\n = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot borrow `owned` as mutable more than once at a time","code":{"code":"E0499","explanation":"A variable was borrowed as mutable more than once.\n\nErroneous code example:\n\n```compile_fail,E0499\nlet mut i = 0;\nlet mut x = &mut i;\nlet mut a = &mut i;\nx;\n// error: cannot borrow `i` as mutable more than once at a time\n```\n\nPlease note that in Rust, you can either have many immutable references, or one\nmutable reference. For more details you may want to read the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n\nExample:\n\n```\nlet mut i = 0;\nlet mut x = &mut i; // ok!\n\n// or:\nlet mut i = 0;\nlet a = &i; // ok!\nlet b = &i; // still ok!\nlet c = &i; // still ok!\nb;\na;\n```\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_block.rs","byte_start":216,"byte_end":221,"line_start":9,"line_end":9,"column_start":26,"column_end":31,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":26,"highlight_end":31}],"label":"first mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_block.rs","byte_start":251,"byte_end":256,"line_start":10,"line_end":10,"column_start":26,"column_end":31,"is_primary":true,"text":[{"text":" let mut_2 = &mut owned[1];","highlight_start":26,"highlight_end":31}],"label":"second mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_block.rs","byte_start":333,"byte_end":339,"line_start":14,"line_end":14,"column_start":25,"column_end":31,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":25,"highlight_end":31}],"label":"first borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices","code":null,"level":"help","spans":[],"children":[],"rendered":null}],"rendered":"error[E0499]: cannot borrow `owned` as mutable more than once at a time\n --> tests/unstable-pass/on_block.rs:10:26\n |\n9 | let mut_1 = &mut owned[0];\n | ----- first mutable borrow occurs here\n10 | let mut_2 = &mut owned[1];\n | ^^^^^ second mutable borrow occurs here\n...\n14 | let undefined = *mut_1 + *mut_2;\n | ------ first borrow later used here\n |\n = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot move out of `owned` because it is borrowed","code":{"code":"E0505","explanation":"A value was moved out while it was still borrowed.\n\nErroneous code example:\n\n```compile_fail,E0505\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let _ref_to_val: &Value = &x;\n eat(x);\n borrow(_ref_to_val);\n}\n```\n\nHere, the function `eat` takes ownership of `x`. However,\n`x` cannot be moved because the borrow to `_ref_to_val`\nneeds to last till the function `borrow`.\nTo fix that you can do a few different things:\n\n* Try to avoid moving the variable.\n* Release borrow before move.\n* Implement the `Copy` trait on the type.\n\nExamples:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: &Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n eat(&x); // pass by reference, if it's possible\n borrow(ref_to_val);\n}\n```\n\nOr:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n borrow(ref_to_val);\n // ref_to_val is no longer used.\n eat(x);\n}\n```\n\nOr:\n\n```\n#[derive(Clone, Copy)] // implement Copy trait\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let ref_to_val: &Value = &x;\n eat(x); // it will be copied here.\n borrow(ref_to_val);\n}\n```\n\nFor more information on Rust's ownership system, take a look at the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_block.rs","byte_start":301,"byte_end":306,"line_start":13,"line_end":13,"column_start":14,"column_end":19,"is_primary":true,"text":[{"text":" drop(owned);","highlight_start":14,"highlight_end":19}],"label":"move out of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_block.rs","byte_start":216,"byte_end":221,"line_start":9,"line_end":9,"column_start":26,"column_end":31,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":26,"highlight_end":31}],"label":"borrow of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_block.rs","byte_start":79,"byte_end":88,"line_start":4,"line_end":4,"column_start":9,"column_end":18,"is_primary":false,"text":[{"text":" let mut owned = vec![1, 32];","highlight_start":9,"highlight_end":18}],"label":"binding `owned` declared here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_block.rs","byte_start":333,"byte_end":339,"line_start":14,"line_end":14,"column_start":25,"column_end":31,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":25,"highlight_end":31}],"label":"borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"consider cloning the value if the performance cost is acceptable","code":null,"level":"help","spans":[{"file_name":"tests/unstable-pass/on_block.rs","byte_start":221,"byte_end":221,"line_start":9,"line_end":9,"column_start":31,"column_end":31,"is_primary":true,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":31,"highlight_end":31}],"label":null,"suggested_replacement":".clone()","suggestion_applicability":"MachineApplicable","expansion":null}],"children":[],"rendered":null}],"rendered":"error[E0505]: cannot move out of `owned` because it is borrowed\n --> tests/unstable-pass/on_block.rs:13:14\n |\n4 | let mut owned = vec![1, 32];\n | --------- binding `owned` declared here\n...\n9 | let mut_1 = &mut owned[0];\n | ----- borrow of `owned` occurs here\n...\n13 | drop(owned);\n | ^^^^^ move out of `owned` occurs here\n14 | let undefined = *mut_1 + *mut_2;\n | ------ borrow later used here\n |\nhelp: consider cloning the value if the performance cost is acceptable\n |\n9 | let mut_1 = &mut owned.clone()[0];\n | ++++++++\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"aborting due to 3 previous errors","code":null,"level":"error","spans":[],"children":[],"rendered":"error: aborting due to 3 previous errors\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"Some errors have detailed explanations: E0464, E0499, E0505.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"Some errors have detailed explanations: E0464, E0499, E0505.\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"For more information about an error, try `rustc --explain E0464`.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"For more information about an error, try `rustc --explain E0464`.\n"} [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] diff of stderr: [INFO] [stdout] [INFO] [stdout] -warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] - --> $DIR/on_fn.rs:1:1 [INFO] [stdout] +error[E0464]: multiple candidates for `rlib` dependency `you_can` found [INFO] [stdout] + --> $DIR/on_fn.rs:1:3 [INFO] [stdout] | [INFO] [stdout] 1 | #[you_can::turn_off_the_borrow_checker] [INFO] [stdout] - | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] - [INFO] [stdout] -warning: the borrow checker is suppressed for these references. [INFO] [stdout] - --> $DIR/on_fn.rs:6:17 [INFO] [stdout] + | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] -6 | let mut_1 = &mut owned[0]; [INFO] [stdout] - | ^^^^^^^^^^^^^ [INFO] [stdout] -7 | let mut_2 = &mut owned[1]; [INFO] [stdout] - | ^^^^^^^^^^^^^ [INFO] [stdout] + = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib [INFO] [stdout] + = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib [INFO] [stdout] [INFO] [stdout] -warning: 2 warnings emitted [INFO] [stdout] +error[E0499]: cannot borrow `owned` as mutable more than once at a time [INFO] [stdout] + --> $DIR/on_fn.rs:7:22 [INFO] [stdout] + | [INFO] [stdout] +6 | let mut_1 = &mut owned[0]; [INFO] [stdout] + | ----- first mutable borrow occurs here [INFO] [stdout] +7 | let mut_2 = &mut owned[1]; [INFO] [stdout] + | ^^^^^ second mutable borrow occurs here [INFO] [stdout] +... [INFO] [stdout] +11 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ first borrow later used here [INFO] [stdout] + | [INFO] [stdout] + = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices [INFO] [stdout] [INFO] [stdout] +error[E0505]: cannot move out of `owned` because it is borrowed [INFO] [stdout] + --> $DIR/on_fn.rs:10:10 [INFO] [stdout] + | [INFO] [stdout] +3 | let mut owned = vec![1, 32]; [INFO] [stdout] + | --------- binding `owned` declared here [INFO] [stdout] +... [INFO] [stdout] +6 | let mut_1 = &mut owned[0]; [INFO] [stdout] + | ----- borrow of `owned` occurs here [INFO] [stdout] +... [INFO] [stdout] +10 | drop(owned); [INFO] [stdout] + | ^^^^^ move out of `owned` occurs here [INFO] [stdout] +11 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ borrow later used here [INFO] [stdout] + | [INFO] [stdout] +help: consider cloning the value if the performance cost is acceptable [INFO] [stdout] + | [INFO] [stdout] +6 | let mut_1 = &mut owned.clone()[0]; [INFO] [stdout] + | ++++++++ [INFO] [stdout] + [INFO] [stdout] +error: aborting due to 3 previous errors [INFO] [stdout] + [INFO] [stdout] +Some errors have detailed explanations: E0464, E0499, E0505. [INFO] [stdout] +For more information about an error, try `rustc --explain E0464`. [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] The actual stderr differed from the expected stderr. [INFO] [stdout] Actual stderr saved to /tmp/on_fn.stage-id.stderr [INFO] [stdout] To update references, rerun the tests and pass the `--bless` flag [INFO] [stdout] To only update this specific test, also pass `--test-args on_fn.rs` [INFO] [stdout] [INFO] [stdout] error: 1 errors occurred comparing output. [INFO] [stdout] status: exit status: 1 [INFO] [stdout] command: "rustc" "tests/unstable-pass/on_fn.rs" "-L" "/tmp" "--target=x86_64-unknown-linux-gnu" "--error-format" "json" "-C" "prefer-dynamic" "-o" "/tmp/on_fn.stage-id" "-A" "unused" "--extern" "you_can" "--extern" "unbounded" "-L" "target/debug/deps" "-L" "/opt/rustwide/target/debug/deps" "-L" "/opt/rustwide/target/debug" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib" "--edition=2021" "-L" "/tmp/on_fn.stage-id.aux" [INFO] [stdout] stdout: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] stderr: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] {"$message_type":"diagnostic","message":"multiple candidates for `rlib` dependency `you_can` found","code":{"code":"E0464","explanation":"The compiler found multiple library files with the requested crate name.\n\n```compile_fail\n// aux-build:crateresolve-1.rs\n// aux-build:crateresolve-2.rs\n// aux-build:crateresolve-3.rs\n\nextern crate crateresolve;\n//~^ ERROR multiple candidates for `rlib` dependency `crateresolve` found\n\nfn main() {}\n```\n\nThis error can occur in several different cases -- for example, when using\n`extern crate` or passing `--extern` options without crate paths. It can also be\ncaused by caching issues with the build directory, in which case `cargo clean`\nmay help.\n\nIn the above example, there are three different library files, all of which\ndefine the same crate name. Without providing a full path, there is no way for\nthe compiler to know which crate it should use.\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_fn.rs","byte_start":2,"byte_end":9,"line_start":1,"line_end":1,"column_start":3,"column_end":10,"is_primary":true,"text":[{"text":"#[you_can::turn_off_the_borrow_checker]","highlight_start":3,"highlight_end":10}],"label":null,"suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null},{"message":"candidate #2: /opt/rustwide/target/debug/libyou_can.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null}],"rendered":"error[E0464]: multiple candidates for `rlib` dependency `you_can` found\n --> tests/unstable-pass/on_fn.rs:1:3\n |\n1 | #[you_can::turn_off_the_borrow_checker]\n | ^^^^^^^\n |\n = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib\n = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot borrow `owned` as mutable more than once at a time","code":{"code":"E0499","explanation":"A variable was borrowed as mutable more than once.\n\nErroneous code example:\n\n```compile_fail,E0499\nlet mut i = 0;\nlet mut x = &mut i;\nlet mut a = &mut i;\nx;\n// error: cannot borrow `i` as mutable more than once at a time\n```\n\nPlease note that in Rust, you can either have many immutable references, or one\nmutable reference. For more details you may want to read the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n\nExample:\n\n```\nlet mut i = 0;\nlet mut x = &mut i; // ok!\n\n// or:\nlet mut i = 0;\nlet a = &i; // ok!\nlet b = &i; // still ok!\nlet c = &i; // still ok!\nb;\na;\n```\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_fn.rs","byte_start":139,"byte_end":144,"line_start":6,"line_end":6,"column_start":22,"column_end":27,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":22,"highlight_end":27}],"label":"first mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_fn.rs","byte_start":170,"byte_end":175,"line_start":7,"line_end":7,"column_start":22,"column_end":27,"is_primary":true,"text":[{"text":" let mut_2 = &mut owned[1];","highlight_start":22,"highlight_end":27}],"label":"second mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_fn.rs","byte_start":240,"byte_end":246,"line_start":11,"line_end":11,"column_start":21,"column_end":27,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":21,"highlight_end":27}],"label":"first borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices","code":null,"level":"help","spans":[],"children":[],"rendered":null}],"rendered":"error[E0499]: cannot borrow `owned` as mutable more than once at a time\n --> tests/unstable-pass/on_fn.rs:7:22\n |\n6 | let mut_1 = &mut owned[0];\n | ----- first mutable borrow occurs here\n7 | let mut_2 = &mut owned[1];\n | ^^^^^ second mutable borrow occurs here\n...\n11 | let undefined = *mut_1 + *mut_2;\n | ------ first borrow later used here\n |\n = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot move out of `owned` because it is borrowed","code":{"code":"E0505","explanation":"A value was moved out while it was still borrowed.\n\nErroneous code example:\n\n```compile_fail,E0505\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let _ref_to_val: &Value = &x;\n eat(x);\n borrow(_ref_to_val);\n}\n```\n\nHere, the function `eat` takes ownership of `x`. However,\n`x` cannot be moved because the borrow to `_ref_to_val`\nneeds to last till the function `borrow`.\nTo fix that you can do a few different things:\n\n* Try to avoid moving the variable.\n* Release borrow before move.\n* Implement the `Copy` trait on the type.\n\nExamples:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: &Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n eat(&x); // pass by reference, if it's possible\n borrow(ref_to_val);\n}\n```\n\nOr:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n borrow(ref_to_val);\n // ref_to_val is no longer used.\n eat(x);\n}\n```\n\nOr:\n\n```\n#[derive(Clone, Copy)] // implement Copy trait\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let ref_to_val: &Value = &x;\n eat(x); // it will be copied here.\n borrow(ref_to_val);\n}\n```\n\nFor more information on Rust's ownership system, take a look at the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/on_fn.rs","byte_start":212,"byte_end":217,"line_start":10,"line_end":10,"column_start":10,"column_end":15,"is_primary":true,"text":[{"text":" drop(owned);","highlight_start":10,"highlight_end":15}],"label":"move out of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_fn.rs","byte_start":139,"byte_end":144,"line_start":6,"line_end":6,"column_start":22,"column_end":27,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":22,"highlight_end":27}],"label":"borrow of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_fn.rs","byte_start":60,"byte_end":69,"line_start":3,"line_end":3,"column_start":9,"column_end":18,"is_primary":false,"text":[{"text":" let mut owned = vec![1, 32];","highlight_start":9,"highlight_end":18}],"label":"binding `owned` declared here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/on_fn.rs","byte_start":240,"byte_end":246,"line_start":11,"line_end":11,"column_start":21,"column_end":27,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":21,"highlight_end":27}],"label":"borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"consider cloning the value if the performance cost is acceptable","code":null,"level":"help","spans":[{"file_name":"tests/unstable-pass/on_fn.rs","byte_start":144,"byte_end":144,"line_start":6,"line_end":6,"column_start":27,"column_end":27,"is_primary":true,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":27,"highlight_end":27}],"label":null,"suggested_replacement":".clone()","suggestion_applicability":"MachineApplicable","expansion":null}],"children":[],"rendered":null}],"rendered":"error[E0505]: cannot move out of `owned` because it is borrowed\n --> tests/unstable-pass/on_fn.rs:10:10\n |\n3 | let mut owned = vec![1, 32];\n | --------- binding `owned` declared here\n...\n6 | let mut_1 = &mut owned[0];\n | ----- borrow of `owned` occurs here\n...\n10 | drop(owned);\n | ^^^^^ move out of `owned` occurs here\n11 | let undefined = *mut_1 + *mut_2;\n | ------ borrow later used here\n |\nhelp: consider cloning the value if the performance cost is acceptable\n |\n6 | let mut_1 = &mut owned.clone()[0];\n | ++++++++\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"aborting due to 3 previous errors","code":null,"level":"error","spans":[],"children":[],"rendered":"error: aborting due to 3 previous errors\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"Some errors have detailed explanations: E0464, E0499, E0505.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"Some errors have detailed explanations: E0464, E0499, E0505.\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"For more information about an error, try `rustc --explain E0464`.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"For more information about an error, try `rustc --explain E0464`.\n"} [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] diff of stderr: [INFO] [stdout] [INFO] [stdout] -warning: this suppresses the borrow checker in an unsafe, unsound, and unstable way that produces undefined behaviour. this is not suitable for any purpose beyond educational experimentation. [INFO] [stdout] - --> $DIR/in_fn.rs:4:5 [INFO] [stdout] +error[E0464]: multiple candidates for `rlib` dependency `you_can` found [INFO] [stdout] + --> $DIR/in_fn.rs:4:8 [INFO] [stdout] | [INFO] [stdout] 4 | #![you_can::turn_off_the_borrow_checker] [INFO] [stdout] - | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] + | ^^^^^^^ [INFO] [stdout] + | [INFO] [stdout] + = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib [INFO] [stdout] + = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib [INFO] [stdout] [INFO] [stdout] -warning: the borrow checker is suppressed for these references. [INFO] [stdout] - --> $DIR/in_fn.rs:9:17 [INFO] [stdout] +error[E0499]: cannot borrow `owned` as mutable more than once at a time [INFO] [stdout] + --> $DIR/in_fn.rs:10:22 [INFO] [stdout] | [INFO] [stdout] 9 | let mut_1 = &mut owned[0]; [INFO] [stdout] - | ^^^^^^^^^^^^^ [INFO] [stdout] + | ----- first mutable borrow occurs here [INFO] [stdout] 10 | let mut_2 = &mut owned[1]; [INFO] [stdout] - | ^^^^^^^^^^^^^ [INFO] [stdout] + | ^^^^^ second mutable borrow occurs here [INFO] [stdout] +... [INFO] [stdout] +14 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ first borrow later used here [INFO] [stdout] + | [INFO] [stdout] + = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices [INFO] [stdout] [INFO] [stdout] -warning: 2 warnings emitted [INFO] [stdout] +error[E0505]: cannot move out of `owned` because it is borrowed [INFO] [stdout] + --> $DIR/in_fn.rs:13:10 [INFO] [stdout] + | [INFO] [stdout] +6 | let mut owned = vec![1, 32]; [INFO] [stdout] + | --------- binding `owned` declared here [INFO] [stdout] +... [INFO] [stdout] +9 | let mut_1 = &mut owned[0]; [INFO] [stdout] + | ----- borrow of `owned` occurs here [INFO] [stdout] +... [INFO] [stdout] +13 | drop(owned); [INFO] [stdout] + | ^^^^^ move out of `owned` occurs here [INFO] [stdout] +14 | let undefined = *mut_1 + *mut_2; [INFO] [stdout] + | ------ borrow later used here [INFO] [stdout] + | [INFO] [stdout] +help: consider cloning the value if the performance cost is acceptable [INFO] [stdout] + | [INFO] [stdout] +9 | let mut_1 = &mut owned.clone()[0]; [INFO] [stdout] + | ++++++++ [INFO] [stdout] [INFO] [stdout] +error: aborting due to 3 previous errors [INFO] [stdout] + [INFO] [stdout] +Some errors have detailed explanations: E0464, E0499, E0505. [INFO] [stdout] +For more information about an error, try `rustc --explain E0464`. [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] The actual stderr differed from the expected stderr. [INFO] [stdout] Actual stderr saved to /tmp/in_fn.stage-id.stderr [INFO] [stdout] To update references, rerun the tests and pass the `--bless` flag [INFO] [stdout] To only update this specific test, also pass `--test-args in_fn.rs` [INFO] [stdout] [INFO] [stdout] error: 1 errors occurred comparing output. [INFO] [stdout] status: exit status: 1 [INFO] [stdout] command: "rustc" "tests/unstable-pass/in_fn.rs" "-L" "/tmp" "--target=x86_64-unknown-linux-gnu" "--error-format" "json" "-C" "prefer-dynamic" "-o" "/tmp/in_fn.stage-id" "-A" "unused" "--extern" "you_can" "--extern" "unbounded" "-L" "target/debug/deps" "-L" "/opt/rustwide/target/debug/deps" "-L" "/opt/rustwide/target/debug" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-L" "/opt/rustwide/rustup-home/toolchains/9e136a30a965bf4e63f03095c57df7257bf96fd6/lib" "--edition=2021" "-L" "/tmp/in_fn.stage-id.aux" [INFO] [stdout] stdout: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] stderr: [INFO] [stdout] ------------------------------------------ [INFO] [stdout] {"$message_type":"diagnostic","message":"multiple candidates for `rlib` dependency `you_can` found","code":{"code":"E0464","explanation":"The compiler found multiple library files with the requested crate name.\n\n```compile_fail\n// aux-build:crateresolve-1.rs\n// aux-build:crateresolve-2.rs\n// aux-build:crateresolve-3.rs\n\nextern crate crateresolve;\n//~^ ERROR multiple candidates for `rlib` dependency `crateresolve` found\n\nfn main() {}\n```\n\nThis error can occur in several different cases -- for example, when using\n`extern crate` or passing `--extern` options without crate paths. It can also be\ncaused by caching issues with the build directory, in which case `cargo clean`\nmay help.\n\nIn the above example, there are three different library files, all of which\ndefine the same crate name. Without providing a full path, there is no way for\nthe compiler to know which crate it should use.\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/in_fn.rs","byte_start":61,"byte_end":68,"line_start":4,"line_end":4,"column_start":8,"column_end":15,"is_primary":true,"text":[{"text":" #![you_can::turn_off_the_borrow_checker]","highlight_start":8,"highlight_end":15}],"label":null,"suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null},{"message":"candidate #2: /opt/rustwide/target/debug/libyou_can.rlib","code":null,"level":"note","spans":[],"children":[],"rendered":null}],"rendered":"error[E0464]: multiple candidates for `rlib` dependency `you_can` found\n --> tests/unstable-pass/in_fn.rs:4:8\n |\n4 | #![you_can::turn_off_the_borrow_checker]\n | ^^^^^^^\n |\n = note: candidate #1: /opt/rustwide/target/debug/deps/libyou_can-46081ce6d095a9b6.rlib\n = note: candidate #2: /opt/rustwide/target/debug/libyou_can.rlib\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot borrow `owned` as mutable more than once at a time","code":{"code":"E0499","explanation":"A variable was borrowed as mutable more than once.\n\nErroneous code example:\n\n```compile_fail,E0499\nlet mut i = 0;\nlet mut x = &mut i;\nlet mut a = &mut i;\nx;\n// error: cannot borrow `i` as mutable more than once at a time\n```\n\nPlease note that in Rust, you can either have many immutable references, or one\nmutable reference. For more details you may want to read the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n\nExample:\n\n```\nlet mut i = 0;\nlet mut x = &mut i; // ok!\n\n// or:\nlet mut i = 0;\nlet a = &i; // ok!\nlet b = &i; // still ok!\nlet c = &i; // still ok!\nb;\na;\n```\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/in_fn.rs","byte_start":187,"byte_end":192,"line_start":9,"line_end":9,"column_start":22,"column_end":27,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":22,"highlight_end":27}],"label":"first mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/in_fn.rs","byte_start":218,"byte_end":223,"line_start":10,"line_end":10,"column_start":22,"column_end":27,"is_primary":true,"text":[{"text":" let mut_2 = &mut owned[1];","highlight_start":22,"highlight_end":27}],"label":"second mutable borrow occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/in_fn.rs","byte_start":288,"byte_end":294,"line_start":14,"line_end":14,"column_start":21,"column_end":27,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":21,"highlight_end":27}],"label":"first borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices","code":null,"level":"help","spans":[],"children":[],"rendered":null}],"rendered":"error[E0499]: cannot borrow `owned` as mutable more than once at a time\n --> tests/unstable-pass/in_fn.rs:10:22\n |\n9 | let mut_1 = &mut owned[0];\n | ----- first mutable borrow occurs here\n10 | let mut_2 = &mut owned[1];\n | ^^^^^ second mutable borrow occurs here\n...\n14 | let undefined = *mut_1 + *mut_2;\n | ------ first borrow later used here\n |\n = help: use `.split_at_mut(position)` to obtain two mutable non-overlapping sub-slices\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"cannot move out of `owned` because it is borrowed","code":{"code":"E0505","explanation":"A value was moved out while it was still borrowed.\n\nErroneous code example:\n\n```compile_fail,E0505\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let _ref_to_val: &Value = &x;\n eat(x);\n borrow(_ref_to_val);\n}\n```\n\nHere, the function `eat` takes ownership of `x`. However,\n`x` cannot be moved because the borrow to `_ref_to_val`\nneeds to last till the function `borrow`.\nTo fix that you can do a few different things:\n\n* Try to avoid moving the variable.\n* Release borrow before move.\n* Implement the `Copy` trait on the type.\n\nExamples:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: &Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n eat(&x); // pass by reference, if it's possible\n borrow(ref_to_val);\n}\n```\n\nOr:\n\n```\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n\n let ref_to_val: &Value = &x;\n borrow(ref_to_val);\n // ref_to_val is no longer used.\n eat(x);\n}\n```\n\nOr:\n\n```\n#[derive(Clone, Copy)] // implement Copy trait\nstruct Value {}\n\nfn borrow(val: &Value) {}\n\nfn eat(val: Value) {}\n\nfn main() {\n let x = Value{};\n let ref_to_val: &Value = &x;\n eat(x); // it will be copied here.\n borrow(ref_to_val);\n}\n```\n\nFor more information on Rust's ownership system, take a look at the\n[References & Borrowing][references-and-borrowing] section of the Book.\n\n[references-and-borrowing]: https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html\n"},"level":"error","spans":[{"file_name":"tests/unstable-pass/in_fn.rs","byte_start":260,"byte_end":265,"line_start":13,"line_end":13,"column_start":10,"column_end":15,"is_primary":true,"text":[{"text":" drop(owned);","highlight_start":10,"highlight_end":15}],"label":"move out of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/in_fn.rs","byte_start":187,"byte_end":192,"line_start":9,"line_end":9,"column_start":22,"column_end":27,"is_primary":false,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":22,"highlight_end":27}],"label":"borrow of `owned` occurs here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/in_fn.rs","byte_start":108,"byte_end":117,"line_start":6,"line_end":6,"column_start":9,"column_end":18,"is_primary":false,"text":[{"text":" let mut owned = vec![1, 32];","highlight_start":9,"highlight_end":18}],"label":"binding `owned` declared here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null},{"file_name":"tests/unstable-pass/in_fn.rs","byte_start":288,"byte_end":294,"line_start":14,"line_end":14,"column_start":21,"column_end":27,"is_primary":false,"text":[{"text":" let undefined = *mut_1 + *mut_2;","highlight_start":21,"highlight_end":27}],"label":"borrow later used here","suggested_replacement":null,"suggestion_applicability":null,"expansion":null}],"children":[{"message":"consider cloning the value if the performance cost is acceptable","code":null,"level":"help","spans":[{"file_name":"tests/unstable-pass/in_fn.rs","byte_start":192,"byte_end":192,"line_start":9,"line_end":9,"column_start":27,"column_end":27,"is_primary":true,"text":[{"text":" let mut_1 = &mut owned[0];","highlight_start":27,"highlight_end":27}],"label":null,"suggested_replacement":".clone()","suggestion_applicability":"MachineApplicable","expansion":null}],"children":[],"rendered":null}],"rendered":"error[E0505]: cannot move out of `owned` because it is borrowed\n --> tests/unstable-pass/in_fn.rs:13:10\n |\n6 | let mut owned = vec![1, 32];\n | --------- binding `owned` declared here\n...\n9 | let mut_1 = &mut owned[0];\n | ----- borrow of `owned` occurs here\n...\n13 | drop(owned);\n | ^^^^^ move out of `owned` occurs here\n14 | let undefined = *mut_1 + *mut_2;\n | ------ borrow later used here\n |\nhelp: consider cloning the value if the performance cost is acceptable\n |\n9 | let mut_1 = &mut owned.clone()[0];\n | ++++++++\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"aborting due to 3 previous errors","code":null,"level":"error","spans":[],"children":[],"rendered":"error: aborting due to 3 previous errors\n\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"Some errors have detailed explanations: E0464, E0499, E0505.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"Some errors have detailed explanations: E0464, E0499, E0505.\n"} [INFO] [stdout] {"$message_type":"diagnostic","message":"For more information about an error, try `rustc --explain E0464`.","code":null,"level":"failure-note","spans":[],"children":[],"rendered":"For more information about an error, try `rustc --explain E0464`.\n"} [INFO] [stdout] [INFO] [stdout] ------------------------------------------ [INFO] [stdout] [INFO] [stdout] thread 'run_pass' panicked at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/compiletest_rs-0.8.0/src/lib.rs:111:22: [INFO] [stdout] Some tests failed [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x557d0260c16a - std::backtrace_rs::backtrace::libunwind::trace::h45f575fdcec9cdc1 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/../../backtrace/src/backtrace/libunwind.rs:116:5 [INFO] [stdout] 1: 0x557d0260c16a - std::backtrace_rs::backtrace::trace_unsynchronized::heed7aaaa28209ac3 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/../../backtrace/src/backtrace/mod.rs:66:5 [INFO] [stdout] 2: 0x557d0260c16a - std::sys::backtrace::_print_fmt::h47d1e3547844619c [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x557d0260c16a - ::fmt::h6c37de0361fa7462 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x557d026368f3 - core::fmt::rt::Argument::fmt::h6606d9b5304941e1 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/core/src/fmt/rt.rs:177:76 [INFO] [stdout] 5: 0x557d026368f3 - core::fmt::write::hf77fe0583268bf67 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/core/src/fmt/mod.rs:1437:21 [INFO] [stdout] 6: 0x557d02608253 - std::io::Write::write_fmt::h672ff980e46892ac [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/io/mod.rs:1887:15 [INFO] [stdout] 7: 0x557d0260bfb2 - std::sys::backtrace::BacktraceLock::print::hce84519ec0e7588e [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 8: 0x557d0260dc6e - std::panicking::default_hook::{{closure}}::h6e0433c33d1ed12b [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/panicking.rs:284:22 [INFO] [stdout] 9: 0x557d0260da77 - std::panicking::default_hook::h19d4e9e8d7fba9e2 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/panicking.rs:308:9 [INFO] [stdout] 10: 0x557d022ecc98 - as core::ops::function::Fn>::call::hd2aa5731f018e269 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/alloc/src/boxed.rs:1984:9 [INFO] [stdout] 11: 0x557d022ecc98 - test::test_main::{{closure}}::h1ae6fb8f80aa49b6 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/test/src/lib.rs:134:21 [INFO] [stdout] 12: 0x557d0260e488 - as core::ops::function::Fn>::call::h4f2af756974b90d5 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/alloc/src/boxed.rs:1984:9 [INFO] [stdout] 13: 0x557d0260e488 - std::panicking::rust_panic_with_hook::hd21771b96ea64164 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/panicking.rs:825:13 [INFO] [stdout] 14: 0x557d0260e28c - std::panicking::begin_panic::{{closure}}::h405cf8b58cc59bd8 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/panicking.rs:754:9 [INFO] [stdout] 15: 0x557d0260c639 - std::sys::backtrace::__rust_end_short_backtrace::h392305d650a0842a [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/sys/backtrace.rs:168:18 [INFO] [stdout] 16: 0x557d0260e192 - std::panicking::begin_panic::h4891113220f911cc [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/panicking.rs:753:5 [INFO] [stdout] 17: 0x557d022ff593 - compiletest_rs::run_tests::hb233faa53082685a [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/compiletest_rs-0.8.0/src/lib.rs:111:22 [INFO] [stdout] 18: 0x557d02299ffa - compile_tests::run_pass::h18472d69818cf906 [INFO] [stdout] at /opt/rustwide/workdir/tests/compile_tests.rs:28:5 [INFO] [stdout] 19: 0x557d022997b7 - compile_tests::run_pass::{{closure}}::h6bc6d9bec6d55ce2 [INFO] [stdout] at /opt/rustwide/workdir/tests/compile_tests.rs:4:14 [INFO] [stdout] 20: 0x557d02298ca6 - core::ops::function::FnOnce::call_once::h297ade5b2b52bd85 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 21: 0x557d022f18db - core::ops::function::FnOnce::call_once::hc1e06e2a5640370a [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 22: 0x557d022f18db - test::__rust_begin_short_backtrace::heb5aa654e2797f5b [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/test/src/lib.rs:632:18 [INFO] [stdout] 23: 0x557d022f11e9 - test::run_test_in_process::{{closure}}::h1329474a96646ad1 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/test/src/lib.rs:655:60 [INFO] [stdout] 24: 0x557d022f11e9 - as core::ops::function::FnOnce<()>>::call_once::hc87a7a8694e6d844 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 25: 0x557d022f11e9 - std::panicking::try::do_call::h3b8456af8bacf88f [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/panicking.rs:573:40 [INFO] [stdout] 26: 0x557d022f11e9 - std::panicking::try::hc177f95c6592cea1 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/panicking.rs:536:19 [INFO] [stdout] 27: 0x557d022f11e9 - std::panic::catch_unwind::h847b2adf17f7da7a [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/panic.rs:358:14 [INFO] [stdout] 28: 0x557d022f11e9 - test::run_test_in_process::h824f7775d92af51e [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/test/src/lib.rs:655:27 [INFO] [stdout] 29: 0x557d022f11e9 - test::run_test::{{closure}}::hdfaf20d18f7af8f6 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/test/src/lib.rs:576:43 [INFO] [stdout] 30: 0x557d022b3f8a - test::run_test::{{closure}}::he83661a0a1c97403 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/test/src/lib.rs:606:41 [INFO] [stdout] 31: 0x557d022b3f8a - std::sys::backtrace::__rust_begin_short_backtrace::hd3a78fd401685e9b [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/sys/backtrace.rs:152:18 [INFO] [stdout] 32: 0x557d022b79c6 - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h78d6a457dee8dc60 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/thread/mod.rs:561:17 [INFO] [stdout] 33: 0x557d022b79c6 - as core::ops::function::FnOnce<()>>::call_once::hc4069b3cc6600bde [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 34: 0x557d022b79c6 - std::panicking::try::do_call::h0dde49ad0af85fa8 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/panicking.rs:573:40 [INFO] [stdout] 35: 0x557d022b79c6 - std::panicking::try::h918d0d3a7e94727d [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/panicking.rs:536:19 [INFO] [stdout] 36: 0x557d022b79c6 - std::panic::catch_unwind::h7016984cdcdd8b9e [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/panic.rs:358:14 [INFO] [stdout] 37: 0x557d022b79c6 - std::thread::Builder::spawn_unchecked_::{{closure}}::h2766f51195a4a65d [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/thread/mod.rs:559:30 [INFO] [stdout] 38: 0x557d022b79c6 - core::ops::function::FnOnce::call_once{{vtable.shim}}::hbd6e39e4ea63a011 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 39: 0x557d026141db - as core::ops::function::FnOnce>::call_once::h34bec2a4cdedc102 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/alloc/src/boxed.rs:1970:9 [INFO] [stdout] 40: 0x557d026141db - as core::ops::function::FnOnce>::call_once::ha62c0d1861fdf293 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/alloc/src/boxed.rs:1970:9 [INFO] [stdout] 41: 0x557d026141db - std::sys::pal::unix::thread::Thread::new::thread_start::h71fe57097907b3f8 [INFO] [stdout] at /rustc/9e136a30a965bf4e63f03095c57df7257bf96fd6/library/std/src/sys/pal/unix/thread.rs:105:17 [INFO] [stdout] 42: 0x712195009ac3 - [INFO] [stdout] 43: 0x71219509aa04 - clone [INFO] [stdout] 44: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] run_pass [INFO] [stdout] [INFO] [stdout] test result: FAILED. 1 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.28s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass `--test compile_tests` [INFO] running `Command { std: "docker" "inspect" "7dd47b92bb918ef81b671b8acd54e32e60cd55e2cc566e2d58e1c123e3691a3d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7dd47b92bb918ef81b671b8acd54e32e60cd55e2cc566e2d58e1c123e3691a3d", kill_on_drop: false }` [INFO] [stdout] 7dd47b92bb918ef81b671b8acd54e32e60cd55e2cc566e2d58e1c123e3691a3d