[INFO] crate typer 0.1.1 is already in cache [INFO] extracting crate typer 0.1.1 into work/ex/clippy-test-run/sources/stable/reg/typer/0.1.1 [INFO] extracting crate typer 0.1.1 into work/ex/clippy-test-run/sources/stable+rustflags=-Dclippy%3A%3Ainto_iter_on_array/reg/typer/0.1.1 [INFO] validating manifest of typer-0.1.1 on toolchain stable [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of typer-0.1.1 on toolchain stable+rustflags=-Dclippy::into_iter_on_array [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing typer-0.1.1 [INFO] removed 5 missing examples [INFO] finished frobbing typer-0.1.1 [INFO] frobbed toml for typer-0.1.1 written to work/ex/clippy-test-run/sources/stable/reg/typer/0.1.1/Cargo.toml [INFO] started frobbing typer-0.1.1 [INFO] removed 5 missing examples [INFO] finished frobbing typer-0.1.1 [INFO] frobbed toml for typer-0.1.1 written to work/ex/clippy-test-run/sources/stable+rustflags=-Dclippy%3A%3Ainto_iter_on_array/reg/typer/0.1.1/Cargo.toml [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] linting typer-0.1.1 against stable for clippy-test-run [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/clippy-test-run/worker-5/stable:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/clippy-test-run/sources/stable/reg/typer/0.1.1:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+stable" "clippy" "--frozen" "--all" "--all-targets"` [INFO] [stdout] 0be32b278860b6e2e3a3393b62d25b7c27a851b6b38cd94d20944ae3219e1473 [INFO] running `"docker" "start" "-a" "0be32b278860b6e2e3a3393b62d25b7c27a851b6b38cd94d20944ae3219e1473"` [INFO] [stderr] Compiling arrayvec v0.4.10 [INFO] [stderr] Compiling proc-macro2 v0.4.26 [INFO] [stderr] Compiling libc v0.2.48 [INFO] [stderr] Compiling num-derive v0.2.4 [INFO] [stderr] Checking xml-rs v0.8.0 [INFO] [stderr] Checking inflate v0.4.4 [INFO] [stderr] Checking stb_truetype v0.2.5 [INFO] [stderr] Checking approx v0.3.1 [INFO] [stderr] Checking ordered-float v1.0.1 [INFO] [stderr] Checking png v0.12.0 [INFO] [stderr] Checking crossbeam-epoch v0.3.1 [INFO] [stderr] Checking rusttype v0.7.3 [INFO] [stderr] Checking num_cpus v1.9.0 [INFO] [stderr] Checking crossbeam-deque v0.2.0 [INFO] [stderr] Checking typer v0.1.1 (/opt/crater/workdir) [INFO] [stderr] Checking rayon-core v1.4.1 [INFO] [stderr] warning: returning the result of a let binding from a block. Consider returning the expression directly. [INFO] [stderr] --> src/chunk.rs:218:3 [INFO] [stderr] | [INFO] [stderr] 218 | res [INFO] [stderr] | ^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::let_and_return)] on by default [INFO] [stderr] note: this expression can be directly returned [INFO] [stderr] --> src/chunk.rs:208:13 [INFO] [stderr] | [INFO] [stderr] 208 | let res = Self { [INFO] [stderr] | ___________________^ [INFO] [stderr] 209 | | break_word: self.break_word, [INFO] [stderr] 210 | | width: self.width, [INFO] [stderr] 211 | | height: self.height, [INFO] [stderr] ... | [INFO] [stderr] 215 | | chunk: self.chunk.new_empty(), [INFO] [stderr] 216 | | }; [INFO] [stderr] | |_________^ [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#let_and_return [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/chunk.rs:320:5 [INFO] [stderr] | [INFO] [stderr] 320 | return self.next(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ help: remove `return` as shown: `self.next()` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::needless_return)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] [INFO] [stderr] warning: value assigned to `scale` is never read [INFO] [stderr] --> src/rusttype_renderer.rs:61:11 [INFO] [stderr] | [INFO] [stderr] 61 | let mut scale = Scale::uniform(0.0); [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(unused_assignments)] on by default [INFO] [stderr] [INFO] [stderr] warning: this argument is passed by reference, but would be more efficient if passed by value [INFO] [stderr] --> src/chunk.rs:62:41 [INFO] [stderr] | [INFO] [stderr] 62 | pub fn create_buffer(&mut self, color: &[u8; 4]) -> Option { [INFO] [stderr] | ^^^^^^^^ help: consider passing by value instead: `[u8; 4]` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::trivially_copy_pass_by_ref)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#trivially_copy_pass_by_ref [INFO] [stderr] [INFO] [stderr] warning: you should consider deriving a `Default` implementation for `chunk::FormatChunk` [INFO] [stderr] --> src/chunk.rs:81:2 [INFO] [stderr] | [INFO] [stderr] 81 | pub fn new() -> Self { [INFO] [stderr] | _____^ [INFO] [stderr] 82 | | Self { [INFO] [stderr] 83 | | font_size: 10, [INFO] [stderr] 84 | | line_height: 1.0, [INFO] [stderr] ... | [INFO] [stderr] 88 | | } [INFO] [stderr] 89 | | } [INFO] [stderr] | |_____^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::new_without_default_derive)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default_derive [INFO] [stderr] help: try this [INFO] [stderr] | [INFO] [stderr] 70 | #[derive(Default)] [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: you should consider adding a `Default` implementation for `chunk::FormatBlock` [INFO] [stderr] --> src/chunk.rs:165:2 [INFO] [stderr] | [INFO] [stderr] 165 | pub fn new() -> Self { [INFO] [stderr] | _____^ [INFO] [stderr] 166 | | Self { [INFO] [stderr] 167 | | text_align: TextAlignHorizontal::Left, [INFO] [stderr] 168 | | break_word: false, [INFO] [stderr] ... | [INFO] [stderr] 174 | | } [INFO] [stderr] 175 | | } [INFO] [stderr] | |_____^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::new_without_default)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default [INFO] [stderr] help: try this [INFO] [stderr] | [INFO] [stderr] 163 | impl Default for chunk::FormatBlock { [INFO] [stderr] 164 | fn default() -> Self { [INFO] [stderr] 165 | Self::new() [INFO] [stderr] 166 | } [INFO] [stderr] 167 | } [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: you should consider deriving a `Default` implementation for `chunk::Line<'a>` [INFO] [stderr] --> src/chunk.rs:248:2 [INFO] [stderr] | [INFO] [stderr] 248 | pub fn new() -> Self { [INFO] [stderr] | _____^ [INFO] [stderr] 249 | | Self { [INFO] [stderr] 250 | | width: 0.0, [INFO] [stderr] 251 | | descent: 0.0, [INFO] [stderr] ... | [INFO] [stderr] 256 | | } [INFO] [stderr] 257 | | } [INFO] [stderr] | |_____^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default_derive [INFO] [stderr] help: try this [INFO] [stderr] | [INFO] [stderr] 238 | #[derive(Default)] [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: this argument is passed by reference, but would be more efficient if passed by value [INFO] [stderr] --> src/img_buffer.rs:22:54 [INFO] [stderr] | [INFO] [stderr] 22 | fn blend_pixel (&mut self, x:usize ,y:usize, pixel: &[u8;4], v:f32) { [INFO] [stderr] | ^^^^^^^ help: consider passing by value instead: `[u8;4]` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#trivially_copy_pass_by_ref [INFO] [stderr] [INFO] [stderr] warning: this argument is passed by reference, but would be more efficient if passed by value [INFO] [stderr] --> src/img_buffer.rs:44:51 [INFO] [stderr] | [INFO] [stderr] 44 | fn put_pixel(&mut self, x:usize ,y:usize, pixel: &[u8;4]) { [INFO] [stderr] | ^^^^^^^ help: consider passing by value instead: `[u8;4]` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#trivially_copy_pass_by_ref [INFO] [stderr] [INFO] [stderr] warning: this argument is passed by reference, but would be more efficient if passed by value [INFO] [stderr] --> src/img_buffer.rs:52:29 [INFO] [stderr] | [INFO] [stderr] 52 | fn clear(&mut self, color: &[u8;4]); [INFO] [stderr] | ^^^^^^^ help: consider passing by value instead: `[u8;4]` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#trivially_copy_pass_by_ref [INFO] [stderr] [INFO] [stderr] error: use of `#[inline]` on trait method `get_pixel_mut` which has no body [INFO] [stderr] --> src/img_buffer.rs:18:2 [INFO] [stderr] | [INFO] [stderr] 18 | #[inline] fn get_pixel_mut(&mut self, x: usize, y: usize) -> &mut [u8]; [INFO] [stderr] | ^^^^^^^^^- [INFO] [stderr] | | [INFO] [stderr] | help: remove [INFO] [stderr] | [INFO] [stderr] = note: #[deny(clippy::inline_fn_without_body)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#inline_fn_without_body [INFO] [stderr] [INFO] [stderr] error: use of `#[inline]` on trait method `width` which has no body [INFO] [stderr] --> src/img_buffer.rs:19:2 [INFO] [stderr] | [INFO] [stderr] 19 | #[inline] fn width(&self) -> usize; [INFO] [stderr] | ^^^^^^^^^- [INFO] [stderr] | | [INFO] [stderr] | help: remove [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#inline_fn_without_body [INFO] [stderr] [INFO] [stderr] error: use of `#[inline]` on trait method `height` which has no body [INFO] [stderr] --> src/img_buffer.rs:20:2 [INFO] [stderr] | [INFO] [stderr] 20 | #[inline] fn height(&self) -> usize; [INFO] [stderr] | ^^^^^^^^^- [INFO] [stderr] | | [INFO] [stderr] | help: remove [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#inline_fn_without_body [INFO] [stderr] [INFO] [stderr] warning: casting u8 to f32 may become silently lossy if types change [INFO] [stderr] --> src/img_buffer.rs:30:4 [INFO] [stderr] | [INFO] [stderr] 30 | pixel[0] as f32 / 255.0, [INFO] [stderr] | ^^^^^^^^^^^^^^^ help: try: `f32::from(pixel[0])` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::cast_lossless)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: casting u8 to f32 may become silently lossy if types change [INFO] [stderr] --> src/img_buffer.rs:31:4 [INFO] [stderr] | [INFO] [stderr] 31 | pixel[1] as f32 / 255.0, [INFO] [stderr] | ^^^^^^^^^^^^^^^ help: try: `f32::from(pixel[1])` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: casting u8 to f32 may become silently lossy if types change [INFO] [stderr] --> src/img_buffer.rs:32:4 [INFO] [stderr] | [INFO] [stderr] 32 | pixel[2] as f32 / 255.0, [INFO] [stderr] | ^^^^^^^^^^^^^^^ help: try: `f32::from(pixel[2])` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: casting u8 to f32 may become silently lossy if types change [INFO] [stderr] --> src/img_buffer.rs:33:4 [INFO] [stderr] | [INFO] [stderr] 33 | pixel[3] as f32 / 255.0, [INFO] [stderr] | ^^^^^^^^^^^^^^^ help: try: `f32::from(pixel[3])` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: casting u8 to f32 may become silently lossy if types change [INFO] [stderr] --> src/img_buffer.rs:36:17 [INFO] [stderr] | [INFO] [stderr] 36 | let o_alpha = o_pixel[3] as f32 / 255.0; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: try: `f32::from(o_pixel[3])` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: casting u8 to f32 may become silently lossy if types change [INFO] [stderr] --> src/img_buffer.rs:38:20 [INFO] [stderr] | [INFO] [stderr] 38 | o_pixel[0] = ((((o_pixel[0] as f32 / 255.0) * (1.0-alpha)) + (f_pixel[0]*alpha)) * 255.0) as u8; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: try: `f32::from(o_pixel[0])` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: casting u8 to f32 may become silently lossy if types change [INFO] [stderr] --> src/img_buffer.rs:39:20 [INFO] [stderr] | [INFO] [stderr] 39 | o_pixel[1] = ((((o_pixel[1] as f32 / 255.0) * (1.0-alpha)) + (f_pixel[1]*alpha)) * 255.0) as u8; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: try: `f32::from(o_pixel[1])` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: casting u8 to f32 may become silently lossy if types change [INFO] [stderr] --> src/img_buffer.rs:40:20 [INFO] [stderr] | [INFO] [stderr] 40 | o_pixel[2] = ((((o_pixel[2] as f32 / 255.0) * (1.0-alpha)) + (f_pixel[2]*alpha)) * 255.0) as u8; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: try: `f32::from(o_pixel[2])` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_lossless [INFO] [stderr] [INFO] [stderr] warning: this argument is passed by reference, but would be more efficient if passed by value [INFO] [stderr] --> src/img_buffer.rs:56:46 [INFO] [stderr] | [INFO] [stderr] 56 | pub fn new(width:usize, height:usize, fill: &[u8; 4]) -> Self { [INFO] [stderr] | ^^^^^^^^ help: consider passing by value instead: `[u8; 4]` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#trivially_copy_pass_by_ref [INFO] [stderr] [INFO] [stderr] warning: you should consider deriving a `Default` implementation for `rusttype_renderer::TextRenderer` [INFO] [stderr] --> src/rusttype_renderer.rs:16:2 [INFO] [stderr] | [INFO] [stderr] 16 | pub fn new () -> Self { [INFO] [stderr] | _____^ [INFO] [stderr] 17 | | Self {} [INFO] [stderr] 18 | | } [INFO] [stderr] | |_____^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default_derive [INFO] [stderr] help: try this [INFO] [stderr] | [INFO] [stderr] 13 | #[derive(Default)] [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: this if-then-else expression returns a bool literal [INFO] [stderr] --> src/rusttype_renderer.rs:257:2 [INFO] [stderr] | [INFO] [stderr] 257 | if [INFO] [stderr] | _____^ [INFO] [stderr] 258 | | rect.max.x < 0 || [INFO] [stderr] 259 | | rect.max.x > w || [INFO] [stderr] 260 | | rect.max.y < 0 || [INFO] [stderr] 261 | | rect.max.y > h [INFO] [stderr] 262 | | {false} else {true} [INFO] [stderr] | |___________________________^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::needless_bool)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_bool [INFO] [stderr] help: you can reduce it to [INFO] [stderr] | [INFO] [stderr] 257 | !(rect.max.x < 0 || [INFO] [stderr] 258 | rect.max.x > w || [INFO] [stderr] 259 | rect.max.y < 0 || [INFO] [stderr] 260 | rect.max.y > h) [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: called `is_some()` after searching an `Iterator` with find. This is more succinctly expressed by calling `any()`. [INFO] [stderr] --> src/rusttype_renderer.rs:291:2 [INFO] [stderr] | [INFO] [stderr] 291 | LINE_BREAK [INFO] [stderr] | _____^ [INFO] [stderr] 292 | | .iter() [INFO] [stderr] 293 | | .find(|e| **e == c) [INFO] [stderr] 294 | | .is_some() [INFO] [stderr] | |__________________^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::search_is_some)] on by default [INFO] [stderr] = note: replace `find(|e| **e == c).is_some()` with `any(|e| **e == c)` [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#search_is_some [INFO] [stderr] [INFO] [stderr] warning: called `is_some()` after searching an `Iterator` with find. This is more succinctly expressed by calling `any()`. [INFO] [stderr] --> src/rusttype_renderer.rs:298:2 [INFO] [stderr] | [INFO] [stderr] 298 | CAN_LINE_BREAK [INFO] [stderr] | _____^ [INFO] [stderr] 299 | | .iter() [INFO] [stderr] 300 | | .find(|e| **e == c) [INFO] [stderr] 301 | | .is_some() [INFO] [stderr] | |__________________^ [INFO] [stderr] | [INFO] [stderr] = note: replace `find(|e| **e == c).is_some()` with `any(|e| **e == c)` [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#search_is_some [INFO] [stderr] [INFO] [stderr] warning: you should consider adding a `Default` implementation for `typer::Typer` [INFO] [stderr] --> src/typer.rs:13:2 [INFO] [stderr] | [INFO] [stderr] 13 | pub fn new() -> Self { [INFO] [stderr] | _____^ [INFO] [stderr] 14 | | Self { [INFO] [stderr] 15 | | block: FormatBlock::new(), [INFO] [stderr] 16 | | } [INFO] [stderr] 17 | | } [INFO] [stderr] | |_____^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default [INFO] [stderr] help: try this [INFO] [stderr] | [INFO] [stderr] 11 | impl Default for typer::Typer { [INFO] [stderr] 12 | fn default() -> Self { [INFO] [stderr] 13 | Self::new() [INFO] [stderr] 14 | } [INFO] [stderr] 15 | } [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: explicit lifetimes given in parameter types where they could be elided (or replaced with `'_` if needed by type declaration) [INFO] [stderr] --> src/typer.rs:28:3 [INFO] [stderr] | [INFO] [stderr] 28 | fn get_chunk<'a>(chunk: &'a mut FormatChunk, level:usize) -> Option<&'a mut FormatChunk> { [INFO] [stderr] | _________^ [INFO] [stderr] 29 | | if level == 0 { [INFO] [stderr] 30 | | return Some(chunk); [INFO] [stderr] 31 | | } [INFO] [stderr] ... | [INFO] [stderr] 41 | | None [INFO] [stderr] 42 | | } [INFO] [stderr] | |_________^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::needless_lifetimes)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_lifetimes [INFO] [stderr] [INFO] [stderr] error: aborting due to 3 previous errors [INFO] [stderr] [INFO] [stderr] error: Could not compile `typer`. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] error: build failed [INFO] running `"docker" "inspect" "0be32b278860b6e2e3a3393b62d25b7c27a851b6b38cd94d20944ae3219e1473"` [INFO] running `"docker" "rm" "-f" "0be32b278860b6e2e3a3393b62d25b7c27a851b6b38cd94d20944ae3219e1473"` [INFO] [stdout] 0be32b278860b6e2e3a3393b62d25b7c27a851b6b38cd94d20944ae3219e1473