[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#2fd6efc32704647e64d3d646d21c4c68eae100e4 for pr-149852-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fradu781%2Fdualsense-rs" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-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-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/radu781/dualsense-rs on toolchain 2fd6efc32704647e64d3d646d21c4c68eae100e4
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "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" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "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] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] c61b5f7069c749fdab51ea4237302e40783d97e354d15a18c188c80a847f5faa
[INFO] running `Command { std: "docker" "start" "-a" "c61b5f7069c749fdab51ea4237302e40783d97e354d15a18c188c80a847f5faa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c61b5f7069c749fdab51ea4237302e40783d97e354d15a18c188c80a847f5faa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c61b5f7069c749fdab51ea4237302e40783d97e354d15a18c188c80a847f5faa", kill_on_drop: false }`
[INFO] [stdout] c61b5f7069c749fdab51ea4237302e40783d97e354d15a18c188c80a847f5faa
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 941aaeb48785d2e2df737d99519e509d0e7530c7681a63a5f3d9746d2bddf5e3
[INFO] running `Command { std: "docker" "start" "-a" "941aaeb48785d2e2df737d99519e509d0e7530c7681a63a5f3d9746d2bddf5e3", 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.43s
[INFO] running `Command { std: "docker" "inspect" "941aaeb48785d2e2df737d99519e509d0e7530c7681a63a5f3d9746d2bddf5e3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "941aaeb48785d2e2df737d99519e509d0e7530c7681a63a5f3d9746d2bddf5e3", kill_on_drop: false }`
[INFO] [stdout] 941aaeb48785d2e2df737d99519e509d0e7530c7681a63a5f3d9746d2bddf5e3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d95ff9e144062c6af65874460abef046530bece8964821cea1f5fb7f2da3aaff
[INFO] running `Command { std: "docker" "start" "-a" "d95ff9e144062c6af65874460abef046530bece8964821cea1f5fb7f2da3aaff", kill_on_drop: false }`
[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]    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 `test` profile [unoptimized + debuginfo] target(s) in 1.26s
[INFO] running `Command { std: "docker" "inspect" "d95ff9e144062c6af65874460abef046530bece8964821cea1f5fb7f2da3aaff", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d95ff9e144062c6af65874460abef046530bece8964821cea1f5fb7f2da3aaff", kill_on_drop: false }`
[INFO] [stdout] d95ff9e144062c6af65874460abef046530bece8964821cea1f5fb7f2da3aaff
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 00950567779e1338b94d7fafe52baf21811d32ae562ea51631d8575b4515fd92
[INFO] running `Command { std: "docker" "start" "-a" "00950567779e1338b94d7fafe52baf21811d32ae562ea51631d8575b4515fd92", 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.03s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/dualsense_rs-e2f22a15d704d632)
[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 13) ... FAILED
[INFO] [stdout] test src/lib.rs - (line 37) ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[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] 14 | 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] 13 + 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] ---- 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] 38 | 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] 37 + 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] 39 | 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] 37 + 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] 
[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] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] running `Command { std: "docker" "inspect" "00950567779e1338b94d7fafe52baf21811d32ae562ea51631d8575b4515fd92", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "00950567779e1338b94d7fafe52baf21811d32ae562ea51631d8575b4515fd92", kill_on_drop: false }`
[INFO] [stdout] 00950567779e1338b94d7fafe52baf21811d32ae562ea51631d8575b4515fd92
