[INFO] cloning repository https://github.com/yeahross0/Weegames-Demo [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/yeahross0/Weegames-Demo" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fyeahross0%2FWeegames-Demo", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fyeahross0%2FWeegames-Demo'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 5c36bad42fc9f941a97467cc025f3a5c5cdf89d4 [INFO] building yeahross0/Weegames-Demo against try#23647e694de8d0904848ad068b2e0ec2dd098c37+target=wasm32-wasip1 for pr-149868 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fyeahross0%2FWeegames-Demo" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/yeahross0/Weegames-Demo [INFO] finished tweaking git repo https://github.com/yeahross0/Weegames-Demo [INFO] tweaked toml for git repo https://github.com/yeahross0/Weegames-Demo written to /workspace/builds/worker-7-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/yeahross0/Weegames-Demo on toolchain 23647e694de8d0904848ad068b2e0ec2dd098c37 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+23647e694de8d0904848ad068b2e0ec2dd098c37" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/yeahross0/Weegames-Demo 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" "+23647e694de8d0904848ad068b2e0ec2dd098c37" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+23647e694de8d0904848ad068b2e0ec2dd098c37" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] e4f5babdb0993cd0f045cfdfff7ba9e2dddb188a4af7a91cd5d5fa6f3d822e21 [INFO] running `Command { std: "docker" "start" "-a" "e4f5babdb0993cd0f045cfdfff7ba9e2dddb188a4af7a91cd5d5fa6f3d822e21", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "e4f5babdb0993cd0f045cfdfff7ba9e2dddb188a4af7a91cd5d5fa6f3d822e21", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e4f5babdb0993cd0f045cfdfff7ba9e2dddb188a4af7a91cd5d5fa6f3d822e21", kill_on_drop: false }` [INFO] [stdout] e4f5babdb0993cd0f045cfdfff7ba9e2dddb188a4af7a91cd5d5fa6f3d822e21 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+23647e694de8d0904848ad068b2e0ec2dd098c37" "build" "--frozen" "--message-format=json" "--target" "wasm32-wasip1", kill_on_drop: false }` [INFO] [stdout] 18e89b4657ae52f96de8effd9d3cda3bdfc43d4812711993505f9ea34c165413 [INFO] running `Command { std: "docker" "start" "-a" "18e89b4657ae52f96de8effd9d3cda3bdfc43d4812711993505f9ea34c165413", kill_on_drop: false }` [INFO] [stderr] Compiling autocfg v1.0.1 [INFO] [stderr] Compiling proc-macro2 v1.0.24 [INFO] [stderr] Compiling unicode-xid v0.2.1 [INFO] [stderr] Compiling syn v1.0.67 [INFO] [stderr] Compiling byteorder v1.3.4 [INFO] [stderr] Compiling proc-macro-hack v0.5.19 [INFO] [stderr] Compiling adler32 v1.2.0 [INFO] [stderr] Compiling bitflags v1.2.1 [INFO] [stderr] Compiling crc32fast v1.2.1 [INFO] [stderr] Compiling memchr v2.3.4 [INFO] [stderr] Compiling proc-macro-nested v0.1.6 [INFO] [stderr] Compiling getrandom v0.1.15 [INFO] [stderr] Compiling ahash v0.4.7 [INFO] [stderr] Compiling wasi v0.9.0+wasi-snapshot-preview1 [INFO] [stderr] Compiling futures-sink v0.3.8 [INFO] [stderr] Compiling cfg-if v1.0.0 [INFO] [stderr] Compiling futures-core v0.3.8 [INFO] [stderr] Compiling serde_derive v1.0.118 [INFO] [stderr] Compiling once_cell v1.5.2 [INFO] [stderr] Compiling cfg-if v0.1.10 [INFO] [stderr] Compiling miniz_oxide v0.3.7 [INFO] [stderr] Compiling futures-channel v0.3.8 [INFO] [stderr] Compiling futures-task v0.3.8 [INFO] [stderr] Compiling hashbrown v0.9.1 [INFO] [stderr] Compiling slab v0.4.2 [INFO] [stderr] Compiling futures-io v0.3.8 [INFO] [stderr] Compiling ryu v1.0.5 [INFO] [stderr] Compiling pin-utils v0.1.0 [INFO] [stderr] Compiling serde v1.0.118 [INFO] [stderr] Compiling sapp-wasm v0.1.26 [INFO] [stderr] Compiling ppv-lite86 v0.2.10 [INFO] [stderr] Compiling rand_core v0.5.1 [INFO] [stderr] Compiling serde_json v1.0.60 [INFO] [stderr] Compiling jpeg-decoder v0.1.22 [INFO] [stderr] Compiling ttf-parser v0.12.1 [INFO] [stderr] Compiling bytemuck v1.5.1 [INFO] [stderr] Compiling color_quant v1.1.0 [INFO] [stderr] Compiling rand_chacha v0.2.2 [INFO] [stderr] Compiling miniquad v0.3.0-alpha.35 [INFO] [stderr] Compiling itoa v0.4.6 [INFO] [stderr] Compiling glam v0.14.0 [INFO] [stderr] Compiling quad-rand v0.2.1 [INFO] [stderr] Compiling bumpalo v3.6.1 [INFO] [stderr] Compiling macroquad_macro v0.1.5 (https://github.com/yeahross0/macroquad?rev=8dd289#8dd28906) [INFO] [stderr] Compiling c2-sys v0.1.0 (https://github.com/yeahross0/cute-c2/?rev=c22e4f8#c22e4f8f) [INFO] [stderr] Compiling rand v0.7.3 [INFO] [stderr] Compiling deflate v0.8.6 [INFO] [stderr] Compiling c2 v0.1.0 (https://github.com/yeahross0/cute-c2/?rev=c22e4f8#c22e4f8f) [INFO] [stderr] Compiling quote v1.0.8 [INFO] [stderr] Compiling num-traits v0.2.14 [INFO] [stderr] Compiling num-integer v0.1.44 [INFO] [stderr] Compiling num-rational v0.3.2 [INFO] [stderr] Compiling num-iter v0.1.42 [INFO] [stderr] Compiling png v0.16.8 [INFO] [stderr] Compiling indexmap v1.6.1 [INFO] [stderr] Compiling fontdue v0.5.2 [INFO] [stderr] Compiling image v0.23.14 [INFO] [stderr] Compiling macroquad v0.3.5 (https://github.com/yeahross0/macroquad?rev=8dd289#8dd28906) [INFO] [stderr] Compiling pin-project-internal v1.0.2 [INFO] [stderr] Compiling futures-macro v0.3.8 [INFO] [stderr] Compiling pin-project v1.0.2 [INFO] [stderr] Compiling futures-util v0.3.8 [INFO] [stderr] Compiling futures-executor v0.3.8 [INFO] [stderr] Compiling futures v0.3.8 [INFO] [stderr] Compiling webgames v0.2.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/main.rs:1218:13 [INFO] [stdout] | [INFO] [stdout] 1218 | let mut high_scores = self [INFO] [stdout] | ----^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Rect` is never constructed [INFO] [stdout] --> src/wee.rs:126:8 [INFO] [stdout] | [INFO] [stdout] 126 | struct Rect { [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `SerialiseObjectList` is never used [INFO] [stdout] --> src/wee.rs:268:7 [INFO] [stdout] | [INFO] [stdout] 268 | trait SerialiseObjectList { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `start_time` and `to_run` are never read [INFO] [stdout] --> src/wee.rs:1143:5 [INFO] [stdout] | [INFO] [stdout] 1139 | pub struct FrameInfo { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 1143 | start_time: f64, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 1144 | to_run: u32, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `FrameInfo` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: creating a mutable reference to mutable static [INFO] [stdout] --> src/main.rs:594:19 [INFO] [stdout] | [INFO] [stdout] 594 | unsafe { *STORAGE.take().unwrap().downcast::().unwrap() } [INFO] [stdout] | ^^^^^^^^^^^^^^ mutable reference to mutable static [INFO] [stdout] | [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: mutable references to mutable statics are dangerous; it's undefined behavior if any other pointer to the static is used or if any other reference is created for the static while the mutable reference lives [INFO] [stdout] = note: `#[warn(static_mut_refs)]` (part of `#[warn(rust_2024_compatibility)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: linking with `rust-lld` failed: exit status: 1 [INFO] [stdout] | [INFO] [stdout] = note: "rust-lld" "-flavor" "wasm" "--export" "__main_void" "--export" "CONTEXT" "--export" "macroquad_audio_crate_version" "--export" "file_loaded" "--export" "allocate_vec_u8" "--export" "crate_version" "--export" "frame" "--export" "key_down" "--export" "key_press" "--export" "key_up" "--export" "mouse_down" "--export" "mouse_move" "--export" "mouse_up" "--export" "mouse_wheel" "--export" "on_clipboard_paste" "--export" "raw_mouse_move" "--export" "resize" "--export" "touch" "-z" "stack-size=1048576" "--stack-first" "--no-demangle" "/lib/rustlib/wasm32-wasip1/lib/self-contained/crt1-command.o" "<17 object files omitted>" "/lib/rustlib/wasm32-wasip1/lib/libpanic_abort-*.rlib" "/opt/rustwide/target/wasm32-wasip1/debug/deps/{libserde_json-2702ce67be55a5db,libryu-0fd3b9e64e209fe9,libitoa-87661f45669e09db,libserde-b238486a6b5eeb3f,libindexmap-098e18976d1b316c,libc2-2585e6b165d1b99b,libc2_sys-9820083ad99f9b95,libfutures-6f6e16d86d59cfa5,libfutures_executor-83cce911da9134b3,libfutures_util-bdfd84a7f76cb1c5,libmemchr-9304c170e10bec3c,libfutures_io-c0ff544b4a7587e6,libslab-7968c4279f005af2,libfutures_channel-f2ca90af6a2a5968,libpin_project-9203618f05cdbb68,libfutures_sink-cfe82523b2809982,libfutures_task-988cfdef5669df1a,libonce_cell-d8e6cee763dbc8a4,libpin_utils-25e51da25cbdd319,libfutures_core-2310e4be0982684f,libmacroquad-20fbea491a8fb5ec,libbumpalo-14bc9a68b3bcc272,libfontdue-cb0cbb16b65e3849,libttf_parser-fe845903bcba9533,libhashbrown-0bd4e4c49b9e2764,libahash-6a5ea761c973327e,libimage-083b9471ba6b478b,libcolor_quant-1e86b52941ac4ea7,libbytemuck-45150022a2168dfb,libpng-0cd62bbe53a69c34,libminiz_oxide-330bc9c14910495c,libcrc32fast-e499feabe4659b96,libcfg_if-2a1f3d8d3a86aef9,libdeflate-2fea622db8b650b9,libbyteorder-d90aa42c6e496df3,libadler32-f79bb24121891b02,libbitflags-8fdb16ad896ddc9c,libnum_rational-704dfc3b60c572ba,libnum_iter-ba9fd34fbbf14cf7,libnum_integer-f2af9fb7fa4e5f8a,libjpeg_decoder-aad19ca892c8bcba,libnum_traits-c3e3e873c5aa0556,libquad_rand-3f6d699ad3c7baf8,libglam-a067d9eed3432399,libminiquad-7a04c1594bdeb41a,libsapp_wasm-3bb0322b922a4c9c}.rlib" "/lib/rustlib/wasm32-wasip1/lib/{libstd-*,libwasi-*,libcfg_if-*,librustc_demangle-*,libstd_detect-*,libhashbrown-*,librustc_std_workspace_alloc-*,libminiz_oxide-*,libadler2-*,libunwind-*,liblibc-*}.rlib" "-l" "c" "/lib/rustlib/wasm32-wasip1/lib/{librustc_std_workspace_core-*,liballoc-*,libcore-*,libcompiler_builtins-*}.rlib" "-L" "/lib/rustlib/wasm32-wasip1/lib/self-contained" "-o" "/opt/rustwide/target/wasm32-wasip1/debug/deps/webgames-8ebe817da6dc1474.wasm" "--gc-sections" "-O0" [INFO] [stdout] = note: some arguments are omitted. use `--verbose` to show all linker arguments [INFO] [stdout] = note: rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/webgames-8ebe817da6dc1474.webgames.c6cb5c499cf90ab7-cgu.08.rcgu.o: undefined symbol: audio_add_buffer [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/webgames-8ebe817da6dc1474.webgames.c6cb5c499cf90ab7-cgu.08.rcgu.o: undefined symbol: audio_source_is_loaded [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.00.rcgu.o): undefined symbol: glGenBuffers [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.00.rcgu.o): undefined symbol: glBufferData [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.00.rcgu.o): undefined symbol: glBufferSubData [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.00.rcgu.o): undefined symbol: glGenBuffers [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.00.rcgu.o): undefined symbol: glBufferData [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.00.rcgu.o): undefined symbol: glBufferSubData [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.00.rcgu.o): undefined symbol: glBindTexture [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.00.rcgu.o): undefined symbol: glCopyTexImage2D [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.00.rcgu.o): undefined symbol: glBufferSubData [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.00.rcgu.o): undefined symbol: glBufferSubData [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.03.rcgu.o): undefined symbol: audio_init [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.03.rcgu.o): undefined symbol: glFlush [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.03.rcgu.o): undefined symbol: glFinish [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.09.rcgu.o): undefined symbol: audio_play_buffer [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.09.rcgu.o): undefined symbol: audio_source_stop [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.14.rcgu.o): undefined symbol: glGenFramebuffers [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.14.rcgu.o): undefined symbol: glBindFramebuffer [INFO] [stdout] rust-lld: error: /opt/rustwide/target/wasm32-wasip1/debug/deps/libmacroquad-20fbea491a8fb5ec.rlib(macroquad-20fbea491a8fb5ec.macroquad.4d68d3b2b757fb58-cgu.14.rcgu.o): undefined symbol: glFramebufferTexture2D [INFO] [stdout] rust-lld: error: too many errors emitted, stopping now (use -error-limit=0 to see all errors) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] error: could not compile `webgames` (bin "webgames") due to 1 previous error; 5 warnings emitted [INFO] running `Command { std: "docker" "inspect" "18e89b4657ae52f96de8effd9d3cda3bdfc43d4812711993505f9ea34c165413", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "18e89b4657ae52f96de8effd9d3cda3bdfc43d4812711993505f9ea34c165413", kill_on_drop: false }` [INFO] [stdout] 18e89b4657ae52f96de8effd9d3cda3bdfc43d4812711993505f9ea34c165413