[INFO] fetching crate garage_rpc 2.1.0... [INFO] checking garage_rpc-2.1.0 against try#b6bca0d7327839b5e3f7a7779947cb9113d08917+rustflags=-Zstrict-projection-item-bounds for 150662-leaf [INFO] extracting crate garage_rpc 2.1.0 into /workspace/builds/worker-2-tc2/source [INFO] started tweaking crates.io crate garage_rpc 2.1.0 [INFO] finished tweaking crates.io crate garage_rpc 2.1.0 [INFO] tweaked toml for crates.io crate garage_rpc 2.1.0 written to /workspace/builds/worker-2-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate garage_rpc 2.1.0 on toolchain b6bca0d7327839b5e3f7a7779947cb9113d08917 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b6bca0d7327839b5e3f7a7779947cb9113d08917" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b6bca0d7327839b5e3f7a7779947cb9113d08917" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Locking 287 packages to latest compatible versions [INFO] [stderr] Adding bytesize v1.3.3 (available: v2.3.1) [INFO] [stderr] Adding generic-array v0.14.7 (available: v0.14.9) [INFO] [stderr] Adding gethostname v0.4.3 (available: v1.1.0) [INFO] [stderr] Adding itertools v0.12.1 (available: v0.14.0) [INFO] [stderr] Adding k8s-openapi v0.21.1 (available: v0.27.1) [INFO] [stderr] Adding kube v0.88.1 (available: v3.1.0) [INFO] [stderr] Adding nix v0.29.0 (available: v0.31.2) [INFO] [stderr] Adding opentelemetry v0.17.0 (available: v0.31.0) [INFO] [stderr] Adding pnet_datalink v0.34.0 (available: v0.35.0) [INFO] [stderr] Adding rand v0.8.5 (available: v0.10.0) [INFO] [stderr] Adding reqwest v0.11.27 (available: v0.13.2) [INFO] [stderr] Adding schemars v0.8.22 (available: v1.2.1) [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b6bca0d7327839b5e3f7a7779947cb9113d08917" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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" "+b6bca0d7327839b5e3f7a7779947cb9113d08917" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 9a0d76ad367e3004cf50c9a1b9de3cfee0074be23850c1facf04c58ea9475bce [INFO] running `Command { std: "docker" "start" "-a" "9a0d76ad367e3004cf50c9a1b9de3cfee0074be23850c1facf04c58ea9475bce", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "9a0d76ad367e3004cf50c9a1b9de3cfee0074be23850c1facf04c58ea9475bce", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "9a0d76ad367e3004cf50c9a1b9de3cfee0074be23850c1facf04c58ea9475bce", kill_on_drop: false }` [INFO] [stdout] 9a0d76ad367e3004cf50c9a1b9de3cfee0074be23850c1facf04c58ea9475bce [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Zstrict-projection-item-bounds" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b6bca0d7327839b5e3f7a7779947cb9113d08917" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 78b0a3a3227331724884c8115a3df2614d362ae629749578a9679da92d7d75a7 [INFO] running `Command { std: "docker" "start" "-a" "78b0a3a3227331724884c8115a3df2614d362ae629749578a9679da92d7d75a7", kill_on_drop: false }` [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Checking errno v0.3.14 [INFO] [stderr] Compiling futures-macro v0.3.32 [INFO] [stderr] Checking serde v1.0.228 [INFO] [stderr] Compiling tokio-macros v2.7.0 [INFO] [stderr] Checking socket2 v0.6.3 [INFO] [stderr] Checking mio v1.2.0 [INFO] [stderr] Compiling libsodium-sys v0.2.7 [INFO] [stderr] Checking signal-hook-registry v1.4.8 [INFO] [stderr] Checking getrandom v0.2.17 [INFO] [stderr] Checking rand_core v0.6.4 [INFO] [stderr] Compiling err-derive v0.3.1 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Checking http v1.4.0 [INFO] [stderr] Checking rand_chacha v0.3.1 [INFO] [stderr] Checking tokio v1.51.1 [INFO] [stderr] Checking toml_datetime v0.6.11 [INFO] [stderr] Checking rand v0.8.5 [INFO] [stderr] Checking futures-util v0.3.32 [INFO] [stderr] Checking serde_spanned v0.6.9 [INFO] [stderr] Checking rmp v0.8.15 [INFO] [stderr] Checking num_cpus v1.17.0 [INFO] [stderr] Compiling nix v0.29.0 [INFO] [stderr] Checking toml_edit v0.22.27 [INFO] [stderr] Checking rmp-serde v1.3.1 [INFO] [stderr] Checking dashmap v4.0.2 [INFO] [stderr] Checking tracing v0.1.44 [INFO] [stderr] Checking thiserror v1.0.69 [INFO] [stderr] Checking http-body v1.0.1 [INFO] [stderr] Compiling garage_util v2.1.0 [INFO] [stderr] Checking arc-swap v1.9.1 [INFO] [stderr] Checking arrayvec v0.5.2 [INFO] [stderr] Checking no-std-net v0.6.0 [INFO] [stderr] Checking pnet_base v0.34.0 [INFO] [stderr] Checking chrono v0.4.44 [INFO] [stderr] Checking serde_json v1.0.149 [INFO] [stderr] Checking hexdump v0.1.2 [INFO] [stderr] Checking ipnetwork v0.20.0 [INFO] [stderr] Checking blake2 v0.10.6 [INFO] [stderr] Compiling proc-macro-error v1.0.4 [INFO] [stderr] Compiling synstructure v0.12.6 [INFO] [stderr] Checking pnet_sys v0.34.0 [INFO] [stderr] Checking bytesize v1.3.3 [INFO] [stderr] Checking toml v0.8.23 [INFO] [stderr] Checking pnet_datalink v0.34.0 [INFO] [stderr] Checking gethostname v0.4.3 [INFO] [stderr] Checking format_table v0.1.1 [INFO] [stderr] Checking futures-executor v0.3.32 [INFO] [stderr] Checking garage_db v2.1.0 [INFO] [stderr] Checking futures v0.3.32 [INFO] [stderr] Checking tokio-stream v0.1.18 [INFO] [stderr] Checking tokio-util v0.7.18 [INFO] [stderr] Checking hyper v1.9.0 [INFO] [stderr] Checking opentelemetry v0.17.0 [INFO] [stderr] Checking kuska-sodiumoxide v0.2.5-0 [INFO] [stderr] Checking kuska-handshake v0.2.0 [INFO] [stderr] Checking garage_net v2.1.0 [INFO] [stderr] Checking garage_rpc v2.1.0 (/opt/rustwide/workdir) [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:168:10 [INFO] [stdout] | [INFO] [stdout] 168 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 170 | H: StreamingEndpointHandler, S: std::marker::Sync [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be sent between threads safely [INFO] [stdout] --> rpc_helper.rs:168:10 [INFO] [stdout] | [INFO] [stdout] 168 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be sent between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Send` [INFO] [stdout] | [INFO] [stdout] 170 | H: StreamingEndpointHandler, S: std::marker::Send [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:168:10 [INFO] [stdout] | [INFO] [stdout] 168 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 170 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Deserialize<'_> [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:168:10 [INFO] [stdout] | [INFO] [stdout] 168 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 170 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Serialize [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:228:10 [INFO] [stdout] | [INFO] [stdout] 228 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 230 | H: StreamingEndpointHandler, S: std::marker::Sync [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be sent between threads safely [INFO] [stdout] --> rpc_helper.rs:228:10 [INFO] [stdout] | [INFO] [stdout] 228 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be sent between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Send` [INFO] [stdout] | [INFO] [stdout] 230 | H: StreamingEndpointHandler, S: std::marker::Send [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:228:10 [INFO] [stdout] | [INFO] [stdout] 228 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 230 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Deserialize<'_> [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:228:10 [INFO] [stdout] | [INFO] [stdout] 228 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 230 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Serialize [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:258:10 [INFO] [stdout] | [INFO] [stdout] 258 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 260 | H: StreamingEndpointHandler, S: std::marker::Sync [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be sent between threads safely [INFO] [stdout] --> rpc_helper.rs:258:10 [INFO] [stdout] | [INFO] [stdout] 258 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be sent between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Send` [INFO] [stdout] | [INFO] [stdout] 260 | H: StreamingEndpointHandler, S: std::marker::Send [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:258:10 [INFO] [stdout] | [INFO] [stdout] 258 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 260 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Deserialize<'_> [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:258:10 [INFO] [stdout] | [INFO] [stdout] 258 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 260 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Serialize [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:298:10 [INFO] [stdout] | [INFO] [stdout] 298 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 301 | S: Send + 'static + std::marker::Sync, [INFO] [stdout] | +++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:298:10 [INFO] [stdout] | [INFO] [stdout] 298 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 301 | S: Send + 'static + replication_mode::_::_serde::Deserialize<'_>, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:298:10 [INFO] [stdout] | [INFO] [stdout] 298 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 301 | S: Send + 'static + replication_mode::_::_serde::Serialize, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:332:10 [INFO] [stdout] | [INFO] [stdout] 332 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 335 | S: Send + 'static + std::marker::Sync, [INFO] [stdout] | +++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:332:10 [INFO] [stdout] | [INFO] [stdout] 332 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 335 | S: Send + 'static + replication_mode::_::_serde::Deserialize<'_>, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:332:10 [INFO] [stdout] | [INFO] [stdout] 332 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 335 | S: Send + 'static + replication_mode::_::_serde::Serialize, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:440:10 [INFO] [stdout] | [INFO] [stdout] 440 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 443 | S: Send + 'static + std::marker::Sync, [INFO] [stdout] | +++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:440:10 [INFO] [stdout] | [INFO] [stdout] 440 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 443 | S: Send + 'static + replication_mode::_::_serde::Deserialize<'_>, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:440:10 [INFO] [stdout] | [INFO] [stdout] 440 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 443 | S: Send + 'static + replication_mode::_::_serde::Serialize, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:477:10 [INFO] [stdout] | [INFO] [stdout] 477 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 480 | S: Send + 'static + std::marker::Sync, [INFO] [stdout] | +++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:477:10 [INFO] [stdout] | [INFO] [stdout] 477 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 480 | S: Send + 'static + replication_mode::_::_serde::Deserialize<'_>, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:477:10 [INFO] [stdout] | [INFO] [stdout] 477 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 480 | S: Send + 'static + replication_mode::_::_serde::Serialize, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:168:10 [INFO] [stdout] | [INFO] [stdout] 168 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 170 | H: StreamingEndpointHandler, S: std::marker::Sync [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be sent between threads safely [INFO] [stdout] --> rpc_helper.rs:168:10 [INFO] [stdout] | [INFO] [stdout] 168 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be sent between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Send` [INFO] [stdout] | [INFO] [stdout] 170 | H: StreamingEndpointHandler, S: std::marker::Send [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:168:10 [INFO] [stdout] | [INFO] [stdout] 168 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 170 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Deserialize<'_> [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:168:10 [INFO] [stdout] | [INFO] [stdout] 168 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 170 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Serialize [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:228:10 [INFO] [stdout] | [INFO] [stdout] 228 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 230 | H: StreamingEndpointHandler, S: std::marker::Sync [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be sent between threads safely [INFO] [stdout] --> rpc_helper.rs:228:10 [INFO] [stdout] | [INFO] [stdout] 228 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be sent between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Send` [INFO] [stdout] | [INFO] [stdout] 230 | H: StreamingEndpointHandler, S: std::marker::Send [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:228:10 [INFO] [stdout] | [INFO] [stdout] 228 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 230 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Deserialize<'_> [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:228:10 [INFO] [stdout] | [INFO] [stdout] 228 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 230 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Serialize [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:258:10 [INFO] [stdout] | [INFO] [stdout] 258 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 260 | H: StreamingEndpointHandler, S: std::marker::Sync [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be sent between threads safely [INFO] [stdout] --> rpc_helper.rs:258:10 [INFO] [stdout] | [INFO] [stdout] 258 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be sent between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Send` [INFO] [stdout] | [INFO] [stdout] 260 | H: StreamingEndpointHandler, S: std::marker::Send [INFO] [stdout] | ++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:258:10 [INFO] [stdout] | [INFO] [stdout] 258 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 260 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Deserialize<'_> [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:258:10 [INFO] [stdout] | [INFO] [stdout] 258 | M: Rpc>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 260 | H: StreamingEndpointHandler, S: replication_mode::_::_serde::Serialize [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:298:10 [INFO] [stdout] | [INFO] [stdout] 298 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 301 | S: Send + 'static + std::marker::Sync, [INFO] [stdout] | +++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:298:10 [INFO] [stdout] | [INFO] [stdout] 298 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 301 | S: Send + 'static + replication_mode::_::_serde::Deserialize<'_>, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:298:10 [INFO] [stdout] | [INFO] [stdout] 298 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 301 | S: Send + 'static + replication_mode::_::_serde::Serialize, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:332:10 [INFO] [stdout] | [INFO] [stdout] 332 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 335 | S: Send + 'static + std::marker::Sync, [INFO] [stdout] | +++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:332:10 [INFO] [stdout] | [INFO] [stdout] 332 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 335 | S: Send + 'static + replication_mode::_::_serde::Deserialize<'_>, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:332:10 [INFO] [stdout] | [INFO] [stdout] 332 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 335 | S: Send + 'static + replication_mode::_::_serde::Serialize, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:440:10 [INFO] [stdout] | [INFO] [stdout] 440 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 443 | S: Send + 'static + std::marker::Sync, [INFO] [stdout] | +++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:440:10 [INFO] [stdout] | [INFO] [stdout] 440 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 443 | S: Send + 'static + replication_mode::_::_serde::Deserialize<'_>, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:440:10 [INFO] [stdout] | [INFO] [stdout] 440 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 443 | S: Send + 'static + replication_mode::_::_serde::Serialize, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: `S` cannot be shared between threads safely [INFO] [stdout] --> rpc_helper.rs:477:10 [INFO] [stdout] | [INFO] [stdout] 477 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ `S` cannot be shared between threads safely [INFO] [stdout] | [INFO] [stdout] note: required because it appears within the type `Result` [INFO] [stdout] --> /rustc/b6bca0d7327839b5e3f7a7779947cb9113d08917/library/core/src/result.rs:557:9 [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Sync` [INFO] [stdout] | [INFO] [stdout] 480 | S: Send + 'static + std::marker::Sync, [INFO] [stdout] | +++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Deserialize<'de>` is not satisfied [INFO] [stdout] --> rpc_helper.rs:477:10 [INFO] [stdout] | [INFO] [stdout] 477 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Deserialize<'_>` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `for<'de> replication_mode::_::_serde::Deserialize<'de>` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 480 | S: Send + 'static + replication_mode::_::_serde::Deserialize<'_>, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `S: serde::Serialize` is not satisfied [INFO] [stdout] --> rpc_helper.rs:477:10 [INFO] [stdout] | [INFO] [stdout] 477 | M: Rpc> + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `replication_mode::_::_serde::Serialize` is not implemented for `S` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `S` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] = note: required for `Result` to implement `replication_mode::_::_serde::Serialize` [INFO] [stdout] help: consider further restricting type parameter `S` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 480 | S: Send + 'static + replication_mode::_::_serde::Serialize, [INFO] [stdout] | ++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] For more information about this error, try `rustc --explain E0277`. [INFO] [stdout] [INFO] [stderr] error: could not compile `garage_rpc` (lib test) due to 24 previous errors [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stdout] For more information about this error, try `rustc --explain E0277`. [INFO] [stdout] [INFO] [stderr] error: could not compile `garage_rpc` (lib) due to 24 previous errors [INFO] running `Command { std: "docker" "inspect" "78b0a3a3227331724884c8115a3df2614d362ae629749578a9679da92d7d75a7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "78b0a3a3227331724884c8115a3df2614d362ae629749578a9679da92d7d75a7", kill_on_drop: false }` [INFO] [stdout] 78b0a3a3227331724884c8115a3df2614d362ae629749578a9679da92d7d75a7