From b511c6a798ba6b847c34aaffc7d8a2a303b4cc1d Mon Sep 17 00:00:00 2001 From: Uwe Klotz Date: Wed, 18 Jan 2023 01:22:26 +0100 Subject: [PATCH] Split feature "sync" into "rtu-sync" and "tcp-sync" This is required to avoid an unused tokio-serial dependency that is only needed for "rtu-sync" but not for "rtu" (async). --- CHANGELOG.md | 4 ++++ Cargo.toml | 44 ++++++++++++++++++++++++++++++------------ src/client/mod.rs | 6 +++--- src/client/sync/mod.rs | 7 ++----- src/lib.rs | 3 +++ src/prelude.rs | 12 +++++++++--- src/server/mod.rs | 2 +- 7 files changed, 54 insertions(+), 24 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 7640418c..472b7e20 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,6 +3,10 @@ # Changelog +## v0.6.0 (Unreleased) + +- Features: Replace "sync" with "rtu-sync" and "tcp-sync" respectively + ## v0.5.4 (2023-01-18) - Fix (Windows): Upgrade dependencies to fix build failures on Windows for Tokio 1.23.0 and later. diff --git a/Cargo.toml b/Cargo.toml index 87b1dd45..ddb89aef 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -5,7 +5,10 @@ name = "tokio-modbus" description = "Tokio-based Modbus library" version = "0.5.4" -authors = ["slowtec GmbH ", "Markus Kohlhase "] +authors = [ + "slowtec GmbH ", + "Markus Kohlhase ", +] license = "MIT OR Apache-2.0" readme = "README.md" keywords = ["fieldbus", "modbus", "hardware", "automation"] @@ -31,20 +34,37 @@ socket2 = { version = "0.4.7", optional = true, default-features = false } tokio = { version = "1.24.2", default-features = false } # Disable default-features to exclude unused dependency on libudev tokio-serial = { version = "5.4.4", optional = true, default-features = false } -tokio-util = { version = "0.7.4", features = ["codec"] } +tokio-util = { version = "0.7.4", default-features = false, features = [ + "codec", +] } [dev-dependencies] env_logger = "0.10.0" futures = "0.3.25" -tokio = { version = "1.24.2", features = ["net", "macros", "io-util", "rt", "time"] } +tokio = { version = "1.24.2", features = [ + "net", + "macros", + "io-util", + "rt-multi-thread", + "time", +] } +tokio-serial = { version = "5.4.3", default-features = false } [features] -default = ["tcp", "rtu"] -rtu = ["tokio-serial", "futures-util/sink"] +default = ["rtu", "tcp"] +rtu = ["futures-util/sink"] tcp = ["tokio/net", "futures-util/sink"] -sync = ["tokio/rt"] -server = ["futures", "socket2/all", "tokio/macros", "tokio/rt", "tokio/rt-multi-thread"] -tcp-server-unstable = ["tcp", "server"] +rtu-sync = ["rtu", "tokio-serial"] +tcp-sync = ["tcp"] +server = ["futures"] +rtu-server = ["rtu", "server", "tokio/macros", "tokio-serial"] +tcp-server-unstable = [ + "tcp", + "server", + "socket2/all", + "tokio/macros", + "tokio/rt-multi-thread", +] [badges] maintenance = { status = "actively-developed" } @@ -52,7 +72,7 @@ maintenance = { status = "actively-developed" } [[example]] name = "rtu-client-sync" path = "examples/rtu-client-sync.rs" -required-features = ["rtu", "sync"] +required-features = ["rtu-sync"] [[example]] name = "rtu-client" @@ -62,7 +82,7 @@ required-features = ["rtu"] [[example]] name = "rtu-server" path = "examples/rtu-server.rs" -required-features = ["rtu", "server"] +required-features = ["rtu-server"] [[example]] name = "tcp-client-custom-fn" @@ -72,7 +92,7 @@ required-features = ["tcp"] [[example]] name = "tcp-client-sync" path = "examples/tcp-client-sync.rs" -required-features = ["tcp", "sync"] +required-features = ["tcp-sync"] [[example]] name = "tcp-client" @@ -82,4 +102,4 @@ required-features = ["tcp"] [[example]] name = "tcp-server" path = "examples/tcp-server.rs" -required-features = ["tcp", "server", "tcp-server-unstable"] +required-features = ["tcp-server-unstable"] diff --git a/src/client/mod.rs b/src/client/mod.rs index 7f612de0..9aca078e 100644 --- a/src/client/mod.rs +++ b/src/client/mod.rs @@ -12,15 +12,15 @@ use async_trait::async_trait; use crate::{frame::*, slave::*}; -#[cfg(feature = "sync")] -pub mod sync; - #[cfg(feature = "rtu")] pub mod rtu; #[cfg(feature = "tcp")] pub mod tcp; +#[cfg(any(feature = "rtu-sync", feature = "tcp-sync"))] +pub mod sync; + /// Transport independent asynchronous client trait #[async_trait] pub trait Client: SlaveContext + Send + Debug { diff --git a/src/client/sync/mod.rs b/src/client/sync/mod.rs index 0da9b58d..2889d686 100644 --- a/src/client/sync/mod.rs +++ b/src/client/sync/mod.rs @@ -3,15 +3,12 @@ //! Synchronous Modbus client -// TODO: Add missing documentation #![allow(missing_docs)] -/// RTU client connections -#[cfg(feature = "rtu")] +#[cfg(feature = "rtu-sync")] pub mod rtu; -/// TCP client connections -#[cfg(feature = "tcp")] +#[cfg(feature = "tcp-sync")] pub mod tcp; use super::{ diff --git a/src/lib.rs b/src/lib.rs index 979ac851..2ccd0175 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -5,6 +5,9 @@ #![warn(rust_2021_compatibility)] #![warn(missing_debug_implementations)] #![warn(unreachable_pub)] +#![warn(clippy::cast_lossless)] +// TODO (v0.6): Decorate functions with #[must_use] +//#![warn(clippy::must_use_candidate)] #![cfg_attr(not(test), warn(unsafe_code))] #![warn(clippy::all)] #![warn(clippy::cast_lossless)] diff --git a/src/prelude.rs b/src/prelude.rs index 9281586e..3b74263d 100644 --- a/src/prelude.rs +++ b/src/prelude.rs @@ -32,6 +32,12 @@ pub mod tcp { #[cfg(feature = "server")] pub use crate::server; +#[allow(missing_docs)] +#[cfg(any(feature = "rtu-sync", feature = "tcp-sync"))] +pub mod sync { + pub use crate::client::sync::*; +} + /////////////////////////////////////////////////////////////////// /// Structs /////////////////////////////////////////////////////////////////// @@ -43,13 +49,13 @@ pub use crate::slave::{Slave, SlaveId}; /////////////////////////////////////////////////////////////////// pub use crate::client::{Client, Reader, Writer}; -#[cfg(feature = "sync")] +#[cfg(any(feature = "rtu-sync", feature = "tcp-sync"))] pub use crate::client::sync::Client as SyncClient; -#[cfg(feature = "sync")] +#[cfg(any(feature = "rtu-sync", feature = "tcp-sync"))] pub use crate::client::sync::Reader as SyncReader; -#[cfg(feature = "sync")] +#[cfg(any(feature = "rtu-sync", feature = "tcp-sync"))] pub use crate::client::sync::Writer as SyncWriter; pub use crate::slave::SlaveContext; diff --git a/src/server/mod.rs b/src/server/mod.rs index 42becfdf..857bc4fe 100644 --- a/src/server/mod.rs +++ b/src/server/mod.rs @@ -6,7 +6,7 @@ // TODO: Add missing documentation #![allow(missing_docs)] -#[cfg(feature = "rtu")] +#[cfg(feature = "rtu-server")] pub mod rtu; #[cfg(feature = "tcp-server-unstable")]