[INFO] fetching crate yatima-core 0.1.1...
[INFO] testing yatima-core-0.1.1 against master#0d162b25edd5bf0dba9a22e83b614f1113e90474 for pr-150681-1
[INFO] extracting crate yatima-core 0.1.1 into /workspace/builds/worker-7-tc1/source
[INFO] started tweaking crates.io crate yatima-core 0.1.1
[INFO] finished tweaking crates.io crate yatima-core 0.1.1
[INFO] tweaked toml for crates.io crate yatima-core 0.1.1 written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate yatima-core 0.1.1 on toolchain 0d162b25edd5bf0dba9a22e83b614f1113e90474
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 102 packages to latest compatible versions
[INFO] [stderr]       Adding aho-corasick v0.7.15 (available: v0.7.20)
[INFO] [stderr]       Adding memchr v2.3.4 (available: v2.7.6)
[INFO] [stderr]       Adding nom v6.2.2 (available: v8.0.0)
[INFO] [stderr]       Adding nom_locate v3.0.2 (available: v5.0.0)
[INFO] [stderr]       Adding num-bigint v0.3.3 (available: v0.4.6)
[INFO] [stderr]       Adding rand v0.8.5 (available: v0.9.2)
[INFO] [stderr]       Adding regex v1.4.6 (available: v1.12.2)
[INFO] [stderr]       Adding sp-cid v0.2.0 (available: v0.3.0)
[INFO] [stderr]       Adding sp-im v0.2.1 (available: v0.3.0)
[INFO] [stderr]       Adding sp-ipld v0.1.2 (available: v0.2.0)
[INFO] [stderr]       Adding sp-multihash v0.2.0 (available: v0.3.0)
[INFO] [stderr]       Adding sp-ropey v0.1.0 (available: v0.2.0)
[INFO] [stderr]       Adding sp-std v3.0.0 (available: v14.0.0)
[INFO] [stderr]       Adding toml_edit v0.19.12 (available: v0.19.15)
[INFO] [stderr]       Adding winnow v0.4.7 (available: v0.4.12)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded bitmaps v3.2.1
[INFO] [stderr]   Downloaded sp-std v3.0.0
[INFO] [stderr]   Downloaded synstructure v0.12.6
[INFO] [stderr]   Downloaded proc-macro-crate v1.3.1
[INFO] [stderr]   Downloaded unsigned-varint v0.7.2
[INFO] [stderr]   Downloaded sp-multihash-derive v0.2.0
[INFO] [stderr]   Downloaded sp-multihash v0.2.0
[INFO] [stderr]   Downloaded match-lookup v0.1.1
[INFO] [stderr]   Downloaded sp-sized-chunks v0.1.0
[INFO] [stderr]   Downloaded funty v1.1.0
[INFO] [stderr]   Downloaded quickcheck_macros v1.1.0
[INFO] [stderr]   Downloaded radium v0.5.3
[INFO] [stderr]   Downloaded base-x v0.2.11
[INFO] [stderr]   Downloaded base256emoji v1.0.2
[INFO] [stderr]   Downloaded wyz v0.2.0
[INFO] [stderr]   Downloaded arrayvec v0.5.2
[INFO] [stderr]   Downloaded nom_locate v3.0.2
[INFO] [stderr]   Downloaded sp-ipld v0.1.2
[INFO] [stderr]   Downloaded blake2b_simd v0.5.11
[INFO] [stderr]   Downloaded blake2s_simd v0.5.11
[INFO] [stderr]   Downloaded num-bigint v0.3.3
[INFO] [stderr]   Downloaded aho-corasick v0.7.15
[INFO] [stderr]   Downloaded bitvec v0.19.6
[INFO] [stderr]   Downloaded nom v6.2.2
[INFO] [stderr]   Downloaded winnow v0.4.7
[INFO] [stderr]   Downloaded blake3 v0.3.8
[INFO] [stderr]   Downloaded sp-ropey v0.1.0
[INFO] [stderr]   Downloaded sp-im v0.2.1
[INFO] [stderr]   Downloaded toml_edit v0.19.12
[INFO] [stderr]   Downloaded regex v1.4.6
[INFO] [stderr]   Downloaded rand_xoshiro v0.4.0
[INFO] [stderr]   Downloaded const-str v0.4.3
[INFO] [stderr]   Downloaded data-encoding-macro-internal v0.1.16
[INFO] [stderr]   Downloaded data-encoding-macro v0.1.18
[INFO] [stderr]   Downloaded sp-cid v0.2.0
[INFO] [stderr]   Downloaded bytecursor v0.1.2
[INFO] [stderr]   Downloaded block-padding v0.2.1
[INFO] [stderr]   Downloaded multibase v0.9.2
[INFO] [stderr]   Downloaded memchr v2.3.4
[INFO] [stderr]   Downloaded sha3 v0.9.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 3721d98e78c6c1c0a8f41c7ca40a86fb88cf7e3ea24eed5dddf1f5e4e2d35900
[INFO] running `Command { std: "docker" "start" "-a" "3721d98e78c6c1c0a8f41c7ca40a86fb88cf7e3ea24eed5dddf1f5e4e2d35900", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "3721d98e78c6c1c0a8f41c7ca40a86fb88cf7e3ea24eed5dddf1f5e4e2d35900", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3721d98e78c6c1c0a8f41c7ca40a86fb88cf7e3ea24eed5dddf1f5e4e2d35900", kill_on_drop: false }`
[INFO] [stdout] 3721d98e78c6c1c0a8f41c7ca40a86fb88cf7e3ea24eed5dddf1f5e4e2d35900
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 9cb170cecfcb0c884be27d3ea6aefb50910a474e73b7b1b167a81377da622e9f
[INFO] running `Command { std: "docker" "start" "-a" "9cb170cecfcb0c884be27d3ea6aefb50910a474e73b7b1b167a81377da622e9f", kill_on_drop: false }`
[INFO] [stderr]    Compiling version_check v0.9.5
[INFO] [stderr]    Compiling proc-macro2 v1.0.105
[INFO] [stderr]    Compiling quote v1.0.43
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]    Compiling equivalent v1.0.2
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling block-padding v0.2.1
[INFO] [stderr]    Compiling constant_time_eq v0.1.5
[INFO] [stderr]    Compiling memchr v2.3.4
[INFO] [stderr]    Compiling sp-std v3.0.0
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling winnow v0.4.7
[INFO] [stderr]    Compiling arrayref v0.3.9
[INFO] [stderr]    Compiling arrayvec v0.5.2
[INFO] [stderr]    Compiling blake3 v0.3.8
[INFO] [stderr]    Compiling unicode-xid v0.2.6
[INFO] [stderr]    Compiling opaque-debug v0.3.1
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling data-encoding v2.9.0
[INFO] [stderr]    Compiling subtle v2.6.1
[INFO] [stderr]    Compiling radium v0.5.3
[INFO] [stderr]    Compiling cpufeatures v0.2.17
[INFO] [stderr]    Compiling cfg-if v0.1.10
[INFO] [stderr]    Compiling cfg-if v1.0.4
[INFO] [stderr]    Compiling const-str v0.4.3
[INFO] [stderr]    Compiling keccak v0.1.5
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling bytecursor v0.1.2
[INFO] [stderr]    Compiling tap v1.0.1
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling generic-array v0.14.9
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]    Compiling nom v6.2.2
[INFO] [stderr]    Compiling blake2s_simd v0.5.11
[INFO] [stderr]    Compiling blake2b_simd v0.5.11
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling wyz v0.2.0
[INFO] [stderr]    Compiling unsigned-varint v0.7.2
[INFO] [stderr]    Compiling funty v1.1.0
[INFO] [stderr]    Compiling base-x v0.2.11
[INFO] [stderr]    Compiling lock_api v0.4.14
[INFO] [stderr]    Compiling num-bigint v0.3.3
[INFO] [stderr]    Compiling rand_core v0.5.1
[INFO] [stderr]    Compiling bitmaps v3.2.1
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling rand_xoshiro v0.4.0
[INFO] [stderr]    Compiling bytecount v0.6.9
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]    Compiling sp-ropey v0.1.0
[INFO] [stderr]    Compiling bitvec v0.19.6
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling sp-sized-chunks v0.1.0
[INFO] [stderr]    Compiling sp-im v0.2.1
[INFO] [stderr]    Compiling digest v0.9.0
[INFO] [stderr]    Compiling block-buffer v0.9.0
[INFO] [stderr]    Compiling crypto-mac v0.8.0
[INFO] [stderr]    Compiling sha3 v0.9.1
[INFO] [stderr]    Compiling sha2 v0.9.9
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling toml_edit v0.19.12
[INFO] [stderr]    Compiling proc-macro-crate v1.3.1
[INFO] [stderr]    Compiling data-encoding-macro-internal v0.1.16
[INFO] [stderr]    Compiling data-encoding-macro v0.1.18
[INFO] [stderr]    Compiling synstructure v0.12.6
[INFO] [stderr]    Compiling match-lookup v0.1.1
[INFO] [stderr]    Compiling sp-multihash-derive v0.2.0
[INFO] [stderr]    Compiling base256emoji v1.0.2
[INFO] [stderr]    Compiling multibase v0.9.2
[INFO] [stderr]    Compiling sp-multihash v0.2.0
[INFO] [stderr]    Compiling nom_locate v3.0.2
[INFO] [stderr]    Compiling sp-cid v0.2.0
[INFO] [stderr]    Compiling sp-ipld v0.1.2
[INFO] [stderr]    Compiling yatima-core v0.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dag.rs:512:11
[INFO] [stdout]     |
[INFO] [stdout] 512 |           last_old.map_or((), |last_old| (*last_old.as_ptr()).next = first_new);
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 512 |           let _ = last_old.map_or((), |last_old| (*last_old.as_ptr()).next = first_new);
[INFO] [stdout]     |           +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dag.rs:516:7
[INFO] [stdout]     |
[INFO] [stdout] 516 |       first_new.map_or((), |first_new| (*first_new.as_ptr()).prev = last_old);
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 516 |       let _ = first_new.map_or((), |first_new| (*first_new.as_ptr()).prev = last_old);
[INFO] [stdout]     |       +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:544:9
[INFO] [stdout]     |
[INFO] [stdout] 544 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 544 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:553:9
[INFO] [stdout]     |
[INFO] [stdout] 553 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 553 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:562:9
[INFO] [stdout]     |
[INFO] [stdout] 562 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 562 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:571:9
[INFO] [stdout]     |
[INFO] [stdout] 571 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 571 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:580:9
[INFO] [stdout]     |
[INFO] [stdout] 580 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 580 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:595:9
[INFO] [stdout]     |
[INFO] [stdout] 595 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 595 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:609:9
[INFO] [stdout]     |
[INFO] [stdout] 609 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 609 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:623:9
[INFO] [stdout]     |
[INFO] [stdout] 623 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 623 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:644:9
[INFO] [stdout]     |
[INFO] [stdout] 644 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 644 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:650:11
[INFO] [stdout]     |
[INFO] [stdout] 650 |           Box::from_raw(link.as_ptr());
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 650 |           let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |           +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:654:9
[INFO] [stdout]     |
[INFO] [stdout] 654 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 654 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:657:9
[INFO] [stdout]     |
[INFO] [stdout] 657 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 657 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:660:9
[INFO] [stdout]     |
[INFO] [stdout] 660 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 660 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:663:9
[INFO] [stdout]     |
[INFO] [stdout] 663 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 663 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:666:9
[INFO] [stdout]     |
[INFO] [stdout] 666 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 666 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:681:9
[INFO] [stdout]     |
[INFO] [stdout] 681 |         Box::from_raw(pref.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 681 |         let _ = Box::from_raw(pref.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]   --> src/dll.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 79 |     self.next.map_or((), |ptr| unsafe { (*ptr.as_ptr()).prev = new_next });
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 79 |     let _ = self.next.map_or((), |ptr| unsafe { (*ptr.as_ptr()).prev = new_next });
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]   --> src/dll.rs:90:5
[INFO] [stdout]    |
[INFO] [stdout] 90 |     self.prev.map_or((), |ptr| unsafe { (*ptr.as_ptr()).next = new_prev });
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 90 |     let _ = self.prev.map_or((), |ptr| unsafe { (*ptr.as_ptr()).next = new_prev });
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dll.rs:100:7
[INFO] [stdout]     |
[INFO] [stdout] 100 |       self.prev.map_or((), |ptr| (*ptr.as_ptr()).next = Some(node));
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 100 |       let _ = self.prev.map_or((), |ptr| (*ptr.as_ptr()).next = Some(node));
[INFO] [stdout]     |       +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dll.rs:152:5
[INFO] [stdout]     |
[INFO] [stdout] 152 | /     first.map_or((), |first| unsafe {
[INFO] [stdout] 153 | |       (*first.as_ptr()).prev = Some(last);
[INFO] [stdout] 154 | |     });
[INFO] [stdout]     | |______^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 152 |     let _ = first.map_or((), |first| unsafe {
[INFO] [stdout]     |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/eval.rs:592:8
[INFO] [stdout]     |
[INFO] [stdout] 592 |     i: &str,
[INFO] [stdout]     |        ^^^^ the lifetime is elided here
[INFO] [stdout] 593 |   ) -> nom::IResult<Span, DAG, crate::parse::error::ParseError<Span>> {
[INFO] [stdout]     |                     ^^^^ the same lifetime is hidden here      ^^^^ the same lifetime is hidden 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: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 593 |   ) -> nom::IResult<Span<'_>, DAG, crate::parse::error::ParseError<Span<'_>>> {
[INFO] [stdout]     |                         ++++                                           ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/eval.rs:601:8
[INFO] [stdout]     |
[INFO] [stdout] 601 |     i: &str,
[INFO] [stdout]     |        ^^^^ the lifetime is elided here
[INFO] [stdout] 602 |   ) -> nom::IResult<Span, Defs, crate::parse::error::ParseError<Span>> {
[INFO] [stdout]     |                     ^^^^ the same lifetime is hidden here       ^^^^ the same lifetime is hidden 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] 602 |   ) -> nom::IResult<Span<'_>, Defs, crate::parse::error::ParseError<Span<'_>>> {
[INFO] [stdout]     |                         ++++                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1026:17
[INFO] [stdout]      |
[INFO] [stdout] 1026 | pub fn parse(i: &str, defs: Defs) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stdout]      |                 ^^^^                         ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stdout]      |                 |                            |
[INFO] [stdout]      |                 |                            the same lifetime is hidden 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] 1026 | pub fn parse(i: &str, defs: Defs) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stdout]      |                                                  ++++                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1038:6
[INFO] [stdout]      |
[INFO] [stdout] 1038 |   i: &str,
[INFO] [stdout]      |      ^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 1041 | ) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stdout]      |              ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stdout]      |              |
[INFO] [stdout]      |              the same lifetime is hidden 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] 1041 | ) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[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/prim/io.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     self.fun_symbol == rhs.fun_symbol
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[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] help: refactor your code, or use `std::ptr::fn_addr_eq` to suppress the lint
[INFO] [stdout]    |
[INFO] [stdout] 23 -     self.fun_symbol == rhs.fun_symbol
[INFO] [stdout] 23 +     std::ptr::fn_addr_eq(self.fun_symbol, rhs.fun_symbol)
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 36.27s
[INFO] running `Command { std: "docker" "inspect" "9cb170cecfcb0c884be27d3ea6aefb50910a474e73b7b1b167a81377da622e9f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9cb170cecfcb0c884be27d3ea6aefb50910a474e73b7b1b167a81377da622e9f", kill_on_drop: false }`
[INFO] [stdout] 9cb170cecfcb0c884be27d3ea6aefb50910a474e73b7b1b167a81377da622e9f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a3e52d793a755d9f9992e4495458c253c7ccbd8b2df98b1e14d5fb7e0be6b748
[INFO] running `Command { std: "docker" "start" "-a" "a3e52d793a755d9f9992e4495458c253c7ccbd8b2df98b1e14d5fb7e0be6b748", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.179
[INFO] [stderr]    Compiling zerocopy v0.8.33
[INFO] [stderr]    Compiling aho-corasick v0.7.15
[INFO] [stderr]    Compiling regex-syntax v0.6.29
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dag.rs:512:11
[INFO] [stdout]     |
[INFO] [stdout] 512 |           last_old.map_or((), |last_old| (*last_old.as_ptr()).next = first_new);
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 512 |           let _ = last_old.map_or((), |last_old| (*last_old.as_ptr()).next = first_new);
[INFO] [stdout]     |           +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dag.rs:516:7
[INFO] [stdout]     |
[INFO] [stdout] 516 |       first_new.map_or((), |first_new| (*first_new.as_ptr()).prev = last_old);
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 516 |       let _ = first_new.map_or((), |first_new| (*first_new.as_ptr()).prev = last_old);
[INFO] [stdout]     |       +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:544:9
[INFO] [stdout]     |
[INFO] [stdout] 544 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 544 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:553:9
[INFO] [stdout]     |
[INFO] [stdout] 553 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 553 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:562:9
[INFO] [stdout]     |
[INFO] [stdout] 562 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 562 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:571:9
[INFO] [stdout]     |
[INFO] [stdout] 571 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 571 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:580:9
[INFO] [stdout]     |
[INFO] [stdout] 580 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 580 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:595:9
[INFO] [stdout]     |
[INFO] [stdout] 595 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 595 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling log v0.4.29
[INFO] [stderr]    Compiling quickcheck_macros v1.1.0
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:609:9
[INFO] [stdout]     |
[INFO] [stdout] 609 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 609 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:623:9
[INFO] [stdout]     |
[INFO] [stdout] 623 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 623 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:644:9
[INFO] [stdout]     |
[INFO] [stdout] 644 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 644 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:650:11
[INFO] [stdout]     |
[INFO] [stdout] 650 |           Box::from_raw(link.as_ptr());
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 650 |           let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |           +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:654:9
[INFO] [stdout]     |
[INFO] [stdout] 654 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 654 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:657:9
[INFO] [stdout]     |
[INFO] [stdout] 657 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 657 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:660:9
[INFO] [stdout]     |
[INFO] [stdout] 660 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 660 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:663:9
[INFO] [stdout]     |
[INFO] [stdout] 663 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 663 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:666:9
[INFO] [stdout]     |
[INFO] [stdout] 666 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 666 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:681:9
[INFO] [stdout]     |
[INFO] [stdout] 681 |         Box::from_raw(pref.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 681 |         let _ = Box::from_raw(pref.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]   --> src/dll.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 79 |     self.next.map_or((), |ptr| unsafe { (*ptr.as_ptr()).prev = new_next });
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 79 |     let _ = self.next.map_or((), |ptr| unsafe { (*ptr.as_ptr()).prev = new_next });
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]   --> src/dll.rs:90:5
[INFO] [stdout]    |
[INFO] [stdout] 90 |     self.prev.map_or((), |ptr| unsafe { (*ptr.as_ptr()).next = new_prev });
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 90 |     let _ = self.prev.map_or((), |ptr| unsafe { (*ptr.as_ptr()).next = new_prev });
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dll.rs:100:7
[INFO] [stdout]     |
[INFO] [stdout] 100 |       self.prev.map_or((), |ptr| (*ptr.as_ptr()).next = Some(node));
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 100 |       let _ = self.prev.map_or((), |ptr| (*ptr.as_ptr()).next = Some(node));
[INFO] [stdout]     |       +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dll.rs:152:5
[INFO] [stdout]     |
[INFO] [stdout] 152 | /     first.map_or((), |first| unsafe {
[INFO] [stdout] 153 | |       (*first.as_ptr()).prev = Some(last);
[INFO] [stdout] 154 | |     });
[INFO] [stdout]     | |______^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 152 |     let _ = first.map_or((), |first| unsafe {
[INFO] [stdout]     |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/eval.rs:592:8
[INFO] [stdout]     |
[INFO] [stdout] 592 |     i: &str,
[INFO] [stdout]     |        ^^^^ the lifetime is elided here
[INFO] [stdout] 593 |   ) -> nom::IResult<Span, DAG, crate::parse::error::ParseError<Span>> {
[INFO] [stdout]     |                     ^^^^ the same lifetime is hidden here      ^^^^ the same lifetime is hidden 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: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 593 |   ) -> nom::IResult<Span<'_>, DAG, crate::parse::error::ParseError<Span<'_>>> {
[INFO] [stdout]     |                         ++++                                           ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/eval.rs:601:8
[INFO] [stdout]     |
[INFO] [stdout] 601 |     i: &str,
[INFO] [stdout]     |        ^^^^ the lifetime is elided here
[INFO] [stdout] 602 |   ) -> nom::IResult<Span, Defs, crate::parse::error::ParseError<Span>> {
[INFO] [stdout]     |                     ^^^^ the same lifetime is hidden here       ^^^^ the same lifetime is hidden 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] 602 |   ) -> nom::IResult<Span<'_>, Defs, crate::parse::error::ParseError<Span<'_>>> {
[INFO] [stdout]     |                         ++++                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1026:17
[INFO] [stdout]      |
[INFO] [stdout] 1026 | pub fn parse(i: &str, defs: Defs) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stdout]      |                 ^^^^                         ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stdout]      |                 |                            |
[INFO] [stdout]      |                 |                            the same lifetime is hidden 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] 1026 | pub fn parse(i: &str, defs: Defs) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stdout]      |                                                  ++++                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1038:6
[INFO] [stdout]      |
[INFO] [stdout] 1038 |   i: &str,
[INFO] [stdout]      |      ^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 1041 | ) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stdout]      |              ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stdout]      |              |
[INFO] [stdout]      |              the same lifetime is hidden 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] 1041 | ) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[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/prim/io.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     self.fun_symbol == rhs.fun_symbol
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[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] help: refactor your code, or use `std::ptr::fn_addr_eq` to suppress the lint
[INFO] [stdout]    |
[INFO] [stdout] 23 -     self.fun_symbol == rhs.fun_symbol
[INFO] [stdout] 23 +     std::ptr::fn_addr_eq(self.fun_symbol, rhs.fun_symbol)
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling regex v1.4.6
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling env_logger v0.8.4
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling quickcheck v1.0.3
[INFO] [stderr]    Compiling yatima-core v0.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dag.rs:512:11
[INFO] [stdout]     |
[INFO] [stdout] 512 |           last_old.map_or((), |last_old| (*last_old.as_ptr()).next = first_new);
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 512 |           let _ = last_old.map_or((), |last_old| (*last_old.as_ptr()).next = first_new);
[INFO] [stdout]     |           +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dag.rs:516:7
[INFO] [stdout]     |
[INFO] [stdout] 516 |       first_new.map_or((), |first_new| (*first_new.as_ptr()).prev = last_old);
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 516 |       let _ = first_new.map_or((), |first_new| (*first_new.as_ptr()).prev = last_old);
[INFO] [stdout]     |       +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:544:9
[INFO] [stdout]     |
[INFO] [stdout] 544 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 544 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:553:9
[INFO] [stdout]     |
[INFO] [stdout] 553 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 553 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:562:9
[INFO] [stdout]     |
[INFO] [stdout] 562 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 562 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:571:9
[INFO] [stdout]     |
[INFO] [stdout] 571 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 571 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:580:9
[INFO] [stdout]     |
[INFO] [stdout] 580 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 580 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:595:9
[INFO] [stdout]     |
[INFO] [stdout] 595 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 595 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:609:9
[INFO] [stdout]     |
[INFO] [stdout] 609 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 609 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:623:9
[INFO] [stdout]     |
[INFO] [stdout] 623 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 623 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:644:9
[INFO] [stdout]     |
[INFO] [stdout] 644 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 644 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:650:11
[INFO] [stdout]     |
[INFO] [stdout] 650 |           Box::from_raw(link.as_ptr());
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 650 |           let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |           +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:654:9
[INFO] [stdout]     |
[INFO] [stdout] 654 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 654 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:657:9
[INFO] [stdout]     |
[INFO] [stdout] 657 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 657 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:660:9
[INFO] [stdout]     |
[INFO] [stdout] 660 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 660 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:663:9
[INFO] [stdout]     |
[INFO] [stdout] 663 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 663 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:666:9
[INFO] [stdout]     |
[INFO] [stdout] 666 |         Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 666 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/dag.rs:681:9
[INFO] [stdout]     |
[INFO] [stdout] 681 |         Box::from_raw(pref.as_ptr());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 681 |         let _ = Box::from_raw(pref.as_ptr());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]   --> src/dll.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 79 |     self.next.map_or((), |ptr| unsafe { (*ptr.as_ptr()).prev = new_next });
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 79 |     let _ = self.next.map_or((), |ptr| unsafe { (*ptr.as_ptr()).prev = new_next });
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]   --> src/dll.rs:90:5
[INFO] [stdout]    |
[INFO] [stdout] 90 |     self.prev.map_or((), |ptr| unsafe { (*ptr.as_ptr()).next = new_prev });
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 90 |     let _ = self.prev.map_or((), |ptr| unsafe { (*ptr.as_ptr()).next = new_prev });
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dll.rs:100:7
[INFO] [stdout]     |
[INFO] [stdout] 100 |       self.prev.map_or((), |ptr| (*ptr.as_ptr()).next = Some(node));
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 100 |       let _ = self.prev.map_or((), |ptr| (*ptr.as_ptr()).next = Some(node));
[INFO] [stdout]     |       +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stdout]    --> src/dll.rs:152:5
[INFO] [stdout]     |
[INFO] [stdout] 152 | /     first.map_or((), |first| unsafe {
[INFO] [stdout] 153 | |       (*first.as_ptr()).prev = Some(last);
[INFO] [stdout] 154 | |     });
[INFO] [stdout]     | |______^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 152 |     let _ = first.map_or((), |first| unsafe {
[INFO] [stdout]     |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/eval.rs:592:8
[INFO] [stdout]     |
[INFO] [stdout] 592 |     i: &str,
[INFO] [stdout]     |        ^^^^ the lifetime is elided here
[INFO] [stdout] 593 |   ) -> nom::IResult<Span, DAG, crate::parse::error::ParseError<Span>> {
[INFO] [stdout]     |                     ^^^^ the same lifetime is hidden here      ^^^^ the same lifetime is hidden 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: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 593 |   ) -> nom::IResult<Span<'_>, DAG, crate::parse::error::ParseError<Span<'_>>> {
[INFO] [stdout]     |                         ++++                                           ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/eval.rs:601:8
[INFO] [stdout]     |
[INFO] [stdout] 601 |     i: &str,
[INFO] [stdout]     |        ^^^^ the lifetime is elided here
[INFO] [stdout] 602 |   ) -> nom::IResult<Span, Defs, crate::parse::error::ParseError<Span>> {
[INFO] [stdout]     |                     ^^^^ the same lifetime is hidden here       ^^^^ the same lifetime is hidden 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] 602 |   ) -> nom::IResult<Span<'_>, Defs, crate::parse::error::ParseError<Span<'_>>> {
[INFO] [stdout]     |                         ++++                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1026:17
[INFO] [stdout]      |
[INFO] [stdout] 1026 | pub fn parse(i: &str, defs: Defs) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stdout]      |                 ^^^^                         ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stdout]      |                 |                            |
[INFO] [stdout]      |                 |                            the same lifetime is hidden 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] 1026 | pub fn parse(i: &str, defs: Defs) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stdout]      |                                                  ++++                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1038:6
[INFO] [stdout]      |
[INFO] [stdout] 1038 |   i: &str,
[INFO] [stdout]      |      ^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 1041 | ) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stdout]      |              ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stdout]      |              |
[INFO] [stdout]      |              the same lifetime is hidden 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] 1041 | ) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stdout]      |                  ++++                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1077:16
[INFO] [stdout]      |
[INFO] [stdout] 1077 |     fn test(i: &str) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stdout]      |                ^^^^             ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stdout]      |                |                |
[INFO] [stdout]      |                |                the same lifetime is hidden 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] 1077 |     fn test(i: &str) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stdout]      |                                     ++++                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1096:16
[INFO] [stdout]      |
[INFO] [stdout] 1096 |     fn test(i: &str) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stdout]      |                ^^^^             ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stdout]      |                |                |
[INFO] [stdout]      |                |                the same lifetime is hidden 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] 1096 |     fn test(i: &str) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stdout]      |                                     ++++                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1127:10
[INFO] [stdout]      |
[INFO] [stdout] 1127 |       i: &str,
[INFO] [stdout]      |          ^^^^ the lifetime is elided here
[INFO] [stdout] 1128 |     ) -> IResult<Span, Vec<(Uses, Name, Term)>, ParseError<Span>> {
[INFO] [stdout]      |                  ^^^^ the same lifetime is hidden here     ^^^^ the same lifetime is hidden 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] 1128 |     ) -> IResult<Span<'_>, Vec<(Uses, Name, Term)>, ParseError<Span<'_>>> {
[INFO] [stdout]      |                      ++++                                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1172:10
[INFO] [stdout]      |
[INFO] [stdout] 1172 |       i: &str,
[INFO] [stdout]      |          ^^^^ the lifetime is elided here
[INFO] [stdout] 1173 |     ) -> IResult<Span, Vec<(Uses, Name, Term)>, ParseError<Span>> {
[INFO] [stdout]      |                  ^^^^ the same lifetime is hidden here     ^^^^ the same lifetime is hidden 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] 1173 |     ) -> IResult<Span<'_>, Vec<(Uses, Name, Term)>, ParseError<Span<'_>>> {
[INFO] [stdout]      |                      ++++                                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1221:16
[INFO] [stdout]      |
[INFO] [stdout] 1221 |     fn test(i: &str) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stdout]      |                ^^^^             ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stdout]      |                |                |
[INFO] [stdout]      |                |                the same lifetime is hidden 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] 1221 |     fn test(i: &str) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stdout]      |                                     ++++                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1237:16
[INFO] [stdout]      |
[INFO] [stdout] 1237 |     fn test(i: &str) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stdout]      |                ^^^^             ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stdout]      |                |                |
[INFO] [stdout]      |                |                the same lifetime is hidden 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] 1237 |     fn test(i: &str) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stdout]      |                                     ++++                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1270:10
[INFO] [stdout]      |
[INFO] [stdout] 1270 |       i: &str,
[INFO] [stdout]      |          ^^^^ the lifetime is elided here
[INFO] [stdout] 1271 |     ) -> IResult<Span, (Term, Term), ParseError<Span>> {
[INFO] [stdout]      |                  ^^^^                           ^^^^ the same lifetime is hidden here
[INFO] [stdout]      |                  |
[INFO] [stdout]      |                  the same lifetime is hidden 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] 1271 |     ) -> IResult<Span<'_>, (Term, Term), ParseError<Span<'_>>> {
[INFO] [stdout]      |                      ++++                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1317:10
[INFO] [stdout]      |
[INFO] [stdout] 1317 |       i: &str,
[INFO] [stdout]      |          ^^^^ the lifetime is elided here
[INFO] [stdout] 1318 |     ) -> IResult<Span, Vec<(Uses, Name, Term)>, ParseError<Span>> {
[INFO] [stdout]      |                  ^^^^ the same lifetime is hidden here     ^^^^ the same lifetime is hidden 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] 1318 |     ) -> IResult<Span<'_>, Vec<(Uses, Name, Term)>, ParseError<Span<'_>>> {
[INFO] [stdout]      |                      ++++                                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]     --> src/parse/term.rs:1346:10
[INFO] [stdout]      |
[INFO] [stdout] 1346 |       i: &str,
[INFO] [stdout]      |          ^^^^ the lifetime is elided here
[INFO] [stdout] 1347 |     ) -> IResult<Span, Vec<(Uses, Name, Term)>, ParseError<Span>> {
[INFO] [stdout]      |                  ^^^^ the same lifetime is hidden here     ^^^^ the same lifetime is hidden 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] 1347 |     ) -> IResult<Span<'_>, Vec<(Uses, Name, Term)>, ParseError<Span<'_>>> {
[INFO] [stdout]      |                      ++++                                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parse/typedef.rs:349:10
[INFO] [stdout]     |
[INFO] [stdout] 349 |       i: &str,
[INFO] [stdout]     |          ^^^^ the lifetime is elided here
[INFO] [stdout] 350 |     ) -> IResult<Span, Variant, ParseError<Span>> {
[INFO] [stdout]     |                  ^^^^                      ^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  the same lifetime is hidden 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] 350 |     ) -> IResult<Span<'_>, Variant, ParseError<Span<'_>>> {
[INFO] [stdout]     |                      ++++                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parse/typedef.rs:490:20
[INFO] [stdout]     |
[INFO] [stdout] 490 |   fn test_parse(i: &str) -> IResult<Span, TypeDef, ParseError<Span>> {
[INFO] [stdout]     |                    ^^^^             ^^^^                      ^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                    |                |
[INFO] [stdout]     |                    |                the same lifetime is hidden 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] 490 |   fn test_parse(i: &str) -> IResult<Span<'_>, TypeDef, ParseError<Span<'_>>> {
[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/prim/io.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     self.fun_symbol == rhs.fun_symbol
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[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] help: refactor your code, or use `std::ptr::fn_addr_eq` to suppress the lint
[INFO] [stdout]    |
[INFO] [stdout] 23 -     self.fun_symbol == rhs.fun_symbol
[INFO] [stdout] 23 +     std::ptr::fn_addr_eq(self.fun_symbol, rhs.fun_symbol)
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 19.10s
[INFO] running `Command { std: "docker" "inspect" "a3e52d793a755d9f9992e4495458c253c7ccbd8b2df98b1e14d5fb7e0be6b748", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a3e52d793a755d9f9992e4495458c253c7ccbd8b2df98b1e14d5fb7e0be6b748", kill_on_drop: false }`
[INFO] [stdout] a3e52d793a755d9f9992e4495458c253c7ccbd8b2df98b1e14d5fb7e0be6b748
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 11a42f707c5398b4f749472bade278f5a15f2d4b657b2da4c4d29a05b1736daa
[INFO] running `Command { std: "docker" "start" "-a" "11a42f707c5398b4f749472bade278f5a15f2d4b657b2da4c4d29a05b1736daa", kill_on_drop: false }`
[INFO] [stderr] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stderr]    --> src/dag.rs:512:11
[INFO] [stderr]     |
[INFO] [stderr] 512 |           last_old.map_or((), |last_old| (*last_old.as_ptr()).next = first_new);
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 512 |           let _ = last_old.map_or((), |last_old| (*last_old.as_ptr()).next = first_new);
[INFO] [stderr]     |           +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stderr]    --> src/dag.rs:516:7
[INFO] [stderr]     |
[INFO] [stderr] 516 |       first_new.map_or((), |first_new| (*first_new.as_ptr()).prev = last_old);
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 516 |       let _ = first_new.map_or((), |first_new| (*first_new.as_ptr()).prev = last_old);
[INFO] [stderr]     |       +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:544:9
[INFO] [stderr]     |
[INFO] [stderr] 544 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 544 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:553:9
[INFO] [stderr]     |
[INFO] [stderr] 553 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 553 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:562:9
[INFO] [stderr]     |
[INFO] [stderr] 562 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 562 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:571:9
[INFO] [stderr]     |
[INFO] [stderr] 571 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 571 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:580:9
[INFO] [stderr]     |
[INFO] [stderr] 580 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 580 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:595:9
[INFO] [stderr]     |
[INFO] [stderr] 595 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 595 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:609:9
[INFO] [stderr]     |
[INFO] [stderr] 609 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 609 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:623:9
[INFO] [stderr]     |
[INFO] [stderr] 623 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 623 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:644:9
[INFO] [stderr]     |
[INFO] [stderr] 644 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 644 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:650:11
[INFO] [stderr]     |
[INFO] [stderr] 650 |           Box::from_raw(link.as_ptr());
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 650 |           let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |           +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:654:9
[INFO] [stderr]     |
[INFO] [stderr] 654 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 654 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:657:9
[INFO] [stderr]     |
[INFO] [stderr] 657 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 657 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:660:9
[INFO] [stderr]     |
[INFO] [stderr] 660 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 660 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:663:9
[INFO] [stderr]     |
[INFO] [stderr] 663 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 663 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:666:9
[INFO] [stderr]     |
[INFO] [stderr] 666 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 666 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:681:9
[INFO] [stderr]     |
[INFO] [stderr] 681 |         Box::from_raw(pref.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 681 |         let _ = Box::from_raw(pref.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stderr]   --> src/dll.rs:79:5
[INFO] [stderr]    |
[INFO] [stderr] 79 |     self.next.map_or((), |ptr| unsafe { (*ptr.as_ptr()).prev = new_next });
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: if you don't need the returned value, use `if let` instead
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]    |
[INFO] [stderr] 79 |     let _ = self.next.map_or((), |ptr| unsafe { (*ptr.as_ptr()).prev = new_next });
[INFO] [stderr]    |     +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stderr]   --> src/dll.rs:90:5
[INFO] [stderr]    |
[INFO] [stderr] 90 |     self.prev.map_or((), |ptr| unsafe { (*ptr.as_ptr()).next = new_prev });
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: if you don't need the returned value, use `if let` instead
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]    |
[INFO] [stderr] 90 |     let _ = self.prev.map_or((), |ptr| unsafe { (*ptr.as_ptr()).next = new_prev });
[INFO] [stderr]    |     +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stderr]    --> src/dll.rs:100:7
[INFO] [stderr]     |
[INFO] [stderr] 100 |       self.prev.map_or((), |ptr| (*ptr.as_ptr()).next = Some(node));
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 100 |       let _ = self.prev.map_or((), |ptr| (*ptr.as_ptr()).next = Some(node));
[INFO] [stderr]     |       +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `Option::<T>::map_or` that must be used
[INFO] [stderr]    --> src/dll.rs:152:5
[INFO] [stderr]     |
[INFO] [stderr] 152 | /     first.map_or((), |first| unsafe {
[INFO] [stderr] 153 | |       (*first.as_ptr()).prev = Some(last);
[INFO] [stderr] 154 | |     });
[INFO] [stderr]     | |______^
[INFO] [stderr]     |
[INFO] [stderr]     = note: if you don't need the returned value, use `if let` instead
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 152 |     let _ = first.map_or((), |first| unsafe {
[INFO] [stderr]     |     +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/eval.rs:592:8
[INFO] [stderr]     |
[INFO] [stderr] 592 |     i: &str,
[INFO] [stderr]     |        ^^^^ the lifetime is elided here
[INFO] [stderr] 593 |   ) -> nom::IResult<Span, DAG, crate::parse::error::ParseError<Span>> {
[INFO] [stderr]     |                     ^^^^ the same lifetime is hidden here      ^^^^ the same lifetime is hidden here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 593 |   ) -> nom::IResult<Span<'_>, DAG, crate::parse::error::ParseError<Span<'_>>> {
[INFO] [stderr]     |                         ++++                                           ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/eval.rs:601:8
[INFO] [stderr]     |
[INFO] [stderr] 601 |     i: &str,
[INFO] [stderr]     |        ^^^^ the lifetime is elided here
[INFO] [stderr] 602 |   ) -> nom::IResult<Span, Defs, crate::parse::error::ParseError<Span>> {
[INFO] [stderr]     |                     ^^^^ the same lifetime is hidden here       ^^^^ the same lifetime is hidden here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 602 |   ) -> nom::IResult<Span<'_>, Defs, crate::parse::error::ParseError<Span<'_>>> {
[INFO] [stderr]     |                         ++++                                            ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]     --> src/parse/term.rs:1026:17
[INFO] [stderr]      |
[INFO] [stderr] 1026 | pub fn parse(i: &str, defs: Defs) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stderr]      |                 ^^^^                         ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stderr]      |                 |                            |
[INFO] [stderr]      |                 |                            the same lifetime is hidden here
[INFO] [stderr]      |                 the lifetime is elided here
[INFO] [stderr]      |
[INFO] [stderr]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]      |
[INFO] [stderr] 1026 | pub fn parse(i: &str, defs: Defs) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stderr]      |                                                  ++++                       ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]     --> src/parse/term.rs:1038:6
[INFO] [stderr]      |
[INFO] [stderr] 1038 |   i: &str,
[INFO] [stderr]      |      ^^^^ the lifetime is elided here
[INFO] [stderr] ...
[INFO] [stderr] 1041 | ) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stderr]      |              ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stderr]      |              |
[INFO] [stderr]      |              the same lifetime is hidden here
[INFO] [stderr]      |
[INFO] [stderr]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]      |
[INFO] [stderr] 1041 | ) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stderr]      |                  ++++                       ++++
[INFO] [stderr] 
[INFO] [stderr] warning: function pointer comparisons do not produce meaningful results since their addresses are not guaranteed to be unique
[INFO] [stderr]   --> src/prim/io.rs:23:5
[INFO] [stderr]    |
[INFO] [stderr] 23 |     self.fun_symbol == rhs.fun_symbol
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: the address of the same function can vary between different codegen units
[INFO] [stderr]    = note: furthermore, different functions could have the same address after being merged together
[INFO] [stderr]    = note: for more information visit <https://doc.rust-lang.org/nightly/core/ptr/fn.fn_addr_eq.html>
[INFO] [stderr]    = note: `#[warn(unpredictable_function_pointer_comparisons)]` on by default
[INFO] [stderr] help: refactor your code, or use `std::ptr::fn_addr_eq` to suppress the lint
[INFO] [stderr]    |
[INFO] [stderr] 23 -     self.fun_symbol == rhs.fun_symbol
[INFO] [stderr] 23 +     std::ptr::fn_addr_eq(self.fun_symbol, rhs.fun_symbol)
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: `yatima-core` (lib) generated 27 warnings (run `cargo fix --lib -p yatima-core` to apply 4 suggestions)
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:544:9
[INFO] [stderr]     |
[INFO] [stderr] 544 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 544 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:553:9
[INFO] [stderr]     |
[INFO] [stderr] 553 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 553 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:562:9
[INFO] [stderr]     |
[INFO] [stderr] 562 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 562 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:571:9
[INFO] [stderr]     |
[INFO] [stderr] 571 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 571 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:580:9
[INFO] [stderr]     |
[INFO] [stderr] 580 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 580 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:595:9
[INFO] [stderr]     |
[INFO] [stderr] 595 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 595 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:609:9
[INFO] [stderr]     |
[INFO] [stderr] 609 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 609 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:623:9
[INFO] [stderr]     |
[INFO] [stderr] 623 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 623 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:644:9
[INFO] [stderr]     |
[INFO] [stderr] 644 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 644 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:650:11
[INFO] [stderr]     |
[INFO] [stderr] 650 |           Box::from_raw(link.as_ptr());
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 650 |           let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |           +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:654:9
[INFO] [stderr]     |
[INFO] [stderr] 654 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 654 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:657:9
[INFO] [stderr]     |
[INFO] [stderr] 657 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 657 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:660:9
[INFO] [stderr]     |
[INFO] [stderr] 660 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 660 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:663:9
[INFO] [stderr]     |
[INFO] [stderr] 663 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 663 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:666:9
[INFO] [stderr]     |
[INFO] [stderr] 666 |         Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 666 |         let _ = Box::from_raw(link.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::boxed::Box::<T>::from_raw` that must be used
[INFO] [stderr]    --> src/dag.rs:681:9
[INFO] [stderr]     |
[INFO] [stderr] 681 |         Box::from_raw(pref.as_ptr());
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 681 |         let _ = Box::from_raw(pref.as_ptr());
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]     --> src/parse/term.rs:1077:16
[INFO] [stderr]      |
[INFO] [stderr] 1077 |     fn test(i: &str) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stderr]      |                ^^^^             ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stderr]      |                |                |
[INFO] [stderr]      |                |                the same lifetime is hidden here
[INFO] [stderr]      |                the lifetime is elided here
[INFO] [stderr]      |
[INFO] [stderr]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]      |
[INFO] [stderr] 1077 |     fn test(i: &str) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stderr]      |                                     ++++                       ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]     --> src/parse/term.rs:1096:16
[INFO] [stderr]      |
[INFO] [stderr] 1096 |     fn test(i: &str) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stderr]      |                ^^^^             ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stderr]      |                |                |
[INFO] [stderr]      |                |                the same lifetime is hidden here
[INFO] [stderr]      |                the lifetime is elided here
[INFO] [stderr]      |
[INFO] [stderr]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]      |
[INFO] [stderr] 1096 |     fn test(i: &str) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stderr]      |                                     ++++                       ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]     --> src/parse/term.rs:1127:10
[INFO] [stderr]      |
[INFO] [stderr] 1127 |       i: &str,
[INFO] [stderr]      |          ^^^^ the lifetime is elided here
[INFO] [stderr] 1128 |     ) -> IResult<Span, Vec<(Uses, Name, Term)>, ParseError<Span>> {
[INFO] [stderr]      |                  ^^^^ the same lifetime is hidden here     ^^^^ the same lifetime is hidden here
[INFO] [stderr]      |
[INFO] [stderr]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]      |
[INFO] [stderr] 1128 |     ) -> IResult<Span<'_>, Vec<(Uses, Name, Term)>, ParseError<Span<'_>>> {
[INFO] [stderr]      |                      ++++                                          ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]     --> src/parse/term.rs:1172:10
[INFO] [stderr]      |
[INFO] [stderr] 1172 |       i: &str,
[INFO] [stderr]      |          ^^^^ the lifetime is elided here
[INFO] [stderr] 1173 |     ) -> IResult<Span, Vec<(Uses, Name, Term)>, ParseError<Span>> {
[INFO] [stderr]      |                  ^^^^ the same lifetime is hidden here     ^^^^ the same lifetime is hidden here
[INFO] [stderr]      |
[INFO] [stderr]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]      |
[INFO] [stderr] 1173 |     ) -> IResult<Span<'_>, Vec<(Uses, Name, Term)>, ParseError<Span<'_>>> {
[INFO] [stderr]      |                      ++++                                          ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]     --> src/parse/term.rs:1221:16
[INFO] [stderr]      |
[INFO] [stderr] 1221 |     fn test(i: &str) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stderr]      |                ^^^^             ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stderr]      |                |                |
[INFO] [stderr]      |                |                the same lifetime is hidden here
[INFO] [stderr]      |                the lifetime is elided here
[INFO] [stderr]      |
[INFO] [stderr]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]      |
[INFO] [stderr] 1221 |     fn test(i: &str) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stderr]      |                                     ++++                       ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]     --> src/parse/term.rs:1237:16
[INFO] [stderr]      |
[INFO] [stderr] 1237 |     fn test(i: &str) -> IResult<Span, Term, ParseError<Span>> {
[INFO] [stderr]      |                ^^^^             ^^^^                   ^^^^ the same lifetime is hidden here
[INFO] [stderr]      |                |                |
[INFO] [stderr]      |                |                the same lifetime is hidden here
[INFO] [stderr]      |                the lifetime is elided here
[INFO] [stderr]      |
[INFO] [stderr]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]      |
[INFO] [stderr] 1237 |     fn test(i: &str) -> IResult<Span<'_>, Term, ParseError<Span<'_>>> {
[INFO] [stderr]      |                                     ++++                       ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]     --> src/parse/term.rs:1270:10
[INFO] [stderr]      |
[INFO] [stderr] 1270 |       i: &str,
[INFO] [stderr]      |          ^^^^ the lifetime is elided here
[INFO] [stderr] 1271 |     ) -> IResult<Span, (Term, Term), ParseError<Span>> {
[INFO] [stderr]      |                  ^^^^                           ^^^^ the same lifetime is hidden here
[INFO] [stderr]      |                  |
[INFO] [stderr]      |                  the same lifetime is hidden here
[INFO] [stderr]      |
[INFO] [stderr]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]      |
[INFO] [stderr] 1271 |     ) -> IResult<Span<'_>, (Term, Term), ParseError<Span<'_>>> {
[INFO] [stderr]      |                      ++++                               ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]     --> src/parse/term.rs:1317:10
[INFO] [stderr]      |
[INFO] [stderr] 1317 |       i: &str,
[INFO] [stderr]      |          ^^^^ the lifetime is elided here
[INFO] [stderr] 1318 |     ) -> IResult<Span, Vec<(Uses, Name, Term)>, ParseError<Span>> {
[INFO] [stderr]      |                  ^^^^ the same lifetime is hidden here     ^^^^ the same lifetime is hidden here
[INFO] [stderr]      |
[INFO] [stderr]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]      |
[INFO] [stderr] 1318 |     ) -> IResult<Span<'_>, Vec<(Uses, Name, Term)>, ParseError<Span<'_>>> {
[INFO] [stderr]      |                      ++++                                          ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]     --> src/parse/term.rs:1346:10
[INFO] [stderr]      |
[INFO] [stderr] 1346 |       i: &str,
[INFO] [stderr]      |          ^^^^ the lifetime is elided here
[INFO] [stderr] 1347 |     ) -> IResult<Span, Vec<(Uses, Name, Term)>, ParseError<Span>> {
[INFO] [stderr]      |                  ^^^^ the same lifetime is hidden here     ^^^^ the same lifetime is hidden here
[INFO] [stderr]      |
[INFO] [stderr]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]      |
[INFO] [stderr] 1347 |     ) -> IResult<Span<'_>, Vec<(Uses, Name, Term)>, ParseError<Span<'_>>> {
[INFO] [stderr]      |                      ++++                                          ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/parse/typedef.rs:349:10
[INFO] [stderr]     |
[INFO] [stderr] 349 |       i: &str,
[INFO] [stderr]     |          ^^^^ the lifetime is elided here
[INFO] [stderr] 350 |     ) -> IResult<Span, Variant, ParseError<Span>> {
[INFO] [stderr]     |                  ^^^^                      ^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                  |
[INFO] [stderr]     |                  the same lifetime is hidden here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 350 |     ) -> IResult<Span<'_>, Variant, ParseError<Span<'_>>> {
[INFO] [stderr]     |                      ++++                          ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/parse/typedef.rs:490:20
[INFO] [stderr]     |
[INFO] [stderr] 490 |   fn test_parse(i: &str) -> IResult<Span, TypeDef, ParseError<Span>> {
[INFO] [stderr]     |                    ^^^^             ^^^^                      ^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                    |                |
[INFO] [stderr]     |                    |                the same lifetime is hidden here
[INFO] [stderr]     |                    the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 490 |   fn test_parse(i: &str) -> IResult<Span<'_>, TypeDef, ParseError<Span<'_>>> {
[INFO] [stderr]     |                                         ++++                          ++++
[INFO] [stderr] 
[INFO] [stderr] warning: `yatima-core` (lib test) generated 38 warnings (11 duplicates) (run `cargo fix --lib -p yatima-core --tests` to apply 11 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.11s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/yatima_core-6a3afd4059d8b175)
[INFO] [stdout] 
[INFO] [stdout] running 110 tests
[INFO] [stdout] test eval::test::reduce_test_all ... ok
[INFO] [stdout] test literal::tests::test_expand ... ok
[INFO] [stdout] test literal::tests::literal_ipld ... ok
[INFO] [stdout] test dll::tests::dll ... ok
[INFO] [stdout] test eval::test::parse_test ... ok
[INFO] [stdout] test parse::literal::tests::test_parse_nat ... ok
[INFO] [stdout] test eval::test::reduce_test_ann ... ok
[INFO] [stdout] test eval::test::reduce_test_app ... ok
[INFO] [stdout] test literal::tests::lit_type_ipld ... ok
[INFO] [stdout] test eval::test::reduce_test_let ... ok
[INFO] [stdout] test parse::term::tests::test_parse_alls ... ok
[INFO] [stdout] test parse::term::tests::test_parse_binders1 ... ok
[INFO] [stdout] test parse::term::tests::test_parse_bound_expression ... ok
[INFO] [stdout] test parse::term::tests::test_parse_apps ... ok
[INFO] [stdout] test parse::term::tests::test_parse_binders ... ok
[INFO] [stdout] test parse::term::tests::test_parse_let ... ok
[INFO] [stdout] test parse::term::tests::test_parse_binder_full ... ok
[INFO] [stdout] test parse::typedef::tests::test_no_sigs_list ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_bool ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_empty ... ok
[INFO] [stdout] test parse::term::tests::test_parse_expression ... ok
[INFO] [stdout] test parse::typedef::tests::test_no_sigs_tuple ... ok
[INFO] [stdout] test eval::test::reduce_test ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_chain ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_nat ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_list ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_equal ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_triple ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_tuple4 ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_pair ... ok
[INFO] [stdout] test position::tests::pos_ipld ... ok
[INFO] [stdout] test prim::bits::tests::bytes_op_ipld ... ok
[INFO] [stdout] test parse::typedef::tests::variant_parse ... ok
[INFO] [stdout] test prim::bits::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::bits::tests::test_bits_to_byte ... ok
[INFO] [stdout] test prim::bits::tests::test_apply ... ok
[INFO] [stdout] test prim::bits::tests::test_bits_to_bytes ... ok
[INFO] [stdout] test position::tests::position_ipld ... ok
[INFO] [stdout] test prim::bits::tests::test_byte_to_bits ... ok
[INFO] [stdout] test prim::bool::tests::nat_op_ipld ... ok
[INFO] [stdout] test prim::bool::tests::test_absorption_2 ... ok
[INFO] [stdout] test prim::bool::tests::test_apply ... ok
[INFO] [stdout] test prim::bool::tests::test_absorption_1 ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_tuple5 ... ok
[INFO] [stdout] test prim::bits::tests::test_bytes_to_bits ... ok
[INFO] [stdout] test prim::bool::tests::test_associativity ... ok
[INFO] [stdout] test prim::bool::tests::test_de_morgan_2 ... ok
[INFO] [stdout] test prim::bool::tests::test_distributivity_of_and_over_or ... ok
[INFO] [stdout] test prim::bool::tests::test_distributivity_of_or_over_and ... ok
[INFO] [stdout] test prim::bool::tests::test_double_negation ... ok
[INFO] [stdout] test prim::bool::tests::test_idempotence ... ok
[INFO] [stdout] test prim::bytes::tests::bytes_op_ipld ... ok
[INFO] [stdout] test prim::bool::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::bool::tests::test_commutativity ... ok
[INFO] [stdout] test prim::bool::tests::test_de_morgan_1 ... ok
[INFO] [stdout] test prim::char::tests::char_op_ipld ... ok
[INFO] [stdout] test prim::char::tests::test_apply ... ok
[INFO] [stdout] test prim::i16::tests::i16_op_ipld ... ok
[INFO] [stdout] test prim::i16::tests::test_apply ... ok
[INFO] [stdout] test prim::char::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::bytes::tests::test_apply ... ok
[INFO] [stdout] test prim::i32::tests::test_apply ... ok
[INFO] [stdout] test prim::i16::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::i32::tests::i32_op_ipld ... ok
[INFO] [stdout] test prim::i32::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::i64::tests::i64_op_ipld ... ok
[INFO] [stdout] test prim::i64::tests::test_apply ... ok
[INFO] [stdout] test prim::i8::tests::i8_op_ipld ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_vector ... ok
[INFO] [stdout] test prim::bytes::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::i64::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::int::tests::int_op_ipld ... ok
[INFO] [stdout] test prim::i8::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::nat::tests::test_apply ... ok
[INFO] [stdout] test prim::i8::tests::test_apply ... ok
[INFO] [stdout] test prim::tests::primop_ipld ... ok
[INFO] [stdout] test prim::int::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::nat::tests::nat_op_ipld ... ok
[INFO] [stdout] test prim::int::tests::test_apply ... ok
[INFO] [stdout] test prim::nat::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::text::tests::test_safe_head ... ok
[INFO] [stdout] test prim::text::tests::text_op_ipld ... ok
[INFO] [stdout] test prim::u16::tests::test_apply ... ok
[INFO] [stdout] test prim::u16::tests::u16_op_ipld ... ok
[INFO] [stdout] test prim::u32::tests::test_apply ... ok
[INFO] [stdout] test prim::u16::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::u32::tests::u32_op_ipld ... ok
[INFO] [stdout] test prim::text::tests::test_safe_split ... ok
[INFO] [stdout] test prim::u64::tests::test_apply ... ok
[INFO] [stdout] test prim::u64::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::u8::tests::test_apply ... ok
[INFO] [stdout] test prim::u64::tests::u64_op_ipld ... ok
[INFO] [stdout] test prim::u8::tests::u8_op_ipld ... ok
[INFO] [stdout] test prim::u32::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test uses::tests::uses_ipld ... ok
[INFO] [stdout] test prim::u8::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::text::tests::test_apply_none_on_invalid ... ok
[INFO] [stdout] test prim::text::tests::test_apply ... ok
[INFO] [stdout] test package::tests::import_ipld ... ok
[INFO] [stdout] test anon::tests::anon_ipld ... ok
[INFO] [stdout] test dag::test::dag_term_iso ... ok
[INFO] [stdout] test parse::typedef::tests::typedef_crazy ... ok
[INFO] [stdout] test meta::tests::meta_ipld ... ok
[INFO] [stdout] test package::tests::index_ipld ... ok
[INFO] [stdout] test term::tests::term_embed_unembed ... ok
[INFO] [stdout] test parse::term::tests::term_parse_print ... ok
[INFO] [stdout] test package::tests::entry_ipld ... ok
[INFO] [stdout] test dag::test::dag_def_iso ... ok
[INFO] [stdout] test defs::tests::def_embed_unembed ... ok
[INFO] [stdout] test package::tests::package_ipld ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 110 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 5.54s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests yatima_core
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[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] running `Command { std: "docker" "inspect" "11a42f707c5398b4f749472bade278f5a15f2d4b657b2da4c4d29a05b1736daa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "11a42f707c5398b4f749472bade278f5a15f2d4b657b2da4c4d29a05b1736daa", kill_on_drop: false }`
[INFO] [stdout] 11a42f707c5398b4f749472bade278f5a15f2d4b657b2da4c4d29a05b1736daa
