[INFO] cloning repository https://github.com/TioT2/weird [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/TioT2/weird" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTioT2%2Fweird", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTioT2%2Fweird'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 15d846fbf6c0fc9fd93c07c269aec5554d478ec5 [INFO] building TioT2/weird against try#d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6 for pr-146237-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTioT2%2Fweird" "/workspace/builds/worker-4-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/TioT2/weird [INFO] finished tweaking git repo https://github.com/TioT2/weird [INFO] tweaked toml for git repo https://github.com/TioT2/weird written to /workspace/builds/worker-4-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/TioT2/weird on toolchain d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/TioT2/weird 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" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 911399fb7df0753adf6dd6ba058133f779eb85ed66ca43c804591e76983075c3 [INFO] running `Command { std: "docker" "start" "-a" "911399fb7df0753adf6dd6ba058133f779eb85ed66ca43c804591e76983075c3", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "911399fb7df0753adf6dd6ba058133f779eb85ed66ca43c804591e76983075c3", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "911399fb7df0753adf6dd6ba058133f779eb85ed66ca43c804591e76983075c3", kill_on_drop: false }` [INFO] [stdout] 911399fb7df0753adf6dd6ba058133f779eb85ed66ca43c804591e76983075c3 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=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" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 6751501a72158cbd2ed19271096aa1984c09929dc03a0b970812c3d550da739b [INFO] running `Command { std: "docker" "start" "-a" "6751501a72158cbd2ed19271096aa1984c09929dc03a0b970812c3d550da739b", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.78 [INFO] [stderr] Compiling bitflags v2.4.2 [INFO] [stderr] Compiling rustix v0.38.31 [INFO] [stderr] Compiling linux-raw-sys v0.4.13 [INFO] [stderr] Compiling log v0.4.21 [INFO] [stderr] Compiling cc v1.0.90 [INFO] [stderr] Compiling memchr v2.7.1 [INFO] [stderr] Compiling smallvec v1.13.1 [INFO] [stderr] Compiling tracing-core v0.1.32 [INFO] [stderr] Compiling libloading v0.8.3 [INFO] [stderr] Compiling wayland-sys v0.31.1 [INFO] [stderr] Compiling thiserror v1.0.57 [INFO] [stderr] Compiling drm-sys v0.6.1 [INFO] [stderr] Compiling as-raw-xcb-connection v1.0.1 [INFO] [stderr] Compiling memmap2 v0.9.4 [INFO] [stderr] Compiling xcursor v0.3.5 [INFO] [stderr] Compiling xkeysym v0.2.0 [INFO] [stderr] Compiling smithay-client-toolkit v0.18.1 [INFO] [stderr] Compiling drm-fourcc v2.2.0 [INFO] [stderr] Compiling ttf-parser v0.20.0 [INFO] [stderr] Compiling dlib v0.5.2 [INFO] [stderr] Compiling arrayref v0.3.7 [INFO] [stderr] Compiling linux-raw-sys v0.6.4 [INFO] [stderr] Compiling cursor-icon v1.1.0 [INFO] [stderr] Compiling ahash v0.8.11 [INFO] [stderr] Compiling x11rb-protocol v0.13.0 [INFO] [stderr] Compiling arrayvec v0.7.4 [INFO] [stderr] Compiling cfg_aliases v0.2.0 [INFO] [stderr] Compiling winit v0.29.14 [INFO] [stderr] Compiling softbuffer v0.4.1 [INFO] [stderr] Compiling getrandom v0.2.12 [INFO] [stderr] Compiling zerocopy v0.7.32 [INFO] [stderr] Compiling tracing v0.1.40 [INFO] [stderr] Compiling raw-window-handle v0.6.0 [INFO] [stderr] Compiling xkbcommon-dl v0.4.2 [INFO] [stderr] Compiling x11-dl v2.21.0 [INFO] [stderr] Compiling smol_str v0.2.1 [INFO] [stderr] Compiling quote v1.0.35 [INFO] [stderr] Compiling quick-xml v0.31.0 [INFO] [stderr] Compiling syn v2.0.52 [INFO] [stderr] Compiling owned_ttf_parser v0.20.0 [INFO] [stderr] Compiling wayland-backend v0.3.3 [INFO] [stderr] Compiling wayland-scanner v0.31.1 [INFO] [stderr] Compiling ab_glyph v0.2.23 [INFO] [stderr] Compiling bytemuck_derive v1.6.0 [INFO] [stderr] Compiling thiserror-impl v1.0.57 [INFO] [stderr] Compiling ctor v0.2.7 [INFO] [stderr] Compiling tiny-xlib v0.2.2 [INFO] [stderr] Compiling bytemuck v1.14.3 [INFO] [stderr] Compiling tiny-skia-path v0.11.4 [INFO] [stderr] Compiling tiny-skia v0.11.4 [INFO] [stderr] Compiling polling v3.5.0 [INFO] [stderr] Compiling drm-ffi v0.7.1 [INFO] [stderr] Compiling drm v0.11.1 [INFO] [stderr] Compiling calloop v0.12.4 [INFO] [stderr] Compiling wayland-client v0.31.2 [INFO] [stderr] Compiling wayland-csd-frame v0.3.0 [INFO] [stderr] Compiling wayland-protocols v0.31.2 [INFO] [stderr] Compiling wayland-cursor v0.31.1 [INFO] [stderr] Compiling calloop-wayland-source v0.2.0 [INFO] [stderr] Compiling x11rb v0.13.0 [INFO] [stderr] Compiling wayland-protocols-wlr v0.2.0 [INFO] [stderr] Compiling wayland-protocols-plasma v0.2.0 [INFO] [stderr] Compiling sctk-adwaita v0.8.1 [INFO] [stderr] Compiling weird v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/map.rs:93:96 [INFO] [stdout] | [INFO] [stdout] 93 | ... << (unsafe { std::mem::transmute::(line.direction.x * point.y - line.direction.y * point.x - line.d_cross_p0) } >> 31))); [INFO] [stdout] | -------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `f32::to_bits` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unnecessary_transmutes)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:60:22 [INFO] [stdout] | [INFO] [stdout] 60 | let x0 = std::mem::transmute::(x0.clamp(0, self.width as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:61:22 [INFO] [stdout] | [INFO] [stdout] 61 | let y0 = std::mem::transmute::(y0.clamp(0, self.height as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:63:22 [INFO] [stdout] | [INFO] [stdout] 63 | let x1 = std::mem::transmute::(x1.clamp(0, self.width as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:64:22 [INFO] [stdout] | [INFO] [stdout] 64 | let y1 = std::mem::transmute::(y1.clamp(0, self.height as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:150:21 [INFO] [stdout] | [INFO] [stdout] 150 | std::mem::transmute::(x0), [INFO] [stdout] | -----------------------------------^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:151:21 [INFO] [stdout] | [INFO] [stdout] 151 | std::mem::transmute::(y0), [INFO] [stdout] | -----------------------------------^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:152:21 [INFO] [stdout] | [INFO] [stdout] 152 | std::mem::transmute::(x1), [INFO] [stdout] | -----------------------------------^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:153:21 [INFO] [stdout] | [INFO] [stdout] 153 | std::mem::transmute::(y1), [INFO] [stdout] | -----------------------------------^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:193:22 [INFO] [stdout] | [INFO] [stdout] 193 | let ie = std::mem::transmute::(delta_y) << 1; [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:194:41 [INFO] [stdout] | [INFO] [stdout] 194 | let mut f = ie.wrapping_sub(std::mem::transmute::(delta_x)); [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:195:39 [INFO] [stdout] | [INFO] [stdout] 195 | let ine = ie.wrapping_sub(std::mem::transmute::(delta_x) << 1); [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:210:22 [INFO] [stdout] | [INFO] [stdout] 210 | let ie = std::mem::transmute::(delta_x) << 1; [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:211:41 [INFO] [stdout] | [INFO] [stdout] 211 | let mut f = ie.wrapping_sub(std::mem::transmute::(delta_y)); [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:212:39 [INFO] [stdout] | [INFO] [stdout] 212 | let ine = ie.wrapping_sub(std::mem::transmute::(delta_y) << 1); [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/main.rs:95:26 [INFO] [stdout] | [INFO] [stdout] 95 | let x0 = std::mem::transmute::(to_screen_x(p0).clamp(screen_x_begin as isize, screen_x_end as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/main.rs:96:26 [INFO] [stdout] | [INFO] [stdout] 96 | let x1 = std::mem::transmute::(to_screen_x(p1).clamp(screen_x_begin as isize, screen_x_end as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:168:29 [INFO] [stdout] | [INFO] [stdout] 168 | value: unsafe { std::mem::transmute::(bits) }, [INFO] [stdout] | -------------------------------^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `u32::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:175:18 [INFO] [stdout] | [INFO] [stdout] 175 | unsafe { std::mem::transmute::(self.value) } [INFO] [stdout] | -------------------------------^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `i32::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:182:29 [INFO] [stdout] | [INFO] [stdout] 182 | let exp = (unsafe { std::mem::transmute::(value) } >> 23) & 0xFF; [INFO] [stdout] | -------------------------------^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `f32::to_bits` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:185:29 [INFO] [stdout] | [INFO] [stdout] 185 | value: unsafe { std::mem::transmute::(unwrap_or(if exp < 134 { [INFO] [stdout] | ^------------------------------ [INFO] [stdout] | | [INFO] [stdout] | _____________________________help: replace this with: `u32::cast_signed` [INFO] [stdout] | | [INFO] [stdout] 186 | | ((std::mem::transmute::(value) & 0x7FFFFF) | 0x800000).checked_shr(134 - exp) [INFO] [stdout] 187 | | } else { [INFO] [stdout] 188 | | ((std::mem::transmute::(value) & 0x7FFFFF) | 0x800000).checked_shl(exp - 134) [INFO] [stdout] 189 | | }, 0) ^ std::mem::transmute::(std::mem::transmute::(value) >> 31)) } [INFO] [stdout] | |__________________________________________________________________________________________________^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:186:19 [INFO] [stdout] | [INFO] [stdout] 186 | ((std::mem::transmute::(value) & 0x7FFFFF) | 0x800000).checked_shr(134 - exp) [INFO] [stdout] | -------------------------------^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `f32::to_bits` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:188:19 [INFO] [stdout] | [INFO] [stdout] 188 | ((std::mem::transmute::(value) & 0x7FFFFF) | 0x800000).checked_shl(exp - 134) [INFO] [stdout] | -------------------------------^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `f32::to_bits` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:189:21 [INFO] [stdout] | [INFO] [stdout] 189 | }, 0) ^ std::mem::transmute::(std::mem::transmute::(value) >> 31)) } [INFO] [stdout] | -------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `i32::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:189:53 [INFO] [stdout] | [INFO] [stdout] 189 | }, 0) ^ std::mem::transmute::(std::mem::transmute::(value) >> 31)) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] help: replace this with [INFO] [stdout] | [INFO] [stdout] 189 - }, 0) ^ std::mem::transmute::(std::mem::transmute::(value) >> 31)) } [INFO] [stdout] 189 + }, 0) ^ std::mem::transmute::(f32::to_bits(value).cast_signed() >> 31)) } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:197:28 [INFO] [stdout] | [INFO] [stdout] 197 | let unsigned = std::mem::transmute::(self.value ^ (self.value >> 31)); [INFO] [stdout] | -------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `i32::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:200:13 [INFO] [stdout] | [INFO] [stdout] 200 | ... std::mem::transmute::((std::mem::transmute::(self.value) & 0x80000000) | ((142 - lz) << 23) | (unwrap_or(unsigned.checked_shl(lz + 1), 0) >> 9)) [INFO] [stdout] | -------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `f32::from_bits` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:200:46 [INFO] [stdout] | [INFO] [stdout] 200 | ... std::mem::transmute::((std::mem::transmute::(self.value) & 0x80000000) | ((142 - lz) << 23) | (unwrap_or(unsign... [INFO] [stdout] | -------------------------------^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `i32::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:264:35 [INFO] [stdout] | [INFO] [stdout] 264 | let mut r: u32 = unsafe { std::mem::transmute::(self.value) }; [INFO] [stdout] | -------------------------------^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `i32::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:439:39 [INFO] [stdout] | [INFO] [stdout] 439 | let fixed_xor_mask = unsafe { std::mem::transmute::((self.value as u32) << 16) >> 31 }; [INFO] [stdout] | -------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `u32::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 57.15s [INFO] running `Command { std: "docker" "inspect" "6751501a72158cbd2ed19271096aa1984c09929dc03a0b970812c3d550da739b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6751501a72158cbd2ed19271096aa1984c09929dc03a0b970812c3d550da739b", kill_on_drop: false }` [INFO] [stdout] 6751501a72158cbd2ed19271096aa1984c09929dc03a0b970812c3d550da739b [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=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" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 8808515f5915e2efe386815d4354078a5164508c5a3e31e0fa22c7affb2d597e [INFO] running `Command { std: "docker" "start" "-a" "8808515f5915e2efe386815d4354078a5164508c5a3e31e0fa22c7affb2d597e", kill_on_drop: false }` [INFO] [stderr] Compiling weird v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/main.rs:95:26 [INFO] [stdout] | [INFO] [stdout] 95 | let x0 = std::mem::transmute::(to_screen_x(p0).clamp(screen_x_begin as isize, screen_x_end as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unnecessary_transmutes)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/main.rs:96:26 [INFO] [stdout] | [INFO] [stdout] 96 | let x1 = std::mem::transmute::(to_screen_x(p1).clamp(screen_x_begin as isize, screen_x_end as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/map.rs:93:96 [INFO] [stdout] | [INFO] [stdout] 93 | ... << (unsafe { std::mem::transmute::(line.direction.x * point.y - line.direction.y * point.x - line.d_cross_p0) } >> 31))); [INFO] [stdout] | -------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `f32::to_bits` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:168:29 [INFO] [stdout] | [INFO] [stdout] 168 | value: unsafe { std::mem::transmute::(bits) }, [INFO] [stdout] | -------------------------------^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `u32::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:175:18 [INFO] [stdout] | [INFO] [stdout] 175 | unsafe { std::mem::transmute::(self.value) } [INFO] [stdout] | -------------------------------^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `i32::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:182:29 [INFO] [stdout] | [INFO] [stdout] 182 | let exp = (unsafe { std::mem::transmute::(value) } >> 23) & 0xFF; [INFO] [stdout] | -------------------------------^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `f32::to_bits` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:185:29 [INFO] [stdout] | [INFO] [stdout] 185 | value: unsafe { std::mem::transmute::(unwrap_or(if exp < 134 { [INFO] [stdout] | ^------------------------------ [INFO] [stdout] | | [INFO] [stdout] | _____________________________help: replace this with: `u32::cast_signed` [INFO] [stdout] | | [INFO] [stdout] 186 | | ((std::mem::transmute::(value) & 0x7FFFFF) | 0x800000).checked_shr(134 - exp) [INFO] [stdout] 187 | | } else { [INFO] [stdout] 188 | | ((std::mem::transmute::(value) & 0x7FFFFF) | 0x800000).checked_shl(exp - 134) [INFO] [stdout] 189 | | }, 0) ^ std::mem::transmute::(std::mem::transmute::(value) >> 31)) } [INFO] [stdout] | |__________________________________________________________________________________________________^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:186:19 [INFO] [stdout] | [INFO] [stdout] 186 | ((std::mem::transmute::(value) & 0x7FFFFF) | 0x800000).checked_shr(134 - exp) [INFO] [stdout] | -------------------------------^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `f32::to_bits` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:188:19 [INFO] [stdout] | [INFO] [stdout] 188 | ((std::mem::transmute::(value) & 0x7FFFFF) | 0x800000).checked_shl(exp - 134) [INFO] [stdout] | -------------------------------^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `f32::to_bits` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:189:21 [INFO] [stdout] | [INFO] [stdout] 189 | }, 0) ^ std::mem::transmute::(std::mem::transmute::(value) >> 31)) } [INFO] [stdout] | -------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `i32::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:189:53 [INFO] [stdout] | [INFO] [stdout] 189 | }, 0) ^ std::mem::transmute::(std::mem::transmute::(value) >> 31)) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] help: replace this with [INFO] [stdout] | [INFO] [stdout] 189 - }, 0) ^ std::mem::transmute::(std::mem::transmute::(value) >> 31)) } [INFO] [stdout] 189 + }, 0) ^ std::mem::transmute::(f32::to_bits(value).cast_signed() >> 31)) } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:197:28 [INFO] [stdout] | [INFO] [stdout] 197 | let unsigned = std::mem::transmute::(self.value ^ (self.value >> 31)); [INFO] [stdout] | -------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `i32::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:200:13 [INFO] [stdout] | [INFO] [stdout] 200 | ... std::mem::transmute::((std::mem::transmute::(self.value) & 0x80000000) | ((142 - lz) << 23) | (unwrap_or(unsigned.checked_shl(lz + 1), 0) >> 9)) [INFO] [stdout] | -------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `f32::from_bits` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:200:46 [INFO] [stdout] | [INFO] [stdout] 200 | ... std::mem::transmute::((std::mem::transmute::(self.value) & 0x80000000) | ((142 - lz) << 23) | (unwrap_or(unsign... [INFO] [stdout] | -------------------------------^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `i32::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:60:22 [INFO] [stdout] | [INFO] [stdout] 60 | let x0 = std::mem::transmute::(x0.clamp(0, self.width as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:61:22 [INFO] [stdout] | [INFO] [stdout] 61 | let y0 = std::mem::transmute::(y0.clamp(0, self.height as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:63:22 [INFO] [stdout] | [INFO] [stdout] 63 | let x1 = std::mem::transmute::(x1.clamp(0, self.width as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:64:22 [INFO] [stdout] | [INFO] [stdout] 64 | let y1 = std::mem::transmute::(y1.clamp(0, self.height as isize)); [INFO] [stdout] | -----------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:150:21 [INFO] [stdout] | [INFO] [stdout] 150 | std::mem::transmute::(x0), [INFO] [stdout] | -----------------------------------^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:151:21 [INFO] [stdout] | [INFO] [stdout] 151 | std::mem::transmute::(y0), [INFO] [stdout] | -----------------------------------^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:152:21 [INFO] [stdout] | [INFO] [stdout] 152 | std::mem::transmute::(x1), [INFO] [stdout] | -----------------------------------^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:153:21 [INFO] [stdout] | [INFO] [stdout] 153 | std::mem::transmute::(y1), [INFO] [stdout] | -----------------------------------^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `isize::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:193:22 [INFO] [stdout] | [INFO] [stdout] 193 | let ie = std::mem::transmute::(delta_y) << 1; [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:194:41 [INFO] [stdout] | [INFO] [stdout] 194 | let mut f = ie.wrapping_sub(std::mem::transmute::(delta_x)); [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:195:39 [INFO] [stdout] | [INFO] [stdout] 195 | let ine = ie.wrapping_sub(std::mem::transmute::(delta_x) << 1); [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:210:22 [INFO] [stdout] | [INFO] [stdout] 210 | let ie = std::mem::transmute::(delta_x) << 1; [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:211:41 [INFO] [stdout] | [INFO] [stdout] 211 | let mut f = ie.wrapping_sub(std::mem::transmute::(delta_y)); [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:264:35 [INFO] [stdout] | [INFO] [stdout] 264 | let mut r: u32 = unsafe { std::mem::transmute::(self.value) }; [INFO] [stdout] | -------------------------------^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `i32::cast_unsigned` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/surface.rs:212:39 [INFO] [stdout] | [INFO] [stdout] 212 | let ine = ie.wrapping_sub(std::mem::transmute::(delta_y) << 1); [INFO] [stdout] | -----------------------------------^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `usize::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary transmute [INFO] [stdout] --> src/util/fixed/mod.rs:439:39 [INFO] [stdout] | [INFO] [stdout] 439 | let fixed_xor_mask = unsafe { std::mem::transmute::((self.value as u32) << 16) >> 31 }; [INFO] [stdout] | -------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: replace this with: `u32::cast_signed` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 2.11s [INFO] running `Command { std: "docker" "inspect" "8808515f5915e2efe386815d4354078a5164508c5a3e31e0fa22c7affb2d597e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8808515f5915e2efe386815d4354078a5164508c5a3e31e0fa22c7affb2d597e", kill_on_drop: false }` [INFO] [stdout] 8808515f5915e2efe386815d4354078a5164508c5a3e31e0fa22c7affb2d597e