From 33bee392b663eb79f8a92f5819c80a95dc62512f Mon Sep 17 00:00:00 2001 From: Lachezar Lechev Date: Mon, 13 May 2024 11:37:01 +0300 Subject: [PATCH 1/9] ci: build and msrv workflows Signed-off-by: Lachezar Lechev --- .github/workflows/build.yml | 42 +++++++++++++++++++++++++++++++++++++ .github/workflows/msrv.yml | 38 +++++++++++++++++++++++++++++++++ 2 files changed, 80 insertions(+) create mode 100644 .github/workflows/build.yml create mode 100644 .github/workflows/msrv.yml diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml new file mode 100644 index 0000000..5a8487f --- /dev/null +++ b/.github/workflows/build.yml @@ -0,0 +1,42 @@ +name: Build + +on: [push] + +# Stops the running workflow of previous pushes +concurrency: + # cancel per workflow + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +jobs: + build: + name: Lint, test and build + runs-on: ubuntu-latest + + steps: + + - name: Checkout + uses: actions/checkout@v4 + + - name: Rust setup (stable) + uses: dtolnay/rust-toolchain@stable + + - uses: Swatinem/rust-cache@v2 + + - name: Lint - rustfmt + run: cargo fmt --all -- --check + + - name: Lint - clippy + run: cargo clippy --all --no-deps -- -D warnings + + - name: Build + run: cargo check + + - name: Test + run: cargo test + + - name: Docs + env: + RUSTDOCFLAGS: -D warnings --cfg docsrs + run: cargo doc --no-deps --all-features + diff --git a/.github/workflows/msrv.yml b/.github/workflows/msrv.yml new file mode 100644 index 0000000..20a2b9d --- /dev/null +++ b/.github/workflows/msrv.yml @@ -0,0 +1,38 @@ +name: MSRV build + +on: + push: + # will checkout the default branch `development` + schedule: + # run every Friday at 17:00 + - cron: '00 17 * * 5' + # Or ran manually + workflow_dispatch: + +# Stops the running workflow of previous pushes +concurrency: + # cancel per workflow + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +env: + RUST_MSRV_VERSION: '1.64' + +jobs: + build: + name: Test and build + runs-on: ubuntu-latest + + steps: + - name: Rust setup (MSRV) + uses: dtolnay/rust-toolchain@master + with: + toolchain: ${{ env.RUST_MSRV_VERSION }} + + - uses: Swatinem/rust-cache@v2 + + - name: Checkout + uses: actions/checkout@v4 + + - run: cargo check + - run: cargo test \ No newline at end of file From a3932c5bfd5445c8da7ec1f7be89b0bd6b61206f Mon Sep 17 00:00:00 2001 From: Lachezar Lechev Date: Mon, 13 May 2024 11:40:08 +0300 Subject: [PATCH 2/9] fix: rustfmt Signed-off-by: Lachezar Lechev --- src/api.rs | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/api.rs b/src/api.rs index 822f5d7..32f3ec3 100644 --- a/src/api.rs +++ b/src/api.rs @@ -110,7 +110,6 @@ impl Client { } } - /// Send a [`MonitorSettings`] ([`MiddlewareCommand`]) to the Arduino Serial Plotter UI /// through an already established connection. pub async fn set_monitor_settings( @@ -132,7 +131,7 @@ impl Client { /// Send a Data lines message to the Arduino Serial Plotter UI to plot. /// - /// + /// pub async fn send(&self, data: &[&str]) -> Result<(), Error> { let data_json = serde_json::to_string(&data).expect("Should always be serializable!"); From 5ff78e43ca29317589ed07fcbc670db048d334ae Mon Sep 17 00:00:00 2001 From: Lachezar Lechev Date: Mon, 13 May 2024 11:43:51 +0300 Subject: [PATCH 3/9] ci: fix build workflow - building docs should use nightly Signed-off-by: Lachezar Lechev --- .github/workflows/build.yml | 30 ++++++++++++++++++------------ 1 file changed, 18 insertions(+), 12 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 5a8487f..ee6f835 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -9,8 +9,8 @@ concurrency: cancel-in-progress: true jobs: - build: - name: Lint, test and build + lint-and-docs: + name: Lint and check docs runs-on: ubuntu-latest steps: @@ -18,10 +18,9 @@ jobs: - name: Checkout uses: actions/checkout@v4 - - name: Rust setup (stable) - uses: dtolnay/rust-toolchain@stable - - - uses: Swatinem/rust-cache@v2 + - name: Rust setup (nightly) for docs + uses: dtolnay/rust-toolchain@nightly + - name: Lint - rustfmt run: cargo fmt --all -- --check @@ -29,14 +28,21 @@ jobs: - name: Lint - clippy run: cargo clippy --all --no-deps -- -D warnings - - name: Build - run: cargo check - - - name: Test - run: cargo test - - name: Docs env: RUSTDOCFLAGS: -D warnings --cfg docsrs run: cargo doc --no-deps --all-features + check-and-test: + name: Lint and check docs + runs-on: ubuntu-latest + + steps: + + - name: Rust setup (stable) + uses: dtolnay/rust-toolchain@stable + + - uses: Swatinem/rust-cache@v2 + + - run: cargo check --all-features + - run: cargo test --all-features \ No newline at end of file From 886f0eb99168f3f98f7a4fc61294bfbf065cddf2 Mon Sep 17 00:00:00 2001 From: Lachezar Lechev Date: Mon, 13 May 2024 11:45:22 +0300 Subject: [PATCH 4/9] fix(Cargo.toml): add msrv and rt-multi-thread feature for tokio dev-dep Signed-off-by: Lachezar Lechev --- Cargo.lock | 17 +++++++++++++++++ Cargo.toml | 6 ++++-- 2 files changed, 21 insertions(+), 2 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 2a925e0..32dfa79 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -156,6 +156,12 @@ version = "0.28.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4271d37baee1b8c7e4b708028c57d816cf9d2434acb33a549475f78c181f6253" +[[package]] +name = "hermit-abi" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d231dfb89cfffdbc30e7fc41579ed6066ad03abda9e567ccafae602b97ec5024" + [[package]] name = "http" version = "1.1.0" @@ -242,6 +248,16 @@ dependencies = [ "winapi", ] +[[package]] +name = "num_cpus" +version = "1.16.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4161fcb6d602d4d2081af7c3a45852d875a03dd337a6bfdd6e06407b61342a43" +dependencies = [ + "hermit-abi", + "libc", +] + [[package]] name = "object" version = "0.32.2" @@ -555,6 +571,7 @@ dependencies = [ "bytes", "libc", "mio", + "num_cpus", "pin-project-lite", "socket2", "tokio-macros", diff --git a/Cargo.toml b/Cargo.toml index 5123656..12bf511 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -12,10 +12,12 @@ categories = ["api-bindings", "asynchronous", "visualization", "data-structures" keywords = ["arduino", "plotting", "protocol", "json"] repository = "https://github.com/LechevSpace/arduino-plotter" +rust-version = "1.64" + [dependencies] tracing = "0.1" -thiserror = "1.0.60" +thiserror = "1" serde_json = "1" serde = { version = "1", features = ["derive"] } @@ -33,4 +35,4 @@ rand = "0.8" [dev-dependencies] tracing-subscriber = { version = "0.3", features = ["env-filter", "json"] } -tokio = { version = "1", features = ["net", "sync", "macros"] } +tokio = { version = "1", features = ["net", "sync", "macros", "rt-multi-thread"] } From 7bf4c7b562f16ab82e25d6fa2c53a07b38277384 Mon Sep 17 00:00:00 2001 From: Lachezar Lechev Date: Mon, 13 May 2024 13:07:07 +0300 Subject: [PATCH 5/9] fix(ci): msrv and build workflows + set Rust msrv to 1.70 Signed-off-by: Lachezar Lechev --- .github/workflows/build.yml | 11 +++++++---- .github/workflows/msrv.yml | 2 +- Cargo.toml | 2 +- 3 files changed, 9 insertions(+), 6 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index ee6f835..f7849bf 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -10,7 +10,7 @@ concurrency: jobs: lint-and-docs: - name: Lint and check docs + name: Lints and check docs runs-on: ubuntu-latest steps: @@ -20,7 +20,8 @@ jobs: - name: Rust setup (nightly) for docs uses: dtolnay/rust-toolchain@nightly - + with: + components: rust-docs, clippy, rustfmt - name: Lint - rustfmt run: cargo fmt --all -- --check @@ -34,10 +35,12 @@ jobs: run: cargo doc --no-deps --all-features check-and-test: - name: Lint and check docs + name: Cargo check and test runs-on: ubuntu-latest - + steps: + - name: Checkout + uses: actions/checkout@v4 - name: Rust setup (stable) uses: dtolnay/rust-toolchain@stable diff --git a/.github/workflows/msrv.yml b/.github/workflows/msrv.yml index 20a2b9d..1808c52 100644 --- a/.github/workflows/msrv.yml +++ b/.github/workflows/msrv.yml @@ -16,7 +16,7 @@ concurrency: cancel-in-progress: true env: - RUST_MSRV_VERSION: '1.64' + RUST_MSRV_VERSION: '1.70' jobs: build: diff --git a/Cargo.toml b/Cargo.toml index 12bf511..00c164d 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -12,7 +12,7 @@ categories = ["api-bindings", "asynchronous", "visualization", "data-structures" keywords = ["arduino", "plotting", "protocol", "json"] repository = "https://github.com/LechevSpace/arduino-plotter" -rust-version = "1.64" +rust-version = "1.70" [dependencies] tracing = "0.1" From e99a1d19fd49ab3d19a9c5487ea097ab64f84c38 Mon Sep 17 00:00:00 2001 From: Lachezar Lechev Date: Mon, 13 May 2024 13:07:38 +0300 Subject: [PATCH 6/9] ci(dependabot): check for outdated actions Signed-off-by: Lachezar Lechev --- .github/dependabot.yml | 7 +++++++ 1 file changed, 7 insertions(+) create mode 100644 .github/dependabot.yml diff --git a/.github/dependabot.yml b/.github/dependabot.yml new file mode 100644 index 0000000..26d29c7 --- /dev/null +++ b/.github/dependabot.yml @@ -0,0 +1,7 @@ +version: 2 +updates: + - package-ecosystem: "github-actions" + directory: "/" + # Check for updates every Monday + schedule: + interval: "weekly" \ No newline at end of file From 6238792a877b3e7c5915a4b8c7cc5580f01f2b0b Mon Sep 17 00:00:00 2001 From: Lachezar Lechev Date: Mon, 13 May 2024 13:07:57 +0300 Subject: [PATCH 7/9] docs: README & lib.rs documentation + badges Signed-off-by: Lachezar Lechev --- README.md | 24 +++++++++++++++--------- src/api.rs | 1 - src/lib.rs | 34 ++++++++++++++++++++++++++++++++++ 3 files changed, 49 insertions(+), 10 deletions(-) diff --git a/README.md b/README.md index 884ea1a..240c282 100644 --- a/README.md +++ b/README.md @@ -1,12 +1,13 @@ -# arduino-plotter -## Protocol crate and CLI used to communicate with Arduino serial plotter +# `arduino-plotter` +## API bindings (protocol) with Client/Server crate for interacting with Arduino Serial Plotter -### Arduino serial plotter: https://github.com/arduino/arduino-serial-plotter-webapp +### Arduino Serial Plotter: https://github.com/arduino/arduino-serial-plotter-webapp +[![sponsor-us]](https://github.com/sponsors/LechevSpace) [![crates-io]](https://crates.io/crates/arduino-plotter) [![docs-rs]](https://docs.rs/arduino-plotter) [![build-yml]](https://github.com/LechevSpace/arduino-plotter/actions/workflows/build.yml) #### Running arduino-serial-plotter webapp -**Arduino Serial Plotter** uses websocket to communicate by sending or receiving commands. +**Arduino Serial Plotter** uses WebSockets to communicate by sending or receiving commands. Requirements: - Node v10 @@ -23,7 +24,7 @@ Default port: **3000** #### Connecting -The **Arduino serial plotter** will send a request to our CLI and the CLI is waiting for a connection on the websocket, this is why you need to open the arduino plotter app after starting the CLI: +The **Arduino Serial Plotter** will send a request to our CLI and the CLI is waiting for a connection on the websocket, this is why you need to open the arduino plotter app after starting the CLI: `http://localhost:3000` (with default port **3000**) @@ -36,7 +37,7 @@ subscriber, however, you can use the `RUST_LOG` env. variable to override it. Running the `minimal` example will give you the most basic use of the crate but it will not be able to send data or handle change of End of Line messages -from the arduino serial plotter application. +from the Arduino Serial Plotter application. `cargo run --example minimal` @@ -52,10 +53,15 @@ random data to the `arduino-serial-plotter-webapp`: - Sends initial settings - Sends Random data with 2 different data lines -- Receives settings from the **Arduino serial plotter** and confirms a new End of Line by sending a settings message back to it -- Receives data messages sent from the **Arduino serial plotter** UI and logs them using `tracing` to the console +- Receives settings from the **Arduino Serial Plotter** and confirms a new End of Line by sending a settings message back to it +- Receives data messages sent from the **Arduino Serial Plotter** UI and logs them using `tracing` to the console ### License Licensed under either of [Apache License, Version 2.0](./LICENSE-APACHE) or [MIT license](./LICENSE-MIT) at your option. -Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions. \ No newline at end of file +Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions. + +[build-yml]: https://img.shields.io/github/actions/workflow/status/LechevSpace/arduino-plotter/build.yml?branch=main&style=for-the-badge +[crates-io]: https://img.shields.io/crates/v/arduino-plotters?logo=rust&style=for-the-badge +[docs-rs]: https://img.shields.io/badge/docs.rs-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo= +[sponsor-us]: https://img.shields.io/github/sponsors/LechevSpace?color=bf3989&label=Sponsor%20us&style=for-the-badge&logoColor=bf3989&logo=data%3Aimage%2Fsvg%2Bxml%3Bbase64%2CPHN2ZyBoZWlnaHQ9IjE2IiB2aWV3Qm94PSIwIDAgMTYgMTYiIHZlcnNpb249IjEuMSIgd2lkdGg9IjE2IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPgogICAgPHBhdGggZmlsbD0iI2JmMzk4OSIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNNC4yNSAyLjVjLTEuMzM2IDAtMi43NSAxLjE2NC0yLjc1IDMgMCAyLjE1IDEuNTggNC4xNDQgMy4zNjUgNS42ODJBMjAuNTY1IDIwLjU2NSAwIDAwOCAxMy4zOTNhMjAuNTYxIDIwLjU2MSAwIDAwMy4xMzUtMi4yMTFDMTIuOTIgOS42NDQgMTQuNSA3LjY1IDE0LjUgNS41YzAtMS44MzYtMS40MTQtMy0yLjc1LTMtMS4zNzMgMC0yLjYwOS45ODYtMy4wMjkgMi40NTZhLjc1Ljc1IDAgMDEtMS40NDIgMEM2Ljg1OSAzLjQ4NiA1LjYyMyAyLjUgNC4yNSAyLjV6TTggMTQuMjVsLS4zNDUuNjY2LS4wMDItLjAwMS0uMDA2LS4wMDMtLjAxOC0uMDFhNy42NDMgNy42NDMgMCAwMS0uMzEtLjE3IDIyLjA3NSAyMi4wNzUgMCAwMS0zLjQzNC0yLjQxNEMyLjA0NSAxMC43MzEgMCA4LjM1IDAgNS41IDAgMi44MzYgMi4wODYgMSA0LjI1IDEgNS43OTcgMSA3LjE1MyAxLjgwMiA4IDMuMDIgOC44NDcgMS44MDIgMTAuMjAzIDEgMTEuNzUgMSAxMy45MTQgMSAxNiAyLjgzNiAxNiA1LjVjMCAyLjg1LTIuMDQ1IDUuMjMxLTMuODg1IDYuODE4YTIyLjA4IDIyLjA4IDAgMDEtMy43NDQgMi41ODRsLS4wMTguMDEtLjAwNi4wMDNoLS4wMDJMOCAxNC4yNXptMCAwbC4zNDUuNjY2YS43NTIuNzUyIDAgMDEtLjY5IDBMOCAxNC4yNXoiPjwvcGF0aD4KPC9zdmc%2BCg%3D%3D diff --git a/src/api.rs b/src/api.rs index 32f3ec3..92de01c 100644 --- a/src/api.rs +++ b/src/api.rs @@ -131,7 +131,6 @@ impl Client { /// Send a Data lines message to the Arduino Serial Plotter UI to plot. /// - /// pub async fn send(&self, data: &[&str]) -> Result<(), Error> { let data_json = serde_json::to_string(&data).expect("Should always be serializable!"); diff --git a/src/lib.rs b/src/lib.rs index 14a93ff..d514b12 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1,3 +1,37 @@ +//! [![sponsor-us]](https://github.com/sponsors/LechevSpace) [![crates-io]](https://crates.io/crates/arduino-plotter) [![docs-rs]](https://docs.rs/arduino-plotter) +//! +//! `arduino-plotter` provides API bindings (the [`protocol`]) and +//! [`Server`]/[`Client`] implementation for interacting with the Arduino +//! Serial Plotter web applicatoin. +//! +//! [crates-io]: https://img.shields.io/crates/v/arduino-plotters?logo=rust&style=for-the-badge +//! [docs-rs]: https://img.shields.io/badge/docs.rs-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo= +//! [sponsor-us]: https://img.shields.io/github/sponsors/LechevSpace?color=bf3989&label=Sponsor%20us&style=for-the-badge&logoColor=bf3989&logo=data%3Aimage%2Fsvg%2Bxml%3Bbase64%2CPHN2ZyBoZWlnaHQ9IjE2IiB2aWV3Qm94PSIwIDAgMTYgMTYiIHZlcnNpb249IjEuMSIgd2lkdGg9IjE2IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPgogICAgPHBhdGggZmlsbD0iI2JmMzk4OSIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNNC4yNSAyLjVjLTEuMzM2IDAtMi43NSAxLjE2NC0yLjc1IDMgMCAyLjE1IDEuNTggNC4xNDQgMy4zNjUgNS42ODJBMjAuNTY1IDIwLjU2NSAwIDAwOCAxMy4zOTNhMjAuNTYxIDIwLjU2MSAwIDAwMy4xMzUtMi4yMTFDMTIuOTIgOS42NDQgMTQuNSA3LjY1IDE0LjUgNS41YzAtMS44MzYtMS40MTQtMy0yLjc1LTMtMS4zNzMgMC0yLjYwOS45ODYtMy4wMjkgMi40NTZhLjc1Ljc1IDAgMDEtMS40NDIgMEM2Ljg1OSAzLjQ4NiA1LjYyMyAyLjUgNC4yNSAyLjV6TTggMTQuMjVsLS4zNDUuNjY2LS4wMDItLjAwMS0uMDA2LS4wMDMtLjAxOC0uMDFhNy42NDMgNy42NDMgMCAwMS0uMzEtLjE3IDIyLjA3NSAyMi4wNzUgMCAwMS0zLjQzNC0yLjQxNEMyLjA0NSAxMC43MzEgMCA4LjM1IDAgNS41IDAgMi44MzYgMi4wODYgMSA0LjI1IDEgNS43OTcgMSA3LjE1MyAxLjgwMiA4IDMuMDIgOC44NDcgMS44MDIgMTAuMjAzIDEgMTEuNzUgMSAxMy45MTQgMSAxNiAyLjgzNiAxNiA1LjVjMCAyLjg1LTIuMDQ1IDUuMjMxLTMuODg1IDYuODE4YTIyLjA4IDIyLjA4IDAgMDEtMy43NDQgMi41ODRsLS4wMTguMDEtLjAwNi4wMDNoLS4wMDJMOCAxNC4yNXptMCAwbC4zNDUuNjY2YS43NTIuNzUyIDAgMDEtLjY5IDBMOCAxNC4yNXoiPjwvcGF0aD4KPC9zdmc%2BCg%3D%3D +//! +//! ## Arduino Serial Plotter: +//! +//! ## Running arduino-serial-plotter webapp +//! +//! **Arduino Serial Plotter** uses WebSockets to communicate by sending or receiving commands. +//! +//! Requirements: +//! - Node v10 +//! +//! ```bash +//! git clone https://github.com/arduino/arduino-serial-plotter-webapp +//! # or when using ssh: +//! # git clone git@github.com:arduino/arduino-serial-plotter-webapp.git +//! cd arduino-serial-plotter-webapp +//! npm i && npm start +//! ``` +//! +//! Default port: **3000** +//! +//! ## Connecting +//! +//! The **Arduino Serial Plotter** will send a request to our CLI and the CLI is waiting for a connection on the websocket, this is why you need to open the arduino plotter app after starting the CLI: +//! +//! `http://localhost:3000` (with default port **3000**) #![deny(clippy::all)] #![deny(rustdoc::broken_intra_doc_links)] // only enables the `doc_cfg` feature when From 21da2b0ef7699d4df6a13d58ec7db63cb6dcfcfe Mon Sep 17 00:00:00 2001 From: Lachezar Lechev Date: Mon, 13 May 2024 13:11:00 +0300 Subject: [PATCH 8/9] fix: rustfmt Signed-off-by: Lachezar Lechev --- src/api.rs | 1 - 1 file changed, 1 deletion(-) diff --git a/src/api.rs b/src/api.rs index 92de01c..48a4613 100644 --- a/src/api.rs +++ b/src/api.rs @@ -130,7 +130,6 @@ impl Client { } /// Send a Data lines message to the Arduino Serial Plotter UI to plot. - /// pub async fn send(&self, data: &[&str]) -> Result<(), Error> { let data_json = serde_json::to_string(&data).expect("Should always be serializable!"); From 3e9b04ef6fd8709de7f0901f67fa0518263aa013 Mon Sep 17 00:00:00 2001 From: Lachezar Lechev Date: Mon, 13 May 2024 13:14:28 +0300 Subject: [PATCH 9/9] fix(example): run data lines Signed-off-by: Lachezar Lechev --- examples/run.rs | 2 +- src/api.rs | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/examples/run.rs b/examples/run.rs index afd86ef..6e992db 100644 --- a/examples/run.rs +++ b/examples/run.rs @@ -106,7 +106,7 @@ async fn run_client_task(client: Client) { } let data1_str = format!("L1:{},L2:{},L3:{}\n", data[0], data[1], data[2]); let data2_str = format!("A:{},B:{},C:{}\n", data[3], data[4], data[5]); - let data = vec![data1_str, data2_str]; + let data: Vec<&str> = vec![&data1_str, &data2_str]; let send_result = client.send(&data).await; match send_result { diff --git a/src/api.rs b/src/api.rs index 48a4613..dbe8ee2 100644 --- a/src/api.rs +++ b/src/api.rs @@ -131,7 +131,7 @@ impl Client { /// Send a Data lines message to the Arduino Serial Plotter UI to plot. pub async fn send(&self, data: &[&str]) -> Result<(), Error> { - let data_json = serde_json::to_string(&data).expect("Should always be serializable!"); + let data_json = serde_json::to_string(data).expect("Should always be serializable!"); self.ws_sink .lock()