[INFO] fetching crate phaneron 0.1.2...
[INFO] testing phaneron-0.1.2 against beta-2025-10-28 for beta-1.92-2
[INFO] extracting crate phaneron 0.1.2 into /workspace/builds/worker-0-tc2/source
[INFO] started tweaking crates.io crate phaneron 0.1.2
[INFO] finished tweaking crates.io crate phaneron 0.1.2
[INFO] tweaked toml for crates.io crate phaneron 0.1.2 written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate phaneron 0.1.2 on toolchain beta-2025-10-28
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-10-28" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate phaneron 0.1.2 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-2025-10-28" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-10-28" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] b3a34d5db07740a5cca4d975714e71fbd6f3e59f1a5c8e43e0a6ac0b1f77fbd7
[INFO] running `Command { std: "docker" "start" "-a" "b3a34d5db07740a5cca4d975714e71fbd6f3e59f1a5c8e43e0a6ac0b1f77fbd7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "b3a34d5db07740a5cca4d975714e71fbd6f3e59f1a5c8e43e0a6ac0b1f77fbd7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b3a34d5db07740a5cca4d975714e71fbd6f3e59f1a5c8e43e0a6ac0b1f77fbd7", kill_on_drop: false }`
[INFO] [stdout] b3a34d5db07740a5cca4d975714e71fbd6f3e59f1a5c8e43e0a6ac0b1f77fbd7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-10-28" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] db188c5bc2b528c1478ff06de4c111e7b5d34de2199a74b7c3a50efc1d606b2e
[INFO] running `Command { std: "docker" "start" "-a" "db188c5bc2b528c1478ff06de4c111e7b5d34de2199a74b7c3a50efc1d606b2e", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v1.0.105
[INFO] [stderr]    Compiling libc v0.2.138
[INFO] [stderr]    Compiling futures-core v0.3.25
[INFO] [stderr]    Compiling serde_derive v1.0.149
[INFO] [stderr]    Compiling serde v1.0.149
[INFO] [stderr]    Compiling futures-sink v0.3.25
[INFO] [stderr]    Compiling itoa v1.0.5
[INFO] [stderr]    Compiling slab v0.4.7
[INFO] [stderr]    Compiling futures-task v0.3.25
[INFO] [stderr]    Compiling futures-channel v0.3.25
[INFO] [stderr]    Compiling tokio v1.26.0
[INFO] [stderr]    Compiling futures-util v0.3.25
[INFO] [stderr]    Compiling generic-array v0.14.6
[INFO] [stderr]    Compiling futures-io v0.3.25
[INFO] [stderr]    Compiling rustversion v1.0.12
[INFO] [stderr]    Compiling tracing-core v0.1.30
[INFO] [stderr]    Compiling http v0.2.9
[INFO] [stderr]    Compiling unicase v2.6.0
[INFO] [stderr]    Compiling indexmap v1.9.2
[INFO] [stderr]    Compiling core_extensions_proc_macros v1.5.3
[INFO] [stderr]    Compiling zstd-safe v5.0.2+zstd.1.5.2
[INFO] [stderr]    Compiling paste v1.0.11
[INFO] [stderr]    Compiling alloc-no-stdlib v2.0.4
[INFO] [stderr]    Compiling unicode-normalization v0.1.22
[INFO] [stderr]    Compiling crossbeam-utils v0.8.15
[INFO] [stderr]    Compiling alloc-stdlib v0.2.2
[INFO] [stderr]    Compiling io-lifetimes v1.0.3
[INFO] [stderr]    Compiling unicode-bidi v0.3.10
[INFO] [stderr]    Compiling ryu v1.0.12
[INFO] [stderr]    Compiling serde_json v1.0.91
[INFO] [stderr]    Compiling miniz_oxide v0.6.2
[INFO] [stderr]    Compiling mime_guess v2.0.4
[INFO] [stderr]    Compiling idna v0.3.0
[INFO] [stderr]    Compiling brotli-decompressor v2.3.4
[INFO] [stderr]    Compiling rustix v0.36.5
[INFO] [stderr]    Compiling mime v0.3.16
[INFO] [stderr]    Compiling async-trait v0.1.64
[INFO] [stderr]    Compiling bytemuck v1.12.3
[INFO] [stderr]    Compiling block-buffer v0.10.3
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling cpufeatures v0.2.5
[INFO] [stderr]    Compiling regex-syntax v0.6.28
[INFO] [stderr]    Compiling tstr_proc_macros v0.2.2
[INFO] [stderr]    Compiling opencl-sys v0.2.4
[INFO] [stderr]    Compiling axum-core v0.3.3
[INFO] [stderr]    Compiling digest v0.10.6
[INFO] [stderr]    Compiling hdrhistogram v7.5.2
[INFO] [stderr]    Compiling core_extensions v1.5.3
[INFO] [stderr]    Compiling safe_arch v0.6.0
[INFO] [stderr]    Compiling url v2.3.1
[INFO] [stderr]    Compiling try-lock v0.2.4
[INFO] [stderr]    Compiling typed-arena v2.0.2
[INFO] [stderr]    Compiling http-body v0.4.5
[INFO] [stderr]    Compiling flate2 v1.0.25
[INFO] [stderr]    Compiling sha1 v0.10.5
[INFO] [stderr]    Compiling linux-raw-sys v0.1.4
[INFO] [stderr]    Compiling tstr v0.2.3
[INFO] [stderr]    Compiling abi_stable_shared v0.11.0
[INFO] [stderr]    Compiling httpdate v1.0.2
[INFO] [stderr]    Compiling wide v0.7.6
[INFO] [stderr]    Compiling want v0.3.0
[INFO] [stderr]    Compiling generational-arena v0.2.8
[INFO] [stderr]    Compiling crossbeam-channel v0.5.7
[INFO] [stderr]    Compiling axum v0.6.10
[INFO] [stderr]    Compiling repr_offset v0.2.2
[INFO] [stderr]    Compiling approx v0.5.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.5
[INFO] [stderr]    Compiling jobserver v0.1.26
[INFO] [stderr]    Compiling getrandom v0.2.8
[INFO] [stderr]    Compiling mio v0.8.5
[INFO] [stderr]    Compiling signal-hook-registry v1.4.0
[INFO] [stderr]    Compiling socket2 v0.4.7
[INFO] [stderr]    Compiling num_cpus v1.14.0
[INFO] [stderr]    Compiling cc v1.0.77
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling brotli v3.3.4
[INFO] [stderr]    Compiling parking_lot v0.12.1
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling num-complex v0.4.3
[INFO] [stderr]    Compiling const_panic v0.2.7
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling http-range-header v0.3.0
[INFO] [stderr]    Compiling iri-string v0.7.0
[INFO] [stderr]    Compiling os_str_bytes v6.4.1
[INFO] [stderr]    Compiling anyhow v1.0.70
[INFO] [stderr]    Compiling base64 v0.20.0
[INFO] [stderr]    Compiling winnow v0.4.1
[INFO] [stderr]    Compiling cl3 v0.9.1
[INFO] [stderr]    Compiling tracing-log v0.1.3
[INFO] [stderr]    Compiling zstd-sys v2.0.7+zstd.1.5.4
[INFO] [stderr]    Compiling regex-automata v0.1.10
[INFO] [stderr]    Compiling clap_lex v0.3.1
[INFO] [stderr]    Compiling regex v1.7.0
[INFO] [stderr]    Compiling sharded-slab v0.1.4
[INFO] [stderr]    Compiling thread_local v1.1.4
[INFO] [stderr]    Compiling base64 v0.21.0
[INFO] [stderr]    Compiling matchit v0.7.0
[INFO] [stderr]    Compiling opencl3 v0.9.2
[INFO] [stderr]    Compiling simba v0.8.0
[INFO] [stderr]    Compiling is-terminal v0.4.2
[INFO] [stderr]    Compiling clap v4.1.4
[INFO] [stderr]    Compiling matchers v0.1.0
[INFO] [stderr]    Compiling as_derive_utils v0.11.0
[INFO] [stderr]    Compiling futures-macro v0.3.25
[INFO] [stderr]    Compiling tokio-macros v1.8.2
[INFO] [stderr]    Compiling tracing-attributes v0.1.23
[INFO] [stderr]    Compiling pin-project-internal v1.0.12
[INFO] [stderr]    Compiling thiserror-impl v1.0.37
[INFO] [stderr]    Compiling abi_stable_derive v0.11.0
[INFO] [stderr]    Compiling axum-macros v0.3.5
[INFO] [stderr]    Compiling nalgebra-macros v0.2.0
[INFO] [stderr]    Compiling tracing v0.1.37
[INFO] [stderr]    Compiling thiserror v1.0.37
[INFO] [stderr]    Compiling pin-project v1.0.12
[INFO] [stderr]    Compiling tungstenite v0.18.0
[INFO] [stderr]    Compiling tracing-subscriber v0.3.16
[INFO] [stderr]    Compiling zstd v0.11.2+zstd.1.5.2
[INFO] [stderr]    Compiling futures-executor v0.3.25
[INFO] [stderr]    Compiling futures v0.3.25
[INFO] [stderr]    Compiling nalgebra v0.32.1
[INFO] [stderr]    Compiling uuid v1.2.2
[INFO] [stderr]    Compiling serde_spanned v0.6.1
[INFO] [stderr]    Compiling toml_datetime v0.6.1
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling serde_path_to_error v0.1.10
[INFO] [stderr]    Compiling toml_edit v0.19.8
[INFO] [stderr]    Compiling tokio-util v0.7.4
[INFO] [stderr]    Compiling async-compression v0.3.15
[INFO] [stderr]    Compiling tokio-tungstenite v0.18.0
[INFO] [stderr]    Compiling hyper v0.14.24
[INFO] [stderr]    Compiling tower v0.4.13
[INFO] [stderr]    Compiling tokio-stream v0.1.12
[INFO] [stderr]    Compiling abi_stable v0.11.1
[INFO] [stderr]    Compiling tower-http v0.4.0
[INFO] [stderr]    Compiling toml v0.7.3
[INFO] [stderr]    Compiling phaneron-plugin v0.1.2
[INFO] [stderr]    Compiling phaneron v0.1.2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unexpected `cfg` condition name: `Debug`
[INFO] [stdout]   --> src/compute.rs:43:7
[INFO] [stdout]    |
[INFO] [stdout] 43 | #[cfg(Debug)]
[INFO] [stdout]    |       ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: expected names are: `docsrs`, `feature`, and `test` and 31 more
[INFO] [stdout]    = help: consider using a Cargo feature instead
[INFO] [stdout]    = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint:
[INFO] [stdout]             [lints.rust]
[INFO] [stdout]             unexpected_cfgs = { level = "warn", check-cfg = ['cfg(Debug)'] }
[INFO] [stdout]    = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(Debug)");` to the top of the `build.rs`
[INFO] [stdout]    = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout]    = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:357:40
[INFO] [stdout]     |
[INFO] [stdout] 357 |     pub async fn set_node_state(&self, graph_id: &GraphId, node_id: &NodeId, state: String) {
[INFO] [stdout]     |                                        ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `context`
[INFO] [stdout]   --> src/compute/audio_output.rs:46:9
[INFO] [stdout]    |
[INFO] [stdout] 46 |         context: &phaneron_plugin::types::FrameContext,
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `context`
[INFO] [stdout]   --> src/compute/video_output.rs:46:9
[INFO] [stdout]    |
[INFO] [stdout] 46 |         context: &phaneron_plugin::types::FrameContext,
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:351:39
[INFO] [stdout]     |
[INFO] [stdout] 351 |     pub async fn set_node_name(&self, graph_id: &GraphId, node_id: &NodeId, name: Option<String>) {
[INFO] [stdout]     |                                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:364:40
[INFO] [stdout]     |
[INFO] [stdout] 364 |     pub async fn get_node_state(&self, graph_id: &GraphId, node_id: &NodeId) -> Option<String> {
[INFO] [stdout]     |                                        ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:370:9
[INFO] [stdout]     |
[INFO] [stdout] 370 |         graph_id: &GraphId,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:384:9
[INFO] [stdout]     |
[INFO] [stdout] 384 |         graph_id: &GraphId,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `user_id` is never read
[INFO] [stdout]   --> src/api.rs:63:9
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct Client {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] 63 |     pub user_id: String,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Client` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FlipperState` is never constructed
[INFO] [stdout]   --> src/api/message.rs:54:12
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub struct FlipperState {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AudioBufferId` is never constructed
[INFO] [stdout]   --> src/compute/audio_frame.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct AudioBufferId(String);
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_from` is never used
[INFO] [stdout]   --> src/compute/audio_frame.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl AudioBufferId {
[INFO] [stdout]    | ------------------ associated function in this implementation
[INFO] [stdout] 26 |     pub fn new_from(id: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `id` is never read
[INFO] [stdout]   --> src/compute/audio_frame.rs:61:9
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct AudioFrame {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] 61 |     pub id: AudioFrameId,
[INFO] [stdout]    |         ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AudioFrame` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VideoBufferId` is never constructed
[INFO] [stdout]   --> src/compute/video_frame.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct VideoBufferId(String);
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_from` is never used
[INFO] [stdout]   --> src/compute/video_frame.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl VideoBufferId {
[INFO] [stdout]    | ------------------ associated function in this implementation
[INFO] [stdout] 29 |     pub fn new_from(id: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `width` and `height` are never read
[INFO] [stdout]   --> src/io.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct LoadedVideoFrame {
[INFO] [stdout]    |            ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub width: usize,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 46 |     pub height: usize,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `gamut_matrix` is never read
[INFO] [stdout]    --> src/load_save.rs:153:5
[INFO] [stdout]     |
[INFO] [stdout] 147 | pub struct Saver {
[INFO] [stdout]     |            ----- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 153 |     gamut_matrix: opencl3::memory::Buffer<opencl3::types::cl_float>,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:440:21
[INFO] [stdout]     |
[INFO] [stdout] 440 |     AudioInputAdded(NodeId, AudioInputId),
[INFO] [stdout]     |     --------------- ^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     field in this variant
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 440 -     AudioInputAdded(NodeId, AudioInputId),
[INFO] [stdout] 440 +     AudioInputAdded((), AudioInputId),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:441:21
[INFO] [stdout]     |
[INFO] [stdout] 441 |     VideoInputAdded(NodeId, VideoInputId),
[INFO] [stdout]     |     --------------- ^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     field in this variant
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 441 -     VideoInputAdded(NodeId, VideoInputId),
[INFO] [stdout] 441 +     VideoInputAdded((), VideoInputId),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:443:9
[INFO] [stdout]     |
[INFO] [stdout] 442 |     AudioOutputAdded(
[INFO] [stdout]     |     ---------------- field in this variant
[INFO] [stdout] 443 |         NodeId,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 443 -         NodeId,
[INFO] [stdout] 443 +         (),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:448:9
[INFO] [stdout]     |
[INFO] [stdout] 447 |     VideoOutputAdded(
[INFO] [stdout]     |     ---------------- field in this variant
[INFO] [stdout] 448 |         NodeId,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 448 -         NodeId,
[INFO] [stdout] 448 +         (),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `node_id` is never read
[INFO] [stdout]    --> src/node_context.rs:455:5
[INFO] [stdout]     |
[INFO] [stdout] 454 | struct NodeContextInner {
[INFO] [stdout]     |        ---------------- field in this struct
[INFO] [stdout] 455 |     node_id: NodeId,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_from` is never used
[INFO] [stdout]    --> src/plugins.rs:222:12
[INFO] [stdout]     |
[INFO] [stdout] 221 | impl PluginId {
[INFO] [stdout]     | ------------- associated function in this implementation
[INFO] [stdout] 222 |     pub fn new_from(id: String) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 25s
[INFO] running `Command { std: "docker" "inspect" "db188c5bc2b528c1478ff06de4c111e7b5d34de2199a74b7c3a50efc1d606b2e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "db188c5bc2b528c1478ff06de4c111e7b5d34de2199a74b7c3a50efc1d606b2e", kill_on_drop: false }`
[INFO] [stdout] db188c5bc2b528c1478ff06de4c111e7b5d34de2199a74b7c3a50efc1d606b2e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-10-28" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 64cb324a812493fd4b69f431924d712ddf8f7d9286bf7374548f932d2a876574
[INFO] running `Command { std: "docker" "start" "-a" "64cb324a812493fd4b69f431924d712ddf8f7d9286bf7374548f932d2a876574", kill_on_drop: false }`
[INFO] [stdout] warning: unexpected `cfg` condition name: `Debug`
[INFO] [stdout]   --> src/compute.rs:43:7
[INFO] [stdout]    |
[INFO] [stdout] 43 | #[cfg(Debug)]
[INFO] [stdout]    |       ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: expected names are: `docsrs`, `feature`, and `test` and 31 more
[INFO] [stdout]    = help: consider using a Cargo feature instead
[INFO] [stdout]    = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint:
[INFO] [stdout]             [lints.rust]
[INFO] [stdout]             unexpected_cfgs = { level = "warn", check-cfg = ['cfg(Debug)'] }
[INFO] [stdout]    = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(Debug)");` to the top of the `build.rs`
[INFO] [stdout]    = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout]    = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:357:40
[INFO] [stdout]     |
[INFO] [stdout] 357 |     pub async fn set_node_state(&self, graph_id: &GraphId, node_id: &NodeId, state: String) {
[INFO] [stdout]     |                                        ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `context`
[INFO] [stdout]   --> src/compute/audio_output.rs:46:9
[INFO] [stdout]    |
[INFO] [stdout] 46 |         context: &phaneron_plugin::types::FrameContext,
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `context`
[INFO] [stdout]   --> src/compute/video_output.rs:46:9
[INFO] [stdout]    |
[INFO] [stdout] 46 |         context: &phaneron_plugin::types::FrameContext,
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:351:39
[INFO] [stdout]     |
[INFO] [stdout] 351 |     pub async fn set_node_name(&self, graph_id: &GraphId, node_id: &NodeId, name: Option<String>) {
[INFO] [stdout]     |                                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:364:40
[INFO] [stdout]     |
[INFO] [stdout] 364 |     pub async fn get_node_state(&self, graph_id: &GraphId, node_id: &NodeId) -> Option<String> {
[INFO] [stdout]     |                                        ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:370:9
[INFO] [stdout]     |
[INFO] [stdout] 370 |         graph_id: &GraphId,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:384:9
[INFO] [stdout]     |
[INFO] [stdout] 384 |         graph_id: &GraphId,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `user_id` is never read
[INFO] [stdout]   --> src/api.rs:63:9
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct Client {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] 63 |     pub user_id: String,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Client` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FlipperState` is never constructed
[INFO] [stdout]   --> src/api/message.rs:54:12
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub struct FlipperState {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AudioBufferId` is never constructed
[INFO] [stdout]   --> src/compute/audio_frame.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct AudioBufferId(String);
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling phaneron v0.1.2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: associated function `new_from` is never used
[INFO] [stdout]   --> src/compute/audio_frame.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl AudioBufferId {
[INFO] [stdout]    | ------------------ associated function in this implementation
[INFO] [stdout] 26 |     pub fn new_from(id: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `id` is never read
[INFO] [stdout]   --> src/compute/audio_frame.rs:61:9
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct AudioFrame {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] 61 |     pub id: AudioFrameId,
[INFO] [stdout]    |         ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AudioFrame` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VideoBufferId` is never constructed
[INFO] [stdout]   --> src/compute/video_frame.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct VideoBufferId(String);
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_from` is never used
[INFO] [stdout]   --> src/compute/video_frame.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl VideoBufferId {
[INFO] [stdout]    | ------------------ associated function in this implementation
[INFO] [stdout] 29 |     pub fn new_from(id: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `width` and `height` are never read
[INFO] [stdout]   --> src/io.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct LoadedVideoFrame {
[INFO] [stdout]    |            ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub width: usize,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 46 |     pub height: usize,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `gamut_matrix` is never read
[INFO] [stdout]    --> src/load_save.rs:153:5
[INFO] [stdout]     |
[INFO] [stdout] 147 | pub struct Saver {
[INFO] [stdout]     |            ----- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 153 |     gamut_matrix: opencl3::memory::Buffer<opencl3::types::cl_float>,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:440:21
[INFO] [stdout]     |
[INFO] [stdout] 440 |     AudioInputAdded(NodeId, AudioInputId),
[INFO] [stdout]     |     --------------- ^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     field in this variant
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 440 -     AudioInputAdded(NodeId, AudioInputId),
[INFO] [stdout] 440 +     AudioInputAdded((), AudioInputId),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:441:21
[INFO] [stdout]     |
[INFO] [stdout] 441 |     VideoInputAdded(NodeId, VideoInputId),
[INFO] [stdout]     |     --------------- ^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     field in this variant
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 441 -     VideoInputAdded(NodeId, VideoInputId),
[INFO] [stdout] 441 +     VideoInputAdded((), VideoInputId),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:443:9
[INFO] [stdout]     |
[INFO] [stdout] 442 |     AudioOutputAdded(
[INFO] [stdout]     |     ---------------- field in this variant
[INFO] [stdout] 443 |         NodeId,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 443 -         NodeId,
[INFO] [stdout] 443 +         (),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:448:9
[INFO] [stdout]     |
[INFO] [stdout] 447 |     VideoOutputAdded(
[INFO] [stdout]     |     ---------------- field in this variant
[INFO] [stdout] 448 |         NodeId,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 448 -         NodeId,
[INFO] [stdout] 448 +         (),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `node_id` is never read
[INFO] [stdout]    --> src/node_context.rs:455:5
[INFO] [stdout]     |
[INFO] [stdout] 454 | struct NodeContextInner {
[INFO] [stdout]     |        ---------------- field in this struct
[INFO] [stdout] 455 |     node_id: NodeId,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_from` is never used
[INFO] [stdout]    --> src/plugins.rs:222:12
[INFO] [stdout]     |
[INFO] [stdout] 221 | impl PluginId {
[INFO] [stdout]     | ------------- associated function in this implementation
[INFO] [stdout] 222 |     pub fn new_from(id: String) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unexpected `cfg` condition name: `Debug`
[INFO] [stdout]   --> src/compute.rs:43:7
[INFO] [stdout]    |
[INFO] [stdout] 43 | #[cfg(Debug)]
[INFO] [stdout]    |       ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: expected names are: `docsrs`, `feature`, and `test` and 31 more
[INFO] [stdout]    = help: consider using a Cargo feature instead
[INFO] [stdout]    = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint:
[INFO] [stdout]             [lints.rust]
[INFO] [stdout]             unexpected_cfgs = { level = "warn", check-cfg = ['cfg(Debug)'] }
[INFO] [stdout]    = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(Debug)");` to the top of the `build.rs`
[INFO] [stdout]    = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout]    = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:357:40
[INFO] [stdout]     |
[INFO] [stdout] 357 |     pub async fn set_node_state(&self, graph_id: &GraphId, node_id: &NodeId, state: String) {
[INFO] [stdout]     |                                        ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `context`
[INFO] [stdout]   --> src/compute/audio_output.rs:46:9
[INFO] [stdout]    |
[INFO] [stdout] 46 |         context: &phaneron_plugin::types::FrameContext,
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `context`
[INFO] [stdout]   --> src/compute/video_output.rs:46:9
[INFO] [stdout]    |
[INFO] [stdout] 46 |         context: &phaneron_plugin::types::FrameContext,
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:351:39
[INFO] [stdout]     |
[INFO] [stdout] 351 |     pub async fn set_node_name(&self, graph_id: &GraphId, node_id: &NodeId, name: Option<String>) {
[INFO] [stdout]     |                                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:364:40
[INFO] [stdout]     |
[INFO] [stdout] 364 |     pub async fn get_node_state(&self, graph_id: &GraphId, node_id: &NodeId) -> Option<String> {
[INFO] [stdout]     |                                        ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:370:9
[INFO] [stdout]     |
[INFO] [stdout] 370 |         graph_id: &GraphId,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `graph_id`
[INFO] [stdout]    --> src/state.rs:384:9
[INFO] [stdout]     |
[INFO] [stdout] 384 |         graph_id: &GraphId,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `user_id` is never read
[INFO] [stdout]   --> src/api.rs:63:9
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct Client {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] 63 |     pub user_id: String,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Client` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FlipperState` is never constructed
[INFO] [stdout]   --> src/api/message.rs:54:12
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub struct FlipperState {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AudioBufferId` is never constructed
[INFO] [stdout]   --> src/compute/audio_frame.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct AudioBufferId(String);
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_from` is never used
[INFO] [stdout]   --> src/compute/audio_frame.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl AudioBufferId {
[INFO] [stdout]    | ------------------ associated function in this implementation
[INFO] [stdout] 26 |     pub fn new_from(id: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `id` is never read
[INFO] [stdout]   --> src/compute/audio_frame.rs:61:9
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct AudioFrame {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] 61 |     pub id: AudioFrameId,
[INFO] [stdout]    |         ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AudioFrame` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VideoBufferId` is never constructed
[INFO] [stdout]   --> src/compute/video_frame.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct VideoBufferId(String);
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_from` is never used
[INFO] [stdout]   --> src/compute/video_frame.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl VideoBufferId {
[INFO] [stdout]    | ------------------ associated function in this implementation
[INFO] [stdout] 29 |     pub fn new_from(id: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `width` and `height` are never read
[INFO] [stdout]   --> src/io.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct LoadedVideoFrame {
[INFO] [stdout]    |            ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub width: usize,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 46 |     pub height: usize,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `gamut_matrix` is never read
[INFO] [stdout]    --> src/load_save.rs:153:5
[INFO] [stdout]     |
[INFO] [stdout] 147 | pub struct Saver {
[INFO] [stdout]     |            ----- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 153 |     gamut_matrix: opencl3::memory::Buffer<opencl3::types::cl_float>,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:440:21
[INFO] [stdout]     |
[INFO] [stdout] 440 |     AudioInputAdded(NodeId, AudioInputId),
[INFO] [stdout]     |     --------------- ^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     field in this variant
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 440 -     AudioInputAdded(NodeId, AudioInputId),
[INFO] [stdout] 440 +     AudioInputAdded((), AudioInputId),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:441:21
[INFO] [stdout]     |
[INFO] [stdout] 441 |     VideoInputAdded(NodeId, VideoInputId),
[INFO] [stdout]     |     --------------- ^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     field in this variant
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 441 -     VideoInputAdded(NodeId, VideoInputId),
[INFO] [stdout] 441 +     VideoInputAdded((), VideoInputId),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:443:9
[INFO] [stdout]     |
[INFO] [stdout] 442 |     AudioOutputAdded(
[INFO] [stdout]     |     ---------------- field in this variant
[INFO] [stdout] 443 |         NodeId,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 443 -         NodeId,
[INFO] [stdout] 443 +         (),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/node_context.rs:448:9
[INFO] [stdout]     |
[INFO] [stdout] 447 |     VideoOutputAdded(
[INFO] [stdout]     |     ---------------- field in this variant
[INFO] [stdout] 448 |         NodeId,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 448 -         NodeId,
[INFO] [stdout] 448 +         (),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `node_id` is never read
[INFO] [stdout]    --> src/node_context.rs:455:5
[INFO] [stdout]     |
[INFO] [stdout] 454 | struct NodeContextInner {
[INFO] [stdout]     |        ---------------- field in this struct
[INFO] [stdout] 455 |     node_id: NodeId,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_from` is never used
[INFO] [stdout]    --> src/plugins.rs:222:12
[INFO] [stdout]     |
[INFO] [stdout] 221 | impl PluginId {
[INFO] [stdout]     | ------------- associated function in this implementation
[INFO] [stdout] 222 |     pub fn new_from(id: String) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 10.48s
[INFO] running `Command { std: "docker" "inspect" "64cb324a812493fd4b69f431924d712ddf8f7d9286bf7374548f932d2a876574", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "64cb324a812493fd4b69f431924d712ddf8f7d9286bf7374548f932d2a876574", kill_on_drop: false }`
[INFO] [stdout] 64cb324a812493fd4b69f431924d712ddf8f7d9286bf7374548f932d2a876574
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-10-28" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] e466efc0f546bdef6ef9779d7fcc837012700682f63d98cc2d398a98e5f9026a
[INFO] running `Command { std: "docker" "start" "-a" "e466efc0f546bdef6ef9779d7fcc837012700682f63d98cc2d398a98e5f9026a", kill_on_drop: false }`
[INFO] [stderr] warning: unexpected `cfg` condition name: `Debug`
[INFO] [stderr]   --> src/compute.rs:43:7
[INFO] [stderr]    |
[INFO] [stderr] 43 | #[cfg(Debug)]
[INFO] [stderr]    |       ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = help: expected names are: `docsrs`, `feature`, and `test` and 31 more
[INFO] [stderr]    = help: consider using a Cargo feature instead
[INFO] [stderr]    = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint:
[INFO] [stderr]             [lints.rust]
[INFO] [stderr]             unexpected_cfgs = { level = "warn", check-cfg = ['cfg(Debug)'] }
[INFO] [stderr]    = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(Debug)");` to the top of the `build.rs`
[INFO] [stderr]    = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stderr]    = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `graph_id`
[INFO] [stderr]    --> src/state.rs:357:40
[INFO] [stderr]     |
[INFO] [stderr] 357 |     pub async fn set_node_state(&self, graph_id: &GraphId, node_id: &NodeId, state: String) {
[INFO] [stderr]     |                                        ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `context`
[INFO] [stderr]   --> src/compute/audio_output.rs:46:9
[INFO] [stderr]    |
[INFO] [stderr] 46 |         context: &phaneron_plugin::types::FrameContext,
[INFO] [stderr]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `context`
[INFO] [stderr]   --> src/compute/video_output.rs:46:9
[INFO] [stderr]    |
[INFO] [stderr] 46 |         context: &phaneron_plugin::types::FrameContext,
[INFO] [stderr]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `graph_id`
[INFO] [stderr]    --> src/state.rs:351:39
[INFO] [stderr]     |
[INFO] [stderr] 351 |     pub async fn set_node_name(&self, graph_id: &GraphId, node_id: &NodeId, name: Option<String>) {
[INFO] [stderr]     |                                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `graph_id`
[INFO] [stderr]    --> src/state.rs:364:40
[INFO] [stderr]     |
[INFO] [stderr] 364 |     pub async fn get_node_state(&self, graph_id: &GraphId, node_id: &NodeId) -> Option<String> {
[INFO] [stderr]     |                                        ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `graph_id`
[INFO] [stderr]    --> src/state.rs:370:9
[INFO] [stderr]     |
[INFO] [stderr] 370 |         graph_id: &GraphId,
[INFO] [stderr]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `graph_id`
[INFO] [stderr]    --> src/state.rs:384:9
[INFO] [stderr]     |
[INFO] [stderr] 384 |         graph_id: &GraphId,
[INFO] [stderr]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_graph_id`
[INFO] [stderr] 
[INFO] [stderr] warning: field `user_id` is never read
[INFO] [stderr]   --> src/api.rs:63:9
[INFO] [stderr]    |
[INFO] [stderr] 62 | pub struct Client {
[INFO] [stderr]    |            ------ field in this struct
[INFO] [stderr] 63 |     pub user_id: String,
[INFO] [stderr]    |         ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Client` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: struct `FlipperState` is never constructed
[INFO] [stderr]   --> src/api/message.rs:54:12
[INFO] [stderr]    |
[INFO] [stderr] 54 | pub struct FlipperState {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `AudioBufferId` is never constructed
[INFO] [stderr]   --> src/compute/audio_frame.rs:24:12
[INFO] [stderr]    |
[INFO] [stderr] 24 | pub struct AudioBufferId(String);
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new_from` is never used
[INFO] [stderr]   --> src/compute/audio_frame.rs:26:12
[INFO] [stderr]    |
[INFO] [stderr] 25 | impl AudioBufferId {
[INFO] [stderr]    | ------------------ associated function in this implementation
[INFO] [stderr] 26 |     pub fn new_from(id: String) -> Self {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `id` is never read
[INFO] [stderr]   --> src/compute/audio_frame.rs:61:9
[INFO] [stderr]    |
[INFO] [stderr] 60 | pub struct AudioFrame {
[INFO] [stderr]    |            ---------- field in this struct
[INFO] [stderr] 61 |     pub id: AudioFrameId,
[INFO] [stderr]    |         ^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `AudioFrame` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: struct `VideoBufferId` is never constructed
[INFO] [stderr]   --> src/compute/video_frame.rs:27:12
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub struct VideoBufferId(String);
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new_from` is never used
[INFO] [stderr]   --> src/compute/video_frame.rs:29:12
[INFO] [stderr]    |
[INFO] [stderr] 28 | impl VideoBufferId {
[INFO] [stderr]    | ------------------ associated function in this implementation
[INFO] [stderr] 29 |     pub fn new_from(id: String) -> Self {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `width` and `height` are never read
[INFO] [stderr]   --> src/io.rs:45:9
[INFO] [stderr]    |
[INFO] [stderr] 42 | pub struct LoadedVideoFrame {
[INFO] [stderr]    |            ---------------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 45 |     pub width: usize,
[INFO] [stderr]    |         ^^^^^
[INFO] [stderr] 46 |     pub height: usize,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `gamut_matrix` is never read
[INFO] [stderr]    --> src/load_save.rs:153:5
[INFO] [stderr]     |
[INFO] [stderr] 147 | pub struct Saver {
[INFO] [stderr]     |            ----- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 153 |     gamut_matrix: opencl3::memory::Buffer<opencl3::types::cl_float>,
[INFO] [stderr]     |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]    --> src/node_context.rs:440:21
[INFO] [stderr]     |
[INFO] [stderr] 440 |     AudioInputAdded(NodeId, AudioInputId),
[INFO] [stderr]     |     --------------- ^^^^^^
[INFO] [stderr]     |     |
[INFO] [stderr]     |     field in this variant
[INFO] [stderr]     |
[INFO] [stderr]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]     |
[INFO] [stderr] 440 -     AudioInputAdded(NodeId, AudioInputId),
[INFO] [stderr] 440 +     AudioInputAdded((), AudioInputId),
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]    --> src/node_context.rs:441:21
[INFO] [stderr]     |
[INFO] [stderr] 441 |     VideoInputAdded(NodeId, VideoInputId),
[INFO] [stderr]     |     --------------- ^^^^^^
[INFO] [stderr]     |     |
[INFO] [stderr]     |     field in this variant
[INFO] [stderr]     |
[INFO] [stderr]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]     |
[INFO] [stderr] 441 -     VideoInputAdded(NodeId, VideoInputId),
[INFO] [stderr] 441 +     VideoInputAdded((), VideoInputId),
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]    --> src/node_context.rs:443:9
[INFO] [stderr]     |
[INFO] [stderr] 442 |     AudioOutputAdded(
[INFO] [stderr]     |     ---------------- field in this variant
[INFO] [stderr] 443 |         NodeId,
[INFO] [stderr]     |         ^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]     |
[INFO] [stderr] 443 -         NodeId,
[INFO] [stderr] 443 +         (),
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]    --> src/node_context.rs:448:9
[INFO] [stderr]     |
[INFO] [stderr] 447 |     VideoOutputAdded(
[INFO] [stderr]     |     ---------------- field in this variant
[INFO] [stderr] 448 |         NodeId,
[INFO] [stderr]     |         ^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `NodeEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]     |
[INFO] [stderr] 448 -         NodeId,
[INFO] [stderr] 448 +         (),
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: field `node_id` is never read
[INFO] [stderr]    --> src/node_context.rs:455:5
[INFO] [stderr]     |
[INFO] [stderr] 454 | struct NodeContextInner {
[INFO] [stderr]     |        ---------------- field in this struct
[INFO] [stderr] 455 |     node_id: NodeId,
[INFO] [stderr]     |     ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new_from` is never used
[INFO] [stderr]    --> src/plugins.rs:222:12
[INFO] [stderr]     |
[INFO] [stderr] 221 | impl PluginId {
[INFO] [stderr]     | ------------- associated function in this implementation
[INFO] [stderr] 222 |     pub fn new_from(id: String) -> Self {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `phaneron` (lib) generated 23 warnings (run `cargo fix --lib -p phaneron` to apply 7 suggestions)
[INFO] [stderr] warning: `phaneron` (lib test) generated 23 warnings (23 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.32s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/phaneron-9cc985f06af187ed)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test io::tests::from_i32_mono ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/phaneron-8f1def2be70547e0)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests phaneron
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "e466efc0f546bdef6ef9779d7fcc837012700682f63d98cc2d398a98e5f9026a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e466efc0f546bdef6ef9779d7fcc837012700682f63d98cc2d398a98e5f9026a", kill_on_drop: false }`
[INFO] [stdout] e466efc0f546bdef6ef9779d7fcc837012700682f63d98cc2d398a98e5f9026a
