[INFO] fetching crate lemu 0.2.22...
[INFO] checking lemu-0.2.22 against try#012cd62c9add58ab3910e44c137d87db3ab70f61 for pr-155915
[INFO] extracting crate lemu 0.2.22 into /workspace/builds/worker-3-tc2/source
[INFO] removed /workspace/builds/worker-3-tc2/source/rust-toolchain.toml
[INFO] started tweaking crates.io crate lemu 0.2.22
[INFO] finished tweaking crates.io crate lemu 0.2.22
[INFO] tweaked toml for crates.io crate lemu 0.2.22 written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate lemu 0.2.22 on toolchain 012cd62c9add58ab3910e44c137d87db3ab70f61
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate lemu 0.2.22 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" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 5161bf878a27539968e2eb7c142fdfe11ad6e1080c4410dfd0e315d3bb5c6034
[INFO] running `Command { std: "docker" "start" "-a" "5161bf878a27539968e2eb7c142fdfe11ad6e1080c4410dfd0e315d3bb5c6034", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "5161bf878a27539968e2eb7c142fdfe11ad6e1080c4410dfd0e315d3bb5c6034", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5161bf878a27539968e2eb7c142fdfe11ad6e1080c4410dfd0e315d3bb5c6034", kill_on_drop: false }`
[INFO] [stdout] 5161bf878a27539968e2eb7c142fdfe11ad6e1080c4410dfd0e315d3bb5c6034
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] fbf43a7d67a568db2ac2bc36fc38b7905780bdce03f98e99155301ceb53391c6
[INFO] running `Command { std: "docker" "start" "-a" "fbf43a7d67a568db2ac2bc36fc38b7905780bdce03f98e99155301ceb53391c6", kill_on_drop: false }`
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]     Checking simd-adler32 v0.3.8
[INFO] [stderr]    Compiling siphasher v1.0.2
[INFO] [stderr]    Compiling beef v0.5.2
[INFO] [stderr]    Compiling libc v0.2.182
[INFO] [stderr]    Compiling regex-syntax v0.8.9
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]     Checking umath v0.0.7
[INFO] [stderr]     Checking bitflags v2.11.0
[INFO] [stderr]     Checking atools v0.1.12
[INFO] [stderr]     Checking anstream v0.5.0
[INFO] [stderr]     Checking array_chunks v1.0.0
[INFO] [stderr]     Checking unicode-width v0.1.14
[INFO] [stderr]     Checking mattr v0.0.2
[INFO] [stderr]    Compiling syn v2.0.116
[INFO] [stderr]     Checking clipline v0.4.0
[INFO] [stderr]     Checking hinted v1.0.0
[INFO] [stderr]     Checking rust-fuzzy-search v0.1.1
[INFO] [stderr]    Compiling phf_shared v0.12.1
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]     Checking fdeflate v0.3.7
[INFO] [stderr]     Checking vecto v0.1.1
[INFO] [stderr]    Compiling phf_generator v0.12.1
[INFO] [stderr]     Checking flate2 v1.1.9
[INFO] [stderr]     Checking png v0.18.1
[INFO] [stderr]    Compiling logos-codegen v0.14.4
[INFO] [stderr]    Compiling lower-macros v0.2.11
[INFO] [stderr]    Compiling car v0.1.3
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling phf_macros v0.12.1
[INFO] [stderr]    Compiling comat v0.1.3
[INFO] [stderr]    Compiling enum_dispatch v0.3.13
[INFO] [stderr]     Checking lerr v0.1.5
[INFO] [stderr]     Checking phf v0.12.1
[INFO] [stderr]    Compiling logos-derive v0.14.4
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking logos v0.14.4
[INFO] [stderr]     Checking lower v0.2.1
[INFO] [stderr]     Checking fimg v0.4.52
[INFO] [stderr]     Checking lemu v0.2.22 (/opt/rustwide/workdir)
[INFO] [stdout] warning: the feature `generic_const_exprs` is incomplete and may not be safe to use and/or cause compiler crashes
[INFO] [stdout]  --> src/lib.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | #![feature(generic_const_exprs, iter_array_chunks)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: see issue #76560 <https://github.com/rust-lang/rust/issues/76560> for more information
[INFO] [stdout]   = note: `#[warn(incomplete_features)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the feature `generic_const_exprs` is incomplete and may not be safe to use and/or cause compiler crashes
[INFO] [stdout]  --> src/lib.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | #![feature(generic_const_exprs, iter_array_chunks)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: see issue #76560 <https://github.com/rust-lang/rust/issues/76560> for more information
[INFO] [stdout]   = note: `#[warn(incomplete_features)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `COUNTER` is never used
[INFO] [stdout]  --> src/executor/mod.rs:2:7
[INFO] [stdout]   |
[INFO] [stdout] 2 | const COUNTER: LAddress = unsafe { LAddress::addr(0) };
[INFO] [stdout]   |       ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Priv` is never constructed
[INFO] [stdout]   --> src/memory.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct Priv {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/executor/mod.rs:223:46
[INFO] [stdout]     |
[INFO] [stdout] 223 |     pub fn get<'a>(&'a self, a: LAddress) -> &LVar<'s> {
[INFO] [stdout]     |                     --                       ^^^^^^^^^ the same lifetime is elided here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 223 |     pub fn get<'a>(&'a self, a: LAddress) -> &'a LVar<'s> {
[INFO] [stdout]     |                                               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function pointer comparisons do not produce meaningful results since their addresses are not guaranteed to be unique
[INFO] [stdout]    --> src/instructions/mod.rs:205:28
[INFO] [stdout]     |
[INFO] [stdout] 205 |                       $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout]     |                              ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/instructions/cop.rs:32:1
[INFO] [stdout]     |
[INFO] [stdout]  32 | / super::op_impl!(ConditionOp, ptr type = for<'f> fn(&LVar<'f>, &LVar<'f>) -> bool {
[INFO] [stdout]  33 | |     Equal => eq,
[INFO] [stdout]  34 | |     StrictEqual => eq,
[INFO] [stdout]  35 | |     NotEqual => ne,
[INFO] [stdout] ...   |
[INFO] [stdout]  39 | |     GreaterThanEq => ge,
[INFO] [stdout]  40 | | });
[INFO] [stdout]     | |__- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: the address of the same function can vary between different codegen units
[INFO] [stdout]     = note: furthermore, different functions could have the same address after being merged together
[INFO] [stdout]     = note: for more information visit <https://doc.rust-lang.org/nightly/core/ptr/fn.fn_addr_eq.html>
[INFO] [stdout]     = note: `#[warn(unpredictable_function_pointer_comparisons)]` on by default
[INFO] [stdout]     = note: this warning originates in the macro `super::op_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: refactor your code, or use `std::ptr::fn_addr_eq` to suppress the lint
[INFO] [stdout]     |
[INFO] [stdout] 205 -                     $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout] 205 +                     $(f if std::ptr::fn_addr_eq(f, $fn as for<'a, 'v, 'b> fn(&'a LVar<'v>, &'b LVar<'v>) -> bool) => Ok(Self::$own),)+
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function pointer comparisons do not produce meaningful results since their addresses are not guaranteed to be unique
[INFO] [stdout]    --> src/instructions/mod.rs:205:28
[INFO] [stdout]     |
[INFO] [stdout] 205 |                       $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout]     |                              ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/instructions/mop.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | / super::op_impl!(MathOp1, ptr type = for<'v> fn(&LVar<'v>) -> f64 {
[INFO] [stdout]  65 | |     Floor => floor,
[INFO] [stdout]  66 | |     Not => not,
[INFO] [stdout]  67 | |     Log => log,
[INFO] [stdout] ...   |
[INFO] [stdout]  78 | |     Log10 => log10,
[INFO] [stdout]  79 | | });
[INFO] [stdout]     | |__- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: the address of the same function can vary between different codegen units
[INFO] [stdout]     = note: furthermore, different functions could have the same address after being merged together
[INFO] [stdout]     = note: for more information visit <https://doc.rust-lang.org/nightly/core/ptr/fn.fn_addr_eq.html>
[INFO] [stdout]     = note: this warning originates in the macro `super::op_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: refactor your code, or use `std::ptr::fn_addr_eq` to suppress the lint
[INFO] [stdout]     |
[INFO] [stdout] 205 -                     $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout] 205 +                     $(f if std::ptr::fn_addr_eq(f, $fn as for<'a, 'b> fn(&'a LVar<'b>) -> f64) => Ok(Self::$own),)+
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function pointer comparisons do not produce meaningful results since their addresses are not guaranteed to be unique
[INFO] [stdout]    --> src/instructions/mod.rs:205:28
[INFO] [stdout]     |
[INFO] [stdout] 205 |                       $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout]     |                              ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/instructions/mop2.rs:103:1
[INFO] [stdout]     |
[INFO] [stdout] 103 | / super::op_impl!(MathOp2, ptr type = for<'f> fn(&LVar<'f>, &LVar<'f>) -> f64 {
[INFO] [stdout] 104 | |     Equal => eq,
[INFO] [stdout] 105 | |     StrictEqual => eq,
[INFO] [stdout] 106 | |     NotEqual => ne,
[INFO] [stdout] ...   |
[INFO] [stdout] 129 | |     Angle => angle,
[INFO] [stdout] 130 | | });
[INFO] [stdout]     | |__- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: the address of the same function can vary between different codegen units
[INFO] [stdout]     = note: furthermore, different functions could have the same address after being merged together
[INFO] [stdout]     = note: for more information visit <https://doc.rust-lang.org/nightly/core/ptr/fn.fn_addr_eq.html>
[INFO] [stdout]     = note: this warning originates in the macro `super::op_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: refactor your code, or use `std::ptr::fn_addr_eq` to suppress the lint
[INFO] [stdout]     |
[INFO] [stdout] 205 -                     $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout] 205 +                     $(f if std::ptr::fn_addr_eq(f, $fn as for<'a, 'v, 'b> fn(&'a LVar<'v>, &'b LVar<'v>) -> f64) => Ok(Self::$own),)+
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/memory.rs:154:16
[INFO] [stdout]     |
[INFO] [stdout] 154 |     pub fn get(&self, a: LAddress) -> &LVar {
[INFO] [stdout]     |                ^^^^^                  ^^^^^
[INFO] [stdout]     |                |                      ||
[INFO] [stdout]     |                |                      |the same lifetime is hidden here
[INFO] [stdout]     |                |                      the same lifetime is elided here
[INFO] [stdout]     |                the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 154 |     pub fn get(&self, a: LAddress) -> &LVar<'_> {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `COUNTER` is never used
[INFO] [stdout]  --> src/executor/mod.rs:2:7
[INFO] [stdout]   |
[INFO] [stdout] 2 | const COUNTER: LAddress = unsafe { LAddress::addr(0) };
[INFO] [stdout]   |       ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Priv` is never constructed
[INFO] [stdout]   --> src/memory.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct Priv {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/executor/mod.rs:223:46
[INFO] [stdout]     |
[INFO] [stdout] 223 |     pub fn get<'a>(&'a self, a: LAddress) -> &LVar<'s> {
[INFO] [stdout]     |                     --                       ^^^^^^^^^ the same lifetime is elided here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 223 |     pub fn get<'a>(&'a self, a: LAddress) -> &'a LVar<'s> {
[INFO] [stdout]     |                                               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function pointer comparisons do not produce meaningful results since their addresses are not guaranteed to be unique
[INFO] [stdout]    --> src/instructions/mod.rs:205:28
[INFO] [stdout]     |
[INFO] [stdout] 205 |                       $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout]     |                              ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/instructions/cop.rs:32:1
[INFO] [stdout]     |
[INFO] [stdout]  32 | / super::op_impl!(ConditionOp, ptr type = for<'f> fn(&LVar<'f>, &LVar<'f>) -> bool {
[INFO] [stdout]  33 | |     Equal => eq,
[INFO] [stdout]  34 | |     StrictEqual => eq,
[INFO] [stdout]  35 | |     NotEqual => ne,
[INFO] [stdout] ...   |
[INFO] [stdout]  39 | |     GreaterThanEq => ge,
[INFO] [stdout]  40 | | });
[INFO] [stdout]     | |__- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: the address of the same function can vary between different codegen units
[INFO] [stdout]     = note: furthermore, different functions could have the same address after being merged together
[INFO] [stdout]     = note: for more information visit <https://doc.rust-lang.org/nightly/core/ptr/fn.fn_addr_eq.html>
[INFO] [stdout]     = note: `#[warn(unpredictable_function_pointer_comparisons)]` on by default
[INFO] [stdout]     = note: this warning originates in the macro `super::op_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: refactor your code, or use `std::ptr::fn_addr_eq` to suppress the lint
[INFO] [stdout]     |
[INFO] [stdout] 205 -                     $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout] 205 +                     $(f if std::ptr::fn_addr_eq(f, $fn as for<'a, 'v, 'b> fn(&'a LVar<'v>, &'b LVar<'v>) -> bool) => Ok(Self::$own),)+
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function pointer comparisons do not produce meaningful results since their addresses are not guaranteed to be unique
[INFO] [stdout]    --> src/instructions/mod.rs:205:28
[INFO] [stdout]     |
[INFO] [stdout] 205 |                       $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout]     |                              ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/instructions/mop.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | / super::op_impl!(MathOp1, ptr type = for<'v> fn(&LVar<'v>) -> f64 {
[INFO] [stdout]  65 | |     Floor => floor,
[INFO] [stdout]  66 | |     Not => not,
[INFO] [stdout]  67 | |     Log => log,
[INFO] [stdout] ...   |
[INFO] [stdout]  78 | |     Log10 => log10,
[INFO] [stdout]  79 | | });
[INFO] [stdout]     | |__- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: the address of the same function can vary between different codegen units
[INFO] [stdout]     = note: furthermore, different functions could have the same address after being merged together
[INFO] [stdout]     = note: for more information visit <https://doc.rust-lang.org/nightly/core/ptr/fn.fn_addr_eq.html>
[INFO] [stdout]     = note: this warning originates in the macro `super::op_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: refactor your code, or use `std::ptr::fn_addr_eq` to suppress the lint
[INFO] [stdout]     |
[INFO] [stdout] 205 -                     $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout] 205 +                     $(f if std::ptr::fn_addr_eq(f, $fn as for<'a, 'b> fn(&'a LVar<'b>) -> f64) => Ok(Self::$own),)+
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function pointer comparisons do not produce meaningful results since their addresses are not guaranteed to be unique
[INFO] [stdout]    --> src/instructions/mod.rs:205:28
[INFO] [stdout]     |
[INFO] [stdout] 205 |                       $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout]     |                              ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/instructions/mop2.rs:103:1
[INFO] [stdout]     |
[INFO] [stdout] 103 | / super::op_impl!(MathOp2, ptr type = for<'f> fn(&LVar<'f>, &LVar<'f>) -> f64 {
[INFO] [stdout] 104 | |     Equal => eq,
[INFO] [stdout] 105 | |     StrictEqual => eq,
[INFO] [stdout] 106 | |     NotEqual => ne,
[INFO] [stdout] ...   |
[INFO] [stdout] 129 | |     Angle => angle,
[INFO] [stdout] 130 | | });
[INFO] [stdout]     | |__- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: the address of the same function can vary between different codegen units
[INFO] [stdout]     = note: furthermore, different functions could have the same address after being merged together
[INFO] [stdout]     = note: for more information visit <https://doc.rust-lang.org/nightly/core/ptr/fn.fn_addr_eq.html>
[INFO] [stdout]     = note: this warning originates in the macro `super::op_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: refactor your code, or use `std::ptr::fn_addr_eq` to suppress the lint
[INFO] [stdout]     |
[INFO] [stdout] 205 -                     $(f if f == $fn => Ok(Self::$own),)+
[INFO] [stdout] 205 +                     $(f if std::ptr::fn_addr_eq(f, $fn as for<'a, 'v, 'b> fn(&'a LVar<'v>, &'b LVar<'v>) -> f64) => Ok(Self::$own),)+
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/memory.rs:154:16
[INFO] [stdout]     |
[INFO] [stdout] 154 |     pub fn get(&self, a: LAddress) -> &LVar {
[INFO] [stdout]     |                ^^^^^                  ^^^^^
[INFO] [stdout]     |                |                      ||
[INFO] [stdout]     |                |                      |the same lifetime is hidden here
[INFO] [stdout]     |                |                      the same lifetime is elided here
[INFO] [stdout]     |                the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 154 |     pub fn get(&self, a: LAddress) -> &LVar<'_> {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 10.68s
[INFO] running `Command { std: "docker" "inspect" "fbf43a7d67a568db2ac2bc36fc38b7905780bdce03f98e99155301ceb53391c6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fbf43a7d67a568db2ac2bc36fc38b7905780bdce03f98e99155301ceb53391c6", kill_on_drop: false }`
[INFO] [stdout] fbf43a7d67a568db2ac2bc36fc38b7905780bdce03f98e99155301ceb53391c6
