[INFO] updating cached repository https://github.com/seemk/libz80-rs [INFO] running `"git" "-c" "credential.helper=" "-c" "credential.helper=/big/crater/work/cargo-home/bin/git-credential-null" "-c" "remote.origin.fetch=refs/heads/*:refs/heads/*" "fetch" "origin" "--force" "--prune"` [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 0a24d459e207116a9d0e1837ef69df21a974ce24 [INFO] testing seemk/libz80-rs against 1.38.0 for beta-1.39-1 [INFO] running `"git" "clone" "work/cache/git-repos/https%3A%2F%2Fgithub.com%2Fseemk%2Flibz80-rs" "work/builds/worker-2/source"` [INFO] [stderr] Cloning into 'work/builds/worker-2/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/seemk/libz80-rs on toolchain 1.38.0 [INFO] running `"/big/crater/work/cargo-home/bin/cargo" "+1.38.0" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started tweaking git repo https://github.com/seemk/libz80-rs [INFO] finished tweaking git repo https://github.com/seemk/libz80-rs [INFO] tweaked toml for git repo https://github.com/seemk/libz80-rs written to work/builds/worker-2/source/Cargo.toml [INFO] crate git repo https://github.com/seemk/libz80-rs already has a lockfile, it will not be regenerated [INFO] running `"/big/crater/work/cargo-home/bin/cargo" "+1.38.0" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] [stderr] error: the lock file /big/crater/work/builds/worker-2/source/Cargo.lock needs to be updated but --locked was passed to prevent this [INFO] the lockfile is outdated, regenerating it [INFO] running `"/big/crater/work/cargo-home/bin/cargo" "+1.38.0" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"` [INFO] running `"/big/crater/work/cargo-home/bin/cargo" "+1.38.0" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"docker" "create" "-v" "/big/crater/work/builds/worker-2/target:/opt/rustwide/target:rw,Z" "-v" "/big/crater/work/builds/worker-2/source:/opt/rustwide/workdir:ro,Z" "-v" "/big/crater/work/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/big/crater/work/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+1.38.0" "build" "--frozen"` [INFO] [stdout] 48e0f083c48391faf8db4396212ff2c748491780b79b7d6c73515ffa83813ba6 [INFO] running `"docker" "start" "-a" "48e0f083c48391faf8db4396212ff2c748491780b79b7d6c73515ffa83813ba6"` [INFO] [stderr] Compiling libz80-rs v0.0.1 (/opt/rustwide/workdir) [INFO] [stderr] warning: unknown lint: `uppercase_variables` [INFO] [stderr] --> src/lib.rs:25:9 [INFO] [stderr] | [INFO] [stderr] 25 | #[allow(uppercase_variables)] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unknown_lints)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unknown lint: `uppercase_variables` [INFO] [stderr] --> src/lib.rs:51:9 [INFO] [stderr] | [INFO] [stderr] 51 | #[allow(uppercase_variables)] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `AF` should have a snake case name [INFO] [stderr] --> src/lib.rs:28:9 [INFO] [stderr] | [INFO] [stderr] 28 | pub AF: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `af` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: structure field `BC` should have a snake case name [INFO] [stderr] --> src/lib.rs:29:9 [INFO] [stderr] | [INFO] [stderr] 29 | pub BC: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `bc` [INFO] [stderr] [INFO] [stderr] warning: structure field `DE` should have a snake case name [INFO] [stderr] --> src/lib.rs:30:9 [INFO] [stderr] | [INFO] [stderr] 30 | pub DE: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `de` [INFO] [stderr] [INFO] [stderr] warning: structure field `HL` should have a snake case name [INFO] [stderr] --> src/lib.rs:31:9 [INFO] [stderr] | [INFO] [stderr] 31 | pub HL: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `hl` [INFO] [stderr] [INFO] [stderr] warning: structure field `IX` should have a snake case name [INFO] [stderr] --> src/lib.rs:32:9 [INFO] [stderr] | [INFO] [stderr] 32 | pub IX: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `ix` [INFO] [stderr] [INFO] [stderr] warning: structure field `IY` should have a snake case name [INFO] [stderr] --> src/lib.rs:33:9 [INFO] [stderr] | [INFO] [stderr] 33 | pub IY: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `iy` [INFO] [stderr] [INFO] [stderr] warning: structure field `SP` should have a snake case name [INFO] [stderr] --> src/lib.rs:34:9 [INFO] [stderr] | [INFO] [stderr] 34 | pub SP: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `sp` [INFO] [stderr] [INFO] [stderr] warning: structure field `R1` should have a snake case name [INFO] [stderr] --> src/lib.rs:53:9 [INFO] [stderr] | [INFO] [stderr] 53 | pub R1: Registers, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `r1` [INFO] [stderr] [INFO] [stderr] warning: structure field `R2` should have a snake case name [INFO] [stderr] --> src/lib.rs:54:9 [INFO] [stderr] | [INFO] [stderr] 54 | pub R2: Registers, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `r2` [INFO] [stderr] [INFO] [stderr] warning: structure field `PC` should have a snake case name [INFO] [stderr] --> src/lib.rs:55:9 [INFO] [stderr] | [INFO] [stderr] 55 | pub PC: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `pc` [INFO] [stderr] [INFO] [stderr] warning: structure field `R` should have a snake case name [INFO] [stderr] --> src/lib.rs:56:9 [INFO] [stderr] | [INFO] [stderr] 56 | pub R: c_uchar, [INFO] [stderr] | ^ help: convert the identifier to snake case: `r` [INFO] [stderr] [INFO] [stderr] warning: structure field `I` should have a snake case name [INFO] [stderr] --> src/lib.rs:57:9 [INFO] [stderr] | [INFO] [stderr] 57 | pub I: c_uchar, [INFO] [stderr] | ^ help: convert the identifier to snake case: `i` [INFO] [stderr] [INFO] [stderr] warning: structure field `IFF1` should have a snake case name [INFO] [stderr] --> src/lib.rs:58:9 [INFO] [stderr] | [INFO] [stderr] 58 | pub IFF1: c_uchar, [INFO] [stderr] | ^^^^ help: convert the identifier to snake case: `iff1` [INFO] [stderr] [INFO] [stderr] warning: structure field `IFF2` should have a snake case name [INFO] [stderr] --> src/lib.rs:59:9 [INFO] [stderr] | [INFO] [stderr] 59 | pub IFF2: c_uchar, [INFO] [stderr] | ^^^^ help: convert the identifier to snake case: `iff2` [INFO] [stderr] [INFO] [stderr] warning: structure field `IM` should have a snake case name [INFO] [stderr] --> src/lib.rs:60:9 [INFO] [stderr] | [INFO] [stderr] 60 | pub IM: c_uchar, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `im` [INFO] [stderr] [INFO] [stderr] warning: method `set_AF1` should have a snake case name [INFO] [stderr] --> src/lib.rs:94:13 [INFO] [stderr] | [INFO] [stderr] 94 | reg_access!(set_AF1, get_AF1, AF, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_af1` [INFO] [stderr] [INFO] [stderr] warning: method `get_AF1` should have a snake case name [INFO] [stderr] --> src/lib.rs:94:22 [INFO] [stderr] | [INFO] [stderr] 94 | reg_access!(set_AF1, get_AF1, AF, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_af1` [INFO] [stderr] [INFO] [stderr] warning: method `set_BC1` should have a snake case name [INFO] [stderr] --> src/lib.rs:95:13 [INFO] [stderr] | [INFO] [stderr] 95 | reg_access!(set_BC1, get_BC1, BC, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_bc1` [INFO] [stderr] [INFO] [stderr] warning: method `get_BC1` should have a snake case name [INFO] [stderr] --> src/lib.rs:95:22 [INFO] [stderr] | [INFO] [stderr] 95 | reg_access!(set_BC1, get_BC1, BC, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_bc1` [INFO] [stderr] [INFO] [stderr] warning: method `set_DE1` should have a snake case name [INFO] [stderr] --> src/lib.rs:96:13 [INFO] [stderr] | [INFO] [stderr] 96 | reg_access!(set_DE1, get_DE1, DE, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_de1` [INFO] [stderr] [INFO] [stderr] warning: method `get_DE1` should have a snake case name [INFO] [stderr] --> src/lib.rs:96:22 [INFO] [stderr] | [INFO] [stderr] 96 | reg_access!(set_DE1, get_DE1, DE, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_de1` [INFO] [stderr] [INFO] [stderr] warning: method `set_HL1` should have a snake case name [INFO] [stderr] --> src/lib.rs:97:13 [INFO] [stderr] | [INFO] [stderr] 97 | reg_access!(set_HL1, get_HL1, HL, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_hl1` [INFO] [stderr] [INFO] [stderr] warning: method `get_HL1` should have a snake case name [INFO] [stderr] --> src/lib.rs:97:22 [INFO] [stderr] | [INFO] [stderr] 97 | reg_access!(set_HL1, get_HL1, HL, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_hl1` [INFO] [stderr] [INFO] [stderr] warning: method `set_AF2` should have a snake case name [INFO] [stderr] --> src/lib.rs:98:13 [INFO] [stderr] | [INFO] [stderr] 98 | reg_access!(set_AF2, get_AF2, AF, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_af2` [INFO] [stderr] [INFO] [stderr] warning: method `get_AF2` should have a snake case name [INFO] [stderr] --> src/lib.rs:98:22 [INFO] [stderr] | [INFO] [stderr] 98 | reg_access!(set_AF2, get_AF2, AF, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_af2` [INFO] [stderr] [INFO] [stderr] warning: method `set_BC2` should have a snake case name [INFO] [stderr] --> src/lib.rs:99:13 [INFO] [stderr] | [INFO] [stderr] 99 | reg_access!(set_BC2, get_BC2, BC, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_bc2` [INFO] [stderr] [INFO] [stderr] warning: method `get_BC2` should have a snake case name [INFO] [stderr] --> src/lib.rs:99:22 [INFO] [stderr] | [INFO] [stderr] 99 | reg_access!(set_BC2, get_BC2, BC, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_bc2` [INFO] [stderr] [INFO] [stderr] warning: method `set_DE2` should have a snake case name [INFO] [stderr] --> src/lib.rs:100:13 [INFO] [stderr] | [INFO] [stderr] 100 | reg_access!(set_DE2, get_DE2, DE, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_de2` [INFO] [stderr] [INFO] [stderr] warning: method `get_DE2` should have a snake case name [INFO] [stderr] --> src/lib.rs:100:22 [INFO] [stderr] | [INFO] [stderr] 100 | reg_access!(set_DE2, get_DE2, DE, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_de2` [INFO] [stderr] [INFO] [stderr] warning: method `set_HL2` should have a snake case name [INFO] [stderr] --> src/lib.rs:101:13 [INFO] [stderr] | [INFO] [stderr] 101 | reg_access!(set_HL2, get_HL2, HL, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_hl2` [INFO] [stderr] [INFO] [stderr] warning: method `get_HL2` should have a snake case name [INFO] [stderr] --> src/lib.rs:101:22 [INFO] [stderr] | [INFO] [stderr] 101 | reg_access!(set_HL2, get_HL2, HL, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_hl2` [INFO] [stderr] [INFO] [stderr] warning: method `set_IY` should have a snake case name [INFO] [stderr] --> src/lib.rs:102:13 [INFO] [stderr] | [INFO] [stderr] 102 | reg_access!(set_IY, get_IY, IY, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `set_iy` [INFO] [stderr] [INFO] [stderr] warning: method `get_IY` should have a snake case name [INFO] [stderr] --> src/lib.rs:102:22 [INFO] [stderr] | [INFO] [stderr] 102 | reg_access!(set_IY, get_IY, IY, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `get_iy` [INFO] [stderr] [INFO] [stderr] warning: method `set_IX` should have a snake case name [INFO] [stderr] --> src/lib.rs:103:13 [INFO] [stderr] | [INFO] [stderr] 103 | reg_access!(set_IX, get_IX, IX, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `set_ix` [INFO] [stderr] [INFO] [stderr] warning: method `get_IX` should have a snake case name [INFO] [stderr] --> src/lib.rs:103:22 [INFO] [stderr] | [INFO] [stderr] 103 | reg_access!(set_IX, get_IX, IX, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `get_ix` [INFO] [stderr] [INFO] [stderr] warning: method `set_SP` should have a snake case name [INFO] [stderr] --> src/lib.rs:104:13 [INFO] [stderr] | [INFO] [stderr] 104 | reg_access!(set_SP, get_SP, SP, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `set_sp` [INFO] [stderr] [INFO] [stderr] warning: method `get_SP` should have a snake case name [INFO] [stderr] --> src/lib.rs:104:22 [INFO] [stderr] | [INFO] [stderr] 104 | reg_access!(set_SP, get_SP, SP, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `get_sp` [INFO] [stderr] [INFO] [stderr] warning: `extern` block uses type `UserData` which is not FFI-safe: this struct has unspecified layout [INFO] [stderr] --> src/lib.rs:174:24 [INFO] [stderr] | [INFO] [stderr] 174 | fn Z80Execute(ctx: *mut Context); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(improper_ctypes)]` on by default [INFO] [stderr] = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct [INFO] [stderr] note: type defined here [INFO] [stderr] --> src/lib.rs:9:1 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct UserData; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `extern` block uses type `UserData` which is not FFI-safe: this struct has unspecified layout [INFO] [stderr] --> src/lib.rs:175:31 [INFO] [stderr] | [INFO] [stderr] 175 | fn Z80ExecuteTStates(ctx: *mut Context, tstates: c_uint) -> [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct [INFO] [stderr] note: type defined here [INFO] [stderr] --> src/lib.rs:9:1 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct UserData; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `extern` block uses type `UserData` which is not FFI-safe: this struct has unspecified layout [INFO] [stderr] --> src/lib.rs:178:22 [INFO] [stderr] | [INFO] [stderr] 178 | fn Z80RESET(ctx: *mut Context); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct [INFO] [stderr] note: type defined here [INFO] [stderr] --> src/lib.rs:9:1 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct UserData; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `extern` block uses type `UserData` which is not FFI-safe: this struct has unspecified layout [INFO] [stderr] --> src/lib.rs:179:20 [INFO] [stderr] | [INFO] [stderr] 179 | fn Z80INT(ctx: *mut Context, value: c_uchar); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct [INFO] [stderr] note: type defined here [INFO] [stderr] --> src/lib.rs:9:1 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct UserData; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `extern` block uses type `UserData` which is not FFI-safe: this struct has unspecified layout [INFO] [stderr] --> src/lib.rs:180:20 [INFO] [stderr] | [INFO] [stderr] 180 | fn Z80NMI(ctx: *mut Context); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct [INFO] [stderr] note: type defined here [INFO] [stderr] --> src/lib.rs:9:1 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct UserData; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 0.51s [INFO] running `"docker" "inspect" "48e0f083c48391faf8db4396212ff2c748491780b79b7d6c73515ffa83813ba6"` [INFO] running `"docker" "rm" "-f" "48e0f083c48391faf8db4396212ff2c748491780b79b7d6c73515ffa83813ba6"` [INFO] [stdout] 48e0f083c48391faf8db4396212ff2c748491780b79b7d6c73515ffa83813ba6 [INFO] running `"docker" "create" "-v" "/big/crater/work/builds/worker-2/target:/opt/rustwide/target:rw,Z" "-v" "/big/crater/work/builds/worker-2/source:/opt/rustwide/workdir:ro,Z" "-v" "/big/crater/work/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/big/crater/work/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+1.38.0" "test" "--frozen" "--no-run"` [INFO] [stdout] 0ab238a7ed4ca9e96e961c625dcacd58ce9ac4eea0a4cdf0892f9563c62dbf92 [INFO] running `"docker" "start" "-a" "0ab238a7ed4ca9e96e961c625dcacd58ce9ac4eea0a4cdf0892f9563c62dbf92"` [INFO] [stderr] Compiling libz80-rs v0.0.1 (/opt/rustwide/workdir) [INFO] [stderr] warning: unknown lint: `uppercase_variables` [INFO] [stderr] --> src/lib.rs:25:9 [INFO] [stderr] | [INFO] [stderr] 25 | #[allow(uppercase_variables)] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unknown_lints)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unknown lint: `uppercase_variables` [INFO] [stderr] --> src/lib.rs:51:9 [INFO] [stderr] | [INFO] [stderr] 51 | #[allow(uppercase_variables)] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `AF` should have a snake case name [INFO] [stderr] --> src/lib.rs:28:9 [INFO] [stderr] | [INFO] [stderr] 28 | pub AF: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `af` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: structure field `BC` should have a snake case name [INFO] [stderr] --> src/lib.rs:29:9 [INFO] [stderr] | [INFO] [stderr] 29 | pub BC: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `bc` [INFO] [stderr] [INFO] [stderr] warning: structure field `DE` should have a snake case name [INFO] [stderr] --> src/lib.rs:30:9 [INFO] [stderr] | [INFO] [stderr] 30 | pub DE: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `de` [INFO] [stderr] [INFO] [stderr] warning: structure field `HL` should have a snake case name [INFO] [stderr] --> src/lib.rs:31:9 [INFO] [stderr] | [INFO] [stderr] 31 | pub HL: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `hl` [INFO] [stderr] [INFO] [stderr] warning: structure field `IX` should have a snake case name [INFO] [stderr] --> src/lib.rs:32:9 [INFO] [stderr] | [INFO] [stderr] 32 | pub IX: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `ix` [INFO] [stderr] [INFO] [stderr] warning: structure field `IY` should have a snake case name [INFO] [stderr] --> src/lib.rs:33:9 [INFO] [stderr] | [INFO] [stderr] 33 | pub IY: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `iy` [INFO] [stderr] [INFO] [stderr] warning: structure field `SP` should have a snake case name [INFO] [stderr] --> src/lib.rs:34:9 [INFO] [stderr] | [INFO] [stderr] 34 | pub SP: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `sp` [INFO] [stderr] [INFO] [stderr] warning: structure field `R1` should have a snake case name [INFO] [stderr] --> src/lib.rs:53:9 [INFO] [stderr] | [INFO] [stderr] 53 | pub R1: Registers, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `r1` [INFO] [stderr] [INFO] [stderr] warning: structure field `R2` should have a snake case name [INFO] [stderr] --> src/lib.rs:54:9 [INFO] [stderr] | [INFO] [stderr] 54 | pub R2: Registers, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `r2` [INFO] [stderr] [INFO] [stderr] warning: structure field `PC` should have a snake case name [INFO] [stderr] --> src/lib.rs:55:9 [INFO] [stderr] | [INFO] [stderr] 55 | pub PC: c_ushort, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `pc` [INFO] [stderr] [INFO] [stderr] warning: structure field `R` should have a snake case name [INFO] [stderr] --> src/lib.rs:56:9 [INFO] [stderr] | [INFO] [stderr] 56 | pub R: c_uchar, [INFO] [stderr] | ^ help: convert the identifier to snake case: `r` [INFO] [stderr] [INFO] [stderr] warning: structure field `I` should have a snake case name [INFO] [stderr] --> src/lib.rs:57:9 [INFO] [stderr] | [INFO] [stderr] 57 | pub I: c_uchar, [INFO] [stderr] | ^ help: convert the identifier to snake case: `i` [INFO] [stderr] [INFO] [stderr] warning: structure field `IFF1` should have a snake case name [INFO] [stderr] --> src/lib.rs:58:9 [INFO] [stderr] | [INFO] [stderr] 58 | pub IFF1: c_uchar, [INFO] [stderr] | ^^^^ help: convert the identifier to snake case: `iff1` [INFO] [stderr] [INFO] [stderr] warning: structure field `IFF2` should have a snake case name [INFO] [stderr] --> src/lib.rs:59:9 [INFO] [stderr] | [INFO] [stderr] 59 | pub IFF2: c_uchar, [INFO] [stderr] | ^^^^ help: convert the identifier to snake case: `iff2` [INFO] [stderr] [INFO] [stderr] warning: structure field `IM` should have a snake case name [INFO] [stderr] --> src/lib.rs:60:9 [INFO] [stderr] | [INFO] [stderr] 60 | pub IM: c_uchar, [INFO] [stderr] | ^^ help: convert the identifier to snake case: `im` [INFO] [stderr] [INFO] [stderr] warning: method `set_AF1` should have a snake case name [INFO] [stderr] --> src/lib.rs:94:13 [INFO] [stderr] | [INFO] [stderr] 94 | reg_access!(set_AF1, get_AF1, AF, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_af1` [INFO] [stderr] [INFO] [stderr] warning: method `get_AF1` should have a snake case name [INFO] [stderr] --> src/lib.rs:94:22 [INFO] [stderr] | [INFO] [stderr] 94 | reg_access!(set_AF1, get_AF1, AF, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_af1` [INFO] [stderr] [INFO] [stderr] warning: method `set_BC1` should have a snake case name [INFO] [stderr] --> src/lib.rs:95:13 [INFO] [stderr] | [INFO] [stderr] 95 | reg_access!(set_BC1, get_BC1, BC, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_bc1` [INFO] [stderr] [INFO] [stderr] warning: method `get_BC1` should have a snake case name [INFO] [stderr] --> src/lib.rs:95:22 [INFO] [stderr] | [INFO] [stderr] 95 | reg_access!(set_BC1, get_BC1, BC, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_bc1` [INFO] [stderr] [INFO] [stderr] warning: method `set_DE1` should have a snake case name [INFO] [stderr] --> src/lib.rs:96:13 [INFO] [stderr] | [INFO] [stderr] 96 | reg_access!(set_DE1, get_DE1, DE, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_de1` [INFO] [stderr] [INFO] [stderr] warning: method `get_DE1` should have a snake case name [INFO] [stderr] --> src/lib.rs:96:22 [INFO] [stderr] | [INFO] [stderr] 96 | reg_access!(set_DE1, get_DE1, DE, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_de1` [INFO] [stderr] [INFO] [stderr] warning: method `set_HL1` should have a snake case name [INFO] [stderr] --> src/lib.rs:97:13 [INFO] [stderr] | [INFO] [stderr] 97 | reg_access!(set_HL1, get_HL1, HL, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_hl1` [INFO] [stderr] [INFO] [stderr] warning: method `get_HL1` should have a snake case name [INFO] [stderr] --> src/lib.rs:97:22 [INFO] [stderr] | [INFO] [stderr] 97 | reg_access!(set_HL1, get_HL1, HL, R1, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_hl1` [INFO] [stderr] [INFO] [stderr] warning: method `set_AF2` should have a snake case name [INFO] [stderr] --> src/lib.rs:98:13 [INFO] [stderr] | [INFO] [stderr] 98 | reg_access!(set_AF2, get_AF2, AF, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_af2` [INFO] [stderr] [INFO] [stderr] warning: method `get_AF2` should have a snake case name [INFO] [stderr] --> src/lib.rs:98:22 [INFO] [stderr] | [INFO] [stderr] 98 | reg_access!(set_AF2, get_AF2, AF, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_af2` [INFO] [stderr] [INFO] [stderr] warning: method `set_BC2` should have a snake case name [INFO] [stderr] --> src/lib.rs:99:13 [INFO] [stderr] | [INFO] [stderr] 99 | reg_access!(set_BC2, get_BC2, BC, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_bc2` [INFO] [stderr] [INFO] [stderr] warning: method `get_BC2` should have a snake case name [INFO] [stderr] --> src/lib.rs:99:22 [INFO] [stderr] | [INFO] [stderr] 99 | reg_access!(set_BC2, get_BC2, BC, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_bc2` [INFO] [stderr] [INFO] [stderr] warning: method `set_DE2` should have a snake case name [INFO] [stderr] --> src/lib.rs:100:13 [INFO] [stderr] | [INFO] [stderr] 100 | reg_access!(set_DE2, get_DE2, DE, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_de2` [INFO] [stderr] [INFO] [stderr] warning: method `get_DE2` should have a snake case name [INFO] [stderr] --> src/lib.rs:100:22 [INFO] [stderr] | [INFO] [stderr] 100 | reg_access!(set_DE2, get_DE2, DE, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_de2` [INFO] [stderr] [INFO] [stderr] warning: method `set_HL2` should have a snake case name [INFO] [stderr] --> src/lib.rs:101:13 [INFO] [stderr] | [INFO] [stderr] 101 | reg_access!(set_HL2, get_HL2, HL, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_hl2` [INFO] [stderr] [INFO] [stderr] warning: method `get_HL2` should have a snake case name [INFO] [stderr] --> src/lib.rs:101:22 [INFO] [stderr] | [INFO] [stderr] 101 | reg_access!(set_HL2, get_HL2, HL, R2, u16); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `get_hl2` [INFO] [stderr] [INFO] [stderr] warning: method `set_IY` should have a snake case name [INFO] [stderr] --> src/lib.rs:102:13 [INFO] [stderr] | [INFO] [stderr] 102 | reg_access!(set_IY, get_IY, IY, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `set_iy` [INFO] [stderr] [INFO] [stderr] warning: method `get_IY` should have a snake case name [INFO] [stderr] --> src/lib.rs:102:22 [INFO] [stderr] | [INFO] [stderr] 102 | reg_access!(set_IY, get_IY, IY, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `get_iy` [INFO] [stderr] [INFO] [stderr] warning: method `set_IX` should have a snake case name [INFO] [stderr] --> src/lib.rs:103:13 [INFO] [stderr] | [INFO] [stderr] 103 | reg_access!(set_IX, get_IX, IX, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `set_ix` [INFO] [stderr] [INFO] [stderr] warning: method `get_IX` should have a snake case name [INFO] [stderr] --> src/lib.rs:103:22 [INFO] [stderr] | [INFO] [stderr] 103 | reg_access!(set_IX, get_IX, IX, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `get_ix` [INFO] [stderr] [INFO] [stderr] warning: method `set_SP` should have a snake case name [INFO] [stderr] --> src/lib.rs:104:13 [INFO] [stderr] | [INFO] [stderr] 104 | reg_access!(set_SP, get_SP, SP, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `set_sp` [INFO] [stderr] [INFO] [stderr] warning: method `get_SP` should have a snake case name [INFO] [stderr] --> src/lib.rs:104:22 [INFO] [stderr] | [INFO] [stderr] 104 | reg_access!(set_SP, get_SP, SP, R1, u16); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `get_sp` [INFO] [stderr] [INFO] [stderr] warning: `extern` block uses type `UserData` which is not FFI-safe: this struct has unspecified layout [INFO] [stderr] --> src/lib.rs:174:24 [INFO] [stderr] | [INFO] [stderr] 174 | fn Z80Execute(ctx: *mut Context); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(improper_ctypes)]` on by default [INFO] [stderr] = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct [INFO] [stderr] note: type defined here [INFO] [stderr] --> src/lib.rs:9:1 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct UserData; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `extern` block uses type `UserData` which is not FFI-safe: this struct has unspecified layout [INFO] [stderr] --> src/lib.rs:175:31 [INFO] [stderr] | [INFO] [stderr] 175 | fn Z80ExecuteTStates(ctx: *mut Context, tstates: c_uint) -> [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct [INFO] [stderr] note: type defined here [INFO] [stderr] --> src/lib.rs:9:1 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct UserData; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `extern` block uses type `UserData` which is not FFI-safe: this struct has unspecified layout [INFO] [stderr] --> src/lib.rs:178:22 [INFO] [stderr] | [INFO] [stderr] 178 | fn Z80RESET(ctx: *mut Context); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct [INFO] [stderr] note: type defined here [INFO] [stderr] --> src/lib.rs:9:1 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct UserData; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `extern` block uses type `UserData` which is not FFI-safe: this struct has unspecified layout [INFO] [stderr] --> src/lib.rs:179:20 [INFO] [stderr] | [INFO] [stderr] 179 | fn Z80INT(ctx: *mut Context, value: c_uchar); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct [INFO] [stderr] note: type defined here [INFO] [stderr] --> src/lib.rs:9:1 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct UserData; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `extern` block uses type `UserData` which is not FFI-safe: this struct has unspecified layout [INFO] [stderr] --> src/lib.rs:180:20 [INFO] [stderr] | [INFO] [stderr] 180 | fn Z80NMI(ctx: *mut Context); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct [INFO] [stderr] note: type defined here [INFO] [stderr] --> src/lib.rs:9:1 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct UserData; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error: linking with `cc` failed: exit code: 1 [INFO] [stderr] | [INFO] [stderr] = note: "cc" "-Wl,--as-needed" "-Wl,-z,noexecstack" "-m64" "-L" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib" "/opt/rustwide/target/debug/deps/z80-182e164fa3e8bce7.z80.6woykznc-cgu.0.rcgu.o" "/opt/rustwide/target/debug/deps/z80-182e164fa3e8bce7.z80.6woykznc-cgu.1.rcgu.o" "/opt/rustwide/target/debug/deps/z80-182e164fa3e8bce7.z80.6woykznc-cgu.2.rcgu.o" "/opt/rustwide/target/debug/deps/z80-182e164fa3e8bce7.z80.6woykznc-cgu.3.rcgu.o" "/opt/rustwide/target/debug/deps/z80-182e164fa3e8bce7.z80.6woykznc-cgu.4.rcgu.o" "-o" "/opt/rustwide/target/debug/deps/z80-182e164fa3e8bce7" "/opt/rustwide/target/debug/deps/z80-182e164fa3e8bce7.50tr7e5i0258rky0.rcgu.o" "-Wl,--gc-sections" "-pie" "-Wl,-zrelro" "-Wl,-znow" "-nodefaultlibs" "-L" "/opt/rustwide/target/debug/deps" "-L" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-lz80" "-Wl,-Bstatic" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libtest-8b6fbd25e1766083.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libterm-bd8f21e3bdd6cbdc.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libgetopts-bfcad117c6a632af.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libunicode_width-79a1f91e8ce4eb83.rlib" "/opt/rustwide/target/debug/deps/liblibc-a3b13f6b27abcc70.rlib" "-Wl,--start-group" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libstd-12ce12f1efc08aa3.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libpanic_unwind-5d3cd1b3ddab72e4.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libbacktrace-f8222943dfd167e2.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libbacktrace_sys-0cd00b2d3108cd48.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/librustc_demangle-485c05ba6ce1b438.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libhashbrown-63e6b1072426ba59.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/librustc_std_workspace_alloc-a421aff1d43911ee.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libunwind-3deef8ef4fe80dff.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libcfg_if-f65a176f0586269e.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/liblibc-ad46d4080f4d7e57.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/liballoc-da6c590582bf0885.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/librustc_std_workspace_core-837ca740df32db0a.rlib" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libcore-db27c965e824589f.rlib" "-Wl,--end-group" "/opt/rustwide/rustup-home/toolchains/1.38.0-x86_64-unknown-linux-gnu/lib/rustlib/x86_64-unknown-linux-gnu/lib/libcompiler_builtins-68a4f8466685ed76.rlib" "-Wl,-Bdynamic" "-lutil" "-lutil" "-ldl" "-lrt" "-lpthread" "-lgcc_s" "-lc" "-lm" "-lrt" "-lpthread" "-lutil" "-lutil" [INFO] [stderr] = note: /usr/bin/ld: cannot find -lz80 [INFO] [stderr] collect2: error: ld returned 1 exit status [INFO] [stderr] [INFO] [stderr] [INFO] [stderr] error: aborting due to previous error [INFO] [stderr] [INFO] [stderr] error: Could not compile `libz80-rs`. [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] running `"docker" "inspect" "0ab238a7ed4ca9e96e961c625dcacd58ce9ac4eea0a4cdf0892f9563c62dbf92"` [INFO] running `"docker" "rm" "-f" "0ab238a7ed4ca9e96e961c625dcacd58ce9ac4eea0a4cdf0892f9563c62dbf92"` [INFO] [stdout] 0ab238a7ed4ca9e96e961c625dcacd58ce9ac4eea0a4cdf0892f9563c62dbf92