[INFO] fetching crate tokio-sync 0.1.8...
[INFO] checking tokio-sync-0.1.8 against try#012cd62c9add58ab3910e44c137d87db3ab70f61 for pr-155915
[INFO] extracting crate tokio-sync 0.1.8 into /workspace/builds/worker-0-tc2/source
[INFO] started tweaking crates.io crate tokio-sync 0.1.8
[INFO] finished tweaking crates.io crate tokio-sync 0.1.8
[INFO] tweaked toml for crates.io crate tokio-sync 0.1.8 written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate tokio-sync 0.1.8 on toolchain 012cd62c9add58ab3910e44c137d87db3ab70f61
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 60 packages to latest compatible versions
[INFO] [stderr]       Adding env_logger v0.6.2 (available: v0.11.10)
[INFO] [stderr]       Adding futures v0.1.31 (available: v0.3.32)
[INFO] [stderr]       Adding loom v0.1.1 (available: v0.7.2)
[INFO] [stderr]       Adding tokio v0.1.22 (available: v1.52.3)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: `package.edition` is unspecified, defaulting to `2015` 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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] ddfebdce845a55df1520bc37485a29af0cd7e32a39a31c208a83b426ae6acf73
[INFO] running `Command { std: "docker" "start" "-a" "ddfebdce845a55df1520bc37485a29af0cd7e32a39a31c208a83b426ae6acf73", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "ddfebdce845a55df1520bc37485a29af0cd7e32a39a31c208a83b426ae6acf73", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ddfebdce845a55df1520bc37485a29af0cd7e32a39a31c208a83b426ae6acf73", kill_on_drop: false }`
[INFO] [stdout] ddfebdce845a55df1520bc37485a29af0cd7e32a39a31c208a83b426ae6acf73
[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" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6c31e033876682b9f82096504bc640a911508e03afdddb1ba236abdb1f98f259
[INFO] running `Command { std: "docker" "start" "-a" "6c31e033876682b9f82096504bc640a911508e03afdddb1ba236abdb1f98f259", kill_on_drop: false }`
[INFO] [stderr] warning: `package.edition` is unspecified, defaulting to `2015` while the latest is `2024`
[INFO] [stderr]     Checking futures v0.1.31
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling memoffset v0.5.6
[INFO] [stderr]    Compiling semver v0.9.0
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]     Checking scoped-tls v0.1.2
[INFO] [stderr]     Checking env_logger v0.6.2
[INFO] [stderr]     Checking iovec v0.1.4
[INFO] [stderr]     Checking net2 v0.2.39
[INFO] [stderr]     Checking bytes v0.4.12
[INFO] [stderr]    Compiling rustc_version v0.2.3
[INFO] [stderr]     Checking mio v0.6.23
[INFO] [stderr]    Compiling parking_lot_core v0.6.3
[INFO] [stderr]    Compiling parking_lot v0.9.0
[INFO] [stderr]     Checking mio-uds v0.6.8
[INFO] [stderr]     Checking crossbeam-queue v0.2.3
[INFO] [stderr]     Checking crossbeam-deque v0.7.4
[INFO] [stderr]     Checking tokio-executor v0.1.10
[INFO] [stderr]     Checking tokio-io v0.1.13
[INFO] [stderr]     Checking tokio-sync v0.1.8
[INFO] [stderr]     Checking tokio-mock-task v0.1.1
[INFO] [stderr]     Checking loom v0.1.1
[INFO] [stderr]     Checking tokio-sync v0.1.8 (/opt/rustwide/workdir)
[INFO] [stdout] warning: use of deprecated function `std::sync::atomic::spin_loop_hint`: use hint::spin_loop instead
[INFO] [stdout]   --> src/loom.rs:36:26
[INFO] [stdout]    |
[INFO] [stdout] 36 |     ::std::sync::atomic::spin_loop_hint();
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/mpsc/block.rs:366:29
[INFO] [stdout]     |
[INFO] [stdout] 366 |         let mut vals = mem::uninitialized();
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/oneshot.rs:133:66
[INFO] [stdout]     |
[INFO] [stdout] 133 |         tx_task: CausalCell::new(ManuallyDrop::new(unsafe { mem::uninitialized() })),
[INFO] [stdout]     |                                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/oneshot.rs:134:66
[INFO] [stdout]     |
[INFO] [stdout] 134 |         rx_task: CausalCell::new(ManuallyDrop::new(unsafe { mem::uninitialized() })),
[INFO] [stdout]     |                                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking tokio-threadpool v0.1.18
[INFO] [stderr]     Checking tokio-current-thread v0.1.7
[INFO] [stderr]     Checking tokio-timer v0.2.13
[INFO] [stdout] warning: use of deprecated method `std::sync::atomic::Atomic::<*mut T>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stdout]    --> src/mpsc/block.rs:269:14
[INFO] [stdout]     |
[INFO] [stdout] 269 |             .compare_and_swap(ptr::null_mut(), block.as_ptr(), ordering);
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::sync::atomic::Atomic::<*mut T>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stdout]    --> src/mpsc/block.rs:311:43
[INFO] [stdout]     |
[INFO] [stdout] 311 |         let next = NonNull::new(self.next.compare_and_swap(
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/bounded.rs:223:32
[INFO] [stdout]     |
[INFO] [stdout] 223 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/bounded.rs:263:32
[INFO] [stdout]     |
[INFO] [stdout] 263 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/bounded.rs:293:32
[INFO] [stdout]     |
[INFO] [stdout] 293 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::sync::atomic::Atomic::<*mut T>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stdout]    --> src/mpsc/list.rs:148:26
[INFO] [stdout]     |
[INFO] [stdout] 148 |                         .compare_and_swap(block_ptr, next_block.as_ptr(), Release);
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/unbounded.rs:145:32
[INFO] [stdout]     |
[INFO] [stdout] 145 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/unbounded.rs:167:32
[INFO] [stdout]     |
[INFO] [stdout] 167 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/unbounded.rs:189:32
[INFO] [stdout]     |
[INFO] [stdout] 189 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/oneshot.rs:50:36
[INFO] [stdout]    |
[INFO] [stdout] 50 |             write!(fmt, "{}", self.description())
[INFO] [stdout]    |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/oneshot.rs:65:36
[INFO] [stdout]    |
[INFO] [stdout] 65 |             write!(fmt, "{}", self.description())
[INFO] [stdout]    |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/semaphore.rs:688:32
[INFO] [stdout]     |
[INFO] [stdout] 688 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/semaphore.rs:734:32
[INFO] [stdout]     |
[INFO] [stdout] 734 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::sync::atomic::Atomic::<usize>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stdout]    --> src/task/atomic_task.rs:179:26
[INFO] [stdout]     |
[INFO] [stdout] 179 |         match self.state.compare_and_swap(WAITING, REGISTERING, Acquire) {
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/watch.rs:126:36
[INFO] [stdout]     |
[INFO] [stdout] 126 |             write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/watch.rs:141:36
[INFO] [stdout]     |
[INFO] [stdout] 141 |             write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `inner` is never read
[INFO] [stdout]    --> src/watch.rs:118:20
[INFO] [stdout]     |
[INFO] [stdout] 117 |     pub struct SendError<T> {
[INFO] [stdout]     |                --------- field in this struct
[INFO] [stdout] 118 |         pub(crate) inner: T,
[INFO] [stdout]     |                    ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `SendError` 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: the type `Task` does not permit being left uninitialized
[INFO] [stdout]    --> src/oneshot.rs:133:61
[INFO] [stdout]     |
[INFO] [stdout] 133 |         tx_task: CausalCell::new(ManuallyDrop::new(unsafe { mem::uninitialized() })),
[INFO] [stdout]     |                                                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                             |
[INFO] [stdout]     |                                                             this code causes undefined behavior when executed
[INFO] [stdout]     |                                                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Task` does not permit being left uninitialized
[INFO] [stdout]    --> src/oneshot.rs:134:61
[INFO] [stdout]     |
[INFO] [stdout] 134 |         rx_task: CausalCell::new(ManuallyDrop::new(unsafe { mem::uninitialized() })),
[INFO] [stdout]     |                                                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                             |
[INFO] [stdout]     |                                                             this code causes undefined behavior when executed
[INFO] [stdout]     |                                                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/watch.rs:258:20
[INFO] [stdout]     |
[INFO] [stdout] 258 |     pub fn get_ref(&self) -> Ref<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]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 258 |     pub fn get_ref(&self) -> Ref<'_, T> {
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/watch.rs:271:21
[INFO] [stdout]     |
[INFO] [stdout] 271 |     pub fn poll_ref(&mut self) -> Poll<Option<Ref<T>>, error::RecvError> {
[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] 271 |     pub fn poll_ref(&mut self) -> Poll<Option<Ref<'_, T>>, error::RecvError> {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking tokio-reactor v0.1.12
[INFO] [stderr]     Checking tokio-codec v0.1.2
[INFO] [stderr]     Checking tokio-fs v0.1.7
[INFO] [stderr]     Checking tokio-udp v0.1.6
[INFO] [stderr]     Checking tokio-tcp v0.1.4
[INFO] [stderr]     Checking tokio-uds v0.2.7
[INFO] [stderr]     Checking tokio v0.1.22
[INFO] [stdout] warning: use of deprecated function `std::sync::atomic::spin_loop_hint`: use hint::spin_loop instead
[INFO] [stdout]   --> src/loom.rs:36:26
[INFO] [stdout]    |
[INFO] [stdout] 36 |     ::std::sync::atomic::spin_loop_hint();
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/mpsc/block.rs:366:29
[INFO] [stdout]     |
[INFO] [stdout] 366 |         let mut vals = mem::uninitialized();
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/oneshot.rs:133:66
[INFO] [stdout]     |
[INFO] [stdout] 133 |         tx_task: CausalCell::new(ManuallyDrop::new(unsafe { mem::uninitialized() })),
[INFO] [stdout]     |                                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/oneshot.rs:134:66
[INFO] [stdout]     |
[INFO] [stdout] 134 |         rx_task: CausalCell::new(ManuallyDrop::new(unsafe { mem::uninitialized() })),
[INFO] [stdout]     |                                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `AssertSend` is never used
[INFO] [stdout]   --> tests/mpsc.rs:13:7
[INFO] [stdout]    |
[INFO] [stdout] 13 | trait AssertSend: Send {}
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `AssertSend` is never used
[INFO] [stdout]   --> tests/oneshot.rs:30:7
[INFO] [stdout]    |
[INFO] [stdout] 30 | trait AssertSend: Send {}
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `AssertSend` is never used
[INFO] [stdout]  --> tests/atomic_task.rs:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | trait AssertSend: Send {}
[INFO] [stdout]   |       ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `AssertSync` is never used
[INFO] [stdout]   --> tests/atomic_task.rs:10:7
[INFO] [stdout]    |
[INFO] [stdout] 10 | trait AssertSync: Send {}
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::sync::atomic::Atomic::<*mut T>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stdout]    --> src/mpsc/block.rs:269:14
[INFO] [stdout]     |
[INFO] [stdout] 269 |             .compare_and_swap(ptr::null_mut(), block.as_ptr(), ordering);
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::sync::atomic::Atomic::<*mut T>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stdout]    --> src/mpsc/block.rs:311:43
[INFO] [stdout]     |
[INFO] [stdout] 311 |         let next = NonNull::new(self.next.compare_and_swap(
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/bounded.rs:223:32
[INFO] [stdout]     |
[INFO] [stdout] 223 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/bounded.rs:263:32
[INFO] [stdout]     |
[INFO] [stdout] 263 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/bounded.rs:293:32
[INFO] [stdout]     |
[INFO] [stdout] 293 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::sync::atomic::Atomic::<*mut T>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stdout]    --> src/mpsc/list.rs:148:26
[INFO] [stdout]     |
[INFO] [stdout] 148 |                         .compare_and_swap(block_ptr, next_block.as_ptr(), Release);
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/unbounded.rs:145:32
[INFO] [stdout]     |
[INFO] [stdout] 145 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/unbounded.rs:167:32
[INFO] [stdout]     |
[INFO] [stdout] 167 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/mpsc/unbounded.rs:189:32
[INFO] [stdout]     |
[INFO] [stdout] 189 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/oneshot.rs:50:36
[INFO] [stdout]    |
[INFO] [stdout] 50 |             write!(fmt, "{}", self.description())
[INFO] [stdout]    |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/oneshot.rs:65:36
[INFO] [stdout]    |
[INFO] [stdout] 65 |             write!(fmt, "{}", self.description())
[INFO] [stdout]    |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/semaphore.rs:688:32
[INFO] [stdout]     |
[INFO] [stdout] 688 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/semaphore.rs:734:32
[INFO] [stdout]     |
[INFO] [stdout] 734 |         write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::sync::atomic::Atomic::<usize>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stdout]    --> src/task/atomic_task.rs:179:26
[INFO] [stdout]     |
[INFO] [stdout] 179 |         match self.state.compare_and_swap(WAITING, REGISTERING, Acquire) {
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/watch.rs:126:36
[INFO] [stdout]     |
[INFO] [stdout] 126 |             write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/watch.rs:141:36
[INFO] [stdout]     |
[INFO] [stdout] 141 |             write!(fmt, "{}", self.description())
[INFO] [stdout]     |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `inner` is never read
[INFO] [stdout]    --> src/watch.rs:118:20
[INFO] [stdout]     |
[INFO] [stdout] 117 |     pub struct SendError<T> {
[INFO] [stdout]     |                --------- field in this struct
[INFO] [stdout] 118 |         pub(crate) inner: T,
[INFO] [stdout]     |                    ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `SendError` 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: the type `Task` does not permit being left uninitialized
[INFO] [stdout]    --> src/oneshot.rs:133:61
[INFO] [stdout]     |
[INFO] [stdout] 133 |         tx_task: CausalCell::new(ManuallyDrop::new(unsafe { mem::uninitialized() })),
[INFO] [stdout]     |                                                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                             |
[INFO] [stdout]     |                                                             this code causes undefined behavior when executed
[INFO] [stdout]     |                                                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Task` does not permit being left uninitialized
[INFO] [stdout]    --> src/oneshot.rs:134:61
[INFO] [stdout]     |
[INFO] [stdout] 134 |         rx_task: CausalCell::new(ManuallyDrop::new(unsafe { mem::uninitialized() })),
[INFO] [stdout]     |                                                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                             |
[INFO] [stdout]     |                                                             this code causes undefined behavior when executed
[INFO] [stdout]     |                                                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/watch.rs:258:20
[INFO] [stdout]     |
[INFO] [stdout] 258 |     pub fn get_ref(&self) -> Ref<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]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 258 |     pub fn get_ref(&self) -> Ref<'_, T> {
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/watch.rs:271:21
[INFO] [stdout]     |
[INFO] [stdout] 271 |     pub fn poll_ref(&mut self) -> Poll<Option<Ref<T>>, error::RecvError> {
[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] 271 |     pub fn poll_ref(&mut self) -> Poll<Option<Ref<'_, T>>, error::RecvError> {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 4.61s
[INFO] running `Command { std: "docker" "inspect" "6c31e033876682b9f82096504bc640a911508e03afdddb1ba236abdb1f98f259", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6c31e033876682b9f82096504bc640a911508e03afdddb1ba236abdb1f98f259", kill_on_drop: false }`
[INFO] [stdout] 6c31e033876682b9f82096504bc640a911508e03afdddb1ba236abdb1f98f259
