[INFO] fetching crate froggy 0.4.2...
[INFO] checking froggy-0.4.2 against try#7b3da9103634dffd4f4365cfd8642427c781d99f+rustflags=-Dinherent-method-on-receiver for 152214-denied
[INFO] extracting crate froggy 0.4.2 into /workspace/builds/worker-0-tc2/source
[INFO] started tweaking crates.io crate froggy 0.4.2
[INFO] finished tweaking crates.io crate froggy 0.4.2
[INFO] tweaked toml for crates.io crate froggy 0.4.2 written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate froggy 0.4.2 on toolchain 7b3da9103634dffd4f4365cfd8642427c781d99f
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+7b3da9103634dffd4f4365cfd8642427c781d99f" "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" "+7b3da9103634dffd4f4365cfd8642427c781d99f" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 1 package to latest compatible version
[INFO] [stderr]       Adding spin v0.4.10 (available: v0.10.0)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+7b3da9103634dffd4f4365cfd8642427c781d99f" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:29356a839a4d14451438f794ce8414e707d72405f44418718d724d22562fe786" "/opt/rustwide/cargo-home/bin/cargo" "+7b3da9103634dffd4f4365cfd8642427c781d99f" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2a6aa32ce5c2404a59c136322b3d2751d27dc72ac6157d7e8a8dd0276f26f9b8
[INFO] running `Command { std: "docker" "start" "-a" "2a6aa32ce5c2404a59c136322b3d2751d27dc72ac6157d7e8a8dd0276f26f9b8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2a6aa32ce5c2404a59c136322b3d2751d27dc72ac6157d7e8a8dd0276f26f9b8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2a6aa32ce5c2404a59c136322b3d2751d27dc72ac6157d7e8a8dd0276f26f9b8", kill_on_drop: false }`
[INFO] [stdout] 2a6aa32ce5c2404a59c136322b3d2751d27dc72ac6157d7e8a8dd0276f26f9b8
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Dinherent-method-on-receiver" "-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:29356a839a4d14451438f794ce8414e707d72405f44418718d724d22562fe786" "/opt/rustwide/cargo-home/bin/cargo" "+7b3da9103634dffd4f4365cfd8642427c781d99f" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0795cc4e56c2fc3713d23933c3c7f42a0b95ee48c5cb0efcf3a51666e9afdbd5
[INFO] running `Command { std: "docker" "start" "-a" "0795cc4e56c2fc3713d23933c3c7f42a0b95ee48c5cb0efcf3a51666e9afdbd5", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]     Checking spin v0.4.10
[INFO] [stderr]     Checking froggy v0.4.2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: use of deprecated constant `std::sync::atomic::ATOMIC_USIZE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/lib.rs:35:48
[INFO] [stdout]    |
[INFO] [stdout] 35 | use std::sync::atomic::{AtomicUsize, Ordering, ATOMIC_USIZE_INIT};
[INFO] [stdout]    |                                                ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::atomic::ATOMIC_USIZE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/lib.rs:54:35
[INFO] [stdout]    |
[INFO] [stdout] 54 | static STORAGE_UID: AtomicUsize = ATOMIC_USIZE_INIT;
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]    |
[INFO] [stdout] 54 - static STORAGE_UID: AtomicUsize = ATOMIC_USIZE_INIT;
[INFO] [stdout] 54 + static STORAGE_UID: AtomicUsize = AtomicUsize::new(0);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::atomic::ATOMIC_USIZE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/lib.rs:35:48
[INFO] [stdout]    |
[INFO] [stdout] 35 | use std::sync::atomic::{AtomicUsize, Ordering, ATOMIC_USIZE_INIT};
[INFO] [stdout]    |                                                ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::atomic::ATOMIC_USIZE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/lib.rs:54:35
[INFO] [stdout]    |
[INFO] [stdout] 54 | static STORAGE_UID: AtomicUsize = ATOMIC_USIZE_INIT;
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]    |
[INFO] [stdout] 54 - static STORAGE_UID: AtomicUsize = ATOMIC_USIZE_INIT;
[INFO] [stdout] 54 + static STORAGE_UID: AtomicUsize = AtomicUsize::new(0);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `index`, `epoch`, `storage_id`, and `pending` are never read
[INFO] [stdout]    --> src/lib.rs:165:13
[INFO] [stdout]     |
[INFO] [stdout] 163 |         pub struct Pointer<'a> {
[INFO] [stdout]     |                    ------- fields in this struct
[INFO] [stdout] 164 |             /// All integer entries are `usize` for future-proofing.
[INFO] [stdout] 165 |             index: usize,
[INFO] [stdout]     |             ^^^^^
[INFO] [stdout] 166 |             epoch: usize,
[INFO] [stdout]     |             ^^^^^
[INFO] [stdout] 167 |             storage_id: usize,
[INFO] [stdout]     |             ^^^^^^^^^^
[INFO] [stdout] 168 |             pending: &'a Pending,
[INFO] [stdout]     |             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Pointer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/lib.rs:77:14
[INFO] [stdout]    |
[INFO] [stdout] 77 |     fn split(&mut self, offset: PointerData) -> (Slice<T>, &mut T, Slice<T>) {
[INFO] [stdout]    |              ^^^^^^^^^                           ^^^^^^^^  ^^^^^^  ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |              |                                   |         |
[INFO] [stdout]    |              |                                   |         the same lifetime is elided here
[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]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 77 |     fn split(&mut self, offset: PointerData) -> (Slice<'_, T>, &mut T, Slice<'_, T>) {
[INFO] [stdout]    |                                                        +++                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:100:18
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn drain_sub(&mut self) -> (Drain<Index>, &mut [Epoch]) {
[INFO] [stdout]     |                  ^^^^^^^^^      ^^^^^^^^^^^^  ^^^^^^^^^^^^ the same lifetime is elided 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] 100 |     fn drain_sub(&mut self) -> (Drain<'_, Index>, &mut [Epoch]) {
[INFO] [stdout]     |                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:356:17
[INFO] [stdout]     |
[INFO] [stdout] 356 |     pub fn iter(&self) -> Iter<T> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[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] 356 |     pub fn iter(&self) -> Iter<'_, T> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:367:21
[INFO] [stdout]     |
[INFO] [stdout] 367 |     pub fn iter_all(&self) -> Iter<T> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[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] 367 |     pub fn iter_all(&self) -> Iter<'_, T> {
[INFO] [stdout]     |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:381:21
[INFO] [stdout]     |
[INFO] [stdout] 381 |     pub fn iter_mut(&mut self) -> IterMut<T> {
[INFO] [stdout]     |                     ^^^^^^^^^     ^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[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] 381 |     pub fn iter_mut(&mut self) -> IterMut<'_, T> {
[INFO] [stdout]     |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:391:25
[INFO] [stdout]     |
[INFO] [stdout] 391 |     pub fn iter_all_mut(&mut self) -> slice::IterMut<T> {
[INFO] [stdout]     |                         ^^^^^^^^^     ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                         |
[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] 391 |     pub fn iter_all_mut(&mut self) -> slice::IterMut<'_, T> {
[INFO] [stdout]     |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:414:18
[INFO] [stdout]     |
[INFO] [stdout] 414 |     pub fn split(&mut self, pointer: &Pointer<T>) -> (Slice<T>, &mut T, Slice<T>) {
[INFO] [stdout]     |                  ^^^^^^^^^                            ^^^^^^^^  ^^^^^^  ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |                                    |         |
[INFO] [stdout]     |                  |                                    |         the same lifetime is elided here
[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] 414 |     pub fn split(&mut self, pointer: &Pointer<T>) -> (Slice<'_, T>, &mut T, Slice<'_, T>) {
[INFO] [stdout]     |                                                             +++                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:425:19
[INFO] [stdout]     |
[INFO] [stdout] 425 |     pub fn cursor(&mut self) -> Cursor<T> {
[INFO] [stdout]     |                   ^^^^^^^^^     ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                   |
[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] 425 |     pub fn cursor(&mut self) -> Cursor<'_, T> {
[INFO] [stdout]     |                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:436:23
[INFO] [stdout]     |
[INFO] [stdout] 436 |     pub fn cursor_end(&mut self) -> Cursor<T> {
[INFO] [stdout]     |                       ^^^^^^^^^     ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                       |
[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] 436 |     pub fn cursor_end(&mut self) -> Cursor<'_, T> {
[INFO] [stdout]     |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: inherent methods on types that implement `Deref` or `Receiver` shadow methods of their target
[INFO] [stdout]    --> src/cursor.rs:102:16
[INFO] [stdout]     |
[INFO] [stdout]  87 | impl<'a, T> ops::Deref for CursorItem<'a, T> {
[INFO] [stdout]     | -------------------------------------------- trait implemented here
[INFO] [stdout]  88 |     type Target = T;
[INFO] [stdout]     |     ----------- with `Target` set here
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn pin(&self) -> Pointer<T> {
[INFO] [stdout]     |                ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: requested on the command line with `-D inherent-method-on-receiver`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/cursor.rs:117:14
[INFO] [stdout]     |
[INFO] [stdout] 117 |     fn split(&mut self, index: usize) -> (Slice<T>, CursorItem<T>, Slice<T>) {
[INFO] [stdout]     |              ^^^^^^^^^                    ^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |              |                            |         |
[INFO] [stdout]     |              |                            |         the same lifetime is hidden here
[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] 117 |     fn split(&mut self, index: usize) -> (Slice<'_, T>, CursorItem<'_, T>, Slice<'_, T>) {
[INFO] [stdout]     |                                                 +++                +++           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/cursor.rs:128:17
[INFO] [stdout]     |
[INFO] [stdout] 128 |     pub fn next(&mut self) -> Option<(Slice<T>, CursorItem<T>, Slice<T>)> {
[INFO] [stdout]     |                 ^^^^^^^^^             ^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |                     |         |
[INFO] [stdout]     |                 |                     |         the same lifetime is hidden here
[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] 128 |     pub fn next(&mut self) -> Option<(Slice<'_, T>, CursorItem<'_, T>, Slice<'_, T>)> {
[INFO] [stdout]     |                                             +++                +++           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/cursor.rs:144:17
[INFO] [stdout]     |
[INFO] [stdout] 144 |     pub fn prev(&mut self) -> Option<(Slice<T>, CursorItem<T>, Slice<T>)> {
[INFO] [stdout]     |                 ^^^^^^^^^             ^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |                     |         |
[INFO] [stdout]     |                 |                     |         the same lifetime is hidden here
[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] 144 |     pub fn prev(&mut self) -> Option<(Slice<'_, T>, CursorItem<'_, T>, Slice<'_, T>)> {
[INFO] [stdout]     |                                             +++                +++           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `index`, `epoch`, `storage_id`, and `pending` are never read
[INFO] [stdout]    --> src/lib.rs:165:13
[INFO] [stdout]     |
[INFO] [stdout] 163 |         pub struct Pointer<'a> {
[INFO] [stdout]     |                    ------- fields in this struct
[INFO] [stdout] 164 |             /// All integer entries are `usize` for future-proofing.
[INFO] [stdout] 165 |             index: usize,
[INFO] [stdout]     |             ^^^^^
[INFO] [stdout] 166 |             epoch: usize,
[INFO] [stdout]     |             ^^^^^
[INFO] [stdout] 167 |             storage_id: usize,
[INFO] [stdout]     |             ^^^^^^^^^^
[INFO] [stdout] 168 |             pending: &'a Pending,
[INFO] [stdout]     |             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Pointer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/lib.rs:77:14
[INFO] [stdout]    |
[INFO] [stdout] 77 |     fn split(&mut self, offset: PointerData) -> (Slice<T>, &mut T, Slice<T>) {
[INFO] [stdout]    |              ^^^^^^^^^                           ^^^^^^^^  ^^^^^^  ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |              |                                   |         |
[INFO] [stdout]    |              |                                   |         the same lifetime is elided here
[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]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 77 |     fn split(&mut self, offset: PointerData) -> (Slice<'_, T>, &mut T, Slice<'_, T>) {
[INFO] [stdout]    |                                                        +++                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:100:18
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn drain_sub(&mut self) -> (Drain<Index>, &mut [Epoch]) {
[INFO] [stdout]     |                  ^^^^^^^^^      ^^^^^^^^^^^^  ^^^^^^^^^^^^ the same lifetime is elided 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] 100 |     fn drain_sub(&mut self) -> (Drain<'_, Index>, &mut [Epoch]) {
[INFO] [stdout]     |                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:356:17
[INFO] [stdout]     |
[INFO] [stdout] 356 |     pub fn iter(&self) -> Iter<T> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[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] 356 |     pub fn iter(&self) -> Iter<'_, T> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:367:21
[INFO] [stdout]     |
[INFO] [stdout] 367 |     pub fn iter_all(&self) -> Iter<T> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[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] 367 |     pub fn iter_all(&self) -> Iter<'_, T> {
[INFO] [stdout]     |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:381:21
[INFO] [stdout]     |
[INFO] [stdout] 381 |     pub fn iter_mut(&mut self) -> IterMut<T> {
[INFO] [stdout]     |                     ^^^^^^^^^     ^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[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] 381 |     pub fn iter_mut(&mut self) -> IterMut<'_, T> {
[INFO] [stdout]     |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `froggy` (lib) due to 1 previous error; 15 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:391:25
[INFO] [stdout]     |
[INFO] [stdout] 391 |     pub fn iter_all_mut(&mut self) -> slice::IterMut<T> {
[INFO] [stdout]     |                         ^^^^^^^^^     ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                         |
[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] 391 |     pub fn iter_all_mut(&mut self) -> slice::IterMut<'_, T> {
[INFO] [stdout]     |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:414:18
[INFO] [stdout]     |
[INFO] [stdout] 414 |     pub fn split(&mut self, pointer: &Pointer<T>) -> (Slice<T>, &mut T, Slice<T>) {
[INFO] [stdout]     |                  ^^^^^^^^^                            ^^^^^^^^  ^^^^^^  ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |                                    |         |
[INFO] [stdout]     |                  |                                    |         the same lifetime is elided here
[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] 414 |     pub fn split(&mut self, pointer: &Pointer<T>) -> (Slice<'_, T>, &mut T, Slice<'_, T>) {
[INFO] [stdout]     |                                                             +++                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:425:19
[INFO] [stdout]     |
[INFO] [stdout] 425 |     pub fn cursor(&mut self) -> Cursor<T> {
[INFO] [stdout]     |                   ^^^^^^^^^     ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                   |
[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] 425 |     pub fn cursor(&mut self) -> Cursor<'_, T> {
[INFO] [stdout]     |                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:436:23
[INFO] [stdout]     |
[INFO] [stdout] 436 |     pub fn cursor_end(&mut self) -> Cursor<T> {
[INFO] [stdout]     |                       ^^^^^^^^^     ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                       |
[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] 436 |     pub fn cursor_end(&mut self) -> Cursor<'_, T> {
[INFO] [stdout]     |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: inherent methods on types that implement `Deref` or `Receiver` shadow methods of their target
[INFO] [stdout]    --> src/cursor.rs:102:16
[INFO] [stdout]     |
[INFO] [stdout]  87 | impl<'a, T> ops::Deref for CursorItem<'a, T> {
[INFO] [stdout]     | -------------------------------------------- trait implemented here
[INFO] [stdout]  88 |     type Target = T;
[INFO] [stdout]     |     ----------- with `Target` set here
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn pin(&self) -> Pointer<T> {
[INFO] [stdout]     |                ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: requested on the command line with `-D inherent-method-on-receiver`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/cursor.rs:117:14
[INFO] [stdout]     |
[INFO] [stdout] 117 |     fn split(&mut self, index: usize) -> (Slice<T>, CursorItem<T>, Slice<T>) {
[INFO] [stdout]     |              ^^^^^^^^^                    ^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |              |                            |         |
[INFO] [stdout]     |              |                            |         the same lifetime is hidden here
[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] 117 |     fn split(&mut self, index: usize) -> (Slice<'_, T>, CursorItem<'_, T>, Slice<'_, T>) {
[INFO] [stdout]     |                                                 +++                +++           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/cursor.rs:128:17
[INFO] [stdout]     |
[INFO] [stdout] 128 |     pub fn next(&mut self) -> Option<(Slice<T>, CursorItem<T>, Slice<T>)> {
[INFO] [stdout]     |                 ^^^^^^^^^             ^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |                     |         |
[INFO] [stdout]     |                 |                     |         the same lifetime is hidden here
[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] 128 |     pub fn next(&mut self) -> Option<(Slice<'_, T>, CursorItem<'_, T>, Slice<'_, T>)> {
[INFO] [stdout]     |                                             +++                +++           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/cursor.rs:144:17
[INFO] [stdout]     |
[INFO] [stdout] 144 |     pub fn prev(&mut self) -> Option<(Slice<T>, CursorItem<T>, Slice<T>)> {
[INFO] [stdout]     |                 ^^^^^^^^^             ^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |                     |         |
[INFO] [stdout]     |                 |                     |         the same lifetime is hidden here
[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] 144 |     pub fn prev(&mut self) -> Option<(Slice<'_, T>, CursorItem<'_, T>, Slice<'_, T>)> {
[INFO] [stdout]     |                                             +++                +++           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `froggy` (lib test) due to 1 previous error; 15 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "0795cc4e56c2fc3713d23933c3c7f42a0b95ee48c5cb0efcf3a51666e9afdbd5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0795cc4e56c2fc3713d23933c3c7f42a0b95ee48c5cb0efcf3a51666e9afdbd5", kill_on_drop: false }`
[INFO] [stdout] 0795cc4e56c2fc3713d23933c3c7f42a0b95ee48c5cb0efcf3a51666e9afdbd5
