[INFO] cloning repository https://github.com/the-flx/demo-rs-flx [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/the-flx/demo-rs-flx" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fthe-flx%2Fdemo-rs-flx", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fthe-flx%2Fdemo-rs-flx'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 1498538260d59b1346b35f6094844e39a4108c51 [INFO] checking the-flx/demo-rs-flx/1498538260d59b1346b35f6094844e39a4108c51 against master#1b8f2e46e14b08208a53585570edd9206374aae8 for pr-155418 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fthe-flx%2Fdemo-rs-flx" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/the-flx/demo-rs-flx [INFO] finished tweaking git repo https://github.com/the-flx/demo-rs-flx [INFO] tweaked toml for git repo https://github.com/the-flx/demo-rs-flx written to /workspace/builds/worker-3-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/the-flx/demo-rs-flx on toolchain 1b8f2e46e14b08208a53585570edd9206374aae8 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1b8f2e46e14b08208a53585570edd9206374aae8" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/the-flx/demo-rs-flx 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" "+1b8f2e46e14b08208a53585570edd9206374aae8" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded rs-flx v0.1.3 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1b8f2e46e14b08208a53585570edd9206374aae8" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 33b45b97284d46703a741e551c32ffa13f2eb36b93e2394f55fa7a69f7991acf [INFO] running `Command { std: "docker" "start" "-a" "33b45b97284d46703a741e551c32ffa13f2eb36b93e2394f55fa7a69f7991acf", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "33b45b97284d46703a741e551c32ffa13f2eb36b93e2394f55fa7a69f7991acf", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "33b45b97284d46703a741e551c32ffa13f2eb36b93e2394f55fa7a69f7991acf", kill_on_drop: false }` [INFO] [stdout] 33b45b97284d46703a741e551c32ffa13f2eb36b93e2394f55fa7a69f7991acf [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1b8f2e46e14b08208a53585570edd9206374aae8" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] bd204af5fa9ec860abb67de89408e6c22e05ab5051406418243aa302bb0b2e98 [INFO] running `Command { std: "docker" "start" "-a" "bd204af5fa9ec860abb67de89408e6c22e05ab5051406418243aa302bb0b2e98", kill_on_drop: false }` [INFO] [stderr] Compiling find-msvc-tools v0.1.5 [INFO] [stderr] Compiling cc v1.2.49 [INFO] [stderr] Compiling rs-flx v0.1.3 [INFO] [stdout] error[E0080]: index out of bounds: the length is 1 but the index is 8 [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/rs-flx-0.1.3/src/./bindings.rs:256:5 [INFO] [stdout] | [INFO] [stdout] 256 | ["Size of _Mbstatet"][::std::mem::size_of::<_Mbstatet>() - 8usize]; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ evaluation of `_` failed here [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0080]: index out of bounds: the length is 1 but the index is 8 [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/rs-flx-0.1.3/src/./bindings.rs:1676:5 [INFO] [stdout] | [INFO] [stdout] 1676 | ["Size of _ldiv_t"][::std::mem::size_of::<_ldiv_t>() - 8usize]; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ evaluation of `_` failed here [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] For more information about this error, try `rustc --explain E0080`. [INFO] [stdout] [INFO] [stderr] warning: rs-flx@0.1.3: In file included from ./c_lib/flx-c/src/flx.c:19: [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c: In function 'insert_dict': [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:541:32: warning: operand of '?:' changes signedness from 'long int' to 'size_t' {aka 'long unsigned int'} due to unsignedness of other operand [-Wsign-compare] [INFO] [stderr] warning: rs-flx@0.1.3: 541 | #define stbds_arrlen(a) ((a) ? (ptrdiff_t) stbds_header(a)->length : 0) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:548:128: note: in expansion of macro 'stbds_arrlen' [INFO] [stderr] warning: rs-flx@0.1.3: 548 | #define stbds_arraddnindex(a,n)(stbds_arrmaybegrow(a,n), (n) ? (stbds_header(a)->length += (n), stbds_header(a)->length-(n)) : stbds_arrlen(a)) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:546:40: note: in expansion of macro 'stbds_arraddnindex' [INFO] [stderr] warning: rs-flx@0.1.3: 546 | #define stbds_arraddn(a,n) ((void)(stbds_arraddnindex(a, n))) // deprecated, use one of the following instead: [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:555:33: note: in expansion of macro 'stbds_arraddn' [INFO] [stderr] warning: rs-flx@0.1.3: 555 | #define stbds_arrinsn(a,i,n) (stbds_arraddn((a),(n)), memmove(&(a)[(i)+(n)], &(a)[i], sizeof *(a) * (stbds_header(a)->length-(n)-(i)))) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:556:33: note: in expansion of macro 'stbds_arrinsn' [INFO] [stderr] warning: rs-flx@0.1.3: 556 | #define stbds_arrins(a,i,v) (stbds_arrinsn((a),(i),1), (a)[i]=(v)) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:409:21: note: in expansion of macro 'stbds_arrins' [INFO] [stderr] warning: rs-flx@0.1.3: 409 | #define arrins stbds_arrins [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c:70:5: note: in expansion of macro 'arrins' [INFO] [stderr] warning: rs-flx@0.1.3: 70 | arrins(new_arr, 0, val); [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c: In function 'get_heatmap_str': [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:541:32: warning: operand of '?:' changes signedness from 'long int' to 'size_t' {aka 'long unsigned int'} due to unsignedness of other operand [-Wsign-compare] [INFO] [stderr] warning: rs-flx@0.1.3: 541 | #define stbds_arrlen(a) ((a) ? (ptrdiff_t) stbds_header(a)->length : 0) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:548:128: note: in expansion of macro 'stbds_arrlen' [INFO] [stderr] warning: rs-flx@0.1.3: 548 | #define stbds_arraddnindex(a,n)(stbds_arrmaybegrow(a,n), (n) ? (stbds_header(a)->length += (n), stbds_header(a)->length-(n)) : stbds_arrlen(a)) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:546:40: note: in expansion of macro 'stbds_arraddnindex' [INFO] [stderr] warning: rs-flx@0.1.3: 546 | #define stbds_arraddn(a,n) ((void)(stbds_arraddnindex(a, n))) // deprecated, use one of the following instead: [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:555:33: note: in expansion of macro 'stbds_arraddn' [INFO] [stderr] warning: rs-flx@0.1.3: 555 | #define stbds_arrinsn(a,i,n) (stbds_arraddn((a),(n)), memmove(&(a)[(i)+(n)], &(a)[i], sizeof *(a) * (stbds_header(a)->length-(n)-(i)))) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:556:33: note: in expansion of macro 'stbds_arrinsn' [INFO] [stderr] warning: rs-flx@0.1.3: 556 | #define stbds_arrins(a,i,v) (stbds_arrinsn((a),(i),1), (a)[i]=(v)) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:409:21: note: in expansion of macro 'stbds_arrins' [INFO] [stderr] warning: rs-flx@0.1.3: 409 | #define arrins stbds_arrins [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c:266:13: note: in expansion of macro 'arrins' [INFO] [stderr] warning: rs-flx@0.1.3: 266 | arrins(group_alist[0], 2, index1); [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:541:32: warning: operand of '?:' changes signedness from 'long int' to 'size_t' {aka 'long unsigned int'} due to unsignedness of other operand [-Wsign-compare] [INFO] [stderr] warning: rs-flx@0.1.3: 541 | #define stbds_arrlen(a) ((a) ? (ptrdiff_t) stbds_header(a)->length : 0) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:548:128: note: in expansion of macro 'stbds_arrlen' [INFO] [stderr] warning: rs-flx@0.1.3: 548 | #define stbds_arraddnindex(a,n)(stbds_arrmaybegrow(a,n), (n) ? (stbds_header(a)->length += (n), stbds_header(a)->length-(n)) : stbds_arrlen(a)) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:546:40: note: in expansion of macro 'stbds_arraddnindex' [INFO] [stderr] warning: rs-flx@0.1.3: 546 | #define stbds_arraddn(a,n) ((void)(stbds_arraddnindex(a, n))) // deprecated, use one of the following instead: [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:555:33: note: in expansion of macro 'stbds_arraddn' [INFO] [stderr] warning: rs-flx@0.1.3: 555 | #define stbds_arrinsn(a,i,n) (stbds_arraddn((a),(n)), memmove(&(a)[(i)+(n)], &(a)[i], sizeof *(a) * (stbds_header(a)->length-(n)-(i)))) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:556:33: note: in expansion of macro 'stbds_arrinsn' [INFO] [stderr] warning: rs-flx@0.1.3: 556 | #define stbds_arrins(a,i,v) (stbds_arrinsn((a),(i),1), (a)[i]=(v)) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:409:21: note: in expansion of macro 'stbds_arrins' [INFO] [stderr] warning: rs-flx@0.1.3: 409 | #define arrins stbds_arrins [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c:285:17: note: in expansion of macro 'arrins' [INFO] [stderr] warning: rs-flx@0.1.3: 285 | arrins(group_alist, 0, new_arr); [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c:346:13: warning: unused variable 'len' [-Wunused-variable] [INFO] [stderr] warning: rs-flx@0.1.3: 346 | int len = arrlen(*scores); [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c:308:10: warning: variable 'basepath_found' set but not used [-Wunused-but-set-variable] [INFO] [stderr] warning: rs-flx@0.1.3: 308 | bool basepath_found = false; [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c: In function 'find_best_match': [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:541:32: warning: operand of '?:' changes signedness from 'long int' to 'size_t' {aka 'long unsigned int'} due to unsignedness of other operand [-Wsign-compare] [INFO] [stderr] warning: rs-flx@0.1.3: 541 | #define stbds_arrlen(a) ((a) ? (ptrdiff_t) stbds_header(a)->length : 0) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:548:128: note: in expansion of macro 'stbds_arrlen' [INFO] [stderr] warning: rs-flx@0.1.3: 548 | #define stbds_arraddnindex(a,n)(stbds_arrmaybegrow(a,n), (n) ? (stbds_header(a)->length += (n), stbds_header(a)->length-(n)) : stbds_arrlen(a)) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:546:40: note: in expansion of macro 'stbds_arraddnindex' [INFO] [stderr] warning: rs-flx@0.1.3: 546 | #define stbds_arraddn(a,n) ((void)(stbds_arraddnindex(a, n))) // deprecated, use one of the following instead: [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:555:33: note: in expansion of macro 'stbds_arraddn' [INFO] [stderr] warning: rs-flx@0.1.3: 555 | #define stbds_arrinsn(a,i,n) (stbds_arraddn((a),(n)), memmove(&(a)[(i)+(n)], &(a)[i], sizeof *(a) * (stbds_header(a)->length-(n)-(i)))) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:556:33: note: in expansion of macro 'stbds_arrinsn' [INFO] [stderr] warning: rs-flx@0.1.3: 556 | #define stbds_arrins(a,i,v) (stbds_arrinsn((a),(i),1), (a)[i]=(v)) [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/../include/stb_ds.h:409:21: note: in expansion of macro 'stbds_arrins' [INFO] [stderr] warning: rs-flx@0.1.3: 409 | #define arrins stbds_arrins [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c:491:25: note: in expansion of macro 'arrins' [INFO] [stderr] warning: rs-flx@0.1.3: 491 | arrins(indices, 0, index); [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c: In function 'word': [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c:147:13: warning: 'strchr' argument missing terminating nul [-Wstringop-overread] [INFO] [stderr] warning: rs-flx@0.1.3: 147 | return !strchr(word_separators, ch); [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~ [INFO] [stderr] warning: rs-flx@0.1.3: ./c_lib/flx-c/src/flx.c:27:19: note: referenced argument declared here [INFO] [stderr] warning: rs-flx@0.1.3: 27 | static const char word_separators[] = { [INFO] [stderr] warning: rs-flx@0.1.3: | ^~~~~~~~~~~~~~~ [INFO] [stderr] error: could not compile `rs-flx` (lib) due to 2 previous errors [INFO] running `Command { std: "docker" "inspect" "bd204af5fa9ec860abb67de89408e6c22e05ab5051406418243aa302bb0b2e98", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "bd204af5fa9ec860abb67de89408e6c22e05ab5051406418243aa302bb0b2e98", kill_on_drop: false }` [INFO] [stdout] bd204af5fa9ec860abb67de89408e6c22e05ab5051406418243aa302bb0b2e98