[INFO] cloning repository https://github.com/itsrainingmani/monkeylang
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/itsrainingmani/monkeylang" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fitsrainingmani%2Fmonkeylang", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fitsrainingmani%2Fmonkeylang'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 4ab39e047dfbc9b06bf585ce42dba89d94d1405f
[INFO] checking itsrainingmani/monkeylang against try#0611f7de057c584b8771102fde7aed6c70c71d3b for pr-146440
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fitsrainingmani%2Fmonkeylang" "/workspace/builds/worker-2-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/itsrainingmani/monkeylang
[INFO] finished tweaking git repo https://github.com/itsrainingmani/monkeylang
[INFO] tweaked toml for git repo https://github.com/itsrainingmani/monkeylang written to /workspace/builds/worker-2-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/itsrainingmani/monkeylang on toolchain 0611f7de057c584b8771102fde7aed6c70c71d3b
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0611f7de057c584b8771102fde7aed6c70c71d3b" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/itsrainingmani/monkeylang 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" "+0611f7de057c584b8771102fde7aed6c70c71d3b" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+0611f7de057c584b8771102fde7aed6c70c71d3b" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] ae6a463c13a0a836d8bb228859fc7be14dbfa95abd188c84345516b1fb539e2e
[INFO] running `Command { std: "docker" "start" "-a" "ae6a463c13a0a836d8bb228859fc7be14dbfa95abd188c84345516b1fb539e2e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "ae6a463c13a0a836d8bb228859fc7be14dbfa95abd188c84345516b1fb539e2e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ae6a463c13a0a836d8bb228859fc7be14dbfa95abd188c84345516b1fb539e2e", kill_on_drop: false }`
[INFO] [stdout] ae6a463c13a0a836d8bb228859fc7be14dbfa95abd188c84345516b1fb539e2e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+0611f7de057c584b8771102fde7aed6c70c71d3b" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 4dd9e7b6e14718485691ec06d208be79395a182c7a861710e2d2e2168686d1db
[INFO] running `Command { std: "docker" "start" "-a" "4dd9e7b6e14718485691ec06d208be79395a182c7a861710e2d2e2168686d1db", kill_on_drop: false }`
[INFO] [stderr]     Checking monkey v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `ast::*`
[INFO] [stdout]    --> src/lib.rs:346:17
[INFO] [stdout]     |
[INFO] [stdout] 346 |     use super::{ast::*, lexer::*, token::*};
[INFO] [stdout]     |                 ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]    --> src/lib.rs:287:13
[INFO] [stdout]     |
[INFO] [stdout] 265 | /             loop {
[INFO] [stdout] 266 | |                 let mut input = String::new();
[INFO] [stdout] 267 | |                 let mut lexer = Lexer::new(String::from("something"));
[INFO] [stdout] 268 | |                 print!("{} ", self.prompt);
[INFO] [stdout] ...   |
[INFO] [stdout] 286 | |             }
[INFO] [stdout]     | |_____________- any code following this expression is unreachable
[INFO] [stdout] 287 |               Ok(())
[INFO] [stdout]     |               ^^^^^^ unreachable expression
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: struct `LetStmt` is never constructed
[INFO] [stdout]    --> src/lib.rs:302:16
[INFO] [stdout]     |
[INFO] [stdout] 302 |     pub struct LetStmt<'a> {
[INFO] [stdout]     |                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `pub` struct has private fields, no public constructor, and is not otherwise reachable through the external API, so consider providing a public constructor or removing it
[INFO] [stdout]     = note: `#[deny(unused_unconstructable_pub_struct)]` (part of `#[deny(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: struct `Identifier` is never constructed
[INFO] [stdout]    --> src/lib.rs:316:16
[INFO] [stdout]     |
[INFO] [stdout] 316 |     pub struct Identifier {
[INFO] [stdout]     |                ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `pub` struct has private fields, no public constructor, and is not otherwise reachable through the external API, so consider providing a public constructor or removing it
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: struct `Program` is never constructed
[INFO] [stdout]    --> src/lib.rs:330:16
[INFO] [stdout]     |
[INFO] [stdout] 330 |     pub struct Program {
[INFO] [stdout]     |                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `pub` struct has private fields, no public constructor, and is not otherwise reachable through the external API, so consider providing a public constructor or removing it
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `name` and `value` are never read
[INFO] [stdout]    --> src/lib.rs:304:9
[INFO] [stdout]     |
[INFO] [stdout] 302 |     pub struct LetStmt<'a> {
[INFO] [stdout]     |                ------- fields in this struct
[INFO] [stdout] 303 |         token: Token,          // the Token::LET token
[INFO] [stdout] 304 |         name: &'a Identifier,  // holds the identifier of the binding
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 305 |         value: dyn Expression, // the expression that produces a value
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/lib.rs:318:9
[INFO] [stdout]     |
[INFO] [stdout] 316 |     pub struct Identifier {
[INFO] [stdout]     |                ---------- field in this struct
[INFO] [stdout] 317 |         token: Token,
[INFO] [stdout] 318 |         value: String,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: struct `Parser` is never constructed
[INFO] [stdout]    --> src/lib.rs:348:16
[INFO] [stdout]     |
[INFO] [stdout] 348 |     pub struct Parser<'a> {
[INFO] [stdout]     |                ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `pub` struct has private fields, no public constructor, and is not otherwise reachable through the external API, so consider providing a public constructor or removing it
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `lexer`, `cur_token`, and `peek_token` are never read
[INFO] [stdout]    --> src/lib.rs:349:9
[INFO] [stdout]     |
[INFO] [stdout] 348 |     pub struct Parser<'a> {
[INFO] [stdout]     |                ------ fields in this struct
[INFO] [stdout] 349 |         lexer: &'a mut Lexer,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 350 |
[INFO] [stdout] 351 |         cur_token: Token,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 352 |         peek_token: Token,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `next_token`, and `parse_program` are never used
[INFO] [stdout]    --> src/lib.rs:356:12
[INFO] [stdout]     |
[INFO] [stdout] 355 |     impl<'a> Parser<'a> {
[INFO] [stdout]     |     ------------------- associated items in this implementation
[INFO] [stdout] 356 |         fn new(lexer: &mut Lexer) -> Parser {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 366 |         fn next_token(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 371 |         fn parse_program() {}
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:356:23
[INFO] [stdout]     |
[INFO] [stdout] 356 |         fn new(lexer: &mut Lexer) -> Parser {
[INFO] [stdout]     |                       ^^^^^^^^^^     ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 356 |         fn new(lexer: &mut Lexer) -> Parser<'_> {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ast::*`
[INFO] [stdout]    --> src/lib.rs:346:17
[INFO] [stdout]     |
[INFO] [stdout] 346 |     use super::{ast::*, lexer::*, token::*};
[INFO] [stdout]     |                 ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `monkey` (lib) due to 4 previous errors; 7 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]    --> src/lib.rs:287:13
[INFO] [stdout]     |
[INFO] [stdout] 265 | /             loop {
[INFO] [stdout] 266 | |                 let mut input = String::new();
[INFO] [stdout] 267 | |                 let mut lexer = Lexer::new(String::from("something"));
[INFO] [stdout] 268 | |                 print!("{} ", self.prompt);
[INFO] [stdout] ...   |
[INFO] [stdout] 286 | |             }
[INFO] [stdout]     | |_____________- any code following this expression is unreachable
[INFO] [stdout] 287 |               Ok(())
[INFO] [stdout]     |               ^^^^^^ unreachable expression
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: struct `LetStmt` is never constructed
[INFO] [stdout]    --> src/lib.rs:302:16
[INFO] [stdout]     |
[INFO] [stdout] 302 |     pub struct LetStmt<'a> {
[INFO] [stdout]     |                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `pub` struct has private fields, no public constructor, and is not otherwise reachable through the external API, so consider providing a public constructor or removing it
[INFO] [stdout]     = note: `#[deny(unused_unconstructable_pub_struct)]` (part of `#[deny(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: struct `Identifier` is never constructed
[INFO] [stdout]    --> src/lib.rs:316:16
[INFO] [stdout]     |
[INFO] [stdout] 316 |     pub struct Identifier {
[INFO] [stdout]     |                ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `pub` struct has private fields, no public constructor, and is not otherwise reachable through the external API, so consider providing a public constructor or removing it
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: struct `Program` is never constructed
[INFO] [stdout]    --> src/lib.rs:330:16
[INFO] [stdout]     |
[INFO] [stdout] 330 |     pub struct Program {
[INFO] [stdout]     |                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `pub` struct has private fields, no public constructor, and is not otherwise reachable through the external API, so consider providing a public constructor or removing it
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `name` and `value` are never read
[INFO] [stdout]    --> src/lib.rs:304:9
[INFO] [stdout]     |
[INFO] [stdout] 302 |     pub struct LetStmt<'a> {
[INFO] [stdout]     |                ------- fields in this struct
[INFO] [stdout] 303 |         token: Token,          // the Token::LET token
[INFO] [stdout] 304 |         name: &'a Identifier,  // holds the identifier of the binding
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 305 |         value: dyn Expression, // the expression that produces a value
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/lib.rs:318:9
[INFO] [stdout]     |
[INFO] [stdout] 316 |     pub struct Identifier {
[INFO] [stdout]     |                ---------- field in this struct
[INFO] [stdout] 317 |         token: Token,
[INFO] [stdout] 318 |         value: String,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: struct `Parser` is never constructed
[INFO] [stdout]    --> src/lib.rs:348:16
[INFO] [stdout]     |
[INFO] [stdout] 348 |     pub struct Parser<'a> {
[INFO] [stdout]     |                ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `pub` struct has private fields, no public constructor, and is not otherwise reachable through the external API, so consider providing a public constructor or removing it
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `lexer`, `cur_token`, and `peek_token` are never read
[INFO] [stdout]    --> src/lib.rs:349:9
[INFO] [stdout]     |
[INFO] [stdout] 348 |     pub struct Parser<'a> {
[INFO] [stdout]     |                ------ fields in this struct
[INFO] [stdout] 349 |         lexer: &'a mut Lexer,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 350 |
[INFO] [stdout] 351 |         cur_token: Token,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 352 |         peek_token: Token,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `next_token`, and `parse_program` are never used
[INFO] [stdout]    --> src/lib.rs:356:12
[INFO] [stdout]     |
[INFO] [stdout] 355 |     impl<'a> Parser<'a> {
[INFO] [stdout]     |     ------------------- associated items in this implementation
[INFO] [stdout] 356 |         fn new(lexer: &mut Lexer) -> Parser {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 366 |         fn next_token(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 371 |         fn parse_program() {}
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:356:23
[INFO] [stdout]     |
[INFO] [stdout] 356 |         fn new(lexer: &mut Lexer) -> Parser {
[INFO] [stdout]     |                       ^^^^^^^^^^     ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 356 |         fn new(lexer: &mut Lexer) -> Parser<'_> {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `monkey` (lib test) due to 4 previous errors; 7 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "4dd9e7b6e14718485691ec06d208be79395a182c7a861710e2d2e2168686d1db", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4dd9e7b6e14718485691ec06d208be79395a182c7a861710e2d2e2168686d1db", kill_on_drop: false }`
[INFO] [stdout] 4dd9e7b6e14718485691ec06d208be79395a182c7a861710e2d2e2168686d1db
