[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::<f32, u32>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<usize, isize>(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::<usize, isize>(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::<usize, isize>(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::<usize, isize>(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::<usize, isize>(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::<usize, isize>(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::<isize, usize>(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::<isize, usize>(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::<u32, i32>(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::<i32, u32>(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::<f32, u32>(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::<u32, i32>(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::<f32, u32>(value) & 0x7FFFFF) | 0x800000).checked_shr(134 - exp)
[INFO] [stdout] 187 | |             } else {
[INFO] [stdout] 188 | |                 ((std::mem::transmute::<f32, u32>(value) & 0x7FFFFF) | 0x800000).checked_shl(exp - 134)
[INFO] [stdout] 189 | |             }, 0) ^ std::mem::transmute::<i32, u32>(std::mem::transmute::<f32, i32>(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::<f32, u32>(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::<f32, u32>(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::<i32, u32>(std::mem::transmute::<f32, i32>(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::<i32, u32>(std::mem::transmute::<f32, i32>(value) >> 31)) }
[INFO] [stdout]     |                                                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: replace this with
[INFO] [stdout]     |
[INFO] [stdout] 189 -             }, 0) ^ std::mem::transmute::<i32, u32>(std::mem::transmute::<f32, i32>(value) >> 31)) }
[INFO] [stdout] 189 +             }, 0) ^ std::mem::transmute::<i32, u32>(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::<i32, u32>(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::<u32, f32>((std::mem::transmute::<i32, u32>(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::<u32, f32>((std::mem::transmute::<i32, u32>(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::<i32, u32>(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::<u32, i32>((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::<isize, usize>(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::<isize, usize>(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::<f32, u32>(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::<u32, i32>(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::<i32, u32>(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::<f32, u32>(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::<u32, i32>(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::<f32, u32>(value) & 0x7FFFFF) | 0x800000).checked_shr(134 - exp)
[INFO] [stdout] 187 | |             } else {
[INFO] [stdout] 188 | |                 ((std::mem::transmute::<f32, u32>(value) & 0x7FFFFF) | 0x800000).checked_shl(exp - 134)
[INFO] [stdout] 189 | |             }, 0) ^ std::mem::transmute::<i32, u32>(std::mem::transmute::<f32, i32>(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::<f32, u32>(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::<f32, u32>(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::<i32, u32>(std::mem::transmute::<f32, i32>(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::<i32, u32>(std::mem::transmute::<f32, i32>(value) >> 31)) }
[INFO] [stdout]     |                                                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: replace this with
[INFO] [stdout]     |
[INFO] [stdout] 189 -             }, 0) ^ std::mem::transmute::<i32, u32>(std::mem::transmute::<f32, i32>(value) >> 31)) }
[INFO] [stdout] 189 +             }, 0) ^ std::mem::transmute::<i32, u32>(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::<i32, u32>(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::<u32, f32>((std::mem::transmute::<i32, u32>(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::<u32, f32>((std::mem::transmute::<i32, u32>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<isize, usize>(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::<usize, isize>(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::<usize, isize>(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::<usize, isize>(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::<usize, isize>(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::<usize, isize>(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::<i32, u32>(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::<usize, isize>(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::<u32, i32>((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
