[INFO] cloning repository https://github.com/radu781/dualsense-rs
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/radu781/dualsense-rs" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fradu781%2Fdualsense-rs", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fradu781%2Fdualsense-rs'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 5103ab5611912e366b6b0b748d7f6cd237a83cfe
[INFO] testing radu781/dualsense-rs against master#1ef7943ee607160a564655b6596f83670ef95df5 for pr-146098-6
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fradu781%2Fdualsense-rs" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/radu781/dualsense-rs
[INFO] removed 0 missing examples
[INFO] finished tweaking git repo https://github.com/radu781/dualsense-rs
[INFO] tweaked toml for git repo https://github.com/radu781/dualsense-rs written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/radu781/dualsense-rs on toolchain 1ef7943ee607160a564655b6596f83670ef95df5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/radu781/dualsense-rs already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded hidapi v2.4.1
[INFO] [stderr]   Downloaded libc v0.2.151
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] d6407a8e69ce0322a870ce2674f5c82fbcadd59a07b4ecfc53320d7ee11bbae8
[INFO] running `Command { std: "docker" "start" "-a" "d6407a8e69ce0322a870ce2674f5c82fbcadd59a07b4ecfc53320d7ee11bbae8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "d6407a8e69ce0322a870ce2674f5c82fbcadd59a07b4ecfc53320d7ee11bbae8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d6407a8e69ce0322a870ce2674f5c82fbcadd59a07b4ecfc53320d7ee11bbae8", kill_on_drop: false }`
[INFO] [stdout] d6407a8e69ce0322a870ce2674f5c82fbcadd59a07b4ecfc53320d7ee11bbae8
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0cd6f5390e051e475ceeefe9aedea122dc65f5869db5f399681016ee0af551da
[INFO] running `Command { std: "docker" "start" "-a" "0cd6f5390e051e475ceeefe9aedea122dc65f5869db5f399681016ee0af551da", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.151
[INFO] [stderr]    Compiling pkg-config v0.3.27
[INFO] [stderr]    Compiling cc v1.0.83
[INFO] [stderr]    Compiling hidapi v2.4.1
[INFO] [stderr]    Compiling dualsense-rs v0.6.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> src/dualsense/stream.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 |     collections::{HashMap, HashSet},
[INFO] [stdout]   |                            ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]    --> src/dualsense/stream.rs:725:38
[INFO] [stdout]     |
[INFO] [stdout] 725 |                 .push(Box::new(move |x| {}));
[INFO] [stdout]     |                                      ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `duration`
[INFO] [stdout]   --> src/dualsense/properties/combo_builder.rs:36:23
[INFO] [stdout]    |
[INFO] [stdout] 36 |     fn cooldown(self, duration: Duration) -> Self {
[INFO] [stdout]    |                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_duration`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `register_pad` is never used
[INFO] [stdout]    --> src/dualsense/stream.rs:396:8
[INFO] [stdout]     |
[INFO] [stdout]  44 | impl DualSense {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 396 |     fn register_pad(&mut self, prop: ComboProperty, mut cb: Box<dyn FnMut(DPad) + 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: enum `Callback` is never used
[INFO] [stdout]  --> src/dualsense/callback_helpers.rs:3:6
[INFO] [stdout]   |
[INFO] [stdout] 3 | enum Callback {
[INFO] [stdout]   |      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackU8` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:10:7
[INFO] [stdout]    |
[INFO] [stdout] 10 | trait ToCallbackU8 {
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackU16` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:14:7
[INFO] [stdout]    |
[INFO] [stdout] 14 | trait ToCallbackU16 {
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackDPad` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:18:7
[INFO] [stdout]    |
[INFO] [stdout] 18 | trait ToCallbackDPad {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackSymbols` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:22:7
[INFO] [stdout]    |
[INFO] [stdout] 22 | trait ToCallbackSymbols {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `offset` and `convert` are never used
[INFO] [stdout]   --> src/dualsense/properties/property.rs:48:19
[INFO] [stdout]    |
[INFO] [stdout] 47 | impl InputProperty {
[INFO] [stdout]    | ------------------ methods in this implementation
[INFO] [stdout] 48 |     pub(crate) fn offset(&self) -> Offset {
[INFO] [stdout]    |                   ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 84 |     pub(crate) fn convert(&self, data: &[u8]) -> ValueType {
[INFO] [stdout]    |                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gyro_accel_into_u16` is never used
[INFO] [stdout]    --> src/dualsense/properties/property.rs:130:4
[INFO] [stdout]     |
[INFO] [stdout] 130 | fn gyro_accel_into_u16(data: &[u8]) -> i16 {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/dualsense/properties/valuetype.rs:7:5
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub(crate) enum ValueType {
[INFO] [stdout]    |                 --------- variants in this enum
[INFO] [stdout]  7 |     U8(u8),
[INFO] [stdout]    |     ^^
[INFO] [stdout]  8 |     U16(u16),
[INFO] [stdout]    |     ^^^
[INFO] [stdout]  9 |     I16(i16),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 10 |     Pad(DPad),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 11 |     Symbol(Symbols),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 12 |     Bool(bool),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 13 |     Combo(ComboProperty),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ValueType` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `NewValueType` is never used
[INFO] [stdout]   --> src/dualsense/properties/valuetype.rs:17:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub(crate) enum NewValueType {
[INFO] [stdout]    |                 ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_dpad`, `to_symbol`, `to_combo`, `to_analog`, and `to_trigger` are never used
[INFO] [stdout]    --> src/dualsense/properties/valuetype.rs:58:19
[INFO] [stdout]     |
[INFO] [stdout]  21 | impl ValueType {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  58 |     pub(crate) fn to_dpad(self) -> DPad {
[INFO] [stdout]     |                   ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  70 |     pub(crate) fn to_symbol(self) -> Symbols {
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     pub(crate) fn to_combo(self) -> ComboProperty {
[INFO] [stdout]     |                   ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub(crate) fn to_analog(self) -> AnalogPad {
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 121 |     pub(crate) fn to_trigger(self) -> Trigger {
[INFO] [stdout]     |                   ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `QUADRANT_ANGLE` is never used
[INFO] [stdout]  --> src/dualsense/properties/analog_pad.rs:6:7
[INFO] [stdout]   |
[INFO] [stdout] 6 | const QUADRANT_ANGLE: u8 = 90;
[INFO] [stdout]   |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_left_combo` and `to_right_combo` are never used
[INFO] [stdout]   --> src/dualsense/properties/analog_pad.rs:59:19
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl AnalogPad {
[INFO] [stdout]    | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub(crate) fn to_left_combo(self) -> ComboProperty {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub(crate) fn to_right_combo(self) -> ComboProperty {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 4.29s
[INFO] running `Command { std: "docker" "inspect" "0cd6f5390e051e475ceeefe9aedea122dc65f5869db5f399681016ee0af551da", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0cd6f5390e051e475ceeefe9aedea122dc65f5869db5f399681016ee0af551da", kill_on_drop: false }`
[INFO] [stdout] 0cd6f5390e051e475ceeefe9aedea122dc65f5869db5f399681016ee0af551da
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] e26138a472a6e7f8f7c415d768928422f01318b1bd7d6d8cd37aa608f07c1c56
[INFO] running `Command { std: "docker" "start" "-a" "e26138a472a6e7f8f7c415d768928422f01318b1bd7d6d8cd37aa608f07c1c56", kill_on_drop: false }`
[INFO] [stderr]    Compiling dualsense-rs v0.6.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> src/dualsense/stream.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 |     collections::{HashMap, HashSet},
[INFO] [stdout]   |                            ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]    --> src/dualsense/stream.rs:725:38
[INFO] [stdout]     |
[INFO] [stdout] 725 |                 .push(Box::new(move |x| {}));
[INFO] [stdout]     |                                      ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `duration`
[INFO] [stdout]   --> src/dualsense/properties/combo_builder.rs:36:23
[INFO] [stdout]    |
[INFO] [stdout] 36 |     fn cooldown(self, duration: Duration) -> Self {
[INFO] [stdout]    |                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_duration`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `register_pad` is never used
[INFO] [stdout]    --> src/dualsense/stream.rs:396:8
[INFO] [stdout]     |
[INFO] [stdout]  44 | impl DualSense {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 396 |     fn register_pad(&mut self, prop: ComboProperty, mut cb: Box<dyn FnMut(DPad) + 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: enum `Callback` is never used
[INFO] [stdout]  --> src/dualsense/callback_helpers.rs:3:6
[INFO] [stdout]   |
[INFO] [stdout] 3 | enum Callback {
[INFO] [stdout]   |      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackU8` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:10:7
[INFO] [stdout]    |
[INFO] [stdout] 10 | trait ToCallbackU8 {
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackU16` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:14:7
[INFO] [stdout]    |
[INFO] [stdout] 14 | trait ToCallbackU16 {
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackDPad` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:18:7
[INFO] [stdout]    |
[INFO] [stdout] 18 | trait ToCallbackDPad {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackSymbols` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:22:7
[INFO] [stdout]    |
[INFO] [stdout] 22 | trait ToCallbackSymbols {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `offset` and `convert` are never used
[INFO] [stdout]   --> src/dualsense/properties/property.rs:48:19
[INFO] [stdout]    |
[INFO] [stdout] 47 | impl InputProperty {
[INFO] [stdout]    | ------------------ methods in this implementation
[INFO] [stdout] 48 |     pub(crate) fn offset(&self) -> Offset {
[INFO] [stdout]    |                   ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 84 |     pub(crate) fn convert(&self, data: &[u8]) -> ValueType {
[INFO] [stdout]    |                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gyro_accel_into_u16` is never used
[INFO] [stdout]    --> src/dualsense/properties/property.rs:130:4
[INFO] [stdout]     |
[INFO] [stdout] 130 | fn gyro_accel_into_u16(data: &[u8]) -> i16 {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/dualsense/properties/valuetype.rs:7:5
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub(crate) enum ValueType {
[INFO] [stdout]    |                 --------- variants in this enum
[INFO] [stdout]  7 |     U8(u8),
[INFO] [stdout]    |     ^^
[INFO] [stdout]  8 |     U16(u16),
[INFO] [stdout]    |     ^^^
[INFO] [stdout]  9 |     I16(i16),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 10 |     Pad(DPad),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 11 |     Symbol(Symbols),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 12 |     Bool(bool),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 13 |     Combo(ComboProperty),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ValueType` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `NewValueType` is never used
[INFO] [stdout]   --> src/dualsense/properties/valuetype.rs:17:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub(crate) enum NewValueType {
[INFO] [stdout]    |                 ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_dpad`, `to_symbol`, `to_combo`, `to_analog`, and `to_trigger` are never used
[INFO] [stdout]    --> src/dualsense/properties/valuetype.rs:58:19
[INFO] [stdout]     |
[INFO] [stdout]  21 | impl ValueType {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  58 |     pub(crate) fn to_dpad(self) -> DPad {
[INFO] [stdout]     |                   ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  70 |     pub(crate) fn to_symbol(self) -> Symbols {
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     pub(crate) fn to_combo(self) -> ComboProperty {
[INFO] [stdout]     |                   ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub(crate) fn to_analog(self) -> AnalogPad {
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 121 |     pub(crate) fn to_trigger(self) -> Trigger {
[INFO] [stdout]     |                   ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `QUADRANT_ANGLE` is never used
[INFO] [stdout]  --> src/dualsense/properties/analog_pad.rs:6:7
[INFO] [stdout]   |
[INFO] [stdout] 6 | const QUADRANT_ANGLE: u8 = 90;
[INFO] [stdout]   |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_left_combo` and `to_right_combo` are never used
[INFO] [stdout]   --> src/dualsense/properties/analog_pad.rs:59:19
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl AnalogPad {
[INFO] [stdout]    | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub(crate) fn to_left_combo(self) -> ComboProperty {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub(crate) fn to_right_combo(self) -> ComboProperty {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> src/dualsense/stream.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 |     collections::{HashMap, HashSet},
[INFO] [stdout]   |                            ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]    --> src/dualsense/stream.rs:725:38
[INFO] [stdout]     |
[INFO] [stdout] 725 |                 .push(Box::new(move |x| {}));
[INFO] [stdout]     |                                      ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `duration`
[INFO] [stdout]   --> src/dualsense/properties/combo_builder.rs:36:23
[INFO] [stdout]    |
[INFO] [stdout] 36 |     fn cooldown(self, duration: Duration) -> Self {
[INFO] [stdout]    |                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_duration`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `register_pad` is never used
[INFO] [stdout]    --> src/dualsense/stream.rs:396:8
[INFO] [stdout]     |
[INFO] [stdout]  44 | impl DualSense {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 396 |     fn register_pad(&mut self, prop: ComboProperty, mut cb: Box<dyn FnMut(DPad) + 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: enum `Callback` is never used
[INFO] [stdout]  --> src/dualsense/callback_helpers.rs:3:6
[INFO] [stdout]   |
[INFO] [stdout] 3 | enum Callback {
[INFO] [stdout]   |      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackU8` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:10:7
[INFO] [stdout]    |
[INFO] [stdout] 10 | trait ToCallbackU8 {
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackU16` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:14:7
[INFO] [stdout]    |
[INFO] [stdout] 14 | trait ToCallbackU16 {
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackDPad` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:18:7
[INFO] [stdout]    |
[INFO] [stdout] 18 | trait ToCallbackDPad {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ToCallbackSymbols` is never used
[INFO] [stdout]   --> src/dualsense/callback_helpers.rs:22:7
[INFO] [stdout]    |
[INFO] [stdout] 22 | trait ToCallbackSymbols {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `offset` and `convert` are never used
[INFO] [stdout]   --> src/dualsense/properties/property.rs:48:19
[INFO] [stdout]    |
[INFO] [stdout] 47 | impl InputProperty {
[INFO] [stdout]    | ------------------ methods in this implementation
[INFO] [stdout] 48 |     pub(crate) fn offset(&self) -> Offset {
[INFO] [stdout]    |                   ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 84 |     pub(crate) fn convert(&self, data: &[u8]) -> ValueType {
[INFO] [stdout]    |                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gyro_accel_into_u16` is never used
[INFO] [stdout]    --> src/dualsense/properties/property.rs:130:4
[INFO] [stdout]     |
[INFO] [stdout] 130 | fn gyro_accel_into_u16(data: &[u8]) -> i16 {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/dualsense/properties/valuetype.rs:7:5
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub(crate) enum ValueType {
[INFO] [stdout]    |                 --------- variants in this enum
[INFO] [stdout]  7 |     U8(u8),
[INFO] [stdout]    |     ^^
[INFO] [stdout]  8 |     U16(u16),
[INFO] [stdout]    |     ^^^
[INFO] [stdout]  9 |     I16(i16),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 10 |     Pad(DPad),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 11 |     Symbol(Symbols),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 12 |     Bool(bool),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 13 |     Combo(ComboProperty),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ValueType` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `NewValueType` is never used
[INFO] [stdout]   --> src/dualsense/properties/valuetype.rs:17:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub(crate) enum NewValueType {
[INFO] [stdout]    |                 ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_dpad`, `to_symbol`, `to_combo`, `to_analog`, and `to_trigger` are never used
[INFO] [stdout]    --> src/dualsense/properties/valuetype.rs:58:19
[INFO] [stdout]     |
[INFO] [stdout]  21 | impl ValueType {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  58 |     pub(crate) fn to_dpad(self) -> DPad {
[INFO] [stdout]     |                   ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  70 |     pub(crate) fn to_symbol(self) -> Symbols {
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     pub(crate) fn to_combo(self) -> ComboProperty {
[INFO] [stdout]     |                   ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub(crate) fn to_analog(self) -> AnalogPad {
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 121 |     pub(crate) fn to_trigger(self) -> Trigger {
[INFO] [stdout]     |                   ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `QUADRANT_ANGLE` is never used
[INFO] [stdout]  --> src/dualsense/properties/analog_pad.rs:6:7
[INFO] [stdout]   |
[INFO] [stdout] 6 | const QUADRANT_ANGLE: u8 = 90;
[INFO] [stdout]   |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_left_combo` and `to_right_combo` are never used
[INFO] [stdout]   --> src/dualsense/properties/analog_pad.rs:59:19
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl AnalogPad {
[INFO] [stdout]    | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub(crate) fn to_left_combo(self) -> ComboProperty {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub(crate) fn to_right_combo(self) -> ComboProperty {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.05s
[INFO] running `Command { std: "docker" "inspect" "e26138a472a6e7f8f7c415d768928422f01318b1bd7d6d8cd37aa608f07c1c56", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e26138a472a6e7f8f7c415d768928422f01318b1bd7d6d8cd37aa608f07c1c56", kill_on_drop: false }`
[INFO] [stdout] e26138a472a6e7f8f7c415d768928422f01318b1bd7d6d8cd37aa608f07c1c56
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 0493a59f69924dc9631bfe6450cd5565740ea6ee8469f7df6f50aa3992d2b6ba
[INFO] running `Command { std: "docker" "start" "-a" "0493a59f69924dc9631bfe6450cd5565740ea6ee8469f7df6f50aa3992d2b6ba", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `HashSet`
[INFO] [stderr]  --> src/dualsense/stream.rs:3:28
[INFO] [stderr]   |
[INFO] [stderr] 3 |     collections::{HashMap, HashSet},
[INFO] [stderr]   |                            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `x`
[INFO] [stderr]    --> src/dualsense/stream.rs:725:38
[INFO] [stderr]     |
[INFO] [stderr] 725 |                 .push(Box::new(move |x| {}));
[INFO] [stderr]     |                                      ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `duration`
[INFO] [stderr]   --> src/dualsense/properties/combo_builder.rs:36:23
[INFO] [stderr]    |
[INFO] [stderr] 36 |     fn cooldown(self, duration: Duration) -> Self {
[INFO] [stderr]    |                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_duration`
[INFO] [stderr] 
[INFO] [stderr] warning: method `register_pad` is never used
[INFO] [stderr]    --> src/dualsense/stream.rs:396:8
[INFO] [stderr]     |
[INFO] [stderr]  44 | impl DualSense {
[INFO] [stderr]     | -------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 396 |     fn register_pad(&mut self, prop: ComboProperty, mut cb: Box<dyn FnMut(DPad) + Send>) {
[INFO] [stderr]     |        ^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: enum `Callback` is never used
[INFO] [stderr]  --> src/dualsense/callback_helpers.rs:3:6
[INFO] [stderr]   |
[INFO] [stderr] 3 | enum Callback {
[INFO] [stderr]   |      ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `ToCallbackU8` is never used
[INFO] [stderr]   --> src/dualsense/callback_helpers.rs:10:7
[INFO] [stderr]    |
[INFO] [stderr] 10 | trait ToCallbackU8 {
[INFO] [stderr]    |       ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `ToCallbackU16` is never used
[INFO] [stderr]   --> src/dualsense/callback_helpers.rs:14:7
[INFO] [stderr]    |
[INFO] [stderr] 14 | trait ToCallbackU16 {
[INFO] [stderr]    |       ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `ToCallbackDPad` is never used
[INFO] [stderr]   --> src/dualsense/callback_helpers.rs:18:7
[INFO] [stderr]    |
[INFO] [stderr] 18 | trait ToCallbackDPad {
[INFO] [stderr]    |       ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `ToCallbackSymbols` is never used
[INFO] [stderr]   --> src/dualsense/callback_helpers.rs:22:7
[INFO] [stderr]    |
[INFO] [stderr] 22 | trait ToCallbackSymbols {
[INFO] [stderr]    |       ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `offset` and `convert` are never used
[INFO] [stderr]   --> src/dualsense/properties/property.rs:48:19
[INFO] [stderr]    |
[INFO] [stderr] 47 | impl InputProperty {
[INFO] [stderr]    | ------------------ methods in this implementation
[INFO] [stderr] 48 |     pub(crate) fn offset(&self) -> Offset {
[INFO] [stderr]    |                   ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 84 |     pub(crate) fn convert(&self, data: &[u8]) -> ValueType {
[INFO] [stderr]    |                   ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `gyro_accel_into_u16` is never used
[INFO] [stderr]    --> src/dualsense/properties/property.rs:130:4
[INFO] [stderr]     |
[INFO] [stderr] 130 | fn gyro_accel_into_u16(data: &[u8]) -> i16 {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple variants are never constructed
[INFO] [stderr]   --> src/dualsense/properties/valuetype.rs:7:5
[INFO] [stderr]    |
[INFO] [stderr]  6 | pub(crate) enum ValueType {
[INFO] [stderr]    |                 --------- variants in this enum
[INFO] [stderr]  7 |     U8(u8),
[INFO] [stderr]    |     ^^
[INFO] [stderr]  8 |     U16(u16),
[INFO] [stderr]    |     ^^^
[INFO] [stderr]  9 |     I16(i16),
[INFO] [stderr]    |     ^^^
[INFO] [stderr] 10 |     Pad(DPad),
[INFO] [stderr]    |     ^^^
[INFO] [stderr] 11 |     Symbol(Symbols),
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr] 12 |     Bool(bool),
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] 13 |     Combo(ComboProperty),
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ValueType` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: enum `NewValueType` is never used
[INFO] [stderr]   --> src/dualsense/properties/valuetype.rs:17:17
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub(crate) enum NewValueType {
[INFO] [stderr]    |                 ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `to_dpad`, `to_symbol`, `to_combo`, `to_analog`, and `to_trigger` are never used
[INFO] [stderr]    --> src/dualsense/properties/valuetype.rs:58:19
[INFO] [stderr]     |
[INFO] [stderr]  21 | impl ValueType {
[INFO] [stderr]     | -------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  58 |     pub(crate) fn to_dpad(self) -> DPad {
[INFO] [stderr]     |                   ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  70 |     pub(crate) fn to_symbol(self) -> Symbols {
[INFO] [stderr]     |                   ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  93 |     pub(crate) fn to_combo(self) -> ComboProperty {
[INFO] [stderr]     |                   ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 105 |     pub(crate) fn to_analog(self) -> AnalogPad {
[INFO] [stderr]     |                   ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 121 |     pub(crate) fn to_trigger(self) -> Trigger {
[INFO] [stderr]     |                   ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `QUADRANT_ANGLE` is never used
[INFO] [stderr]  --> src/dualsense/properties/analog_pad.rs:6:7
[INFO] [stderr]   |
[INFO] [stderr] 6 | const QUADRANT_ANGLE: u8 = 90;
[INFO] [stderr]   |       ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `to_left_combo` and `to_right_combo` are never used
[INFO] [stderr]   --> src/dualsense/properties/analog_pad.rs:59:19
[INFO] [stderr]    |
[INFO] [stderr] 14 | impl AnalogPad {
[INFO] [stderr]    | -------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 59 |     pub(crate) fn to_left_combo(self) -> ComboProperty {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 63 |     pub(crate) fn to_right_combo(self) -> ComboProperty {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `dualsense-rs` (lib) generated 16 warnings (run `cargo fix --lib -p dualsense-rs` to apply 3 suggestions)
[INFO] [stderr] warning: `dualsense-rs` (lib test) generated 16 warnings (16 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.04s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/dualsense_rs-1b23eade5e7ecfbe)
[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] [stderr]    Doc-tests dualsense_rs
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test src/lib.rs - (line 37) ... FAILED
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] [stdout] test src/lib.rs - (line 13) ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- src/lib.rs - (line 37) stdout ----
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `DualSense`
[INFO] [stdout]  --> src/lib.rs:38:22
[INFO] [stdout]   |
[INFO] [stdout] 3 | let mut controller = DualSense::default();
[INFO] [stdout]   |                      ^^^^^^^^^ use of undeclared type `DualSense`
[INFO] [stdout]   |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]   |
[INFO] [stdout] 2 + use dualsense_rs::DualSense;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `TriggerEffect`
[INFO] [stdout]  --> src/lib.rs:39:36
[INFO] [stdout]   |
[INFO] [stdout] 4 | controller.set_left_trigger_effect(TriggerEffect::Mode1);
[INFO] [stdout]   |                                    ^^^^^^^^^^^^^ use of undeclared type `TriggerEffect`
[INFO] [stdout]   |
[INFO] [stdout] help: consider importing this enum
[INFO] [stdout]   |
[INFO] [stdout] 2 + use dualsense_rs::properties::trigger_effect::TriggerEffect;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 2 previous errors
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0433`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 13) stdout ----
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `DualSense`
[INFO] [stdout]  --> src/lib.rs:14:22
[INFO] [stdout]   |
[INFO] [stdout] 3 | let mut controller = DualSense::default();
[INFO] [stdout]   |                      ^^^^^^^^^ use of undeclared type `DualSense`
[INFO] [stdout]   |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]   |
[INFO] [stdout] 2 + use dualsense_rs::DualSense;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 1 previous error
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0433`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     src/lib.rs - (line 13)
[INFO] [stdout]     src/lib.rs - (line 37)
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.19s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "0493a59f69924dc9631bfe6450cd5565740ea6ee8469f7df6f50aa3992d2b6ba", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0493a59f69924dc9631bfe6450cd5565740ea6ee8469f7df6f50aa3992d2b6ba", kill_on_drop: false }`
[INFO] [stdout] 0493a59f69924dc9631bfe6450cd5565740ea6ee8469f7df6f50aa3992d2b6ba
