[INFO] fetching crate webgl-rendering-context 0.1.0... [INFO] testing webgl-rendering-context-0.1.0 against master#350d0ef0ec0493e6d21cfb265cb8211a0e74d766 for pr-145330-1 [INFO] extracting crate webgl-rendering-context 0.1.0 into /workspace/builds/worker-2-tc1/source [INFO] removed /workspace/builds/worker-2-tc1/source/.cargo/config [INFO] started tweaking crates.io crate webgl-rendering-context 0.1.0 [INFO] finished tweaking crates.io crate webgl-rendering-context 0.1.0 [INFO] tweaked toml for crates.io crate webgl-rendering-context 0.1.0 written to /workspace/builds/worker-2-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate webgl-rendering-context 0.1.0 on toolchain 350d0ef0ec0493e6d21cfb265cb8211a0e74d766 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Locking 33 packages to latest compatible versions [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 535254f14d51ce1565253e5bdf5ac4fc303ad73011b6dc965db1586d55219e29 [INFO] running `Command { std: "docker" "start" "-a" "535254f14d51ce1565253e5bdf5ac4fc303ad73011b6dc965db1586d55219e29", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "535254f14d51ce1565253e5bdf5ac4fc303ad73011b6dc965db1586d55219e29", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "535254f14d51ce1565253e5bdf5ac4fc303ad73011b6dc965db1586d55219e29", kill_on_drop: false }` [INFO] [stdout] 535254f14d51ce1565253e5bdf5ac4fc303ad73011b6dc965db1586d55219e29 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] b6869943dc2f334447d903f712c4737aadda213ac8cf6e434864acd0af1cfaf2 [INFO] running `Command { std: "docker" "start" "-a" "b6869943dc2f334447d903f712c4737aadda213ac8cf6e434864acd0af1cfaf2", kill_on_drop: false }` [INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling sha1_smol v1.0.1 [INFO] [stderr] Compiling stdweb-internal-runtime v0.1.5 [INFO] [stderr] Compiling base-x v0.2.11 [INFO] [stderr] Compiling stdweb v0.4.20 [INFO] [stderr] Compiling discard v1.0.4 [INFO] [stderr] Compiling sha1 v0.6.1 [INFO] [stderr] Compiling stdweb-derive v0.5.3 [INFO] [stderr] Compiling stdweb-internal-macros v0.2.9 [INFO] [stderr] Compiling webgl-rendering-context v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] [INFO] [stdout] error: internal compiler error: /rustc-dev/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/compiler/rustc_codegen_ssa/src/mir/intrinsic.rs:123:21: nullary intrinsic type_name must either be in a const block or explicitly opted out because it is inherently a runtime intrinsic [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/stdweb-0.4.20/src/webcore/type_name.rs:5:9 [INFO] [stdout] | [INFO] [stdout] 5 | intrinsics::type_name::< T >() [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] thread 'rustc' (206) panicked at /rustc-dev/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/compiler/rustc_codegen_ssa/src/mir/intrinsic.rs:123:21: [INFO] [stderr] Box [INFO] [stderr] stack backtrace: [INFO] [stderr] 0: 0x73ee88fe5a43 - ::fmt::hff1a9408d012ee89 [INFO] [stderr] 1: 0x73ee89801bfc - core::fmt::write::h2f1fc679f228cc52 [INFO] [stderr] 2: 0x73ee88fd0493 - std::io::Write::write_fmt::haa2231cbd9aebf95 [INFO] [stderr] 3: 0x73ee88fe58a2 - std::sys::backtrace::BacktraceLock::print::h28bfdbcac6d3828b [INFO] [stderr] 4: 0x73ee88fc7c1f - std::panicking::default_hook::{{closure}}::h1f968e3a24b0e3b4 [INFO] [stderr] 5: 0x73ee88fc774b - std::panicking::default_hook::h43da101644971931 [INFO] [stderr] 6: 0x73ee880491b5 - std[619c96d97fe952c]::panicking::update_hook::>::{closure#0} [INFO] [stderr] 7: 0x73ee88fc8313 - std::panicking::panic_with_hook::hb4e916c3e65eccec [INFO] [stderr] 8: 0x73ee88082991 - std[619c96d97fe952c]::panicking::begin_panic::::{closure#0} [INFO] [stderr] 9: 0x73ee88082966 - std[619c96d97fe952c]::sys::backtrace::__rust_end_short_backtrace::::{closure#0}, !> [INFO] [stderr] 10: 0x73ee88080ad6 - std[619c96d97fe952c]::panicking::begin_panic:: [INFO] [stderr] 11: 0x73ee8806d2f1 - ::emit_producing_guarantee [INFO] [stderr] 12: 0x73ee8868367c - ::span_bug:: [INFO] [stderr] 13: 0x73ee88671ae7 - rustc_middle[5ca2e9449305faae]::util::bug::opt_span_bug_fmt::::{closure#0} [INFO] [stderr] 14: 0x73ee88671a4a - rustc_middle[5ca2e9449305faae]::ty::context::tls::with_opt::::{closure#0}, !>::{closure#0} [INFO] [stderr] 15: 0x73ee88671a1b - rustc_middle[5ca2e9449305faae]::ty::context::tls::with_context_opt::::{closure#0}, !>::{closure#0}, !> [INFO] [stderr] 16: 0x73ee86720ee7 - rustc_middle[5ca2e9449305faae]::util::bug::span_bug_fmt:: [INFO] [stderr] 17: 0x73ee8a731c7b - >>::codegen_intrinsic_call [INFO] [stderr] 18: 0x73ee8ac1a388 - rustc_codegen_ssa[d211144dd38b4208]::mir::codegen_mir::> [INFO] [stderr] 19: 0x73ee89976057 - rustc_codegen_llvm[ebd76f8efcabca32]::base::compile_codegen_unit::module_codegen [INFO] [stderr] 20: 0x73ee8a929f14 - ::compile_codegen_unit [INFO] [stderr] 21: 0x73ee8a927e3a - ::codegen_crate [INFO] [stderr] 22: 0x73ee8a9912b0 - ::codegen_and_build_linker [INFO] [stderr] 23: 0x73ee8a98ee3c - rustc_interface[b77c32c3bfe8d9]::passes::create_and_enter_global_ctxt::, rustc_driver_impl[c8262843f73b2e4e]::run_compiler::{closure#0}::{closure#2}>::{closure#2}::{closure#0} [INFO] [stderr] 24: 0x73ee8a9efe03 - rustc_interface[b77c32c3bfe8d9]::interface::run_compiler::<(), rustc_driver_impl[c8262843f73b2e4e]::run_compiler::{closure#0}>::{closure#1} [INFO] [stderr] 25: 0x73ee8a94e7fb - std[619c96d97fe952c]::sys::backtrace::__rust_begin_short_backtrace::::{closure#1}, ()>::{closure#0}, ()>::{closure#0}::{closure#0}, ()> [INFO] [stderr] 26: 0x73ee8a94e4d4 - <::spawn_unchecked_::{closure#1}, ()>::{closure#0}, ()>::{closure#0}::{closure#0}, ()>::{closure#1} as core[b7f6e7468eb674bd]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0} [INFO] [stderr] 27: 0x73ee8a94a28b - std::sys::pal::unix::thread::Thread::new::thread_start::h66ff1bba185a50cf [INFO] [stderr] 28: 0x73ee8428aaa4 - [INFO] [stderr] 29: 0x73ee84317a34 - clone [INFO] [stderr] 30: 0x0 - [INFO] [stderr] [INFO] [stderr] note: using internal features is not supported and expected to cause internal compiler errors when used incorrectly [INFO] [stderr] [INFO] [stderr] warning: the ICE couldn't be written to `/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/stdweb-0.4.20/rustc-ice-2025-10-02T06_57_13-204.txt`: Read-only file system (os error 30) [INFO] [stderr] [INFO] [stderr] note: rustc 1.91.0-nightly (350d0ef0e 2025-08-13) running on x86_64-unknown-linux-gnu [INFO] [stderr] [INFO] [stderr] note: compiler flags: --crate-type lib -C embed-bitcode=no -C debuginfo=2 [INFO] [stderr] [INFO] [stderr] note: some of the compiler flags provided by cargo are hidden [INFO] [stderr] [INFO] [stderr] query stack during panic: [INFO] [stderr] end of query stack [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:730:85 [INFO] [stdout] | [INFO] [stdout] 730 | js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{(offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 730 - js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{(offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] 730 + js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{offset as f64}, @{(size as f64)}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:730:105 [INFO] [stdout] | [INFO] [stdout] 730 | js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{(offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 730 - js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{(offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] 730 + js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{(offset as f64)}, @{size as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:782:59 [INFO] [stdout] | [INFO] [stdout] 782 | js!( @(no_return) @{self}.bufferData(@{target}, @{(size as f64)}, @{usage}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 782 - js!( @(no_return) @{self}.bufferData(@{target}, @{(size as f64)}, @{usage}); ); [INFO] [stdout] 782 + js!( @(no_return) @{self}.bufferData(@{target}, @{size as f64}, @{usage}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:794:62 [INFO] [stdout] | [INFO] [stdout] 794 | js!( @(no_return) @{self}.bufferSubData(@{target}, @{(dst_byte_offset as f64)}, @{src_data}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 794 - js!( @(no_return) @{self}.bufferSubData(@{target}, @{(dst_byte_offset as f64)}, @{src_data}); ); [INFO] [stdout] 794 + js!( @(no_return) @{self}.bufferSubData(@{target}, @{dst_byte_offset as f64}, @{src_data}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:798:62 [INFO] [stdout] | [INFO] [stdout] 798 | ... js!( @(no_return) @{self}.bufferSubData(@{target}, @{(dst_byte_offset as f64)}, @{unsafe { src_data.as_array_buffer_view() }}, @{sr... [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 798 - js!( @(no_return) @{self}.bufferSubData(@{target}, @{(dst_byte_offset as f64)}, @{unsafe { src_data.as_array_buffer_view() }}, @{src_offset}, @{length}); ); [INFO] [stdout] 798 + js!( @(no_return) @{self}.bufferSubData(@{target}, @{dst_byte_offset as f64}, @{unsafe { src_data.as_array_buffer_view() }}, @{src_offset}, @{length}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:842:67 [INFO] [stdout] | [INFO] [stdout] 842 | (js! { return @{self}.clientWaitSync(@{sync}, @{flags}, @{(timeout as f64)}); } ).try_into().unwrap() [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 842 - (js! { return @{self}.clientWaitSync(@{sync}, @{flags}, @{(timeout as f64)}); } ).try_into().unwrap() [INFO] [stdout] 842 + (js! { return @{self}.clientWaitSync(@{sync}, @{flags}, @{timeout as f64}); } ).try_into().unwrap() [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:854:145 [INFO] [stdout] | [INFO] [stdout] 854 | ...lformat}, @{width}, @{height}, @{border}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 854 - js!( @(no_return) @{self}.compressedTexImage2D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{border}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] 854 + js!( @(no_return) @{self}.compressedTexImage2D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{border}, @{image_size}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:866:155 [INFO] [stdout] | [INFO] [stdout] 866 | ...@{width}, @{height}, @{depth}, @{border}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 866 - js!( @(no_return) @{self}.compressedTexImage3D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{depth}, @{border}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] 866 + js!( @(no_return) @{self}.compressedTexImage3D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{depth}, @{border}, @{image_size}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:874:153 [INFO] [stdout] | [INFO] [stdout] 874 | ...yoffset}, @{width}, @{height}, @{format}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 874 - js!( @(no_return) @{self}.compressedTexSubImage2D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{width}, @{height}, @{format}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] 874 + js!( @(no_return) @{self}.compressedTexSubImage2D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{width}, @{height}, @{format}, @{image_size}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:886:175 [INFO] [stdout] | [INFO] [stdout] 886 | ...@{width}, @{height}, @{depth}, @{format}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 886 - js!( @(no_return) @{self}.compressedTexSubImage3D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{zoffset}, @{width}, @{height}, @{depth}, @{format}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] 886 + js!( @(no_return) @{self}.compressedTexSubImage3D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{zoffset}, @{width}, @{height}, @{depth}, @{format}, @{image_size}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:894:88 [INFO] [stdout] | [INFO] [stdout] 894 | ... js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(... [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 894 - js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] 894 + js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{read_offset as f64}, @{(write_offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:894:113 [INFO] [stdout] | [INFO] [stdout] 894 | ... js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(... [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 894 - js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] 894 + js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{write_offset as f64}, @{(size as f64)}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:894:139 [INFO] [stdout] | [INFO] [stdout] 894 | ...rget}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 894 - js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] 894 + js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{size as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1034:79 [INFO] [stdout] | [INFO] [stdout] 1034 | js!( @(no_return) @{self}.drawElements(@{mode}, @{count}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1034 - js!( @(no_return) @{self}.drawElements(@{mode}, @{count}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] 1034 + js!( @(no_return) @{self}.drawElements(@{mode}, @{count}, @{type_}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1038:88 [INFO] [stdout] | [INFO] [stdout] 1038 | js!( @(no_return) @{self}.drawElementsInstanced(@{mode}, @{count}, @{type_}, @{(offset as f64)}, @{instance_count}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1038 - js!( @(no_return) @{self}.drawElementsInstanced(@{mode}, @{count}, @{type_}, @{(offset as f64)}, @{instance_count}); ); [INFO] [stdout] 1038 + js!( @(no_return) @{self}.drawElementsInstanced(@{mode}, @{count}, @{type_}, @{offset as f64}, @{instance_count}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1042:102 [INFO] [stdout] | [INFO] [stdout] 1042 | js!( @(no_return) @{self}.drawRangeElements(@{mode}, @{start}, @{end}, @{count}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1042 - js!( @(no_return) @{self}.drawRangeElements(@{mode}, @{start}, @{end}, @{count}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] 1042 + js!( @(no_return) @{self}.drawRangeElements(@{mode}, @{start}, @{end}, @{count}, @{type_}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1134:65 [INFO] [stdout] | [INFO] [stdout] 1134 | ... js!( @(no_return) @{self}.getBufferSubData(@{target}, @{(src_byte_offset as f64)}, @{unsafe { dst_buffer.as_array_buffer_view() }},... [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1134 - js!( @(no_return) @{self}.getBufferSubData(@{target}, @{(src_byte_offset as f64)}, @{unsafe { dst_buffer.as_array_buffer_view() }}, @{dst_offset}, @{length}); ); [INFO] [stdout] 1134 + js!( @(no_return) @{self}.getBufferSubData(@{target}, @{src_byte_offset as f64}, @{unsafe { dst_buffer.as_array_buffer_view() }}, @{dst_offset}, @{length}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1342:102 [INFO] [stdout] | [INFO] [stdout] 1342 | js!( @(no_return) @{self}.readPixels(@{x}, @{y}, @{width}, @{height}, @{format}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1342 - js!( @(no_return) @{self}.readPixels(@{x}, @{y}, @{width}, @{height}, @{format}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] 1342 + js!( @(no_return) @{self}.readPixels(@{x}, @{y}, @{width}, @{height}, @{format}, @{type_}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1414:141 [INFO] [stdout] | [INFO] [stdout] 1414 | ..., @{width}, @{height}, @{border}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1414 - js!( @(no_return) @{self}.texImage2D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{border}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] 1414 + js!( @(no_return) @{self}.texImage2D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{border}, @{format}, @{type_}, @{pbo_offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1426:151 [INFO] [stdout] | [INFO] [stdout] 1426 | ..., @{height}, @{depth}, @{border}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1426 - js!( @(no_return) @{self}.texImage3D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{depth}, @{border}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] 1426 + js!( @(no_return) @{self}.texImage3D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{depth}, @{border}, @{format}, @{type_}, @{pbo_offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1466:138 [INFO] [stdout] | [INFO] [stdout] 1466 | ... @{yoffset}, @{width}, @{height}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1466 - js!( @(no_return) @{self}.texSubImage2D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{width}, @{height}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] 1466 + js!( @(no_return) @{self}.texSubImage2D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{width}, @{height}, @{format}, @{type_}, @{pbo_offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1478:160 [INFO] [stdout] | [INFO] [stdout] 1478 | ...}, @{width}, @{height}, @{depth}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1478 - js!( @(no_return) @{self}.texSubImage3D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{zoffset}, @{width}, @{height}, @{depth}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] 1478 + js!( @(no_return) @{self}.texSubImage3D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{zoffset}, @{width}, @{height}, @{depth}, @{format}, @{type_}, @{pbo_offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1734:98 [INFO] [stdout] | [INFO] [stdout] 1734 | js!( @(no_return) @{self}.vertexAttribIPointer(@{index}, @{size}, @{type_}, @{stride}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1734 - js!( @(no_return) @{self}.vertexAttribIPointer(@{index}, @{size}, @{type_}, @{stride}, @{(offset as f64)}); ); [INFO] [stdout] 1734 + js!( @(no_return) @{self}.vertexAttribIPointer(@{index}, @{size}, @{type_}, @{stride}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1738:112 [INFO] [stdout] | [INFO] [stdout] 1738 | js!( @(no_return) @{self}.vertexAttribPointer(@{index}, @{size}, @{type_}, @{normalized}, @{stride}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1738 - js!( @(no_return) @{self}.vertexAttribPointer(@{index}, @{size}, @{type_}, @{normalized}, @{stride}, @{(offset as f64)}); ); [INFO] [stdout] 1738 + js!( @(no_return) @{self}.vertexAttribPointer(@{index}, @{size}, @{type_}, @{normalized}, @{stride}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:1746:65 [INFO] [stdout] | [INFO] [stdout] 1746 | js!( @(no_return) @{self}.waitSync(@{sync}, @{flags}, @{(timeout as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 1746 - js!( @(no_return) @{self}.waitSync(@{sync}, @{flags}, @{(timeout as f64)}); ); [INFO] [stdout] 1746 + js!( @(no_return) @{self}.waitSync(@{sync}, @{flags}, @{timeout as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2355:85 [INFO] [stdout] | [INFO] [stdout] 2355 | js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{(offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2355 - js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{(offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] 2355 + js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{offset as f64}, @{(size as f64)}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2355:105 [INFO] [stdout] | [INFO] [stdout] 2355 | js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{(offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2355 - js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{(offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] 2355 + js!( @(no_return) @{self}.bindBufferRange(@{target}, @{index}, @{buffer}, @{(offset as f64)}, @{size as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2407:59 [INFO] [stdout] | [INFO] [stdout] 2407 | js!( @(no_return) @{self}.bufferData(@{target}, @{(size as f64)}, @{usage}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2407 - js!( @(no_return) @{self}.bufferData(@{target}, @{(size as f64)}, @{usage}); ); [INFO] [stdout] 2407 + js!( @(no_return) @{self}.bufferData(@{target}, @{size as f64}, @{usage}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2419:62 [INFO] [stdout] | [INFO] [stdout] 2419 | js!( @(no_return) @{self}.bufferSubData(@{target}, @{(dst_byte_offset as f64)}, @{src_data}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2419 - js!( @(no_return) @{self}.bufferSubData(@{target}, @{(dst_byte_offset as f64)}, @{src_data}); ); [INFO] [stdout] 2419 + js!( @(no_return) @{self}.bufferSubData(@{target}, @{dst_byte_offset as f64}, @{src_data}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2423:62 [INFO] [stdout] | [INFO] [stdout] 2423 | ... js!( @(no_return) @{self}.bufferSubData(@{target}, @{(dst_byte_offset as f64)}, @{unsafe { src_data.as_array_buffer_view() }}, @{sr... [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2423 - js!( @(no_return) @{self}.bufferSubData(@{target}, @{(dst_byte_offset as f64)}, @{unsafe { src_data.as_array_buffer_view() }}, @{src_offset}, @{length}); ); [INFO] [stdout] 2423 + js!( @(no_return) @{self}.bufferSubData(@{target}, @{dst_byte_offset as f64}, @{unsafe { src_data.as_array_buffer_view() }}, @{src_offset}, @{length}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2467:67 [INFO] [stdout] | [INFO] [stdout] 2467 | (js! { return @{self}.clientWaitSync(@{sync}, @{flags}, @{(timeout as f64)}); } ).try_into().unwrap() [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2467 - (js! { return @{self}.clientWaitSync(@{sync}, @{flags}, @{(timeout as f64)}); } ).try_into().unwrap() [INFO] [stdout] 2467 + (js! { return @{self}.clientWaitSync(@{sync}, @{flags}, @{timeout as f64}); } ).try_into().unwrap() [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2479:145 [INFO] [stdout] | [INFO] [stdout] 2479 | ...lformat}, @{width}, @{height}, @{border}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2479 - js!( @(no_return) @{self}.compressedTexImage2D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{border}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] 2479 + js!( @(no_return) @{self}.compressedTexImage2D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{border}, @{image_size}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2491:155 [INFO] [stdout] | [INFO] [stdout] 2491 | ...@{width}, @{height}, @{depth}, @{border}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2491 - js!( @(no_return) @{self}.compressedTexImage3D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{depth}, @{border}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] 2491 + js!( @(no_return) @{self}.compressedTexImage3D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{depth}, @{border}, @{image_size}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2499:153 [INFO] [stdout] | [INFO] [stdout] 2499 | ...yoffset}, @{width}, @{height}, @{format}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2499 - js!( @(no_return) @{self}.compressedTexSubImage2D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{width}, @{height}, @{format}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] 2499 + js!( @(no_return) @{self}.compressedTexSubImage2D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{width}, @{height}, @{format}, @{image_size}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2511:175 [INFO] [stdout] | [INFO] [stdout] 2511 | ...@{width}, @{height}, @{depth}, @{format}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2511 - js!( @(no_return) @{self}.compressedTexSubImage3D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{zoffset}, @{width}, @{height}, @{depth}, @{format}, @{image_size}, @{(offset as f64)}); ); [INFO] [stdout] 2511 + js!( @(no_return) @{self}.compressedTexSubImage3D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{zoffset}, @{width}, @{height}, @{depth}, @{format}, @{image_size}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2519:88 [INFO] [stdout] | [INFO] [stdout] 2519 | ... js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(... [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2519 - js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] 2519 + js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{read_offset as f64}, @{(write_offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2519:113 [INFO] [stdout] | [INFO] [stdout] 2519 | ... js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(... [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2519 - js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] 2519 + js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{write_offset as f64}, @{(size as f64)}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2519:139 [INFO] [stdout] | [INFO] [stdout] 2519 | ...rget}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2519 - js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{(size as f64)}); ); [INFO] [stdout] 2519 + js!( @(no_return) @{self}.copyBufferSubData(@{read_target}, @{write_target}, @{(read_offset as f64)}, @{(write_offset as f64)}, @{size as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2659:79 [INFO] [stdout] | [INFO] [stdout] 2659 | js!( @(no_return) @{self}.drawElements(@{mode}, @{count}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2659 - js!( @(no_return) @{self}.drawElements(@{mode}, @{count}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] 2659 + js!( @(no_return) @{self}.drawElements(@{mode}, @{count}, @{type_}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2663:88 [INFO] [stdout] | [INFO] [stdout] 2663 | js!( @(no_return) @{self}.drawElementsInstanced(@{mode}, @{count}, @{type_}, @{(offset as f64)}, @{instance_count}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2663 - js!( @(no_return) @{self}.drawElementsInstanced(@{mode}, @{count}, @{type_}, @{(offset as f64)}, @{instance_count}); ); [INFO] [stdout] 2663 + js!( @(no_return) @{self}.drawElementsInstanced(@{mode}, @{count}, @{type_}, @{offset as f64}, @{instance_count}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2667:102 [INFO] [stdout] | [INFO] [stdout] 2667 | js!( @(no_return) @{self}.drawRangeElements(@{mode}, @{start}, @{end}, @{count}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2667 - js!( @(no_return) @{self}.drawRangeElements(@{mode}, @{start}, @{end}, @{count}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] 2667 + js!( @(no_return) @{self}.drawRangeElements(@{mode}, @{start}, @{end}, @{count}, @{type_}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2759:65 [INFO] [stdout] | [INFO] [stdout] 2759 | ... js!( @(no_return) @{self}.getBufferSubData(@{target}, @{(src_byte_offset as f64)}, @{unsafe { dst_buffer.as_array_buffer_view() }},... [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2759 - js!( @(no_return) @{self}.getBufferSubData(@{target}, @{(src_byte_offset as f64)}, @{unsafe { dst_buffer.as_array_buffer_view() }}, @{dst_offset}, @{length}); ); [INFO] [stdout] 2759 + js!( @(no_return) @{self}.getBufferSubData(@{target}, @{src_byte_offset as f64}, @{unsafe { dst_buffer.as_array_buffer_view() }}, @{dst_offset}, @{length}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:2967:102 [INFO] [stdout] | [INFO] [stdout] 2967 | js!( @(no_return) @{self}.readPixels(@{x}, @{y}, @{width}, @{height}, @{format}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 2967 - js!( @(no_return) @{self}.readPixels(@{x}, @{y}, @{width}, @{height}, @{format}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] 2967 + js!( @(no_return) @{self}.readPixels(@{x}, @{y}, @{width}, @{height}, @{format}, @{type_}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:3039:141 [INFO] [stdout] | [INFO] [stdout] 3039 | ..., @{width}, @{height}, @{border}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 3039 - js!( @(no_return) @{self}.texImage2D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{border}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] 3039 + js!( @(no_return) @{self}.texImage2D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{border}, @{format}, @{type_}, @{pbo_offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:3051:151 [INFO] [stdout] | [INFO] [stdout] 3051 | ..., @{height}, @{depth}, @{border}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 3051 - js!( @(no_return) @{self}.texImage3D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{depth}, @{border}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] 3051 + js!( @(no_return) @{self}.texImage3D(@{target}, @{level}, @{internalformat}, @{width}, @{height}, @{depth}, @{border}, @{format}, @{type_}, @{pbo_offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:3091:138 [INFO] [stdout] | [INFO] [stdout] 3091 | ... @{yoffset}, @{width}, @{height}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 3091 - js!( @(no_return) @{self}.texSubImage2D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{width}, @{height}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] 3091 + js!( @(no_return) @{self}.texSubImage2D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{width}, @{height}, @{format}, @{type_}, @{pbo_offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:3103:160 [INFO] [stdout] | [INFO] [stdout] 3103 | ...}, @{width}, @{height}, @{depth}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 3103 - js!( @(no_return) @{self}.texSubImage3D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{zoffset}, @{width}, @{height}, @{depth}, @{format}, @{type_}, @{(pbo_offset as f64)}); ); [INFO] [stdout] 3103 + js!( @(no_return) @{self}.texSubImage3D(@{target}, @{level}, @{xoffset}, @{yoffset}, @{zoffset}, @{width}, @{height}, @{depth}, @{format}, @{type_}, @{pbo_offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:3359:98 [INFO] [stdout] | [INFO] [stdout] 3359 | js!( @(no_return) @{self}.vertexAttribIPointer(@{index}, @{size}, @{type_}, @{stride}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 3359 - js!( @(no_return) @{self}.vertexAttribIPointer(@{index}, @{size}, @{type_}, @{stride}, @{(offset as f64)}); ); [INFO] [stdout] 3359 + js!( @(no_return) @{self}.vertexAttribIPointer(@{index}, @{size}, @{type_}, @{stride}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:3363:112 [INFO] [stdout] | [INFO] [stdout] 3363 | js!( @(no_return) @{self}.vertexAttribPointer(@{index}, @{size}, @{type_}, @{normalized}, @{stride}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 3363 - js!( @(no_return) @{self}.vertexAttribPointer(@{index}, @{size}, @{type_}, @{normalized}, @{stride}, @{(offset as f64)}); ); [INFO] [stdout] 3363 + js!( @(no_return) @{self}.vertexAttribPointer(@{index}, @{size}, @{type_}, @{normalized}, @{stride}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:3371:65 [INFO] [stdout] | [INFO] [stdout] 3371 | js!( @(no_return) @{self}.waitSync(@{sync}, @{flags}, @{(timeout as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 3371 - js!( @(no_return) @{self}.waitSync(@{sync}, @{flags}, @{(timeout as f64)}); ); [INFO] [stdout] 3371 + js!( @(no_return) @{self}.waitSync(@{sync}, @{flags}, @{timeout as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:3816:59 [INFO] [stdout] | [INFO] [stdout] 3816 | js!( @(no_return) @{self}.bufferData(@{target}, @{(size as f64)}, @{usage}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 3816 - js!( @(no_return) @{self}.bufferData(@{target}, @{(size as f64)}, @{usage}); ); [INFO] [stdout] 3816 + js!( @(no_return) @{self}.bufferData(@{target}, @{size as f64}, @{usage}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:3824:62 [INFO] [stdout] | [INFO] [stdout] 3824 | js!( @(no_return) @{self}.bufferSubData(@{target}, @{(offset as f64)}, @{data}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 3824 - js!( @(no_return) @{self}.bufferSubData(@{target}, @{(offset as f64)}, @{data}); ); [INFO] [stdout] 3824 + js!( @(no_return) @{self}.bufferSubData(@{target}, @{offset as f64}, @{data}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:3956:79 [INFO] [stdout] | [INFO] [stdout] 3956 | js!( @(no_return) @{self}.drawElements(@{mode}, @{count}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 3956 - js!( @(no_return) @{self}.drawElements(@{mode}, @{count}, @{type_}, @{(offset as f64)}); ); [INFO] [stdout] 3956 + js!( @(no_return) @{self}.drawElements(@{mode}, @{count}, @{type_}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/lib.rs:4328:112 [INFO] [stdout] | [INFO] [stdout] 4328 | js!( @(no_return) @{self}.vertexAttribPointer(@{index}, @{size}, @{type_}, @{normalized}, @{stride}, @{(offset as f64)}); ); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 4328 - js!( @(no_return) @{self}.vertexAttribPointer(@{index}, @{size}, @{type_}, @{normalized}, @{stride}, @{(offset as f64)}); ); [INFO] [stdout] 4328 + js!( @(no_return) @{self}.vertexAttribPointer(@{index}, @{size}, @{type_}, @{normalized}, @{stride}, @{offset as f64}); ); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] error: could not compile `stdweb` (lib); 4712 warnings emitted [INFO] [stderr] [INFO] [stderr] Caused by: [INFO] [stderr] process didn't exit successfully: `/opt/rustwide/rustup-home/toolchains/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/bin/rustc --crate-name stdweb --edition=2015 /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/stdweb-0.4.20/src/lib.rs --error-format=json --json=diagnostic-rendered-ansi,artifacts,future-incompat --crate-type lib --emit=dep-info,metadata,link -C embed-bitcode=no -C debuginfo=2 --cfg 'feature="default"' --cfg 'feature="serde"' --cfg 'feature="serde_json"' --check-cfg 'cfg(docsrs,test)' --check-cfg 'cfg(feature, values("default", "docs-rs", "experimental_features_which_may_break_on_minor_version_bumps", "futures-channel-preview", "futures-core-preview", "futures-executor-preview", "futures-support", "futures-util-preview", "nightly", "serde", "serde_json", "web_test"))' -C metadata=27d82cb831e22029 -C extra-filename=-30f6bb3ccb216884 --out-dir /opt/rustwide/target/debug/deps -L dependency=/opt/rustwide/target/debug/deps --extern discard=/opt/rustwide/target/debug/deps/libdiscard-11fc78d17c12a98b.rmeta --extern serde=/opt/rustwide/target/debug/deps/libserde-37646bd4e49bfacd.rmeta --extern serde_json=/opt/rustwide/target/debug/deps/libserde_json-f8dd111aa1eebc08.rmeta --extern stdweb_derive=/opt/rustwide/target/debug/deps/libstdweb_derive-f3b445fab85e761f.so --extern stdweb_internal_macros=/opt/rustwide/target/debug/deps/libstdweb_internal_macros-c600d71d18b49445.so --extern stdweb_internal_runtime=/opt/rustwide/target/debug/deps/libstdweb_internal_runtime-05009161a230db30.rmeta --cap-lints allow --cap-lints=forbid --cfg rust_nightly` (exit status: 101) [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] [INFO] [stdout] error: internal compiler error: /rustc-dev/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/compiler/rustc_codegen_ssa/src/mir/intrinsic.rs:123:21: nullary intrinsic type_name must either be in a const block or explicitly opted out because it is inherently a runtime intrinsic [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/stdweb-0.4.20/src/webcore/type_name.rs:5:9 [INFO] [stdout] | [INFO] [stdout] 5 | intrinsics::type_name::< T >() [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] thread 'rustc' (214) panicked at /rustc-dev/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/compiler/rustc_codegen_ssa/src/mir/intrinsic.rs:123:21: [INFO] [stderr] Box [INFO] [stderr] stack backtrace: [INFO] [stderr] 0: 0x795edfbe5a43 - ::fmt::hff1a9408d012ee89 [INFO] [stderr] 1: 0x795ee0401bfc - core::fmt::write::h2f1fc679f228cc52 [INFO] [stderr] 2: 0x795edfbd0493 - std::io::Write::write_fmt::haa2231cbd9aebf95 [INFO] [stderr] 3: 0x795edfbe58a2 - std::sys::backtrace::BacktraceLock::print::h28bfdbcac6d3828b [INFO] [stderr] 4: 0x795edfbc7c1f - std::panicking::default_hook::{{closure}}::h1f968e3a24b0e3b4 [INFO] [stderr] 5: 0x795edfbc774b - std::panicking::default_hook::h43da101644971931 [INFO] [stderr] 6: 0x795edec491b5 - std[619c96d97fe952c]::panicking::update_hook::>::{closure#0} [INFO] [stderr] 7: 0x795edfbc8313 - std::panicking::panic_with_hook::hb4e916c3e65eccec [INFO] [stderr] 8: 0x795edec82991 - std[619c96d97fe952c]::panicking::begin_panic::::{closure#0} [INFO] [stderr] 9: 0x795edec82966 - std[619c96d97fe952c]::sys::backtrace::__rust_end_short_backtrace::::{closure#0}, !> [INFO] [stderr] 10: 0x795edec80ad6 - std[619c96d97fe952c]::panicking::begin_panic:: [INFO] [stderr] 11: 0x795edec6d2f1 - ::emit_producing_guarantee [INFO] [stderr] 12: 0x795edf28367c - ::span_bug:: [INFO] [stderr] 13: 0x795edf271ae7 - rustc_middle[5ca2e9449305faae]::util::bug::opt_span_bug_fmt::::{closure#0} [INFO] [stderr] 14: 0x795edf271a4a - rustc_middle[5ca2e9449305faae]::ty::context::tls::with_opt::::{closure#0}, !>::{closure#0} [INFO] [stderr] 15: 0x795edf271a1b - rustc_middle[5ca2e9449305faae]::ty::context::tls::with_context_opt::::{closure#0}, !>::{closure#0}, !> [INFO] [stderr] 16: 0x795edd320ee7 - rustc_middle[5ca2e9449305faae]::util::bug::span_bug_fmt:: [INFO] [stderr] 17: 0x795ee1331c7b - >>::codegen_intrinsic_call [INFO] [stderr] 18: 0x795ee181a388 - rustc_codegen_ssa[d211144dd38b4208]::mir::codegen_mir::> [INFO] [stderr] 19: 0x795ee0576057 - rustc_codegen_llvm[ebd76f8efcabca32]::base::compile_codegen_unit::module_codegen [INFO] [stderr] 20: 0x795ee1529f14 - ::compile_codegen_unit [INFO] [stderr] 21: 0x795ee1527e3a - ::codegen_crate [INFO] [stderr] 22: 0x795ee15912b0 - ::codegen_and_build_linker [INFO] [stderr] 23: 0x795ee158ee3c - rustc_interface[b77c32c3bfe8d9]::passes::create_and_enter_global_ctxt::, rustc_driver_impl[c8262843f73b2e4e]::run_compiler::{closure#0}::{closure#2}>::{closure#2}::{closure#0} [INFO] [stderr] 24: 0x795ee15efe03 - rustc_interface[b77c32c3bfe8d9]::interface::run_compiler::<(), rustc_driver_impl[c8262843f73b2e4e]::run_compiler::{closure#0}>::{closure#1} [INFO] [stderr] 25: 0x795ee154e7fb - std[619c96d97fe952c]::sys::backtrace::__rust_begin_short_backtrace::::{closure#1}, ()>::{closure#0}, ()>::{closure#0}::{closure#0}, ()> [INFO] [stderr] 26: 0x795ee154e4d4 - <::spawn_unchecked_::{closure#1}, ()>::{closure#0}, ()>::{closure#0}::{closure#0}, ()>::{closure#1} as core[b7f6e7468eb674bd]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0} [INFO] [stderr] 27: 0x795ee154a28b - std::sys::pal::unix::thread::Thread::new::thread_start::h66ff1bba185a50cf [INFO] [stderr] 28: 0x795edae8aaa4 - [INFO] [stderr] 29: 0x795edaf17a34 - clone [INFO] [stderr] 30: 0x0 - [INFO] [stderr] [INFO] [stderr] note: we would appreciate a bug report: https://github.com/rust-lang/rust/issues/new?labels=C-bug%2C+I-ICE%2C+T-compiler&template=ice.md [INFO] [stderr] [INFO] [stderr] note: please make sure that you have updated to the latest nightly [INFO] [stderr] [INFO] [stderr] warning: the ICE couldn't be written to `/opt/rustwide/workdir/rustc-ice-2025-10-02T06_57_19-211.txt`: Read-only file system (os error 30) [INFO] [stderr] [INFO] [stderr] note: rustc 1.91.0-nightly (350d0ef0e 2025-08-13) running on x86_64-unknown-linux-gnu [INFO] [stderr] [INFO] [stderr] note: compiler flags: --crate-type lib -C embed-bitcode=no -C debuginfo=2 [INFO] [stderr] [INFO] [stderr] note: some of the compiler flags provided by cargo are hidden [INFO] [stderr] [INFO] [stderr] query stack during panic: [INFO] [stderr] end of query stack [INFO] [stderr] error: could not compile `webgl-rendering-context` (lib); 54 warnings emitted [INFO] [stderr] [INFO] [stderr] Caused by: [INFO] [stderr] process didn't exit successfully: `/opt/rustwide/rustup-home/toolchains/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/bin/rustc --crate-name webgl_rendering_context --edition=2015 src/lib.rs --error-format=json --json=diagnostic-rendered-ansi,artifacts,future-incompat --crate-type lib --emit=dep-info,metadata,link -C embed-bitcode=no -C debuginfo=2 --check-cfg 'cfg(docsrs,test)' --check-cfg 'cfg(feature, values())' -C metadata=b201ce2040d2ffa0 -C extra-filename=-15dcc7de0d68106f --out-dir /opt/rustwide/target/debug/deps -L dependency=/opt/rustwide/target/debug/deps --extern serde=/opt/rustwide/target/debug/deps/libserde-37646bd4e49bfacd.rmeta --extern serde_derive=/opt/rustwide/target/debug/deps/libserde_derive-63e4350cad049a1b.so --extern stdweb=/opt/rustwide/target/debug/deps/libstdweb-30f6bb3ccb216884.rmeta --extern stdweb_derive=/opt/rustwide/target/debug/deps/libstdweb_derive-f3b445fab85e761f.so --cap-lints=forbid` (exit status: 101) [INFO] running `Command { std: "docker" "inspect" "b6869943dc2f334447d903f712c4737aadda213ac8cf6e434864acd0af1cfaf2", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "b6869943dc2f334447d903f712c4737aadda213ac8cf6e434864acd0af1cfaf2", kill_on_drop: false }` [INFO] [stdout] b6869943dc2f334447d903f712c4737aadda213ac8cf6e434864acd0af1cfaf2