[INFO] cloning repository https://github.com/TorsteinTenstad/gloomy-dungeon
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/TorsteinTenstad/gloomy-dungeon" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTorsteinTenstad%2Fgloomy-dungeon", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTorsteinTenstad%2Fgloomy-dungeon'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 0628ba18913e8dd144d320548c14db4b7df16cb9
[INFO] checking TorsteinTenstad/gloomy-dungeon against try#fa4dd1f19bfeb3fd235dc7f1406c42404436bef5 for pr-145108-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTorsteinTenstad%2Fgloomy-dungeon" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/TorsteinTenstad/gloomy-dungeon
[INFO] finished tweaking git repo https://github.com/TorsteinTenstad/gloomy-dungeon
[INFO] tweaked toml for git repo https://github.com/TorsteinTenstad/gloomy-dungeon written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/TorsteinTenstad/gloomy-dungeon on toolchain fa4dd1f19bfeb3fd235dc7f1406c42404436bef5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/TorsteinTenstad/gloomy-dungeon 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" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "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 clap_builder v4.5.52
[INFO] [stderr]   Downloaded clap v4.5.52
[INFO] [stderr]   Downloaded syn v2.0.110
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:61361fe0aef631f17e9d025a70c5a647956f8c671dd02950a60ad3f5cc5526d7" "/opt/rustwide/cargo-home/bin/cargo" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 5cdb5ce223067e06da632edc0c770ee56f23cf1e68b70a86b878709fadf12320
[INFO] running `Command { std: "docker" "start" "-a" "5cdb5ce223067e06da632edc0c770ee56f23cf1e68b70a86b878709fadf12320", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "5cdb5ce223067e06da632edc0c770ee56f23cf1e68b70a86b878709fadf12320", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5cdb5ce223067e06da632edc0c770ee56f23cf1e68b70a86b878709fadf12320", kill_on_drop: false }`
[INFO] [stdout] 5cdb5ce223067e06da632edc0c770ee56f23cf1e68b70a86b878709fadf12320
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:61361fe0aef631f17e9d025a70c5a647956f8c671dd02950a60ad3f5cc5526d7" "/opt/rustwide/cargo-home/bin/cargo" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2bb1fbf7c774870de44d9fa7fdc5e78e8f042559a917eb17651548400f2b586f
[INFO] running `Command { std: "docker" "start" "-a" "2bb1fbf7c774870de44d9fa7fdc5e78e8f042559a917eb17651548400f2b586f", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.103
[INFO] [stderr]    Compiling unicode-ident v1.0.22
[INFO] [stderr]    Compiling quote v1.0.42
[INFO] [stderr]     Checking is_terminal_polyfill v1.70.2
[INFO] [stderr]     Checking anstyle-query v1.1.5
[INFO] [stderr]     Checking clap_lex v0.7.6
[INFO] [stderr]     Checking anstream v0.6.21
[INFO] [stderr]     Checking clap_builder v4.5.52
[INFO] [stderr]    Compiling syn v2.0.110
[INFO] [stderr]     Checking clap v4.5.52
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]     Checking gloomy-dungeon v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `distance`
[INFO] [stdout]  --> src/character_filter.rs:5:31
[INFO] [stdout]   |
[INFO] [stdout] 5 |     hex_grid::{DistanceRange, distance, distance_within_range},
[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: `distance`
[INFO] [stdout]  --> src/character_filter.rs:5:31
[INFO] [stdout]   |
[INFO] [stdout] 5 |     hex_grid::{DistanceRange, distance, distance_within_range},
[INFO] [stdout]   |                               ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InputDummy` is never constructed
[INFO] [stdout]   --> src/main.rs:96:8
[INFO] [stdout]    |
[INFO] [stdout] 96 | struct InputDummy {}
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `with_incremented` and `decrement_all` are never used
[INFO] [stdout]   --> src/enum_map.rs:8:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | impl<K: Eq + Hash> EnumMap<K> {
[INFO] [stdout]    | ----------------------------- methods in this implementation
[INFO] [stdout]  8 |     pub fn with_incremented(self, key: K, increment: isize) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 25 |     pub fn decrement_all(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/hex_grid.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl PosOddQHex {
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 15 |     pub fn new(r: isize, q: isize) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/hex_grid.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 26 | impl PosAxial {
[INFO] [stdout]    | ------------- associated function in this implementation
[INFO] [stdout] 27 |     pub fn new(r: isize, q: isize) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PosDelta` is never constructed
[INFO] [stdout]   --> src/hex_grid.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct PosDelta {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `perform_movement_unchecked` is never used
[INFO] [stdout]  --> src/movement.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn perform_movement_unchecked<'a, P>(character: &mut Character, path: P)
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `play_card_unchecked` is never used
[INFO] [stdout]  --> src/play.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub fn play_card_unchecked(character: &mut Character, card_data: CardData) -> usize {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `end_turn` is never used
[INFO] [stdout]   --> src/play.rs:16:8
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub fn end_turn(character: &mut Character) {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `begin_turn` is never used
[INFO] [stdout]   --> src/play.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub fn begin_turn(character: &mut Character) {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PlayCardOrEndTurn` is never used
[INFO] [stdout]   --> src/play_state.rs:12:10
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum PlayCardOrEndTurn {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Cancelable` is never used
[INFO] [stdout]   --> src/play_state.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum Cancelable<T> {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PendingInput` is never used
[INFO] [stdout]   --> src/play_state.rs:22:10
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub enum PendingInput<T> {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Input` is never used
[INFO] [stdout]   --> src/play_state.rs:28:11
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub trait Input {
[INFO] [stdout]    |           ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlayState` is never constructed
[INFO] [stdout]   --> src/play_state.rs:39:12
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct PlayState {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ExecutionState` is never used
[INFO] [stdout]   --> src/play_state.rs:46:6
[INFO] [stdout]    |
[INFO] [stdout] 46 | enum ExecutionState {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `step_play_state` is never used
[INFO] [stdout]   --> src/play_state.rs:52:8
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn step_play_state(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `execute_action` is never used
[INFO] [stdout]    --> src/play_state.rs:128:4
[INFO] [stdout]     |
[INFO] [stdout] 128 | fn execute_action<C>(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PopAbilityResult` is never used
[INFO] [stdout]  --> src/pop_ability.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub enum PopAbilityResult {
[INFO] [stdout]   |          ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `pop_ability_ignore_unsatisfied` is never used
[INFO] [stdout]   --> src/pop_ability.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub fn pop_ability_ignore_unsatisfied<C>(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `pop_ability` is never used
[INFO] [stdout]   --> src/pop_ability.rs:29:8
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub fn pop_ability<'a, C>(source_character: &'a mut Character, characters: C) -> PopAbilityResult
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `map_action` is never used
[INFO] [stdout]   --> src/pop_ability.rs:64:8
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub fn map_action(character: &Character, action: Action) -> Action {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `filter_map_action_for_fury` is never used
[INFO] [stdout]   --> src/pop_ability.rs:75:8
[INFO] [stdout]    |
[INFO] [stdout] 75 | pub fn filter_map_action_for_fury(action: &Action) -> Option<Action> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `optional_precondition_is_met` is never used
[INFO] [stdout]   --> src/precondition.rs:24:8
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub fn optional_precondition_is_met<'a, C>(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `precondition_is_met` is never used
[INFO] [stdout]   --> src/precondition.rs:35:8
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub fn precondition_is_met<'a, C>(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ActionInputOnSelf` is never constructed
[INFO] [stdout]  --> src/resolve_action.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct ActionInputOnSelf {}
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ActionInputTargeted` is never constructed
[INFO] [stdout]   --> src/resolve_action.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct ActionInputTargeted {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ActionInputMovement` is never constructed
[INFO] [stdout]   --> src/resolve_action.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct ActionInputMovement {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_action_movement` is never used
[INFO] [stdout]   --> src/resolve_action.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub fn resolve_action_movement(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_action_targeted` is never used
[INFO] [stdout]   --> src/resolve_action.rs:30:8
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn resolve_action_targeted<C>(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_action_on_self` is never used
[INFO] [stdout]   --> src/resolve_action.rs:41:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub fn resolve_action_on_self<C>(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `single_out` is never used
[INFO] [stdout]  --> src/single_out.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub fn single_out<T>(v: &mut [T], index: usize) -> Option<(&mut T, DiscontinuousSpan<'_, T>)> {
[INFO] [stdout]   |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `try_get`, `get`, and `end_turn` are never used
[INFO] [stdout]   --> src/turn_stats.rs:20:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl TurnStats {
[INFO] [stdout]    | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 20 |     fn try_get(&self, turn_index_relative: usize, stat: &TurnStat) -> Option<usize> {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     pub fn get(&self, turn_index_relative: usize, stat: &TurnStat) -> usize {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |     pub fn end_turn(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InputDummy` is never constructed
[INFO] [stdout]   --> src/main.rs:96:8
[INFO] [stdout]    |
[INFO] [stdout] 96 | struct InputDummy {}
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/hex_grid.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl PosOddQHex {
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 15 |     pub fn new(r: isize, q: isize) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PosDelta` is never constructed
[INFO] [stdout]   --> src/hex_grid.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct PosDelta {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PlayCardOrEndTurn` is never used
[INFO] [stdout]   --> src/play_state.rs:12:10
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum PlayCardOrEndTurn {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Cancelable` is never used
[INFO] [stdout]   --> src/play_state.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum Cancelable<T> {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PendingInput` is never used
[INFO] [stdout]   --> src/play_state.rs:22:10
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub enum PendingInput<T> {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Input` is never used
[INFO] [stdout]   --> src/play_state.rs:28:11
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub trait Input {
[INFO] [stdout]    |           ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlayState` is never constructed
[INFO] [stdout]   --> src/play_state.rs:39:12
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct PlayState {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ExecutionState` is never used
[INFO] [stdout]   --> src/play_state.rs:46:6
[INFO] [stdout]    |
[INFO] [stdout] 46 | enum ExecutionState {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `step_play_state` is never used
[INFO] [stdout]   --> src/play_state.rs:52:8
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn step_play_state(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `execute_action` is never used
[INFO] [stdout]    --> src/play_state.rs:128:4
[INFO] [stdout]     |
[INFO] [stdout] 128 | fn execute_action<C>(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `pop_ability_ignore_unsatisfied` is never used
[INFO] [stdout]   --> src/pop_ability.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub fn pop_ability_ignore_unsatisfied<C>(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `OnSelf` is never constructed
[INFO] [stdout]   --> src/test/tools.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub enum ActionInput {
[INFO] [stdout]    |          ----------- variant in this enum
[INFO] [stdout] 17 |     OnSelf(ActionInputOnSelf),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ActionInput` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 5.20s
[INFO] running `Command { std: "docker" "inspect" "2bb1fbf7c774870de44d9fa7fdc5e78e8f042559a917eb17651548400f2b586f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2bb1fbf7c774870de44d9fa7fdc5e78e8f042559a917eb17651548400f2b586f", kill_on_drop: false }`
[INFO] [stdout] 2bb1fbf7c774870de44d9fa7fdc5e78e8f042559a917eb17651548400f2b586f
