Skip to content

feat: add support for rust_http_proxy #22

feat: add support for rust_http_proxy

feat: add support for rust_http_proxy #22

GitHub Actions / clippy ubuntu-latest succeeded Sep 4, 2024 in 1s

clippy ubuntu-latest

13 warnings

Details

Results

Message level Amount
Internal compiler error 0
Error 0
Warning 13
Note 0
Help 0

Versions

  • rustc 1.80.1 (3f5fd8dd4 2024-08-06)
  • cargo 1.80.1 (376290515 2024-07-16)
  • clippy 0.1.80 (3f5fd8d 2024-08-06)

Annotations

Check warning on line 172 in crates/shadowsocks-service/src/local/tun/tcp.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

transmute used without annotations

warning: transmute used without annotations
   --> crates/shadowsocks-service/src/local/tun/tcp.rs:172:38
    |
172 |         let recv_buf = unsafe { mem::transmute::<_, &mut [u8]>(buf.unfilled_mut()) };
    |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider adding missing annotations: `transmute::<&mut [std::mem::MaybeUninit<u8>], &mut [u8]>`
    |
    = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#missing_transmute_annotations
    = note: `#[warn(clippy::missing_transmute_annotations)]` on by default

Check warning on line 117 in crates/shadowsocks-service/src/local/socks/server/mod.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

unnecessary closure used to substitute value for `Option::None`

warning: unnecessary closure used to substitute value for `Option::None`
   --> crates/shadowsocks-service/src/local/socks/server/mod.rs:114:46
    |
114 |           let udp_associate_addr: ServerAddr = self
    |  ______________________________________________^
115 | |             .udp_associate_addr
116 | |             .as_ref()
117 | |             .or_else(|| self.udp_bind_addr.as_ref())
    | |______________--------------------------------------^
    |                |
    |                help: use `or(..)` instead: `or(self.udp_bind_addr.as_ref())`
    |
    = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_lazy_evaluations

Check warning on line 118 in crates/shadowsocks-service/src/local/socks/server/mod.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

unnecessary closure used to substitute value for `Option::None`

warning: unnecessary closure used to substitute value for `Option::None`
   --> crates/shadowsocks-service/src/local/socks/server/mod.rs:114:46
    |
114 |           let udp_associate_addr: ServerAddr = self
    |  ______________________________________________^
115 | |             .udp_associate_addr
116 | |             .as_ref()
117 | |             .or_else(|| self.udp_bind_addr.as_ref())
118 | |             .unwrap_or_else(|| &self.client_config)
    | |______________-------------------------------------^
    |                |
    |                help: use `unwrap_or(..)` instead: `unwrap_or(&self.client_config)`
    |
    = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_lazy_evaluations
    = note: `#[warn(clippy::unnecessary_lazy_evaluations)]` on by default

Check warning on line 86 in crates/shadowsocks-service/src/local/redir/udprelay/sys/unix/linux.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

this `match` can be collapsed into the outer `if let`

warning: this `match` can be collapsed into the outer `if let`
  --> crates/shadowsocks-service/src/local/redir/udprelay/sys/unix/linux.rs:77:21
   |
77 | /                     match errno {
78 | |                         libc::ENOPROTOOPT => {
79 | |                             // SO_REUSEPORT is supported after 3.9
80 | |                             trace!("failed to set SO_REUSEPORT, error: {}", err);
...  |
85 | |                         }
86 | |                     }
   | |_____________________^
   |
help: the outer pattern can be modified to include the inner pattern
  --> crates/shadowsocks-service/src/local/redir/udprelay/sys/unix/linux.rs:76:29
   |
