From 4481f38023e6be94080272a4d457741ac120a2ff Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Linus=20F=C3=A4rnstrand?= Date: Sun, 27 Oct 2024 19:03:22 +0100 Subject: [PATCH 1/2] Remove custom NeverOkResult trait and instead use new Rust 1.82 matching --- src/bin/tcp2udp.rs | 6 ++---- src/forward_traffic.rs | 3 +-- src/lib.rs | 12 ------------ 3 files changed, 3 insertions(+), 18 deletions(-) diff --git a/src/bin/tcp2udp.rs b/src/bin/tcp2udp.rs index 5ff1819..cb86f24 100644 --- a/src/bin/tcp2udp.rs +++ b/src/bin/tcp2udp.rs @@ -4,7 +4,7 @@ use clap::Parser; use err_context::ErrorExt as _; use std::num::NonZeroU8; -use udp_over_tcp::{tcp2udp, NeverOkResult}; +use udp_over_tcp::tcp2udp; #[derive(Debug, Parser)] #[command( @@ -30,9 +30,7 @@ fn main() { let runtime = create_runtime(options.threads); - let error = runtime - .block_on(tcp2udp::run(options.tcp2udp_options)) - .into_error(); + let Err(error) = runtime.block_on(tcp2udp::run(options.tcp2udp_options)); log::error!("Error: {}", error.display("\nCaused by: ")); std::process::exit(1); } diff --git a/src/forward_traffic.rs b/src/forward_traffic.rs index cf08b8a..9914170 100644 --- a/src/forward_traffic.rs +++ b/src/forward_traffic.rs @@ -1,4 +1,3 @@ -use crate::NeverOkResult; use err_context::BoxedErrorExt as _; use err_context::ResultExt as _; use futures::future::select; @@ -41,7 +40,7 @@ pub async fn process_udp_over_tcp( } }; let udp2tcp = async move { - let error = process_udp2tcp(udp_in, tcp_out).await.into_error(); + let Err(error) = process_udp2tcp(udp_in, tcp_out).await; log::error!("Error: {}", error.display("\nCaused by: ")); }; diff --git a/src/lib.rs b/src/lib.rs index b0a9db4..274b9cb 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -95,15 +95,3 @@ pub use tcp_options::{ApplyTcpOptionsError, ApplyTcpOptionsErrorKind, TcpOptions /// Size of the header (in bytes) that is prepended to each datagram in the TCP stream. pub use forward_traffic::HEADER_LEN; - -/// Helper trait for `Result` types. Allows getting the `E` value -/// in a way that is guaranteed to not panic. -pub trait NeverOkResult { - fn into_error(self) -> E; -} - -impl NeverOkResult for Result { - fn into_error(self) -> E { - self.expect_err("Result can't be Ok variant") - } -} From e0c6b2e399b8dc56e67f6f918c84457fb001e73d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Linus=20F=C3=A4rnstrand?= Date: Sun, 27 Oct 2024 19:05:12 +0100 Subject: [PATCH 2/2] Bump MSRV --- .github/workflows/ci.yml | 2 +- Cargo.toml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index b796ddf..c0e08a0 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -69,7 +69,7 @@ jobs: - os: ubuntu-latest # MSRV. Not considered breaking when this has to be bumped. # But update `rust-version` in `Cargo.toml` - rust: 1.80.0 + rust: 1.82.0 runs-on: ${{ matrix.os }} steps: - uses: actions/checkout@v4 diff --git a/Cargo.toml b/Cargo.toml index 52f7b8f..8fb6258 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -6,7 +6,7 @@ license = "MIT OR Apache-2.0" description = "Tunnel UDP traffic inside a TCP stream. Each datagram is prefixed with a 16 bit unsigned integer containing the length" repository = "https://github.com/mullvad/udp-over-tcp" edition = "2021" -rust-version = "1.80.0" +rust-version = "1.82.0" publish = false [[bin]]