[INFO] cloning repository https://github.com/jonnydee/markemptydirs
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/jonnydee/markemptydirs" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjonnydee%2Fmarkemptydirs", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjonnydee%2Fmarkemptydirs'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 5d6a562457d4da82c3f236451410641ae23a9099
[INFO] testing jonnydee/markemptydirs against beta-2026-04-21 for beta-1.96-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjonnydee%2Fmarkemptydirs" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/jonnydee/markemptydirs
[INFO] finished tweaking git repo https://github.com/jonnydee/markemptydirs
[INFO] tweaked toml for git repo https://github.com/jonnydee/markemptydirs written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/jonnydee/markemptydirs on toolchain beta-2026-04-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/jonnydee/markemptydirs 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" "+beta-2026-04-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: `package.edition` is unspecified, defaulting to `2015` while the latest is `2024`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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" "+beta-2026-04-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 11eef2a80ade818d658eb9da9db91bb9060dd2849ce57fc07782270aef715221
[INFO] running `Command { std: "docker" "start" "-a" "11eef2a80ade818d658eb9da9db91bb9060dd2849ce57fc07782270aef715221", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "11eef2a80ade818d658eb9da9db91bb9060dd2849ce57fc07782270aef715221", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "11eef2a80ade818d658eb9da9db91bb9060dd2849ce57fc07782270aef715221", kill_on_drop: false }`
[INFO] [stdout] 11eef2a80ade818d658eb9da9db91bb9060dd2849ce57fc07782270aef715221
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-04-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cb3cc84b0bc5fc89242e8a68b12a3e0dfb303aad881ea158ce2e2355bfc88e2e
[INFO] running `Command { std: "docker" "start" "-a" "cb3cc84b0bc5fc89242e8a68b12a3e0dfb303aad881ea158ce2e2355bfc88e2e", kill_on_drop: false }`
[INFO] [stderr] warning: `package.edition` is unspecified, defaulting to `2015` while the latest is `2024`
[INFO] [stderr]    Compiling libc v0.2.47
[INFO] [stderr]    Compiling cfg-if v0.1.6
[INFO] [stderr]    Compiling arrayvec v0.4.10
[INFO] [stderr]    Compiling nodrop v0.1.13
[INFO] [stderr]    Compiling memoffset v0.2.1
[INFO] [stderr]    Compiling cc v1.0.28
[INFO] [stderr]    Compiling lazy_static v1.2.0
[INFO] [stderr]    Compiling scopeguard v0.3.3
[INFO] [stderr]    Compiling rayon-core v1.4.1
[INFO] [stderr]    Compiling num-traits v0.2.6
[INFO] [stderr]    Compiling autocfg v0.1.2
[INFO] [stderr]    Compiling num-integer v0.1.39
[INFO] [stderr]    Compiling rayon v1.0.3
[INFO] [stderr]    Compiling either v1.5.0
[INFO] [stderr]    Compiling unicode-width v0.1.5
[INFO] [stderr]    Compiling rustc-demangle v0.1.13
[INFO] [stderr]    Compiling crossbeam-utils v0.2.2
[INFO] [stderr]    Compiling log v0.4.6
[INFO] [stderr]    Compiling quick-error v1.2.2
[INFO] [stderr]    Compiling strsim v0.7.0
[INFO] [stderr]    Compiling bitflags v1.0.4
[INFO] [stderr]    Compiling textwrap v0.10.0
[INFO] [stderr]    Compiling yaml-rust v0.3.5
[INFO] [stderr]    Compiling pathdiff v0.1.0
[INFO] [stderr]    Compiling backtrace v0.3.13
[INFO] [stderr]    Compiling crossbeam-epoch v0.3.1
[INFO] [stderr]    Compiling crossbeam-deque v0.2.0
[INFO] [stderr]    Compiling num_cpus v1.9.0
[INFO] [stderr]    Compiling time v0.1.42
[INFO] [stderr]    Compiling atty v0.2.11
[INFO] [stderr]    Compiling backtrace-sys v0.1.28
[INFO] [stderr]    Compiling clap v2.32.0
[INFO] [stderr]    Compiling chrono v0.4.6
[INFO] [stderr]    Compiling log-panics v2.0.0
[INFO] [stderr]    Compiling std-logger v0.3.2
[INFO] [stderr]    Compiling api v0.1.0 (/opt/rustwide/workdir/libs/api)
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:21:1
[INFO] [stdout]    |
[INFO] [stdout] 21 | / quick_error! {
[INFO] [stdout] 22 | |     #[derive(Debug)]
[INFO] [stdout] 23 | |     pub enum Error {
[INFO] [stdout] 24 | |         Io(err: std::io::Error) {
[INFO] [stdout] ...  |
[INFO] [stdout] 39 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout]    = note: this warning originates in the macro `quick_error` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:21:1
[INFO] [stdout]    |
[INFO] [stdout] 21 | / quick_error! {
[INFO] [stdout] 22 | |     #[derive(Debug)]
[INFO] [stdout] 23 | |     pub enum Error {
[INFO] [stdout] 24 | |         Io(err: std::io::Error) {
[INFO] [stdout] ...  |
[INFO] [stdout] 39 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `quick_error` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:21:1
[INFO] [stdout]    |
[INFO] [stdout] 21 | / quick_error! {
[INFO] [stdout] 22 | |     #[derive(Debug)]
[INFO] [stdout] 23 | |     pub enum Error {
[INFO] [stdout] 24 | |         Io(err: std::io::Error) {
[INFO] [stdout] ...  |
[INFO] [stdout] 39 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `quick_error` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:21:1
[INFO] [stdout]    |
[INFO] [stdout] 21 | / quick_error! {
[INFO] [stdout] 22 | |     #[derive(Debug)]
[INFO] [stdout] 23 | |     pub enum Error {
[INFO] [stdout] 24 | |         Io(err: std::io::Error) {
[INFO] [stdout] ...  |
[INFO] [stdout] 39 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `quick_error` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/application/session.rs:10:22
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub command: Box<Command>,
[INFO] [stdout]    |                      ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub command: Box<dyn Command>,
[INFO] [stdout]    |                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/application/session.rs:11:22
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub context: Box<Context>,
[INFO] [stdout]    |                      ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub context: Box<dyn Context>,
[INFO] [stdout]    |                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/context.rs:64:19
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fsaccess: Box<FileSystemAccess>,
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fsaccess: Box<dyn FileSystemAccess>,
[INFO] [stdout]    |                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/context.rs:65:19
[INFO] [stdout]    |
[INFO] [stdout] 65 |     notifier: Box<Notifier>,
[INFO] [stdout]    |                   ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 65 |     notifier: Box<dyn Notifier>,
[INFO] [stdout]    |                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/mod.rs:28:16
[INFO] [stdout]    |
[INFO] [stdout] 28 |     DryRun(Box<Command>),
[INFO] [stdout]    |                ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 28 |     DryRun(Box<dyn Command>),
[INFO] [stdout]    |                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/mod.rs:29:13
[INFO] [stdout]    |
[INFO] [stdout] 29 |     Run(Box<Command>),
[INFO] [stdout]    |             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 |     Run(Box<dyn Command>),
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/lib.rs:34:24
[INFO] [stdout]    |
[INFO] [stdout] 34 |         Other(err: Box<std::error::Error>) {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 34 |         Other(err: Box<dyn std::error::Error>) {
[INFO] [stdout]    |                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/mod.rs:23:29
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn execute(&self, ctx: &context::Context) -> Result<()>;
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn execute(&self, ctx: &dyn context::Context) -> Result<()>;
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/context.rs:41:32
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn get_notifier(&self) -> &Notifier;
[INFO] [stdout]    |                                ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn get_notifier(&self) -> &dyn Notifier;
[INFO] [stdout]    |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/clean.rs:23:29
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn execute(&self, ctx: &Context) -> Result<()> {
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn execute(&self, ctx: &dyn Context) -> Result<()> {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> libs/api/src/commands/context.rs:156:32
[INFO] [stdout]     |
[INFO] [stdout] 156 |     fn get_notifier(&self) -> &Notifier {
[INFO] [stdout]     |                                ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 156 |     fn get_notifier(&self) -> &dyn Notifier {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/list.rs:38:29
[INFO] [stdout]    |
[INFO] [stdout] 38 |     fn execute(&self, ctx: &Context) -> Result<()> {
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 38 |     fn execute(&self, ctx: &dyn Context) -> Result<()> {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/purge.rs:19:30
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn execute(&self, _ctx: &Context) -> Result<()> {
[INFO] [stdout]    |                              ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn execute(&self, _ctx: &dyn Context) -> Result<()> {
[INFO] [stdout]    |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/update.rs:29:29
[INFO] [stdout]    |
[INFO] [stdout] 29 |     fn execute(&self, ctx: &Context) -> Result<()> {
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 |     fn execute(&self, ctx: &dyn Context) -> Result<()> {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/fs/access.rs:14:56
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub fn create_file_system_access(dry_run: bool) -> Box<FileSystemAccess> {
[INFO] [stdout]    |                                                        ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub fn create_file_system_access(dry_run: bool) -> Box<dyn FileSystemAccess> {
[INFO] [stdout]    |                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/application/session.rs:19:71
[INFO] [stdout]    |
[INFO] [stdout] 19 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<Notifier>,
[INFO] [stdout]    |                                                                       ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 19 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<dyn Notifier>,
[INFO] [stdout]    |                                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/application/session.rs:34:71
[INFO] [stdout]    |
[INFO] [stdout] 34 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<Notifier>,
[INFO] [stdout]    |                                                                       ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 34 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<dyn Notifier>,
[INFO] [stdout]    |                                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/application/session.rs:35:52
[INFO] [stdout]    |
[INFO] [stdout] 35 |         fsaccess_factory: impl FnOnce(bool) -> Box<FileSystemAccess>,
[INFO] [stdout]    |                                                    ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 35 |         fsaccess_factory: impl FnOnce(bool) -> Box<dyn FileSystemAccess>,
[INFO] [stdout]    |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/context.rs:73:71
[INFO] [stdout]    |
[INFO] [stdout] 73 |         notifier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<Notifier>,
[INFO] [stdout]    |                                                                       ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 73 |         notifier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<dyn Notifier>,
[INFO] [stdout]    |                                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/context.rs:74:52
[INFO] [stdout]    |
[INFO] [stdout] 74 |         fsaccess_factory: impl FnOnce(bool) -> Box<FileSystemAccess>,
[INFO] [stdout]    |                                                    ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 74 |         fsaccess_factory: impl FnOnce(bool) -> Box<dyn FileSystemAccess>,
[INFO] [stdout]    |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/notification/logger.rs:12:78
[INFO] [stdout]    |
[INFO] [stdout] 12 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<Notifier> {
[INFO] [stdout]    |                                                                              ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 12 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<dyn Notifier> {
[INFO] [stdout]    |                                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/notification/stdout.rs:11:78
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<Notifier> {
[INFO] [stdout]    |                                                                              ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<dyn Notifier> {
[INFO] [stdout]    |                                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:26:29
[INFO] [stdout]    |
[INFO] [stdout] 26 |             description(err.description())
[INFO] [stdout]    |                             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:36:29
[INFO] [stdout]    |
[INFO] [stdout] 36 |             description(err.description())
[INFO] [stdout]    |                             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `marker_found`, `marker_required`, `child_count`, and `dir_count` are never read
[INFO] [stdout]   --> libs/api/src/commands/list.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | struct ListStatistics {
[INFO] [stdout]    |        -------------- fields in this struct
[INFO] [stdout] 21 |     pub dir: PathBuf,
[INFO] [stdout] 22 |     pub marker_found: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 23 |     pub marker_required: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     pub child_count: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 25 |     pub dir_count: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ListStatistics` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling ui v0.1.0 (/opt/rustwide/workdir/libs/ui)
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> libs/ui/src/cli/command_parsing.rs:9:24
[INFO] [stdout]   |
[INFO] [stdout] 9 | impl CommandParser for commands::Command {
[INFO] [stdout]   |                        ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]   = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]   = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]   |
[INFO] [stdout] 9 | impl CommandParser for dyn commands::Command {
[INFO] [stdout]   |                        +++
[INFO] [stdout] help: alternatively use a blanket implementation to implement `CommandParser` for all types that also implement `commands::Command`
[INFO] [stdout]   |
[INFO] [stdout] 9 - impl CommandParser for commands::Command {
[INFO] [stdout] 9 + impl<T: commands::Command> CommandParser for T {
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/ui/src/cli/mod.rs:28:29
[INFO] [stdout]    |
[INFO] [stdout] 28 |         if let Some(exec) = commands::Command::parse(&matches) {
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 28 |         if let Some(exec) = <dyn commands::Command>::parse(&matches) {
[INFO] [stdout]    |                             ++++                  +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling markemptydirs v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 11.03s
[INFO] running `Command { std: "docker" "inspect" "cb3cc84b0bc5fc89242e8a68b12a3e0dfb303aad881ea158ce2e2355bfc88e2e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cb3cc84b0bc5fc89242e8a68b12a3e0dfb303aad881ea158ce2e2355bfc88e2e", kill_on_drop: false }`
[INFO] [stdout] cb3cc84b0bc5fc89242e8a68b12a3e0dfb303aad881ea158ce2e2355bfc88e2e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-04-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d695f039e19e924a522ed72740d730aa204f20afb3e0eeb17e3a6d5ebf5fdba1
[INFO] running `Command { std: "docker" "start" "-a" "d695f039e19e924a522ed72740d730aa204f20afb3e0eeb17e3a6d5ebf5fdba1", kill_on_drop: false }`
[INFO] [stderr] warning: `package.edition` is unspecified, defaulting to `2015` while the latest is `2024`
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:21:1
[INFO] [stdout]    |
[INFO] [stdout] 21 | / quick_error! {
[INFO] [stdout] 22 | |     #[derive(Debug)]
[INFO] [stdout] 23 | |     pub enum Error {
[INFO] [stdout] 24 | |         Io(err: std::io::Error) {
[INFO] [stdout] ...  |
[INFO] [stdout] 39 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout]    = note: this warning originates in the macro `quick_error` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:21:1
[INFO] [stdout]    |
[INFO] [stdout] 21 | / quick_error! {
[INFO] [stdout] 22 | |     #[derive(Debug)]
[INFO] [stdout] 23 | |     pub enum Error {
[INFO] [stdout] 24 | |         Io(err: std::io::Error) {
[INFO] [stdout] ...  |
[INFO] [stdout] 39 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `quick_error` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:21:1
[INFO] [stdout]    |
[INFO] [stdout] 21 | / quick_error! {
[INFO] [stdout] 22 | |     #[derive(Debug)]
[INFO] [stdout] 23 | |     pub enum Error {
[INFO] [stdout] 24 | |         Io(err: std::io::Error) {
[INFO] [stdout] ...  |
[INFO] [stdout] 39 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `quick_error` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:21:1
[INFO] [stdout]    |
[INFO] [stdout] 21 | / quick_error! {
[INFO] [stdout] 22 | |     #[derive(Debug)]
[INFO] [stdout] 23 | |     pub enum Error {
[INFO] [stdout] 24 | |         Io(err: std::io::Error) {
[INFO] [stdout] ...  |
[INFO] [stdout] 39 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `quick_error` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/application/session.rs:10:22
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub command: Box<Command>,
[INFO] [stdout]    |                      ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub command: Box<dyn Command>,
[INFO] [stdout]    |                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/application/session.rs:11:22
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub context: Box<Context>,
[INFO] [stdout]    |                      ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub context: Box<dyn Context>,
[INFO] [stdout]    |                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/context.rs:64:19
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fsaccess: Box<FileSystemAccess>,
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fsaccess: Box<dyn FileSystemAccess>,
[INFO] [stdout]    |                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/context.rs:65:19
[INFO] [stdout]    |
[INFO] [stdout] 65 |     notifier: Box<Notifier>,
[INFO] [stdout]    |                   ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 65 |     notifier: Box<dyn Notifier>,
[INFO] [stdout]    |                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/mod.rs:28:16
[INFO] [stdout]    |
[INFO] [stdout] 28 |     DryRun(Box<Command>),
[INFO] [stdout]    |                ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 28 |     DryRun(Box<dyn Command>),
[INFO] [stdout]    |                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/mod.rs:29:13
[INFO] [stdout]    |
[INFO] [stdout] 29 |     Run(Box<Command>),
[INFO] [stdout]    |             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 |     Run(Box<dyn Command>),
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/lib.rs:34:24
[INFO] [stdout]    |
[INFO] [stdout] 34 |         Other(err: Box<std::error::Error>) {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 34 |         Other(err: Box<dyn std::error::Error>) {
[INFO] [stdout]    |                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/mod.rs:23:29
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn execute(&self, ctx: &context::Context) -> Result<()>;
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn execute(&self, ctx: &dyn context::Context) -> Result<()>;
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/context.rs:41:32
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn get_notifier(&self) -> &Notifier;
[INFO] [stdout]    |                                ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn get_notifier(&self) -> &dyn Notifier;
[INFO] [stdout]    |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/clean.rs:23:29
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn execute(&self, ctx: &Context) -> Result<()> {
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn execute(&self, ctx: &dyn Context) -> Result<()> {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> libs/api/src/commands/context.rs:156:32
[INFO] [stdout]     |
[INFO] [stdout] 156 |     fn get_notifier(&self) -> &Notifier {
[INFO] [stdout]     |                                ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 156 |     fn get_notifier(&self) -> &dyn Notifier {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/list.rs:38:29
[INFO] [stdout]    |
[INFO] [stdout] 38 |     fn execute(&self, ctx: &Context) -> Result<()> {
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 38 |     fn execute(&self, ctx: &dyn Context) -> Result<()> {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/purge.rs:19:30
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn execute(&self, _ctx: &Context) -> Result<()> {
[INFO] [stdout]    |                              ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn execute(&self, _ctx: &dyn Context) -> Result<()> {
[INFO] [stdout]    |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/update.rs:29:29
[INFO] [stdout]    |
[INFO] [stdout] 29 |     fn execute(&self, ctx: &Context) -> Result<()> {
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 |     fn execute(&self, ctx: &dyn Context) -> Result<()> {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/fs/access.rs:14:56
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub fn create_file_system_access(dry_run: bool) -> Box<FileSystemAccess> {
[INFO] [stdout]    |                                                        ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub fn create_file_system_access(dry_run: bool) -> Box<dyn FileSystemAccess> {
[INFO] [stdout]    |                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/application/session.rs:19:71
[INFO] [stdout]    |
[INFO] [stdout] 19 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<Notifier>,
[INFO] [stdout]    |                                                                       ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 19 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<dyn Notifier>,
[INFO] [stdout]    |                                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/application/session.rs:34:71
[INFO] [stdout]    |
[INFO] [stdout] 34 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<Notifier>,
[INFO] [stdout]    |                                                                       ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 34 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<dyn Notifier>,
[INFO] [stdout]    |                                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/application/session.rs:35:52
[INFO] [stdout]    |
[INFO] [stdout] 35 |         fsaccess_factory: impl FnOnce(bool) -> Box<FileSystemAccess>,
[INFO] [stdout]    |                                                    ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 35 |         fsaccess_factory: impl FnOnce(bool) -> Box<dyn FileSystemAccess>,
[INFO] [stdout]    |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling markemptydirs v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/context.rs:73:71
[INFO] [stdout]    |
[INFO] [stdout] 73 |         notifier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<Notifier>,
[INFO] [stdout]    |                                                                       ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 73 |         notifier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<dyn Notifier>,
[INFO] [stdout]    |                                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/commands/context.rs:74:52
[INFO] [stdout]    |
[INFO] [stdout] 74 |         fsaccess_factory: impl FnOnce(bool) -> Box<FileSystemAccess>,
[INFO] [stdout]    |                                                    ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 74 |         fsaccess_factory: impl FnOnce(bool) -> Box<dyn FileSystemAccess>,
[INFO] [stdout]    |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/notification/logger.rs:12:78
[INFO] [stdout]    |
[INFO] [stdout] 12 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<Notifier> {
[INFO] [stdout]    |                                                                              ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 12 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<dyn Notifier> {
[INFO] [stdout]    |                                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/api/src/notification/stdout.rs:11:78
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<Notifier> {
[INFO] [stdout]    |                                                                              ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<dyn Notifier> {
[INFO] [stdout]    |                                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:26:29
[INFO] [stdout]    |
[INFO] [stdout] 26 |             description(err.description())
[INFO] [stdout]    |                             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> libs/api/src/lib.rs:36:29
[INFO] [stdout]    |
[INFO] [stdout] 36 |             description(err.description())
[INFO] [stdout]    |                             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `marker_found`, `marker_required`, `child_count`, and `dir_count` are never read
[INFO] [stdout]   --> libs/api/src/commands/list.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | struct ListStatistics {
[INFO] [stdout]    |        -------------- fields in this struct
[INFO] [stdout] 21 |     pub dir: PathBuf,
[INFO] [stdout] 22 |     pub marker_found: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 23 |     pub marker_required: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     pub child_count: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 25 |     pub dir_count: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ListStatistics` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> libs/ui/src/cli/command_parsing.rs:9:24
[INFO] [stdout]   |
[INFO] [stdout] 9 | impl CommandParser for commands::Command {
[INFO] [stdout]   |                        ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]   = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]   = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]   |
[INFO] [stdout] 9 | impl CommandParser for dyn commands::Command {
[INFO] [stdout]   |                        +++
[INFO] [stdout] help: alternatively use a blanket implementation to implement `CommandParser` for all types that also implement `commands::Command`
[INFO] [stdout]   |
[INFO] [stdout] 9 - impl CommandParser for commands::Command {
[INFO] [stdout] 9 + impl<T: commands::Command> CommandParser for T {
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> libs/ui/src/cli/mod.rs:28:29
[INFO] [stdout]    |
[INFO] [stdout] 28 |         if let Some(exec) = commands::Command::parse(&matches) {
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 28 |         if let Some(exec) = <dyn commands::Command>::parse(&matches) {
[INFO] [stdout]    |                             ++++                  +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.51s
[INFO] running `Command { std: "docker" "inspect" "d695f039e19e924a522ed72740d730aa204f20afb3e0eeb17e3a6d5ebf5fdba1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d695f039e19e924a522ed72740d730aa204f20afb3e0eeb17e3a6d5ebf5fdba1", kill_on_drop: false }`
[INFO] [stdout] d695f039e19e924a522ed72740d730aa204f20afb3e0eeb17e3a6d5ebf5fdba1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-04-21" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 9ffe4cf4c9ce90670489919249bdaf81086d070e92d2c8430c451a8b783edee9
[INFO] running `Command { std: "docker" "start" "-a" "9ffe4cf4c9ce90670489919249bdaf81086d070e92d2c8430c451a8b783edee9", kill_on_drop: false }`
[INFO] [stderr] warning: `package.edition` is unspecified, defaulting to `2015` while the latest is `2024`
[INFO] [stderr] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stderr]   --> libs/api/src/lib.rs:21:1
[INFO] [stderr]    |
[INFO] [stderr] 21 | / quick_error! {
[INFO] [stderr] 22 | |     #[derive(Debug)]
[INFO] [stderr] 23 | |     pub enum Error {
[INFO] [stderr] 24 | |         Io(err: std::io::Error) {
[INFO] [stderr] ...  |
[INFO] [stderr] 39 | | }
[INFO] [stderr]    | |_^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr]    = note: this warning originates in the macro `quick_error` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stderr]   --> libs/api/src/lib.rs:21:1
[INFO] [stderr]    |
[INFO] [stderr] 21 | / quick_error! {
[INFO] [stderr] 22 | |     #[derive(Debug)]
[INFO] [stderr] 23 | |     pub enum Error {
[INFO] [stderr] 24 | |         Io(err: std::io::Error) {
[INFO] [stderr] ...  |
[INFO] [stderr] 39 | | }
[INFO] [stderr]    | |_^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this warning originates in the macro `quick_error` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/application/session.rs:10:22
[INFO] [stderr]    |
[INFO] [stderr] 10 |     pub command: Box<Command>,
[INFO] [stderr]    |                      ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 10 |     pub command: Box<dyn Command>,
[INFO] [stderr]    |                      +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/application/session.rs:11:22
[INFO] [stderr]    |
[INFO] [stderr] 11 |     pub context: Box<Context>,
[INFO] [stderr]    |                      ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 11 |     pub context: Box<dyn Context>,
[INFO] [stderr]    |                      +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/context.rs:64:19
[INFO] [stderr]    |
[INFO] [stderr] 64 |     fsaccess: Box<FileSystemAccess>,
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 64 |     fsaccess: Box<dyn FileSystemAccess>,
[INFO] [stderr]    |                   +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/context.rs:65:19
[INFO] [stderr]    |
[INFO] [stderr] 65 |     notifier: Box<Notifier>,
[INFO] [stderr]    |                   ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 65 |     notifier: Box<dyn Notifier>,
[INFO] [stderr]    |                   +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/mod.rs:28:16
[INFO] [stderr]    |
[INFO] [stderr] 28 |     DryRun(Box<Command>),
[INFO] [stderr]    |                ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 28 |     DryRun(Box<dyn Command>),
[INFO] [stderr]    |                +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/mod.rs:29:13
[INFO] [stderr]    |
[INFO] [stderr] 29 |     Run(Box<Command>),
[INFO] [stderr]    |             ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 29 |     Run(Box<dyn Command>),
[INFO] [stderr]    |             +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/lib.rs:34:24
[INFO] [stderr]    |
[INFO] [stderr] 34 |         Other(err: Box<std::error::Error>) {
[INFO] [stderr]    |                        ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 34 |         Other(err: Box<dyn std::error::Error>) {
[INFO] [stderr]    |                        +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/mod.rs:23:29
[INFO] [stderr]    |
[INFO] [stderr] 23 |     fn execute(&self, ctx: &context::Context) -> Result<()>;
[INFO] [stderr]    |                             ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 23 |     fn execute(&self, ctx: &dyn context::Context) -> Result<()>;
[INFO] [stderr]    |                             +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/context.rs:41:32
[INFO] [stderr]    |
[INFO] [stderr] 41 |     fn get_notifier(&self) -> &Notifier;
[INFO] [stderr]    |                                ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 41 |     fn get_notifier(&self) -> &dyn Notifier;
[INFO] [stderr]    |                                +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/clean.rs:23:29
[INFO] [stderr]    |
[INFO] [stderr] 23 |     fn execute(&self, ctx: &Context) -> Result<()> {
[INFO] [stderr]    |                             ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 23 |     fn execute(&self, ctx: &dyn Context) -> Result<()> {
[INFO] [stderr]    |                             +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> libs/api/src/commands/context.rs:156:32
[INFO] [stderr]     |
[INFO] [stderr] 156 |     fn get_notifier(&self) -> &Notifier {
[INFO] [stderr]     |                                ^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 156 |     fn get_notifier(&self) -> &dyn Notifier {
[INFO] [stderr]     |                                +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/list.rs:38:29
[INFO] [stderr]    |
[INFO] [stderr] 38 |     fn execute(&self, ctx: &Context) -> Result<()> {
[INFO] [stderr]    |                             ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 38 |     fn execute(&self, ctx: &dyn Context) -> Result<()> {
[INFO] [stderr]    |                             +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/purge.rs:19:30
[INFO] [stderr]    |
[INFO] [stderr] 19 |     fn execute(&self, _ctx: &Context) -> Result<()> {
[INFO] [stderr]    |                              ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 19 |     fn execute(&self, _ctx: &dyn Context) -> Result<()> {
[INFO] [stderr]    |                              +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/update.rs:29:29
[INFO] [stderr]    |
[INFO] [stderr] 29 |     fn execute(&self, ctx: &Context) -> Result<()> {
[INFO] [stderr]    |                             ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 29 |     fn execute(&self, ctx: &dyn Context) -> Result<()> {
[INFO] [stderr]    |                             +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/fs/access.rs:14:56
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub fn create_file_system_access(dry_run: bool) -> Box<FileSystemAccess> {
[INFO] [stderr]    |                                                        ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub fn create_file_system_access(dry_run: bool) -> Box<dyn FileSystemAccess> {
[INFO] [stderr]    |                                                        +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/application/session.rs:19:71
[INFO] [stderr]    |
[INFO] [stderr] 19 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<Notifier>,
[INFO] [stderr]    |                                                                       ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 19 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<dyn Notifier>,
[INFO] [stderr]    |                                                                       +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/application/session.rs:34:71
[INFO] [stderr]    |
[INFO] [stderr] 34 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<Notifier>,
[INFO] [stderr]    |                                                                       ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 34 |         nofitier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<dyn Notifier>,
[INFO] [stderr]    |                                                                       +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/application/session.rs:35:52
[INFO] [stderr]    |
[INFO] [stderr] 35 |         fsaccess_factory: impl FnOnce(bool) -> Box<FileSystemAccess>,
[INFO] [stderr]    |                                                    ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 35 |         fsaccess_factory: impl FnOnce(bool) -> Box<dyn FileSystemAccess>,
[INFO] [stderr]    |                                                    +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/context.rs:73:71
[INFO] [stderr]    |
[INFO] [stderr] 73 |         notifier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<Notifier>,
[INFO] [stderr]    |                                                                       ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 73 |         notifier_factory: impl FnOnce(LogLevel, MessageLength) -> Box<dyn Notifier>,
[INFO] [stderr]    |                                                                       +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/commands/context.rs:74:52
[INFO] [stderr]    |
[INFO] [stderr] 74 |         fsaccess_factory: impl FnOnce(bool) -> Box<FileSystemAccess>,
[INFO] [stderr]    |                                                    ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 74 |         fsaccess_factory: impl FnOnce(bool) -> Box<dyn FileSystemAccess>,
[INFO] [stderr]    |                                                    +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/notification/logger.rs:12:78
[INFO] [stderr]    |
[INFO] [stderr] 12 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<Notifier> {
[INFO] [stderr]    |                                                                              ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 12 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<dyn Notifier> {
[INFO] [stderr]    |                                                                              +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/api/src/notification/stdout.rs:11:78
[INFO] [stderr]    |
[INFO] [stderr] 11 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<Notifier> {
[INFO] [stderr]    |                                                                              ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 11 |     pub fn create(log_level: LogLevel, message_length: MessageLength) -> Box<dyn Notifier> {
[INFO] [stderr]    |                                                                              +++
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stderr]   --> libs/api/src/lib.rs:26:29
[INFO] [stderr]    |
[INFO] [stderr] 26 |             description(err.description())
[INFO] [stderr]    |                             ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stderr]   --> libs/api/src/lib.rs:36:29
[INFO] [stderr]    |
[INFO] [stderr] 36 |             description(err.description())
[INFO] [stderr]    |                             ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `marker_found`, `marker_required`, `child_count`, and `dir_count` are never read
[INFO] [stderr]   --> libs/api/src/commands/list.rs:22:9
[INFO] [stderr]    |
[INFO] [stderr] 20 | struct ListStatistics {
[INFO] [stderr]    |        -------------- fields in this struct
[INFO] [stderr] 21 |     pub dir: PathBuf,
[INFO] [stderr] 22 |     pub marker_found: bool,
[INFO] [stderr]    |         ^^^^^^^^^^^^
[INFO] [stderr] 23 |     pub marker_required: bool,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^
[INFO] [stderr] 24 |     pub child_count: usize,
[INFO] [stderr]    |         ^^^^^^^^^^^
[INFO] [stderr] 25 |     pub dir_count: usize,
[INFO] [stderr]    |         ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stderr]    |
[INFO] [stdout] running 0 tests
[INFO] [stderr]    = note: `ListStatistics` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stderr] 
[INFO] [stdout] 
[INFO] [stderr] warning: `api` (lib) generated 29 warnings (2 duplicates) (run `cargo fix --lib -p api` to apply 22 suggestions)
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> libs/ui/src/cli/command_parsing.rs:9:24
[INFO] [stderr]   |
[INFO] [stderr] 9 | impl CommandParser for commands::Command {
[INFO] [stderr]   |                        ^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]   = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr]   = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]   |
[INFO] [stderr] 9 | impl CommandParser for dyn commands::Command {
[INFO] [stderr]   |                        +++
[INFO] [stderr] help: alternatively use a blanket implementation to implement `CommandParser` for all types that also implement `commands::Command`
[INFO] [stderr]   |
[INFO] [stderr] 9 - impl CommandParser for commands::Command {
[INFO] [stderr] 9 + impl<T: commands::Command> CommandParser for T {
[INFO] [stderr]   |
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> libs/ui/src/cli/mod.rs:28:29
[INFO] [stderr]    |
[INFO] [stderr] 28 |         if let Some(exec) = commands::Command::parse(&matches) {
[INFO] [stderr]    |                             ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 28 |         if let Some(exec) = <dyn commands::Command>::parse(&matches) {
[INFO] [stderr]    |                             ++++                  +
[INFO] [stderr] 
[INFO] [stderr] warning: `ui` (lib) generated 2 warnings (run `cargo fix --lib -p ui` to apply 2 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.08s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/markemptydirs-c00aeca92f348d68)
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/markemptydirs-d9c69462f5413668)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests markemptydirs
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "9ffe4cf4c9ce90670489919249bdaf81086d070e92d2c8430c451a8b783edee9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9ffe4cf4c9ce90670489919249bdaf81086d070e92d2c8430c451a8b783edee9", kill_on_drop: false }`
[INFO] [stdout] 9ffe4cf4c9ce90670489919249bdaf81086d070e92d2c8430c451a8b783edee9
