[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] checking radu781/dualsense-rs against try#50d7e48beb74b48bd17c3749bfb73843c9ae0166 for pr-151102
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fradu781%2Fdualsense-rs" "/workspace/builds/worker-4-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc2/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-4-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/radu781/dualsense-rs on toolchain 50d7e48beb74b48bd17c3749bfb73843c9ae0166
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+50d7e48beb74b48bd17c3749bfb73843c9ae0166" "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" "+50d7e48beb74b48bd17c3749bfb73843c9ae0166" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[ERROR] error running command: no output for 300 seconds
[INFO] checking radu781/dualsense-rs against try#50d7e48beb74b48bd17c3749bfb73843c9ae0166 for pr-151102
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fradu781%2Fdualsense-rs" "/workspace/builds/worker-4-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc2/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-4-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/radu781/dualsense-rs on toolchain 50d7e48beb74b48bd17c3749bfb73843c9ae0166
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+50d7e48beb74b48bd17c3749bfb73843c9ae0166" "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" "+50d7e48beb74b48bd17c3749bfb73843c9ae0166" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[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-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+50d7e48beb74b48bd17c3749bfb73843c9ae0166" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 75c0fa6a91b4d391636ac90ccdf46a3a9ba6dcd45c2cfccad35a5c1e88a7ddf7
[INFO] running `Command { std: "docker" "start" "-a" "75c0fa6a91b4d391636ac90ccdf46a3a9ba6dcd45c2cfccad35a5c1e88a7ddf7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "75c0fa6a91b4d391636ac90ccdf46a3a9ba6dcd45c2cfccad35a5c1e88a7ddf7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "75c0fa6a91b4d391636ac90ccdf46a3a9ba6dcd45c2cfccad35a5c1e88a7ddf7", kill_on_drop: false }`
[INFO] [stdout] 75c0fa6a91b4d391636ac90ccdf46a3a9ba6dcd45c2cfccad35a5c1e88a7ddf7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+50d7e48beb74b48bd17c3749bfb73843c9ae0166" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 027115ceeb4c98fd2048c05a4254b9b2780e7912a99360bd1e1350dd9fbc5cde
[INFO] running `Command { std: "docker" "start" "-a" "027115ceeb4c98fd2048c05a4254b9b2780e7912a99360bd1e1350dd9fbc5cde", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.151
[INFO] [stderr]    Compiling cc v1.0.83
[INFO] [stderr]    Compiling hidapi v2.4.1
[INFO] [stderr]     Checking 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 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: `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: 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: 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: 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 `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 `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 `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: 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: 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: 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: 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_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: 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 2.25s
[INFO] running `Command { std: "docker" "inspect" "027115ceeb4c98fd2048c05a4254b9b2780e7912a99360bd1e1350dd9fbc5cde", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "027115ceeb4c98fd2048c05a4254b9b2780e7912a99360bd1e1350dd9fbc5cde", kill_on_drop: false }`
[INFO] [stdout] 027115ceeb4c98fd2048c05a4254b9b2780e7912a99360bd1e1350dd9fbc5cde
