[INFO] updating cached repository https://github.com/PiotrAleksander/roguelike-template [INFO] running `"git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "-c" "remote.origin.fetch=refs/heads/*:refs/heads/*" "fetch" "origin" "--force" "--prune"` [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 662cc7e3d7d4b66d5e6761826f672eee8b0b5148 [INFO] checking PiotrAleksander/roguelike-template against try#e4dba30b9b475d8750370c4dfb49b6541990904d for pr-71393 [INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FPiotrAleksander%2Froguelike-template" "/workspace/builds/worker-0/source"` [INFO] [stderr] Cloning into '/workspace/builds/worker-0/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/PiotrAleksander/roguelike-template on toolchain e4dba30b9b475d8750370c4dfb49b6541990904d [INFO] running `"/workspace/cargo-home/bin/cargo" "+e4dba30b9b475d8750370c4dfb49b6541990904d" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started tweaking git repo https://github.com/PiotrAleksander/roguelike-template [INFO] finished tweaking git repo https://github.com/PiotrAleksander/roguelike-template [INFO] tweaked toml for git repo https://github.com/PiotrAleksander/roguelike-template written to /workspace/builds/worker-0/source/Cargo.toml [INFO] crate git repo https://github.com/PiotrAleksander/roguelike-template already has a lockfile, it will not be regenerated [INFO] running `"/workspace/cargo-home/bin/cargo" "+e4dba30b9b475d8750370c4dfb49b6541990904d" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+e4dba30b9b475d8750370c4dfb49b6541990904d" "check" "--frozen" "--all" "--all-targets"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] b2a678d91ee693a47820bf86f7a6edacb50da917b3b1a3df3bd889de40eb899a [INFO] running `"docker" "start" "-a" "b2a678d91ee693a47820bf86f7a6edacb50da917b3b1a3df3bd889de40eb899a"` [INFO] [stderr] Compiling cc v1.0.50 [INFO] [stderr] Compiling pkg-config v0.3.17 [INFO] [stderr] Checking lazy_static v0.1.16 [INFO] [stderr] Compiling tcod-sys v5.0.1 [INFO] [stderr] Checking tcod v0.15.0 [INFO] [stderr] Checking roguelike v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] error: expected type, found `:` [INFO] [stderr] --> src/main.rs:141:30 [INFO] [stderr] | [INFO] [stderr] 141 | let num_monsters = rand: :thread_rng().gen_range(0, MAX_ROOMS_MONSTERS + 1); [INFO] [stderr] | - ^ expected type [INFO] [stderr] | | [INFO] [stderr] | tried to parse a type due to this type ascription [INFO] [stderr] | [INFO] [stderr] = note: `#![feature(type_ascription)]` lets you annotate an expression with a type: `: ` [INFO] [stderr] = note: see issue #23416 for more information [INFO] [stderr] [INFO] [stderr] error: expected one of `:`, `;`, `=`, `@`, or `|`, found `+` [INFO] [stderr] --> src/main.rs:186:21 [INFO] [stderr] | [INFO] [stderr] 186 | let mut objects + vec![player]; [INFO] [stderr] | ^ expected one of `:`, `;`, `=`, `@`, or `|` [INFO] [stderr] [INFO] [stderr] error: expected one of `(`, `[`, or `{`, found `is_blocked` [INFO] [stderr] --> src/main.rs:331:9 [INFO] [stderr] | [INFO] [stderr] 331 | id !is_blocked(x + dx, y + dy, map, objects) { [INFO] [stderr] | ^^^^^^^^^^ expected one of `(`, `[`, or `{` [INFO] [stderr] [INFO] [stderr] error: expected type, found `:` [INFO] [stderr] --> src/main.rs:141:30 [INFO] [stderr] | [INFO] [stderr] 141 | let num_monsters = rand: :thread_rng().gen_range(0, MAX_ROOMS_MONSTERS + 1); [INFO] [stderr] | - ^ expected type [INFO] [stderr] | | [INFO] [stderr] | tried to parse a type due to this type ascription [INFO] [stderr] | [INFO] [stderr] = note: `#![feature(type_ascription)]` lets you annotate an expression with a type: `: ` [INFO] [stderr] = note: see issue #23416 for more information [INFO] [stderr] [INFO] [stderr] error: expected one of `:`, `;`, `=`, `@`, or `|`, found `+` [INFO] [stderr] --> src/main.rs:186:21 [INFO] [stderr] | [INFO] [stderr] 186 | let mut objects + vec![player]; [INFO] [stderr] | ^ expected one of `:`, `;`, `=`, `@`, or `|` [INFO] [stderr] [INFO] [stderr] error: expected one of `(`, `[`, or `{`, found `is_blocked` [INFO] [stderr] --> src/main.rs:331:9 [INFO] [stderr] | [INFO] [stderr] 331 | id !is_blocked(x + dx, y + dy, map, objects) { [INFO] [stderr] | ^^^^^^^^^^ expected one of `(`, `[`, or `{` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `rand` [INFO] [stderr] --> src/main.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use rand::Rng; [INFO] [stderr] | ^^^^ use of undeclared type or module `rand` [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find value `root` in this scope [INFO] [stderr] --> src/main.rs:317:30 [INFO] [stderr] | [INFO] [stderr] 317 | let fullscreen = root.is_fullscreen(); [INFO] [stderr] | ^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find value `root` in this scope [INFO] [stderr] --> src/main.rs:318:13 [INFO] [stderr] | [INFO] [stderr] 318 | root.set_fullscreen(!fullscreen); [INFO] [stderr] | ^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `rand` [INFO] [stderr] --> src/main.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use rand::Rng; [INFO] [stderr] | ^^^^ use of undeclared type or module `rand` [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find value `root` in this scope [INFO] [stderr] --> src/main.rs:317:30 [INFO] [stderr] | [INFO] [stderr] 317 | let fullscreen = root.is_fullscreen(); [INFO] [stderr] | ^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find value `root` in this scope [INFO] [stderr] --> src/main.rs:318:13 [INFO] [stderr] | [INFO] [stderr] 318 | root.set_fullscreen(!fullscreen); [INFO] [stderr] | ^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:294:9 [INFO] [stderr] | [INFO] [stderr] 285 | match key { [INFO] [stderr] | --- this expression has type `tcod::input::Key` [INFO] [stderr] ... [INFO] [stderr] 294 | (Key { code: Up, .. }, _, true) => { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected struct `tcod::input::Key`, found tuple [INFO] [stderr] | [INFO] [stderr] = note: expected struct `tcod::input::Key` [INFO] [stderr] found tuple `(_, _, _)` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:298:9 [INFO] [stderr] | [INFO] [stderr] 285 | match key { [INFO] [stderr] | --- this expression has type `tcod::input::Key` [INFO] [stderr] ... [INFO] [stderr] 298 | (Key { code: Down, .. }, _, true) => { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected struct `tcod::input::Key`, found tuple [INFO] [stderr] | [INFO] [stderr] = note: expected struct `tcod::input::Key` [INFO] [stderr] found tuple `(_, _, _)` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:302:9 [INFO] [stderr] | [INFO] [stderr] 285 | match key { [INFO] [stderr] | --- this expression has type `tcod::input::Key` [INFO] [stderr] ... [INFO] [stderr] 302 | (Key { code: Left, .. }, _, true) => { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected struct `tcod::input::Key`, found tuple [INFO] [stderr] | [INFO] [stderr] = note: expected struct `tcod::input::Key` [INFO] [stderr] found tuple `(_, _, _)` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:306:9 [INFO] [stderr] | [INFO] [stderr] 285 | match key { [INFO] [stderr] | --- this expression has type `tcod::input::Key` [INFO] [stderr] ... [INFO] [stderr] 306 | (Key { code: Right, .. }, _, true) => { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected struct `tcod::input::Key`, found tuple [INFO] [stderr] | [INFO] [stderr] = note: expected struct `tcod::input::Key` [INFO] [stderr] found tuple `(_, _, _)` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:294:9 [INFO] [stderr] | [INFO] [stderr] 285 | match key { [INFO] [stderr] | --- this expression has type `tcod::input::Key` [INFO] [stderr] ... [INFO] [stderr] 294 | (Key { code: Up, .. }, _, true) => { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected struct `tcod::input::Key`, found tuple [INFO] [stderr] | [INFO] [stderr] = note: expected struct `tcod::input::Key` [INFO] [stderr] found tuple `(_, _, _)` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:298:9 [INFO] [stderr] | [INFO] [stderr] 285 | match key { [INFO] [stderr] | --- this expression has type `tcod::input::Key` [INFO] [stderr] ... [INFO] [stderr] 298 | (Key { code: Down, .. }, _, true) => { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected struct `tcod::input::Key`, found tuple [INFO] [stderr] | [INFO] [stderr] = note: expected struct `tcod::input::Key` [INFO] [stderr] found tuple `(_, _, _)` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:302:9 [INFO] [stderr] | [INFO] [stderr] 285 | match key { [INFO] [stderr] | --- this expression has type `tcod::input::Key` [INFO] [stderr] ... [INFO] [stderr] 302 | (Key { code: Left, .. }, _, true) => { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected struct `tcod::input::Key`, found tuple [INFO] [stderr] | [INFO] [stderr] = note: expected struct `tcod::input::Key` [INFO] [stderr] found tuple `(_, _, _)` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:306:9 [INFO] [stderr] | [INFO] [stderr] 285 | match key { [INFO] [stderr] | --- this expression has type `tcod::input::Key` [INFO] [stderr] ... [INFO] [stderr] 306 | (Key { code: Right, .. }, _, true) => { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected struct `tcod::input::Key`, found tuple [INFO] [stderr] | [INFO] [stderr] = note: expected struct `tcod::input::Key` [INFO] [stderr] found tuple `(_, _, _)` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:296:13 [INFO] [stderr] | [INFO] [stderr] 285 | / match key { [INFO] [stderr] 286 | | Key { [INFO] [stderr] 287 | | code: Enter, [INFO] [stderr] 288 | | alt: true, [INFO] [stderr] ... | [INFO] [stderr] 296 | | TookTurn [INFO] [stderr] | | ^^^^^^^^ expected `()`, found enum `PlayerAction` [INFO] [stderr] ... | [INFO] [stderr] 320 | | } [INFO] [stderr] 321 | | } [INFO] [stderr] | | -- help: consider using a semicolon here [INFO] [stderr] | |_____| [INFO] [stderr] | expected this to be `()` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:296:13 [INFO] [stderr] | [INFO] [stderr] 285 | / match key { [INFO] [stderr] 286 | | Key { [INFO] [stderr] 287 | | code: Enter, [INFO] [stderr] 288 | | alt: true, [INFO] [stderr] ... | [INFO] [stderr] 296 | | TookTurn [INFO] [stderr] | | ^^^^^^^^ expected `()`, found enum `PlayerAction` [INFO] [stderr] ... | [INFO] [stderr] 320 | | } [INFO] [stderr] 321 | | } [INFO] [stderr] | | -- help: consider using a semicolon here [INFO] [stderr] | |_____| [INFO] [stderr] | expected this to be `()` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:300:13 [INFO] [stderr] | [INFO] [stderr] 285 | / match key { [INFO] [stderr] 286 | | Key { [INFO] [stderr] 287 | | code: Enter, [INFO] [stderr] 288 | | alt: true, [INFO] [stderr] ... | [INFO] [stderr] 300 | | TookTurn [INFO] [stderr] | | ^^^^^^^^ expected `()`, found enum `PlayerAction` [INFO] [stderr] ... | [INFO] [stderr] 320 | | } [INFO] [stderr] 321 | | } [INFO] [stderr] | | -- help: consider using a semicolon here [INFO] [stderr] | |_____| [INFO] [stderr] | expected this to be `()` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:300:13 [INFO] [stderr] | [INFO] [stderr] 285 | / match key { [INFO] [stderr] 286 | | Key { [INFO] [stderr] 287 | | code: Enter, [INFO] [stderr] 288 | | alt: true, [INFO] [stderr] ... | [INFO] [stderr] 300 | | TookTurn [INFO] [stderr] | | ^^^^^^^^ expected `()`, found enum `PlayerAction` [INFO] [stderr] ... | [INFO] [stderr] 320 | | } [INFO] [stderr] 321 | | } [INFO] [stderr] | | -- help: consider using a semicolon here [INFO] [stderr] | |_____| [INFO] [stderr] | expected this to be `()` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:304:13 [INFO] [stderr] | [INFO] [stderr] 285 | / match key { [INFO] [stderr] 286 | | Key { [INFO] [stderr] 287 | | code: Enter, [INFO] [stderr] 288 | | alt: true, [INFO] [stderr] ... | [INFO] [stderr] 304 | | TookTurn [INFO] [stderr] | | ^^^^^^^^ expected `()`, found enum `PlayerAction` [INFO] [stderr] ... | [INFO] [stderr] 320 | | } [INFO] [stderr] 321 | | } [INFO] [stderr] | | -- help: consider using a semicolon here [INFO] [stderr] | |_____| [INFO] [stderr] | expected this to be `()` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:304:13 [INFO] [stderr] | [INFO] [stderr] 285 | / match key { [INFO] [stderr] 286 | | Key { [INFO] [stderr] 287 | | code: Enter, [INFO] [stderr] 288 | | alt: true, [INFO] [stderr] ... | [INFO] [stderr] 304 | | TookTurn [INFO] [stderr] | | ^^^^^^^^ expected `()`, found enum `PlayerAction` [INFO] [stderr] ... | [INFO] [stderr] 320 | | } [INFO] [stderr] 321 | | } [INFO] [stderr] | | -- help: consider using a semicolon here [INFO] [stderr] | |_____| [INFO] [stderr] | expected this to be `()` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:308:13 [INFO] [stderr] | [INFO] [stderr] 285 | / match key { [INFO] [stderr] 286 | | Key { [INFO] [stderr] 287 | | code: Enter, [INFO] [stderr] 288 | | alt: true, [INFO] [stderr] ... | [INFO] [stderr] 308 | | TookTurn [INFO] [stderr] | | ^^^^^^^^ expected `()`, found enum `PlayerAction` [INFO] [stderr] ... | [INFO] [stderr] 320 | | } [INFO] [stderr] 321 | | } [INFO] [stderr] | | -- help: consider using a semicolon here [INFO] [stderr] | |_____| [INFO] [stderr] | expected this to be `()` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:308:13 [INFO] [stderr] | [INFO] [stderr] 285 | / match key { [INFO] [stderr] 286 | | Key { [INFO] [stderr] 287 | | code: Enter, [INFO] [stderr] 288 | | alt: true, [INFO] [stderr] ... | [INFO] [stderr] 308 | | TookTurn [INFO] [stderr] | | ^^^^^^^^ expected `()`, found enum `PlayerAction` [INFO] [stderr] ... | [INFO] [stderr] 320 | | } [INFO] [stderr] 321 | | } [INFO] [stderr] | | -- help: consider using a semicolon here [INFO] [stderr] | |_____| [INFO] [stderr] | expected this to be `()` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:319:13 [INFO] [stderr] | [INFO] [stderr] 285 | / match key { [INFO] [stderr] 286 | | Key { [INFO] [stderr] 287 | | code: Enter, [INFO] [stderr] 288 | | alt: true, [INFO] [stderr] ... | [INFO] [stderr] 319 | | DidntTakeTurn [INFO] [stderr] | | ^^^^^^^^^^^^^ expected `()`, found enum `PlayerAction` [INFO] [stderr] 320 | | } [INFO] [stderr] 321 | | } [INFO] [stderr] | | -- help: consider using a semicolon here [INFO] [stderr] | |_____| [INFO] [stderr] | expected this to be `()` [INFO] [stderr] [INFO] [stderr] error[E0609]: no field `alive` on type `Object` [INFO] [stderr] --> src/main.rs:323:40 [INFO] [stderr] | [INFO] [stderr] 323 | let player_alive = objects[PLAYER].alive; [INFO] [stderr] | ^^^^^ unknown field [INFO] [stderr] | [INFO] [stderr] = note: available fields are: `x`, `y`, `char`, `color` [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> src/main.rs:326:5 [INFO] [stderr] | [INFO] [stderr] 324 | / match (key, key.text(), player_alive) { [INFO] [stderr] 325 | | } [INFO] [stderr] | |_____- any code following this expression is unreachable [INFO] [stderr] 326 | false [INFO] [stderr] | ^^^^^ unreachable expression [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unreachable_code)]` on by default [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:319:13 [INFO] [stderr] | [INFO] [stderr] 285 | / match key { [INFO] [stderr] 286 | | Key { [INFO] [stderr] 287 | | code: Enter, [INFO] [stderr] 288 | | alt: true, [INFO] [stderr] ... | [INFO] [stderr] 319 | | DidntTakeTurn [INFO] [stderr] | | ^^^^^^^^^^^^^ expected `()`, found enum `PlayerAction` [INFO] [stderr] 320 | | } [INFO] [stderr] 321 | | } [INFO] [stderr] | | -- help: consider using a semicolon here [INFO] [stderr] | |_____| [INFO] [stderr] | expected this to be `()` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:326:5 [INFO] [stderr] | [INFO] [stderr] 280 | fn handle_keys(tcod: &mut Tcod, game: &Game, objects: &mut Vec) -> PlayerAction { [INFO] [stderr] | ------------ expected `PlayerAction` because of return type [INFO] [stderr] ... [INFO] [stderr] 326 | false [INFO] [stderr] | ^^^^^ expected enum `PlayerAction`, found `bool` [INFO] [stderr] [INFO] [stderr] error[E0609]: no field `alive` on type `Object` [INFO] [stderr] --> src/main.rs:323:40 [INFO] [stderr] | [INFO] [stderr] 323 | let player_alive = objects[PLAYER].alive; [INFO] [stderr] | ^^^^^ unknown field [INFO] [stderr] | [INFO] [stderr] = note: available fields are: `x`, `y`, `char`, `color` [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> src/main.rs:326:5 [INFO] [stderr] | [INFO] [stderr] 324 | / match (key, key.text(), player_alive) { [INFO] [stderr] 325 | | } [INFO] [stderr] | |_____- any code following this expression is unreachable [INFO] [stderr] 326 | false [INFO] [stderr] | ^^^^^ unreachable expression [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unreachable_code)]` on by default [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `pos` found for struct `Object` in the current scope [INFO] [stderr] --> src/main.rs:330:30 [INFO] [stderr] | [INFO] [stderr] 115 | struct Object { [INFO] [stderr] | ------------- method `pos` not found for this [INFO] [stderr] ... [INFO] [stderr] 330 | let (x, y) = objects[id].pos(); [INFO] [stderr] | ^^^ method not found in `Object` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `pos` found for reference `&Object` in the current scope [INFO] [stderr] --> src/main.rs:347:61 [INFO] [stderr] | [INFO] [stderr] 347 | let target_id = objects.iter().position(|object| object.pos() == (x, y)); [INFO] [stderr] | ^^^ method not found in `&Object` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:326:5 [INFO] [stderr] | [INFO] [stderr] 280 | fn handle_keys(tcod: &mut Tcod, game: &Game, objects: &mut Vec) -> PlayerAction { [INFO] [stderr] | ------------ expected `PlayerAction` because of return type [INFO] [stderr] ... [INFO] [stderr] 326 | false [INFO] [stderr] | ^^^^^ expected enum `PlayerAction`, found `bool` [INFO] [stderr] [INFO] [stderr] error[E0609]: no field `name` on type `Object` [INFO] [stderr] --> src/main.rs:353:36 [INFO] [stderr] | [INFO] [stderr] 353 | objects[target_id].name [INFO] [stderr] | ^^^^ unknown field [INFO] [stderr] | [INFO] [stderr] = note: available fields are: `x`, `y`, `char`, `color` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `pos` found for struct `Object` in the current scope [INFO] [stderr] --> src/main.rs:330:30 [INFO] [stderr] | [INFO] [stderr] 115 | struct Object { [INFO] [stderr] | ------------- method `pos` not found for this [INFO] [stderr] ... [INFO] [stderr] 330 | let (x, y) = objects[id].pos(); [INFO] [stderr] | ^^^ method not found in `Object` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `pos` found for reference `&Object` in the current scope [INFO] [stderr] --> src/main.rs:347:61 [INFO] [stderr] | [INFO] [stderr] 347 | let target_id = objects.iter().position(|object| object.pos() == (x, y)); [INFO] [stderr] | ^^^ method not found in `&Object` [INFO] [stderr] [INFO] [stderr] error[E0609]: no field `name` on type `Object` [INFO] [stderr] --> src/main.rs:353:36 [INFO] [stderr] | [INFO] [stderr] 353 | objects[target_id].name [INFO] [stderr] | ^^^^ unknown field [INFO] [stderr] | [INFO] [stderr] = note: available fields are: `x`, `y`, `char`, `color` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:411:50 [INFO] [stderr] | [INFO] [stderr] 411 | let exit = handle_keys(&mut tcod, &game, player); [INFO] [stderr] | ^^^^^^ expected struct `std::vec::Vec`, found struct `Object` [INFO] [stderr] | [INFO] [stderr] = note: expected mutable reference `&mut std::vec::Vec` [INFO] [stderr] found mutable reference `&mut Object` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:411:50 [INFO] [stderr] | [INFO] [stderr] 411 | let exit = handle_keys(&mut tcod, &game, player); [INFO] [stderr] | ^^^^^^ expected struct `std::vec::Vec`, found struct `Object` [INFO] [stderr] | [INFO] [stderr] = note: expected mutable reference `&mut std::vec::Vec` [INFO] [stderr] found mutable reference `&mut Object` [INFO] [stderr] [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:412:12 [INFO] [stderr] | [INFO] [stderr] 412 | if exit { [INFO] [stderr] | ^^^^ expected `bool`, found enum `PlayerAction` [INFO] [stderr] [INFO] [stderr] error: aborting due to 22 previous errors; 1 warning emitted [INFO] [stderr] [INFO] [stderr] Some errors have detailed explanations: E0308, E0425, E0432, E0599, E0609. [INFO] [stderr] For more information about an error, try `rustc --explain E0308`. [INFO] [stderr] error: could not compile `roguelike`. [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] error[E0308]: mismatched types [INFO] [stderr] --> src/main.rs:412:12 [INFO] [stderr] | [INFO] [stderr] 412 | if exit { [INFO] [stderr] | ^^^^ expected `bool`, found enum `PlayerAction` [INFO] [stderr] [INFO] [stderr] error: aborting due to 22 previous errors; 1 warning emitted [INFO] [stderr] [INFO] [stderr] Some errors have detailed explanations: E0308, E0425, E0432, E0599, E0609. [INFO] [stderr] For more information about an error, try `rustc --explain E0308`. [INFO] [stderr] error: could not compile `roguelike`. [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] running `"docker" "inspect" "b2a678d91ee693a47820bf86f7a6edacb50da917b3b1a3df3bd889de40eb899a"` [INFO] running `"docker" "rm" "-f" "b2a678d91ee693a47820bf86f7a6edacb50da917b3b1a3df3bd889de40eb899a"` [INFO] [stdout] b2a678d91ee693a47820bf86f7a6edacb50da917b3b1a3df3bd889de40eb899a