[INFO] fetching crate sandcastle 0.0.1...
[INFO] building sandcastle-0.0.1 against master#ad85bc524b1ad696e42061ad8338d382dffbdbe5 for pr-146237-1
[INFO] extracting crate sandcastle 0.0.1 into /workspace/builds/worker-4-tc1/source
[INFO] started tweaking crates.io crate sandcastle 0.0.1
[INFO] finished tweaking crates.io crate sandcastle 0.0.1
[INFO] tweaked toml for crates.io crate sandcastle 0.0.1 written to /workspace/builds/worker-4-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate sandcastle 0.0.1 on toolchain ad85bc524b1ad696e42061ad8338d382dffbdbe5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 26 packages to latest compatible versions
[INFO] [stderr]       Adding euclid v0.17.3 (available: v0.22.11)
[INFO] [stderr]       Adding image v0.18.0 (available: v0.25.8)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded enum_primitive v0.1.1
[INFO] [stderr]   Downloaded lzw v0.10.0
[INFO] [stderr]   Downloaded gif v0.9.2
[INFO] [stderr]   Downloaded euclid v0.17.3
[INFO] [stderr]   Downloaded image v0.18.0
[INFO] [stderr]   Downloaded num-rational v0.1.43
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 4d2bb024015c6e630e3aba7da9c59ded0405c467f98ace6a0be35902a3768730
[INFO] running `Command { std: "docker" "start" "-a" "4d2bb024015c6e630e3aba7da9c59ded0405c467f98ace6a0be35902a3768730", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4d2bb024015c6e630e3aba7da9c59ded0405c467f98ace6a0be35902a3768730", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4d2bb024015c6e630e3aba7da9c59ded0405c467f98ace6a0be35902a3768730", kill_on_drop: false }`
[INFO] [stdout] 4d2bb024015c6e630e3aba7da9c59ded0405c467f98ace6a0be35902a3768730
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] eff2e96d6fbcdaaabcd82746a99befdc124a9c47ea61771a5209fe8ca28d51a9
[INFO] running `Command { std: "docker" "start" "-a" "eff2e96d6fbcdaaabcd82746a99befdc124a9c47ea61771a5209fe8ca28d51a9", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]    Compiling num-rational v0.1.43
[INFO] [stderr]    Compiling lzw v0.10.0
[INFO] [stderr]    Compiling inflate v0.3.4
[INFO] [stderr]    Compiling deflate v0.7.20
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling num-traits v0.1.43
[INFO] [stderr]    Compiling jpeg-decoder v0.1.22
[INFO] [stderr]    Compiling enum_primitive v0.1.1
[INFO] [stderr]    Compiling euclid v0.17.3
[INFO] [stderr]    Compiling gif v0.9.2
[INFO] [stderr]    Compiling num-iter v0.1.45
[INFO] [stderr]    Compiling png v0.11.0
[INFO] [stderr]    Compiling image v0.18.0
[INFO] [stderr]    Compiling sandcastle v0.0.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/renderer.rs:6:25
[INFO] [stdout]   |
[INFO] [stdout] 6 |     fn render(node: Box<RenderNode>) -> RenderResult<()>;
[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] 6 |     fn render(node: Box<dyn RenderNode>) -> RenderResult<()>;
[INFO] [stdout]   |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/render_node.rs:3:36
[INFO] [stdout]   |
[INFO] [stdout] 3 |     fn parent(&self) -> Option<Box<RenderNode>>;
[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] 3 |     fn parent(&self) -> Option<Box<dyn RenderNode>>;
[INFO] [stdout]   |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/render_node.rs:4:27
[INFO] [stdout]   |
[INFO] [stdout] 4 |     fn children(&self) -> Iterator<Item=Box<RenderNode>>;
[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] 4 |     fn children(&self) -> dyn Iterator<Item=Box<RenderNode>>;
[INFO] [stdout]   |                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/render_node.rs:4:45
[INFO] [stdout]   |
[INFO] [stdout] 4 |     fn children(&self) -> Iterator<Item=Box<RenderNode>>;
[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] 4 |     fn children(&self) -> Iterator<Item=Box<dyn RenderNode>>;
[INFO] [stdout]   |                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/nodes/transform.rs:20:29
[INFO] [stdout]    |
[INFO] [stdout] 20 |     pub fn child(&self) -> &RenderNode {
[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] 20 |     pub fn child(&self) -> &dyn RenderNode {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Image` is never constructed
[INFO] [stdout]  --> src/nodes/image.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Image<P: Pixel, C> {
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `buffer` are never used
[INFO] [stdout]   --> src/nodes/image.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl<P: Pixel, C> Image<P, C> {
[INFO] [stdout]    | ----------------------------- associated items in this implementation
[INFO] [stdout] 10 |     fn new(buffer: ImageBuffer<P, C>) -> Image<P, C> {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     fn buffer(&self) -> &ImageBuffer<P, C> {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Mask` is never constructed
[INFO] [stdout]  --> src/nodes/mask.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct Mask {
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Transform` is never constructed
[INFO] [stdout]  --> src/nodes/transform.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Transform<N: RenderNode> {
[INFO] [stdout]   |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `child`, and `transform` are never used
[INFO] [stdout]   --> src/nodes/transform.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl<N: RenderNode> Transform<N> {
[INFO] [stdout]    | -------------------------------- associated items in this implementation
[INFO] [stdout] 13 |     pub fn new(child: N, transform: Transform3D<f64>) -> Transform<N> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 20 |     pub fn child(&self) -> &RenderNode {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn transform(&self) -> &Transform3D<f64> {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Shadow` is never constructed
[INFO] [stdout]  --> src/nodes/shadow.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Shadow {
[INFO] [stdout]   |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Gradient` is never constructed
[INFO] [stdout]  --> src/nodes/gradient.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub struct Gradient {
[INFO] [stdout]   |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 7.20s
[INFO] running `Command { std: "docker" "inspect" "eff2e96d6fbcdaaabcd82746a99befdc124a9c47ea61771a5209fe8ca28d51a9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "eff2e96d6fbcdaaabcd82746a99befdc124a9c47ea61771a5209fe8ca28d51a9", kill_on_drop: false }`
[INFO] [stdout] eff2e96d6fbcdaaabcd82746a99befdc124a9c47ea61771a5209fe8ca28d51a9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] e4e146de6bf0d52370a5364a9dfa250081a5f24c620a7961c96f19c0096c9ee8
[INFO] running `Command { std: "docker" "start" "-a" "e4e146de6bf0d52370a5364a9dfa250081a5f24c620a7961c96f19c0096c9ee8", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/renderer.rs:6:25
[INFO] [stdout]   |
[INFO] [stdout] 6 |     fn render(node: Box<RenderNode>) -> RenderResult<()>;
[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] 6 |     fn render(node: Box<dyn RenderNode>) -> RenderResult<()>;
[INFO] [stdout]   |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/render_node.rs:3:36
[INFO] [stdout]   |
[INFO] [stdout] 3 |     fn parent(&self) -> Option<Box<RenderNode>>;
[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] 3 |     fn parent(&self) -> Option<Box<dyn RenderNode>>;
[INFO] [stdout]   |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/render_node.rs:4:27
[INFO] [stdout]   |
[INFO] [stdout] 4 |     fn children(&self) -> Iterator<Item=Box<RenderNode>>;
[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] 4 |     fn children(&self) -> dyn Iterator<Item=Box<RenderNode>>;
[INFO] [stdout]   |                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/render_node.rs:4:45
[INFO] [stdout]   |
[INFO] [stdout] 4 |     fn children(&self) -> Iterator<Item=Box<RenderNode>>;
[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] 4 |     fn children(&self) -> Iterator<Item=Box<dyn RenderNode>>;
[INFO] [stdout]   |                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/nodes/transform.rs:20:29
[INFO] [stdout]    |
[INFO] [stdout] 20 |     pub fn child(&self) -> &RenderNode {
[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] 20 |     pub fn child(&self) -> &dyn RenderNode {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Image` is never constructed
[INFO] [stdout]  --> src/nodes/image.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Image<P: Pixel, C> {
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `buffer` are never used
[INFO] [stdout]   --> src/nodes/image.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl<P: Pixel, C> Image<P, C> {
[INFO] [stdout]    | ----------------------------- associated items in this implementation
[INFO] [stdout] 10 |     fn new(buffer: ImageBuffer<P, C>) -> Image<P, C> {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     fn buffer(&self) -> &ImageBuffer<P, C> {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Mask` is never constructed
[INFO] [stdout]  --> src/nodes/mask.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct Mask {
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Transform` is never constructed
[INFO] [stdout]  --> src/nodes/transform.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Transform<N: RenderNode> {
[INFO] [stdout]   |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `child`, and `transform` are never used
[INFO] [stdout]   --> src/nodes/transform.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl<N: RenderNode> Transform<N> {
[INFO] [stdout]    | -------------------------------- associated items in this implementation
[INFO] [stdout] 13 |     pub fn new(child: N, transform: Transform3D<f64>) -> Transform<N> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 20 |     pub fn child(&self) -> &RenderNode {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn transform(&self) -> &Transform3D<f64> {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Shadow` is never constructed
[INFO] [stdout]  --> src/nodes/shadow.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Shadow {
[INFO] [stdout]   |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Gradient` is never constructed
[INFO] [stdout]  --> src/nodes/gradient.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub struct Gradient {
[INFO] [stdout]   |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling sandcastle v0.0.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/renderer.rs:6:25
[INFO] [stdout]   |
[INFO] [stdout] 6 |     fn render(node: Box<RenderNode>) -> RenderResult<()>;
[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] 6 |     fn render(node: Box<dyn RenderNode>) -> RenderResult<()>;
[INFO] [stdout]   |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/render_node.rs:3:36
[INFO] [stdout]   |
[INFO] [stdout] 3 |     fn parent(&self) -> Option<Box<RenderNode>>;
[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] 3 |     fn parent(&self) -> Option<Box<dyn RenderNode>>;
[INFO] [stdout]   |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/render_node.rs:4:27
[INFO] [stdout]   |
[INFO] [stdout] 4 |     fn children(&self) -> Iterator<Item=Box<RenderNode>>;
[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] 4 |     fn children(&self) -> dyn Iterator<Item=Box<RenderNode>>;
[INFO] [stdout]   |                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]  --> src/render_node.rs:4:45
[INFO] [stdout]   |
[INFO] [stdout] 4 |     fn children(&self) -> Iterator<Item=Box<RenderNode>>;
[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] 4 |     fn children(&self) -> Iterator<Item=Box<dyn RenderNode>>;
[INFO] [stdout]   |                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/nodes/transform.rs:20:29
[INFO] [stdout]    |
[INFO] [stdout] 20 |     pub fn child(&self) -> &RenderNode {
[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] 20 |     pub fn child(&self) -> &dyn RenderNode {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Image` is never constructed
[INFO] [stdout]  --> src/nodes/image.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Image<P: Pixel, C> {
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `buffer` are never used
[INFO] [stdout]   --> src/nodes/image.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl<P: Pixel, C> Image<P, C> {
[INFO] [stdout]    | ----------------------------- associated items in this implementation
[INFO] [stdout] 10 |     fn new(buffer: ImageBuffer<P, C>) -> Image<P, C> {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     fn buffer(&self) -> &ImageBuffer<P, C> {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Mask` is never constructed
[INFO] [stdout]  --> src/nodes/mask.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct Mask {
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Transform` is never constructed
[INFO] [stdout]  --> src/nodes/transform.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Transform<N: RenderNode> {
[INFO] [stdout]   |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `child`, and `transform` are never used
[INFO] [stdout]   --> src/nodes/transform.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl<N: RenderNode> Transform<N> {
[INFO] [stdout]    | -------------------------------- associated items in this implementation
[INFO] [stdout] 13 |     pub fn new(child: N, transform: Transform3D<f64>) -> Transform<N> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 20 |     pub fn child(&self) -> &RenderNode {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn transform(&self) -> &Transform3D<f64> {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Shadow` is never constructed
[INFO] [stdout]  --> src/nodes/shadow.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Shadow {
[INFO] [stdout]   |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Gradient` is never constructed
[INFO] [stdout]  --> src/nodes/gradient.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub struct Gradient {
[INFO] [stdout]   |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.49s
[INFO] running `Command { std: "docker" "inspect" "e4e146de6bf0d52370a5364a9dfa250081a5f24c620a7961c96f19c0096c9ee8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e4e146de6bf0d52370a5364a9dfa250081a5f24c620a7961c96f19c0096c9ee8", kill_on_drop: false }`
[INFO] [stdout] e4e146de6bf0d52370a5364a9dfa250081a5f24c620a7961c96f19c0096c9ee8
