[INFO] updating cached repository https://github.com/ruggeri/rust_learning
[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] 6564c9e695a39cf690d74e0eb370d542f146007c
[INFO] checking ruggeri/rust_learning against master#209b2be09fcaff937480d1fbbe8b31646e361c7a for pr-70917
[INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fruggeri%2Frust_learning" "/workspace/builds/worker-4/source"`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/ruggeri/rust_learning on toolchain 209b2be09fcaff937480d1fbbe8b31646e361c7a
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "read-manifest" "--manifest-path" "Cargo.toml"`
[INFO] started tweaking git repo https://github.com/ruggeri/rust_learning
[INFO] finished tweaking git repo https://github.com/ruggeri/rust_learning
[INFO] tweaked toml for git repo https://github.com/ruggeri/rust_learning written to /workspace/builds/worker-4/source/Cargo.toml
[INFO] crate git repo https://github.com/ruggeri/rust_learning already has a lockfile, it will not be regenerated
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4/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" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "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] 407c534476189a193f15129ee92399ee5cde2d712d58284453a744f13bc2020f
[INFO] running `"docker" "start" "-a" "407c534476189a193f15129ee92399ee5cde2d712d58284453a744f13bc2020f"`
[INFO] [stderr]     Checking rust_learning v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] error[E0499]: cannot borrow `*self` as mutable more than once at a time
[INFO] [stderr]   --> src/bst/bst.rs:79:61
[INFO] [stderr]    |
[INFO] [stderr] 75 |       fn find_mut(&mut self, t: &T) -> &mut BST<T> {
[INFO] [stderr]    |                   - let's call the lifetime of this reference `'1`
[INFO] [stderr] 76 | /         match self {
[INFO] [stderr] 77 | |             Nil => self,
[INFO] [stderr] 78 | |             Node(NodeData { value, left, .. }) if *t < *value => left.find_mut(t),
[INFO] [stderr]    | |                                    ---- first mutable borrow occurs here
[INFO] [stderr] 79 | |             Node(NodeData { value, .. }) if *t == *value => self,
[INFO] [stderr]    | |                                                             ^^^^ second mutable borrow occurs here
[INFO] [stderr] 80 | |             Node(NodeData { value, right, .. }) if *value < *t => right.find_mut(t),
[INFO] [stderr] 81 | |             Node(_) => unreachable!(),
[INFO] [stderr] 82 | |         }
[INFO] [stderr]    | |_________- returning this value requires that `self.0.left` is borrowed for `'1`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/bst/bst.rs:146:21
[INFO] [stderr]     |
[INFO] [stderr] 146 |                 let mut prev_node = left.find_max_mut();
[INFO] [stderr]     |                     ----^^^^^^^^^
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] error: aborting due to previous error
[INFO] [stderr] 
[INFO] [stderr] For more information about this error, try `rustc --explain E0499`.
[INFO] [stderr] error: could not compile `rust_learning`.
[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[E0499]: cannot borrow `*self` as mutable more than once at a time
[INFO] [stderr]   --> src/bst/bst.rs:79:61
[INFO] [stderr]    |
[INFO] [stderr] 75 |       fn find_mut(&mut self, t: &T) -> &mut BST<T> {
[INFO] [stderr]    |                   - let's call the lifetime of this reference `'1`
[INFO] [stderr] 76 | /         match self {
[INFO] [stderr] 77 | |             Nil => self,
[INFO] [stderr] 78 | |             Node(NodeData { value, left, .. }) if *t < *value => left.find_mut(t),
[INFO] [stderr]    | |                                    ---- first mutable borrow occurs here
[INFO] [stderr] 79 | |             Node(NodeData { value, .. }) if *t == *value => self,
[INFO] [stderr]    | |                                                             ^^^^ second mutable borrow occurs here
[INFO] [stderr] 80 | |             Node(NodeData { value, right, .. }) if *value < *t => right.find_mut(t),
[INFO] [stderr] 81 | |             Node(_) => unreachable!(),
[INFO] [stderr] 82 | |         }
[INFO] [stderr]    | |_________- returning this value requires that `self.0.left` is borrowed for `'1`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/bst/bst.rs:146:21
[INFO] [stderr]     |
[INFO] [stderr] 146 |                 let mut prev_node = left.find_max_mut();
[INFO] [stderr]     |                     ----^^^^^^^^^
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] error: aborting due to previous error
[INFO] [stderr] 
[INFO] [stderr] For more information about this error, try `rustc --explain E0499`.
[INFO] [stderr] error: could not compile `rust_learning`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] running `"docker" "inspect" "407c534476189a193f15129ee92399ee5cde2d712d58284453a744f13bc2020f"`
[INFO] running `"docker" "rm" "-f" "407c534476189a193f15129ee92399ee5cde2d712d58284453a744f13bc2020f"`
[INFO] [stdout] 407c534476189a193f15129ee92399ee5cde2d712d58284453a744f13bc2020f