76 |                 if let Some(errno) = err.raw_os_error() {
   |                             ^^^^^ replace this binding
77 |                     match errno {
78 |                         libc::ENOPROTOOPT => {
   |                         ^^^^^^^^^^^^^^^^^ with this pattern
   = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#collapsible_match
   = note: `#[warn(clippy::collapsible_match)]` on by default

Check warning on line 105 in crates/shadowsocks-service/src/local/net/tcp/auto_proxy_stream.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

this expression creates a reference which is immediately dereferenced by the compiler

warning: this expression creates a reference which is immediately dereferenced by the compiler
   --> crates/shadowsocks-service/src/local/net/tcp/auto_proxy_stream.rs:105:23
    |
105 |         wait_response(&mut stream).await?;
    |                       ^^^^^^^^^^^ help: change this to: `stream`
    |
    = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrow
    = note: `#[warn(clippy::needless_borrow)]` on by default

Check warning on line 191 in crates/shadowsocks-service/src/local/loadbalancing/server_stat.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

casting the result of `i32::abs()` to u32

warning: casting the result of `i32::abs()` to u32
   --> crates/shadowsocks-service/src/local/loadbalancing/server_stat.rs:191:30
    |
191 |                     .map(|s| (*s as i32 - self.data.latency_median as i32).abs() as u32)
    |                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: replace with: `(*s as i32 - self.data.latency_median as i32).unsigned_abs()`
    |
    = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cast_abs_to_unsigned
    = note: `#[warn(clippy::cast_abs_to_unsigned)]` on by default

Check warning on line 69 in crates/shadowsocks-service/src/local/loadbalancing/server_data.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

using `clone` on type `ServerStatData` which implements the `Copy` trait

warning: using `clone` on type `ServerStatData` which implements the `Copy` trait
  --> crates/shadowsocks-service/src/local/loadbalancing/server_data.rs:69:9
   |
69 |         self.stat_data.lock().await.data().clone()
   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try dereferencing it: `*self.stat_data.lock().await.data()`
   |
   = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#clone_on_copy

Check warning on line 56 in crates/shadowsocks-service/src/local/loadbalancing/server_data.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

using `clone` on type `ServerStatData` which implements the `Copy` trait

warning: using `clone` on type `ServerStatData` which implements the `Copy` trait
  --> crates/shadowsocks-service/src/local/loadbalancing/server_data.rs:56:38
   |
56 |             (stat.push_score(score), stat.data().clone())
   |                                      ^^^^^^^^^^^^^^^^^^^ help: try dereferencing it: `*stat.data()`
   |
   = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#clone_on_copy
   = note: `#[warn(clippy::clone_on_copy)]` on by default

Check warning on line 919 in crates/shadowsocks-service/src/local/loadbalancing/ping_balancer.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

redundant pattern matching, consider using `is_ok()`

warning: redundant pattern matching, consider using `is_ok()`
   --> crates/shadowsocks-service/src/local/loadbalancing/ping_balancer.rs:919:16
    |
919 |         if let Ok(..) = response.parse(&buf) {
    |         -------^^^^^^----------------------- help: try: `if response.parse(&buf).is_ok()`
    |
    = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_pattern_matching

Check warning on line 878 in crates/shadowsocks-service/src/local/loadbalancing/ping_balancer.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

redundant pattern matching, consider using `is_ok()`

warning: redundant pattern matching, consider using `is_ok()`
   --> crates/shadowsocks-service/src/local/loadbalancing/ping_balancer.rs:878:16
    |
878 |         if let Ok(..) = response.parse(&buf) {
    |         -------^^^^^^----------------------- help: try: `if response.parse(&buf).is_ok()`
    |
    = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_pattern_matching
    = note: `#[warn(clippy::redundant_pattern_matching)]` on by default

Check warning on line 32 in crates/shadowsocks-service/src/local/tun/mod.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

unused import: `AbstractDevice`

warning: unused import: `AbstractDevice`
  --> crates/shadowsocks-service/src/local/tun/mod.rs:32:78
   |
32 |             create_as_async, AsyncDevice, Configuration as TunConfiguration, AbstractDevice, Error as TunError, Layer,
   |                                                                              ^^^^^^^^^^^^^^

Check warning on line 8 in crates/shadowsocks-service/src/local/utils.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

unused imports: `AsyncReadExt`, `AsyncWriteExt`, and `time`

warning: unused imports: `AsyncReadExt`, `AsyncWriteExt`, and `time`
 --> crates/shadowsocks-service/src/local/utils.rs:8:41
  |
8 |     io::{copy_bidirectional, AsyncRead, AsyncReadExt, AsyncWrite, AsyncWriteExt},
  |                                         ^^^^^^^^^^^^              ^^^^^^^^^^^^^
9 |     time,
  |     ^^^^

Check warning on line 3 in crates/shadowsocks-service/src/local/utils.rs

See this annotation in the file changed.

@github-actions github-actions / clippy ubuntu-latest

unused import: `time::Duration`

warning: unused import: `time::Duration`
 --> crates/shadowsocks-service/src/local/utils.rs:3:32
  |
3 | use std::{io, net::SocketAddr, time::Duration};
  |                                ^^^^^^^^^^^^^^
  |
  = note: `#[warn(unused_imports)]` on by default