[INFO] fetching crate redis-module 2.0.7...
[INFO] testing redis-module-2.0.7 against beta-2026-04-21 for beta-1.96-2
[INFO] extracting crate redis-module 2.0.7 into /workspace/builds/worker-1-tc2/source
[INFO] started tweaking crates.io crate redis-module 2.0.7
[INFO] removed 0 missing examples
[INFO] finished tweaking crates.io crate redis-module 2.0.7
[INFO] tweaked toml for crates.io crate redis-module 2.0.7 written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate redis-module 2.0.7 on toolchain beta-2026-04-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate redis-module 2.0.7 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" "+beta-2026-04-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 3a3701e819f48ef0d0b923efa6ac150b79c3697d2b87e0beca4b6bd2f15b657d
[INFO] running `Command { std: "docker" "start" "-a" "3a3701e819f48ef0d0b923efa6ac150b79c3697d2b87e0beca4b6bd2f15b657d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "3a3701e819f48ef0d0b923efa6ac150b79c3697d2b87e0beca4b6bd2f15b657d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3a3701e819f48ef0d0b923efa6ac150b79c3697d2b87e0beca4b6bd2f15b657d", kill_on_drop: false }`
[INFO] [stdout] 3a3701e819f48ef0d0b923efa6ac150b79c3697d2b87e0beca4b6bd2f15b657d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-04-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 15a111f3bfc8a92c130f07ddbb3a5fde5e892bae8b751e7be97c563a191b61b3
[INFO] running `Command { std: "docker" "start" "-a" "15a111f3bfc8a92c130f07ddbb3a5fde5e892bae8b751e7be97c563a191b61b3", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.149
[INFO] [stderr]    Compiling glob v0.3.1
[INFO] [stderr]    Compiling rustix v0.38.20
[INFO] [stderr]    Compiling prettyplease v0.2.15
[INFO] [stderr]    Compiling linux-raw-sys v0.4.10
[INFO] [stderr]    Compiling bitflags v2.4.1
[INFO] [stderr]    Compiling regex-syntax v0.8.2
[INFO] [stderr]    Compiling syn v2.0.38
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling memchr v2.6.4
[INFO] [stderr]    Compiling clang-sys v1.6.1
[INFO] [stderr]    Compiling libloading v0.7.4
[INFO] [stderr]    Compiling num-traits v0.2.17
[INFO] [stderr]    Compiling lazy_static v1.4.0
[INFO] [stderr]    Compiling bindgen v0.66.1
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling either v1.9.0
[INFO] [stderr]    Compiling home v0.5.5
[INFO] [stderr]    Compiling memoffset v0.7.1
[INFO] [stderr]    Compiling log v0.4.20
[INFO] [stderr]    Compiling peeking_take_while v0.1.2
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling unicode-xid v0.0.4
[INFO] [stderr]    Compiling shlex v1.2.0
[INFO] [stderr]    Compiling lazycell v1.3.0
[INFO] [stderr]    Compiling cc v1.0.83
[INFO] [stderr]    Compiling synom v0.11.3
[INFO] [stderr]    Compiling regex-automata v0.4.3
[INFO] [stderr]    Compiling which v4.4.2
[INFO] [stderr]    Compiling backtrace v0.3.69
[INFO] [stderr]    Compiling gimli v0.28.0
[INFO] [stderr]    Compiling serde v1.0.189
[INFO] [stderr]    Compiling quote v0.3.15
[INFO] [stderr]    Compiling syn v0.11.11
[INFO] [stderr]    Compiling cexpr v0.6.0
[INFO] [stderr]    Compiling regex v1.10.2
[INFO] [stderr]    Compiling miniz_oxide v0.7.1
[INFO] [stderr]    Compiling addr2line v0.21.0
[INFO] [stderr]    Compiling num-traits v0.1.43
[INFO] [stderr]    Compiling object v0.32.1
[INFO] [stderr]    Compiling rustc-demangle v0.1.23
[INFO] [stderr]    Compiling linkme-impl v0.3.17
[INFO] [stderr]    Compiling serde_derive v1.0.189
[INFO] [stderr]    Compiling nix v0.26.4
[INFO] [stderr]    Compiling linkme v0.3.17
[INFO] [stderr]    Compiling enum-primitive-derive v0.1.2
[INFO] [stderr]    Compiling strum_macros v0.24.3
[INFO] [stderr]    Compiling redis-module-macros-internals v2.0.7
[INFO] [stderr]    Compiling redis-module v2.0.7 (/opt/rustwide/workdir)
[INFO] [stdout] warning: calling this function with a null pointer is undefined behavior, even if the result of the function is unused
[INFO] [stdout]    --> src/raw.rs:274:31
[INFO] [stdout]     |
[INFO] [stdout] 274 |             String::from_utf8(slice::from_raw_parts(format, 3).to_vec()).ok()?,
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: for more information, visit <https://doc.rust-lang.org/std/ptr/index.html> and <https://doc.rust-lang.org/reference/behavior-considered-undefined.html>
[INFO] [stdout] note: null pointer originates from here
[INFO] [stdout]    --> src/raw.rs:266:33
[INFO] [stdout]     |
[INFO] [stdout] 266 |         let format: *const u8 = ptr::null();
[INFO] [stdout]     |                                 ^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(invalid_null_arguments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/stream.rs:22:14
[INFO] [stdout]    |
[INFO] [stdout] 22 |         key: &RedisKey,
[INFO] [stdout]    |              ^^^^^^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 27 |     ) -> Result<StreamIterator, RedisError> {
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 27 |     ) -> Result<StreamIterator<'_>, RedisError> {
[INFO] [stdout]    |                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/context/mod.rs:856:14
[INFO] [stdout]     |
[INFO] [stdout] 856 |     unsafe { Box::from_raw(pd as *mut Option<F>) };
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 856 |     unsafe { let _ = Box::from_raw(pd as *mut Option<F>); };
[INFO] [stdout]     |              +++++++                                    +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]     --> src/context/mod.rs:1218:48
[INFO] [stdout]      |
[INFO] [stdout] 1218 |     pub fn add_section(self, name: &'a str) -> InfoContextBuilderSectionBuilder {
[INFO] [stdout]      |                                     --         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]      |                                     |
[INFO] [stdout]      |                                     the lifetime is named here
[INFO] [stdout]      |
[INFO] [stdout]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]      |
[INFO] [stdout] 1218 |     pub fn add_section(self, name: &'a str) -> InfoContextBuilderSectionBuilder<'a> {
[INFO] [stdout]      |                                                                                ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `CString::from_raw` that must be used
[INFO] [stdout]    --> src/context/commands.rs:455:28
[INFO] [stdout]     |
[INFO] [stdout] 455 |                     unsafe{CString::from_raw(v.notes as *mut c_char)};
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(from_raw(ptr))` if you intend to drop the `CString`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 455 |                     unsafe{let _ = CString::from_raw(v.notes as *mut c_char);};
[INFO] [stdout]     |                            +++++++                                          +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `CString::from_raw` that must be used
[INFO] [stdout]    --> src/context/commands.rs:460:32
[INFO] [stdout]     |
[INFO] [stdout] 460 |                         unsafe{CString::from_raw(v.bs.keyword.keyword as *mut c_char)};
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(from_raw(ptr))` if you intend to drop the `CString`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 460 |                         unsafe{let _ = CString::from_raw(v.bs.keyword.keyword as *mut c_char);};
[INFO] [stdout]     |                                +++++++                                                       +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/key.rs:170:32
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub fn get_stream_iterator(&self, reverse: bool) -> Result<StreamIterator, RedisError> {
[INFO] [stdout]     |                                ^^^^^                           ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                |
[INFO] [stdout]     |                                the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub fn get_stream_iterator(&self, reverse: bool) -> Result<StreamIterator<'_>, RedisError> {
[INFO] [stdout]     |                                                                              ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/key.rs:175:9
[INFO] [stdout]     |
[INFO] [stdout] 175 |         &self,
[INFO] [stdout]     |         ^^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 180 |     ) -> Result<StreamIterator, RedisError> {
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 180 |     ) -> Result<StreamIterator<'_>, RedisError> {
[INFO] [stdout]     |                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/key.rs:238:26
[INFO] [stdout]     |
[INFO] [stdout] 238 |     pub fn as_string_dma(&self) -> Result<StringDMA, RedisError> {
[INFO] [stdout]     |                          ^^^^^            ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 238 |     pub fn as_string_dma(&self) -> Result<StringDMA<'_>, RedisError> {
[INFO] [stdout]     |                                                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]    --> src/logging.rs:160:29
[INFO] [stdout]     |
[INFO] [stdout] 160 |             log::set_logger(&LOGGER).map(|()| log::set_max_level(log::LevelFilter::Trace))
[INFO] [stdout]     |                             ^^^^^^^ shared reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` (part of `#[warn(rust_2024_compatibility)]`) on by default
[INFO] [stdout] help: use `&raw const` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 160 |             log::set_logger(&raw const LOGGER).map(|()| log::set_max_level(log::LevelFilter::Trace))
[INFO] [stdout]     |                              +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 18s
[INFO] running `Command { std: "docker" "inspect" "15a111f3bfc8a92c130f07ddbb3a5fde5e892bae8b751e7be97c563a191b61b3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "15a111f3bfc8a92c130f07ddbb3a5fde5e892bae8b751e7be97c563a191b61b3", kill_on_drop: false }`
[INFO] [stdout] 15a111f3bfc8a92c130f07ddbb3a5fde5e892bae8b751e7be97c563a191b61b3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-04-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0dcb4a0d79277f93ab790d5b1aa37ecc39e4a78531b43db2a19f22def7cee1cc
[INFO] running `Command { std: "docker" "start" "-a" "0dcb4a0d79277f93ab790d5b1aa37ecc39e4a78531b43db2a19f22def7cee1cc", kill_on_drop: false }`
[INFO] [stderr]    Compiling bindgen v0.66.1
[INFO] [stderr]    Compiling anyhow v1.0.75
[INFO] [stderr]    Compiling combine v4.6.6
[INFO] [stderr]    Compiling url v2.4.1
[INFO] [stderr]    Compiling redis-module-macros-internals v2.0.7
[INFO] [stderr]    Compiling socket2 v0.4.10
[INFO] [stderr]    Compiling sha1_smol v1.0.0
[INFO] [stderr]    Compiling redis v0.23.3
[INFO] [stderr]    Compiling redis-module v2.0.7 (/opt/rustwide/workdir)
[INFO] [stdout] warning: calling this function with a null pointer is undefined behavior, even if the result of the function is unused
[INFO] [stdout]    --> src/raw.rs:274:31
[INFO] [stdout]     |
[INFO] [stdout] 274 |             String::from_utf8(slice::from_raw_parts(format, 3).to_vec()).ok()?,
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: for more information, visit <https://doc.rust-lang.org/std/ptr/index.html> and <https://doc.rust-lang.org/reference/behavior-considered-undefined.html>
[INFO] [stdout] note: null pointer originates from here
[INFO] [stdout]    --> src/raw.rs:266:33
[INFO] [stdout]     |
[INFO] [stdout] 266 |         let format: *const u8 = ptr::null();
[INFO] [stdout]     |                                 ^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(invalid_null_arguments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/stream.rs:22:14
[INFO] [stdout]    |
[INFO] [stdout] 22 |         key: &RedisKey,
[INFO] [stdout]    |              ^^^^^^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 27 |     ) -> Result<StreamIterator, RedisError> {
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 27 |     ) -> Result<StreamIterator<'_>, RedisError> {
[INFO] [stdout]    |                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/context/mod.rs:856:14
[INFO] [stdout]     |
[INFO] [stdout] 856 |     unsafe { Box::from_raw(pd as *mut Option<F>) };
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 856 |     unsafe { let _ = Box::from_raw(pd as *mut Option<F>); };
[INFO] [stdout]     |              +++++++                                    +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]     --> src/context/mod.rs:1218:48
[INFO] [stdout]      |
[INFO] [stdout] 1218 |     pub fn add_section(self, name: &'a str) -> InfoContextBuilderSectionBuilder {
[INFO] [stdout]      |                                     --         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]      |                                     |
[INFO] [stdout]      |                                     the lifetime is named here
[INFO] [stdout]      |
[INFO] [stdout]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]      |
[INFO] [stdout] 1218 |     pub fn add_section(self, name: &'a str) -> InfoContextBuilderSectionBuilder<'a> {
[INFO] [stdout]      |                                                                                ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `CString::from_raw` that must be used
[INFO] [stdout]    --> src/context/commands.rs:455:28
[INFO] [stdout]     |
[INFO] [stdout] 455 |                     unsafe{CString::from_raw(v.notes as *mut c_char)};
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(from_raw(ptr))` if you intend to drop the `CString`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 455 |                     unsafe{let _ = CString::from_raw(v.notes as *mut c_char);};
[INFO] [stdout]     |                            +++++++                                          +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `CString::from_raw` that must be used
[INFO] [stdout]    --> src/context/commands.rs:460:32
[INFO] [stdout]     |
[INFO] [stdout] 460 |                         unsafe{CString::from_raw(v.bs.keyword.keyword as *mut c_char)};
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(from_raw(ptr))` if you intend to drop the `CString`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 460 |                         unsafe{let _ = CString::from_raw(v.bs.keyword.keyword as *mut c_char);};
[INFO] [stdout]     |                                +++++++                                                       +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/key.rs:170:32
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub fn get_stream_iterator(&self, reverse: bool) -> Result<StreamIterator, RedisError> {
[INFO] [stdout]     |                                ^^^^^                           ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                |
[INFO] [stdout]     |                                the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub fn get_stream_iterator(&self, reverse: bool) -> Result<StreamIterator<'_>, RedisError> {
[INFO] [stdout]     |                                                                              ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/key.rs:175:9
[INFO] [stdout]     |
[INFO] [stdout] 175 |         &self,
[INFO] [stdout]     |         ^^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 180 |     ) -> Result<StreamIterator, RedisError> {
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 180 |     ) -> Result<StreamIterator<'_>, RedisError> {
[INFO] [stdout]     |                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/key.rs:238:26
[INFO] [stdout]     |
[INFO] [stdout] 238 |     pub fn as_string_dma(&self) -> Result<StringDMA, RedisError> {
[INFO] [stdout]     |                          ^^^^^            ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 238 |     pub fn as_string_dma(&self) -> Result<StringDMA<'_>, RedisError> {
[INFO] [stdout]     |                                                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]    --> src/logging.rs:160:29
[INFO] [stdout]     |
[INFO] [stdout] 160 |             log::set_logger(&LOGGER).map(|()| log::set_max_level(log::LevelFilter::Trace))
[INFO] [stdout]     |                             ^^^^^^^ shared reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` (part of `#[warn(rust_2024_compatibility)]`) on by default
[INFO] [stdout] help: use `&raw const` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 160 |             log::set_logger(&raw const LOGGER).map(|()| log::set_max_level(log::LevelFilter::Trace))
[INFO] [stdout]     |                              +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: calling this function with a null pointer is undefined behavior, even if the result of the function is unused
[INFO] [stdout]    --> src/raw.rs:274:31
[INFO] [stdout]     |
[INFO] [stdout] 274 |             String::from_utf8(slice::from_raw_parts(format, 3).to_vec()).ok()?,
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: for more information, visit <https://doc.rust-lang.org/std/ptr/index.html> and <https://doc.rust-lang.org/reference/behavior-considered-undefined.html>
[INFO] [stdout] note: null pointer originates from here
[INFO] [stdout]    --> src/raw.rs:266:33
[INFO] [stdout]     |
[INFO] [stdout] 266 |         let format: *const u8 = ptr::null();
[INFO] [stdout]     |                                 ^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(invalid_null_arguments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/stream.rs:22:14
[INFO] [stdout]    |
[INFO] [stdout] 22 |         key: &RedisKey,
[INFO] [stdout]    |              ^^^^^^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 27 |     ) -> Result<StreamIterator, RedisError> {
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 27 |     ) -> Result<StreamIterator<'_>, RedisError> {
[INFO] [stdout]    |                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]    --> src/context/mod.rs:856:14
[INFO] [stdout]     |
[INFO] [stdout] 856 |     unsafe { Box::from_raw(pd as *mut Option<F>) };
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 856 |     unsafe { let _ = Box::from_raw(pd as *mut Option<F>); };
[INFO] [stdout]     |              +++++++                                    +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]     --> src/context/mod.rs:1218:48
[INFO] [stdout]      |
[INFO] [stdout] 1218 |     pub fn add_section(self, name: &'a str) -> InfoContextBuilderSectionBuilder {
[INFO] [stdout]      |                                     --         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]      |                                     |
[INFO] [stdout]      |                                     the lifetime is named here
[INFO] [stdout]      |
[INFO] [stdout]      = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]      |
[INFO] [stdout] 1218 |     pub fn add_section(self, name: &'a str) -> InfoContextBuilderSectionBuilder<'a> {
[INFO] [stdout]      |                                                                                ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `CString::from_raw` that must be used
[INFO] [stdout]    --> src/context/commands.rs:455:28
[INFO] [stdout]     |
[INFO] [stdout] 455 |                     unsafe{CString::from_raw(v.notes as *mut c_char)};
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(from_raw(ptr))` if you intend to drop the `CString`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 455 |                     unsafe{let _ = CString::from_raw(v.notes as *mut c_char);};
[INFO] [stdout]     |                            +++++++                                          +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `CString::from_raw` that must be used
[INFO] [stdout]    --> src/context/commands.rs:460:32
[INFO] [stdout]     |
[INFO] [stdout] 460 |                         unsafe{CString::from_raw(v.bs.keyword.keyword as *mut c_char)};
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: call `drop(from_raw(ptr))` if you intend to drop the `CString`
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 460 |                         unsafe{let _ = CString::from_raw(v.bs.keyword.keyword as *mut c_char);};
[INFO] [stdout]     |                                +++++++                                                       +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/key.rs:170:32
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub fn get_stream_iterator(&self, reverse: bool) -> Result<StreamIterator, RedisError> {
[INFO] [stdout]     |                                ^^^^^                           ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                |
[INFO] [stdout]     |                                the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub fn get_stream_iterator(&self, reverse: bool) -> Result<StreamIterator<'_>, RedisError> {
[INFO] [stdout]     |                                                                              ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/key.rs:175:9
[INFO] [stdout]     |
[INFO] [stdout] 175 |         &self,
[INFO] [stdout]     |         ^^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 180 |     ) -> Result<StreamIterator, RedisError> {
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 180 |     ) -> Result<StreamIterator<'_>, RedisError> {
[INFO] [stdout]     |                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/key.rs:238:26
[INFO] [stdout]     |
[INFO] [stdout] 238 |     pub fn as_string_dma(&self) -> Result<StringDMA, RedisError> {
[INFO] [stdout]     |                          ^^^^^            ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 238 |     pub fn as_string_dma(&self) -> Result<StringDMA<'_>, RedisError> {
[INFO] [stdout]     |                                                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]    --> src/logging.rs:160:29
[INFO] [stdout]     |
[INFO] [stdout] 160 |             log::set_logger(&LOGGER).map(|()| log::set_max_level(log::LevelFilter::Trace))
[INFO] [stdout]     |                             ^^^^^^^ shared reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` (part of `#[warn(rust_2024_compatibility)]`) on by default
[INFO] [stdout] help: use `&raw const` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 160 |             log::set_logger(&raw const LOGGER).map(|()| log::set_max_level(log::LevelFilter::Trace))
[INFO] [stdout]     |                              +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `redis_module_macros`
[INFO] [stdout]  --> examples/server_events.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use redis_module_macros::{config_changed_event_handler, cron_event_handler, flush_event_handler};
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `redis_module_macros`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `redis_module_macros`, use `cargo add redis_module_macros` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `redis_module_macros`
[INFO] [stdout]  --> examples/info_handler_multiple_sections.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use redis_module_macros::{info_command_handler, InfoSection};
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `redis_module_macros`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `redis_module_macros`, use `cargo add redis_module_macros` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0432`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `redis-module` (example "server_events") due to 1 previous error
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error[E0277]: the trait bound `(String, Vec<(String, ...)>): From<...>` is not satisfied
[INFO] [stdout]     --> examples/info_handler_multiple_sections.rs:20:35
[INFO] [stdout]      |
[INFO] [stdout]   20 |     let _ = ctx.build_one_section(data)?;
[INFO] [stdout]      |                 ----------------- ^^^^ unsatisfied trait bound
[INFO] [stdout]      |                 |
[INFO] [stdout]      |                 required by a bound introduced by this call
[INFO] [stdout]      |
[INFO] [stdout]      = help: the trait `From<InfoSection1>` is not implemented for `(std::string::String, Vec<(std::string::String, InfoContextBuilderFieldTopLevelValue)>)`
[INFO] [stdout]      = help: the following other types implement trait `From<T>`:
[INFO] [stdout]                `(T, T)` implements `From<[T; 2]>`
[INFO] [stdout]                `(T, T, T)` implements `From<[T; 3]>`
[INFO] [stdout]                `(T, T, T, T)` implements `From<[T; 4]>`
[INFO] [stdout]                `(T, T, T, T, T)` implements `From<[T; 5]>`
[INFO] [stdout]                `(T, T, T, T, T, T)` implements `From<[T; 6]>`
[INFO] [stdout]                `(T, T, T, T, T, T, T)` implements `From<[T; 7]>`
[INFO] [stdout]                `(T, T, T, T, T, T, T, T)` implements `From<[T; 8]>`
[INFO] [stdout]                `(T, T, T, T, T, T, T, T, T)` implements `From<[T; 9]>`
[INFO] [stdout]              and 6 others
[INFO] [stdout]      = note: required for `InfoSection1` to implement `Into<(std::string::String, Vec<(std::string::String, InfoContextBuilderFieldTopLevelValue)>)>`
[INFO] [stdout] note: required by a bound in `InfoContext::build_one_section`
[INFO] [stdout]     --> src/context/mod.rs:1259:33
[INFO] [stdout]      |
[INFO] [stdout] 1259 |     pub fn build_one_section<T: Into<OneInfoSectionData>>(&self, data: T) -> RedisResult<()> {
[INFO] [stdout]      |                                 ^^^^^^^^^^^^^^^^^^^^^^^^ required by this bound in `InfoContext::build_one_section`
[INFO] [stdout]      = note: the full name for the type has been written to '/opt/rustwide/target/debug/examples/info_handler_multiple_sections-69e43265477297bd.long-type-17811838812911967964.txt'
[INFO] [stdout]      = note: consider using `--verbose` to print the full type name to the console
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `(String, Vec<(String, ...)>): From<...>` is not satisfied
[INFO] [stdout]     --> examples/info_handler_multiple_sections.rs:26:27
[INFO] [stdout]      |
[INFO] [stdout]   26 |     ctx.build_one_section(data)
[INFO] [stdout]      |         ----------------- ^^^^ unsatisfied trait bound
[INFO] [stdout]      |         |
[INFO] [stdout]      |         required by a bound introduced by this call
[INFO] [stdout]      |
[INFO] [stdout]      = help: the trait `From<InfoSection2>` is not implemented for `(std::string::String, Vec<(std::string::String, InfoContextBuilderFieldTopLevelValue)>)`
[INFO] [stdout]      = help: the following other types implement trait `From<T>`:
[INFO] [stdout]                `(T, T)` implements `From<[T; 2]>`
[INFO] [stdout]                `(T, T, T)` implements `From<[T; 3]>`
[INFO] [stdout]                `(T, T, T, T)` implements `From<[T; 4]>`
[INFO] [stdout]                `(T, T, T, T, T)` implements `From<[T; 5]>`
[INFO] [stdout]                `(T, T, T, T, T, T)` implements `From<[T; 6]>`
[INFO] [stdout]                `(T, T, T, T, T, T, T)` implements `From<[T; 7]>`
[INFO] [stdout]                `(T, T, T, T, T, T, T, T)` implements `From<[T; 8]>`
[INFO] [stdout]                `(T, T, T, T, T, T, T, T, T)` implements `From<[T; 9]>`
[INFO] [stdout]              and 6 others
[INFO] [stdout]      = note: required for `InfoSection2` to implement `Into<(std::string::String, Vec<(std::string::String, InfoContextBuilderFieldTopLevelValue)>)>`
[INFO] [stdout] note: required by a bound in `InfoContext::build_one_section`
[INFO] [stdout]     --> src/context/mod.rs:1259:33
[INFO] [stdout]      |
[INFO] [stdout] 1259 |     pub fn build_one_section<T: Into<OneInfoSectionData>>(&self, data: T) -> RedisResult<()> {
[INFO] [stdout]      |                                 ^^^^^^^^^^^^^^^^^^^^^^^^ required by this bound in `InfoContext::build_one_section`
[INFO] [stdout]      = note: the full name for the type has been written to '/opt/rustwide/target/debug/examples/info_handler_multiple_sections-69e43265477297bd.long-type-9835333265614937503.txt'
[INFO] [stdout]      = note: consider using `--verbose` to print the full type name to the console
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0277, E0432.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0277`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `redis-module` (example "info_handler_multiple_sections") due to 3 previous errors
[INFO] running `Command { std: "docker" "inspect" "0dcb4a0d79277f93ab790d5b1aa37ecc39e4a78531b43db2a19f22def7cee1cc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0dcb4a0d79277f93ab790d5b1aa37ecc39e4a78531b43db2a19f22def7cee1cc", kill_on_drop: false }`
[INFO] [stdout] 0dcb4a0d79277f93ab790d5b1aa37ecc39e4a78531b43db2a19f22def7cee1cc
