[INFO] cloning repository https://github.com/leximainw/celeste-berry-indicator
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/leximainw/celeste-berry-indicator" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fleximainw%2Fceleste-berry-indicator", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fleximainw%2Fceleste-berry-indicator'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 8a25ef03e019fea1fb54b08978965e5549367575
[INFO] checking leximainw/celeste-berry-indicator/8a25ef03e019fea1fb54b08978965e5549367575 against master#377656d3dd3f9c23a9c8713e163f4365a5261a84 for pr-146470-3
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fleximainw%2Fceleste-berry-indicator" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/leximainw/celeste-berry-indicator
[INFO] finished tweaking git repo https://github.com/leximainw/celeste-berry-indicator
[INFO] tweaked toml for git repo https://github.com/leximainw/celeste-berry-indicator written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/leximainw/celeste-berry-indicator on toolchain 377656d3dd3f9c23a9c8713e163f4365a5261a84
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "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" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 25 packages to latest compatible versions
[INFO] [stderr]       Adding dirs v5.0.1 (available: v6.0.0)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 069fe74413cfa642576ad585ad17805e039ed5df00b5223a2016bb02948b9705
[INFO] running `Command { std: "docker" "start" "-a" "069fe74413cfa642576ad585ad17805e039ed5df00b5223a2016bb02948b9705", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "069fe74413cfa642576ad585ad17805e039ed5df00b5223a2016bb02948b9705", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "069fe74413cfa642576ad585ad17805e039ed5df00b5223a2016bb02948b9705", kill_on_drop: false }`
[INFO] [stdout] 069fe74413cfa642576ad585ad17805e039ed5df00b5223a2016bb02948b9705
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] dcd0688cc8f9f67996282175339524eb43b6d0ca81b4c4fea8e9d13481c5749d
[INFO] running `Command { std: "docker" "start" "-a" "dcd0688cc8f9f67996282175339524eb43b6d0ca81b4c4fea8e9d13481c5749d", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.178
[INFO] [stderr]     Checking option-ext v0.2.0
[INFO] [stderr]     Checking dirs-sys v0.4.1
[INFO] [stderr]     Checking dirs v5.0.1
[INFO] [stderr]     Checking celeste-berry-indicator v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `flag_chevron::FlagChevron as FlagChevron`
[INFO] [stdout]  --> src/backgrounds/mod.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use flag_chevron::FlagChevron as FlagChevron;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `flag_composite::FlagComposite as FlagComposite`
[INFO] [stdout]   --> src/backgrounds/mod.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub use flag_composite::FlagComposite as FlagComposite;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `flag_stripes::FlagStripe as FlagStripe`
[INFO] [stdout]   --> src/backgrounds/mod.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use flag_stripes::FlagStripe as FlagStripe;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `decompress::Decompress as Decompress`
[INFO] [stdout]  --> src/compression/mod.rs:5:9
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub use decompress::Decompress as Decompress;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `berrytracker::BerryTrackerLevel as BerryTrackerLevel`
[INFO] [stdout]  --> src/savedata/mod.rs:5:9
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub use berrytracker::BerryTrackerLevel as BerryTrackerLevel;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `flag_chevron::FlagChevron as FlagChevron`
[INFO] [stdout]  --> src/backgrounds/mod.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use flag_chevron::FlagChevron as FlagChevron;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `flag_composite::FlagComposite as FlagComposite`
[INFO] [stdout]   --> src/backgrounds/mod.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub use flag_composite::FlagComposite as FlagComposite;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `flag_stripes::FlagStripe as FlagStripe`
[INFO] [stdout]   --> src/backgrounds/mod.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use flag_stripes::FlagStripe as FlagStripe;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `decompress::Decompress as Decompress`
[INFO] [stdout]  --> src/compression/mod.rs:5:9
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub use decompress::Decompress as Decompress;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `berrytracker::BerryTrackerLevel as BerryTrackerLevel`
[INFO] [stdout]  --> src/savedata/mod.rs:5:9
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub use berrytracker::BerryTrackerLevel as BerryTrackerLevel;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `stripe`
[INFO] [stdout]   --> src/backgrounds/flag_chevron.rs:44:25
[INFO] [stdout]    |
[INFO] [stdout] 44 |             for (index, stripe) in self.chevron.iter().enumerate() {
[INFO] [stdout]    |                         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_stripe`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `iter`
[INFO] [stdout]  --> src/image/bmp.rs:9:26
[INFO] [stdout]   |
[INFO] [stdout] 9 |     fn from_bytes(&self, iter: &mut dyn Iterator<Item=&u8>) -> Result<Box<dyn Image>, Box<dyn std::error::Error>> {
[INFO] [stdout]   |                          ^^^^ help: if this is intentional, prefix it with an underscore: `_iter`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `stripe`
[INFO] [stdout]   --> src/backgrounds/flag_chevron.rs:44:25
[INFO] [stdout]    |
[INFO] [stdout] 44 |             for (index, stripe) in self.chevron.iter().enumerate() {
[INFO] [stdout]    |                         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_stripe`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_pixel` is never used
[INFO] [stdout]  --> src/backgrounds/generator.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub trait Metagenerator {
[INFO] [stdout]   |           ------------- method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 7 |     fn get_pixel(&self, point: (usize, usize), size: (usize, usize)) -> (Color, u16) {
[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 `push` are never used
[INFO] [stdout]   --> src/berries/berry_row.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl BerryRow {
[INFO] [stdout]    | ------------- associated items in this implementation
[INFO] [stdout] 14 |     pub fn new(color: u32) -> BerryRow {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn push(&mut self, vec: Vec<bool>) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BitReader` is never constructed
[INFO] [stdout]  --> src/compression/bitstream.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct BitReader<R: Read> {
[INFO] [stdout]   |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `fill`, `read_bits`, `read_bool`, `read_u8`, and `read_u16` are never used
[INFO] [stdout]   --> src/compression/bitstream.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl<R: Read> BitReader<R> {
[INFO] [stdout]    | -------------------------- associated items in this implementation
[INFO] [stdout] 13 |     pub fn new(base: R) -> BitReader<R> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 21 |     fn fill(&mut self, bytes: usize) -> Result<()> {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn read_bits(&mut self, bits: usize) -> Result<Option<u64>> {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub fn read_bool(&mut self) -> Result<Option<bool>> {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |     pub fn read_u8(&mut self) -> Result<Option<u8>> {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 87 |     pub fn read_u16(&mut self) -> Result<Option<u16>> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Decompress` is never constructed
[INFO] [stdout]   --> src/compression/decompress.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct Decompress<R: Read> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `DecompressState` is never used
[INFO] [stdout]   --> src/compression/decompress.rs:16:6
[INFO] [stdout]    |
[INFO] [stdout] 16 | enum DecompressState {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/compression/decompress.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | impl<R: Read> Decompress<R> {
[INFO] [stdout]    | --------------------------- associated function in this implementation
[INFO] [stdout] 23 |     pub fn new(base: R) -> Decompress<R> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/image/color.rs:87:12
[INFO] [stdout]     |
[INFO] [stdout]   9 | impl Color {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  87 |     pub fn get_red(&self) -> u32 {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  91 |     pub fn get_green(&self) -> u32 {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn get_blue(&self) -> u32 {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     pub fn set_red(&self, value: u32) -> Color {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 110 |     pub fn set_green(&self, value: u32) -> Color {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub fn set_blue(&self, value: u32) -> Color {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 131 |     pub fn from_srgba(r: u8, g: u8, b: u8, a: u8) -> Color {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 170 |     pub fn from_rgba_linear(r: u8, g: u8, b: u8, a: u8) -> Color {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn from_rgba32_linear(color: u32) -> Color {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 188 |     pub fn to_rgba32_linear(&self) -> u32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_pixel_index` and `to_rgba32_image` are never used
[INFO] [stdout]   --> src/image/image.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub trait Image {
[INFO] [stdout]    |           ----- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 13 |     fn set_pixel_index(&mut self, index: usize, color: Color);
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 14 |
[INFO] [stdout] 15 |     fn to_rgba32_image(self: Box<Self>) -> RGBA32Image;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `from_bytes` is never used
[INFO] [stdout]  --> src/image/parser.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub trait Parser {
[INFO] [stdout]   |           ------ method in this trait
[INFO] [stdout] 4 |     fn from_bytes(&self, iter: &mut dyn Iterator<Item=&u8>) -> Result<Box<dyn Image>, Box<dyn std::error::Error>>;
[INFO] [stdout]   |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `match_slice`, `parse_image`, and `read_u32` are never used
[INFO] [stdout]    --> src/image/qoi.rs:11:8
[INFO] [stdout]     |
[INFO] [stdout]  10 | impl QoiParser {
[INFO] [stdout]     | -------------- associated functions in this implementation
[INFO] [stdout]  11 |     fn match_slice(iter: &mut dyn Iterator<Item=&u8>, slice: &[u8]) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  20 |     fn parse_image(iter: &mut dyn Iterator<Item=&u8>) -> Option<Box<dyn Image>> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     fn read_u32(iter: &mut dyn Iterator<Item=&u8>) -> Option<u32> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `iter`
[INFO] [stdout]  --> src/image/bmp.rs:9:26
[INFO] [stdout]   |
[INFO] [stdout] 9 |     fn from_bytes(&self, iter: &mut dyn Iterator<Item=&u8>) -> Result<Box<dyn Image>, Box<dyn std::error::Error>> {
[INFO] [stdout]   |                          ^^^^ help: if this is intentional, prefix it with an underscore: `_iter`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_pixel` is never used
[INFO] [stdout]  --> src/backgrounds/generator.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub trait Metagenerator {
[INFO] [stdout]   |           ------------- method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 7 |     fn get_pixel(&self, point: (usize, usize), size: (usize, usize)) -> (Color, u16) {
[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 `push` are never used
[INFO] [stdout]   --> src/berries/berry_row.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl BerryRow {
[INFO] [stdout]    | ------------- associated items in this implementation
[INFO] [stdout] 14 |     pub fn new(color: u32) -> BerryRow {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn push(&mut self, vec: Vec<bool>) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BitReader` is never constructed
[INFO] [stdout]  --> src/compression/bitstream.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct BitReader<R: Read> {
[INFO] [stdout]   |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `fill`, `read_bits`, `read_bool`, `read_u8`, and `read_u16` are never used
[INFO] [stdout]   --> src/compression/bitstream.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl<R: Read> BitReader<R> {
[INFO] [stdout]    | -------------------------- associated items in this implementation
[INFO] [stdout] 13 |     pub fn new(base: R) -> BitReader<R> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 21 |     fn fill(&mut self, bytes: usize) -> Result<()> {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn read_bits(&mut self, bits: usize) -> Result<Option<u64>> {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub fn read_bool(&mut self) -> Result<Option<bool>> {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |     pub fn read_u8(&mut self) -> Result<Option<u8>> {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 87 |     pub fn read_u16(&mut self) -> Result<Option<u16>> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Decompress` is never constructed
[INFO] [stdout]   --> src/compression/decompress.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct Decompress<R: Read> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `DecompressState` is never used
[INFO] [stdout]   --> src/compression/decompress.rs:16:6
[INFO] [stdout]    |
[INFO] [stdout] 16 | enum DecompressState {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/compression/decompress.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | impl<R: Read> Decompress<R> {
[INFO] [stdout]    | --------------------------- associated function in this implementation
[INFO] [stdout] 23 |     pub fn new(base: R) -> Decompress<R> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/image/color.rs:87:12
[INFO] [stdout]     |
[INFO] [stdout]   9 | impl Color {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  87 |     pub fn get_red(&self) -> u32 {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  91 |     pub fn get_green(&self) -> u32 {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn get_blue(&self) -> u32 {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     pub fn set_red(&self, value: u32) -> Color {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 110 |     pub fn set_green(&self, value: u32) -> Color {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub fn set_blue(&self, value: u32) -> Color {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 131 |     pub fn from_srgba(r: u8, g: u8, b: u8, a: u8) -> Color {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 170 |     pub fn from_rgba_linear(r: u8, g: u8, b: u8, a: u8) -> Color {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn from_rgba32_linear(color: u32) -> Color {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 188 |     pub fn to_rgba32_linear(&self) -> u32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_pixel_index` and `to_rgba32_image` are never used
[INFO] [stdout]   --> src/image/image.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub trait Image {
[INFO] [stdout]    |           ----- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 13 |     fn set_pixel_index(&mut self, index: usize, color: Color);
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 14 |
[INFO] [stdout] 15 |     fn to_rgba32_image(self: Box<Self>) -> RGBA32Image;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `from_bytes` is never used
[INFO] [stdout]  --> src/image/parser.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub trait Parser {
[INFO] [stdout]   |           ------ method in this trait
[INFO] [stdout] 4 |     fn from_bytes(&self, iter: &mut dyn Iterator<Item=&u8>) -> Result<Box<dyn Image>, Box<dyn std::error::Error>>;
[INFO] [stdout]   |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `match_slice`, `parse_image`, and `read_u32` are never used
[INFO] [stdout]    --> src/image/qoi.rs:11:8
[INFO] [stdout]     |
[INFO] [stdout]  10 | impl QoiParser {
[INFO] [stdout]     | -------------- associated functions in this implementation
[INFO] [stdout]  11 |     fn match_slice(iter: &mut dyn Iterator<Item=&u8>, slice: &[u8]) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  20 |     fn parse_image(iter: &mut dyn Iterator<Item=&u8>) -> Option<Box<dyn Image>> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     fn read_u32(iter: &mut dyn Iterator<Item=&u8>) -> Option<u32> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2.07s
[INFO] running `Command { std: "docker" "inspect" "dcd0688cc8f9f67996282175339524eb43b6d0ca81b4c4fea8e9d13481c5749d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "dcd0688cc8f9f67996282175339524eb43b6d0ca81b4c4fea8e9d13481c5749d", kill_on_drop: false }`
[INFO] [stdout] dcd0688cc8f9f67996282175339524eb43b6d0ca81b4c4fea8e9d13481c5749d
