[INFO] updating cached repository https://github.com/UnicodeSnowman/writing_an_interpreter_in_rust [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] 0952a8d5bbdba06124f3cc94e5528daa4a81c828 [INFO] checking UnicodeSnowman/writing_an_interpreter_in_rust against master#45d050cde277b22a755847338f2acc2c7b834141 for pr-71393 [INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FUnicodeSnowman%2Fwriting_an_interpreter_in_rust" "/workspace/builds/worker-3/source"` [INFO] [stderr] Cloning into '/workspace/builds/worker-3/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/UnicodeSnowman/writing_an_interpreter_in_rust on toolchain 45d050cde277b22a755847338f2acc2c7b834141 [INFO] running `"/workspace/cargo-home/bin/cargo" "+45d050cde277b22a755847338f2acc2c7b834141" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started tweaking git repo https://github.com/UnicodeSnowman/writing_an_interpreter_in_rust [INFO] finished tweaking git repo https://github.com/UnicodeSnowman/writing_an_interpreter_in_rust [INFO] tweaked toml for git repo https://github.com/UnicodeSnowman/writing_an_interpreter_in_rust written to /workspace/builds/worker-3/source/Cargo.toml [INFO] crate git repo https://github.com/UnicodeSnowman/writing_an_interpreter_in_rust already has a lockfile, it will not be regenerated [INFO] running `"/workspace/cargo-home/bin/cargo" "+45d050cde277b22a755847338f2acc2c7b834141" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/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" "+45d050cde277b22a755847338f2acc2c7b834141" "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] e0a12766504de03c36f332cce7487c0b12273315bdaeead2e071559ad5ceb281 [INFO] running `"docker" "start" "-a" "e0a12766504de03c36f332cce7487c0b12273315bdaeead2e071559ad5ceb281"` [INFO] [stderr] Checking writing_an_interpreter_in_rust v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/ast.rs:16:29 [INFO] [stderr] | [INFO] [stderr] 16 | pub statements: Vec> [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn Statement` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/ast.rs:32:16 [INFO] [stderr] | [INFO] [stderr] 32 | value: Box [INFO] [stderr] | ^^^^^^^^^^ help: use `dyn`: `dyn Expression` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/ast.rs:16:29 [INFO] [stderr] | [INFO] [stderr] 16 | pub statements: Vec> [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn Statement` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/ast.rs:32:16 [INFO] [stderr] | [INFO] [stderr] 32 | value: Box [INFO] [stderr] | ^^^^^^^^^^ help: use `dyn`: `dyn Expression` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `blah` [INFO] [stderr] --> src/parser.rs:26:13 [INFO] [stderr] | [INFO] [stderr] 26 | let blah = lexer.current_token(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_blah` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: private trait `ast::Statement` in public interface (error E0445) [INFO] [stderr] --> src/ast.rs:16:5 [INFO] [stderr] | [INFO] [stderr] 16 | pub statements: Vec> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(private_in_public)]` on by default [INFO] [stderr] = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release! [INFO] [stderr] = note: for more information, see issue #34537 [INFO] [stderr] [INFO] [stderr] warning: method is never used: `token_literal` [INFO] [stderr] --> src/ast.rs:20:5 [INFO] [stderr] | [INFO] [stderr] 20 | fn token_literal(&self) -> &str { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `name` [INFO] [stderr] --> src/ast.rs:31:5 [INFO] [stderr] | [INFO] [stderr] 31 | name: Identifier<'a>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `value` [INFO] [stderr] --> src/ast.rs:32:5 [INFO] [stderr] | [INFO] [stderr] 32 | value: Box [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `value` [INFO] [stderr] --> src/ast.rs:47:5 [INFO] [stderr] | [INFO] [stderr] 47 | value: &'a str [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `lexer` [INFO] [stderr] --> src/parser.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | lexer: &'p mut Lexer, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `errors` [INFO] [stderr] --> src/parser.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | errors: Vec<&'p str>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `current_token` [INFO] [stderr] --> src/parser.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | current_token: Token<'p>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `peek_token` [INFO] [stderr] --> src/parser.rs:9:5 [INFO] [stderr] | [INFO] [stderr] 9 | peek_token: Token<'p> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `next_token` [INFO] [stderr] --> src/parser.rs:46:5 [INFO] [stderr] | [INFO] [stderr] 46 | fn next_token(&'p mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: the feature `slice_patterns` has been stable since 1.42.0 and no longer requires an attribute to enable [INFO] [stderr] --> src/main.rs:1:12 [INFO] [stderr] | [INFO] [stderr] 1 | #![feature(slice_patterns)] [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(stable_features)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `blah` [INFO] [stderr] --> src/parser.rs:26:13 [INFO] [stderr] | [INFO] [stderr] 26 | let blah = lexer.current_token(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_blah` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 14 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: private trait `ast::Statement` in public interface (error E0445) [INFO] [stderr] --> src/ast.rs:16:5 [INFO] [stderr] | [INFO] [stderr] 16 | pub statements: Vec> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(private_in_public)]` on by default [INFO] [stderr] = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release! [INFO] [stderr] = note: for more information, see issue #34537 [INFO] [stderr] [INFO] [stderr] warning: method is never used: `token_literal` [INFO] [stderr] --> src/ast.rs:20:5 [INFO] [stderr] | [INFO] [stderr] 20 | fn token_literal(&self) -> &str { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `name` [INFO] [stderr] --> src/ast.rs:31:5 [INFO] [stderr] | [INFO] [stderr] 31 | name: Identifier<'a>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `value` [INFO] [stderr] --> src/ast.rs:32:5 [INFO] [stderr] | [INFO] [stderr] 32 | value: Box [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `value` [INFO] [stderr] --> src/ast.rs:47:5 [INFO] [stderr] | [INFO] [stderr] 47 | value: &'a str [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `lexer` [INFO] [stderr] --> src/parser.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | lexer: &'p mut Lexer, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `errors` [INFO] [stderr] --> src/parser.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | errors: Vec<&'p str>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `current_token` [INFO] [stderr] --> src/parser.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | current_token: Token<'p>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `peek_token` [INFO] [stderr] --> src/parser.rs:9:5 [INFO] [stderr] | [INFO] [stderr] 9 | peek_token: Token<'p> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `next_token` [INFO] [stderr] --> src/parser.rs:46:5 [INFO] [stderr] | [INFO] [stderr] 46 | fn next_token(&'p mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: the feature `slice_patterns` has been stable since 1.42.0 and no longer requires an attribute to enable [INFO] [stderr] --> src/main.rs:1:12 [INFO] [stderr] | [INFO] [stderr] 1 | #![feature(slice_patterns)] [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(stable_features)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 14 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 0.99s [INFO] running `"docker" "inspect" "e0a12766504de03c36f332cce7487c0b12273315bdaeead2e071559ad5ceb281"` [INFO] running `"docker" "rm" "-f" "e0a12766504de03c36f332cce7487c0b12273315bdaeead2e071559ad5ceb281"` [INFO] [stdout] e0a12766504de03c36f332cce7487c0b12273315bdaeead2e071559ad5ceb281