1
0
Fork 0
mirror of https://github.com/actix/actix-web.git synced 2025-01-17 12:45:31 +00:00

clippy warnings

This commit is contained in:
Nikolay Kim 2019-07-17 15:08:30 +06:00
parent ef3e1037a8
commit 4092c7f326
26 changed files with 84 additions and 90 deletions

View file

@ -1,3 +1,4 @@
#![allow(clippy::borrow_interior_mutable_const, clippy::type_complexity)]
//! Cross-origin resource sharing (CORS) for Actix applications //! Cross-origin resource sharing (CORS) for Actix applications
//! //!
//! CORS middleware could be used with application and with resource. //! CORS middleware could be used with application and with resource.
@ -162,6 +163,7 @@ impl<T> AllOrSome<T> {
/// .max_age(3600); /// .max_age(3600);
/// # } /// # }
/// ``` /// ```
#[derive(Default)]
pub struct Cors { pub struct Cors {
cors: Option<Inner>, cors: Option<Inner>,
methods: bool, methods: bool,

View file

@ -1,3 +1,5 @@
#![allow(clippy::borrow_interior_mutable_const, clippy::type_complexity)]
//! Static files support //! Static files support
use std::cell::RefCell; use std::cell::RefCell;
use std::fmt::Write; use std::fmt::Write;
@ -57,7 +59,7 @@ pub struct ChunkedReadFile {
fn handle_error(err: BlockingError<io::Error>) -> Error { fn handle_error(err: BlockingError<io::Error>) -> Error {
match err { match err {
BlockingError::Error(err) => err.into(), BlockingError::Error(err) => err.into(),
BlockingError::Canceled => ErrorInternalServerError("Unexpected error").into(), BlockingError::Canceled => ErrorInternalServerError("Unexpected error"),
} }
} }

View file

@ -24,8 +24,8 @@ use crate::ChunkedReadFile;
bitflags! { bitflags! {
pub(crate) struct Flags: u32 { pub(crate) struct Flags: u32 {
const ETAG = 0b00000001; const ETAG = 0b0000_0001;
const LAST_MD = 0b00000010; const LAST_MD = 0b0000_0010;
} }
} }
@ -311,8 +311,8 @@ impl Responder for NamedFile {
return Ok(resp.streaming(reader)); return Ok(resp.streaming(reader));
} }
match req.method() { match *req.method() {
&Method::HEAD | &Method::GET => (), Method::HEAD | Method::GET => (),
_ => { _ => {
return Ok(HttpResponse::MethodNotAllowed() return Ok(HttpResponse::MethodNotAllowed()
.header(header::CONTENT_TYPE, "text/plain") .header(header::CONTENT_TYPE, "text/plain")

View file

@ -1,3 +1,9 @@
#![allow(
clippy::type_complexity,
clippy::new_without_default,
dead_code,
deprecated
)]
mod app; mod app;
mod helpers; mod helpers;
mod request; mod request;

View file

@ -333,8 +333,7 @@ struct CookieIdentityExtention {
impl CookieIdentityInner { impl CookieIdentityInner {
fn new(key: &[u8]) -> CookieIdentityInner { fn new(key: &[u8]) -> CookieIdentityInner {
let key_v2: Vec<u8> = let key_v2: Vec<u8> = key.iter().chain([1, 0, 0, 0].iter()).cloned().collect();
key.iter().chain([1, 0, 0, 0].iter()).map(|e| *e).collect();
CookieIdentityInner { CookieIdentityInner {
key: Key::from_master(key), key: Key::from_master(key),
key_v2: Key::from_master(&key_v2), key_v2: Key::from_master(&key_v2),
@ -585,13 +584,14 @@ impl IdentityPolicy for CookieIdentityPolicy {
) )
} else if self.0.always_update_cookie() && id.is_some() { } else if self.0.always_update_cookie() && id.is_some() {
let visit_timestamp = SystemTime::now(); let visit_timestamp = SystemTime::now();
let mut login_timestamp = None; let login_timestamp = if self.0.requires_oob_data() {
if self.0.requires_oob_data() {
let CookieIdentityExtention { let CookieIdentityExtention {
login_timestamp: lt, login_timestamp: lt,
} = res.request().extensions_mut().remove().unwrap(); } = res.request().extensions_mut().remove().unwrap();
login_timestamp = lt; lt
} } else {
None
};
self.0.set_cookie( self.0.set_cookie(
res, res,
Some(CookieValue { Some(CookieValue {

View file

@ -1,3 +1,5 @@
#![allow(clippy::borrow_interior_mutable_const)]
mod error; mod error;
mod extractor; mod extractor;
mod server; mod server;

View file

@ -418,7 +418,7 @@ impl Stream for Field {
inner.poll(&self.safety) inner.poll(&self.safety)
} else if !self.safety.is_clean() { } else if !self.safety.is_clean() {
return Err(MultipartError::NotConsumed); Err(MultipartError::NotConsumed)
} else { } else {
Ok(Async::NotReady) Ok(Async::NotReady)
} }
@ -533,11 +533,9 @@ impl InnerField {
let b_size = boundary.len() + b_len; let b_size = boundary.len() + b_len;
if len < b_size { if len < b_size {
return Ok(Async::NotReady); return Ok(Async::NotReady);
} else { } else if &payload.buf[b_len..b_size] == boundary.as_bytes() {
if &payload.buf[b_len..b_size] == boundary.as_bytes() { // found boundary
// found boundary return Ok(Async::Ready(None));
return Ok(Async::Ready(None));
}
} }
} }
} }
@ -557,7 +555,7 @@ impl InnerField {
// check boundary // check boundary
if (&payload.buf[cur..cur + 2] == b"\r\n" if (&payload.buf[cur..cur + 2] == b"\r\n"
&& &payload.buf[cur + 2..cur + 4] == b"--") && &payload.buf[cur + 2..cur + 4] == b"--")
|| (&payload.buf[cur..cur + 1] == b"\r" || (&payload.buf[cur..=cur] == b"\r"
&& &payload.buf[cur + 1..cur + 3] == b"--") && &payload.buf[cur + 1..cur + 3] == b"--")
{ {
if cur != 0 { if cur != 0 {

View file

@ -342,7 +342,7 @@ where
} }
} }
(SessionStatus::Purged, _) => { (SessionStatus::Purged, _) => {
inner.remove_cookie(&mut res); let _ = inner.remove_cookie(&mut res);
res res
} }
_ => res, _ => res,

View file

@ -1,3 +1,4 @@
#![allow(clippy::borrow_interior_mutable_const)]
//! Actix actors integration for Actix web framework //! Actix actors integration for Actix web framework
mod context; mod context;
pub mod ws; pub mod ws;

View file

@ -435,7 +435,7 @@ where
} }
} }
Frame::Binary(data) => Message::Binary( Frame::Binary(data) => Message::Binary(
data.map(|b| b.freeze()).unwrap_or_else(|| Bytes::new()), data.map(|b| b.freeze()).unwrap_or_else(Bytes::new),
), ),
Frame::Ping(s) => Message::Ping(s), Frame::Ping(s) => Message::Ping(s),
Frame::Pong(s) => Message::Pong(s), Frame::Pong(s) => Message::Pong(s),

View file

@ -12,9 +12,9 @@ enum ResourceType {
impl fmt::Display for ResourceType { impl fmt::Display for ResourceType {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match self { match *self {
&ResourceType::Async => write!(f, "to_async"), ResourceType::Async => write!(f, "to_async"),
&ResourceType::Sync => write!(f, "to"), ResourceType::Sync => write!(f, "to"),
} }
} }
} }
@ -34,16 +34,16 @@ pub enum GuardType {
impl fmt::Display for GuardType { impl fmt::Display for GuardType {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match self { match *self {
&GuardType::Get => write!(f, "Get"), GuardType::Get => write!(f, "Get"),
&GuardType::Post => write!(f, "Post"), GuardType::Post => write!(f, "Post"),
&GuardType::Put => write!(f, "Put"), GuardType::Put => write!(f, "Put"),
&GuardType::Delete => write!(f, "Delete"), GuardType::Delete => write!(f, "Delete"),
&GuardType::Head => write!(f, "Head"), GuardType::Head => write!(f, "Head"),
&GuardType::Connect => write!(f, "Connect"), GuardType::Connect => write!(f, "Connect"),
&GuardType::Options => write!(f, "Options"), GuardType::Options => write!(f, "Options"),
&GuardType::Trace => write!(f, "Trace"), GuardType::Trace => write!(f, "Trace"),
&GuardType::Patch => write!(f, "Patch"), GuardType::Patch => write!(f, "Patch"),
} }
} }
} }
@ -92,37 +92,27 @@ impl actix_web::dev::HttpServiceFactory for {name} {{
fn guess_resource_type(typ: &syn::Type) -> ResourceType { fn guess_resource_type(typ: &syn::Type) -> ResourceType {
let mut guess = ResourceType::Sync; let mut guess = ResourceType::Sync;
match typ { if let syn::Type::ImplTrait(typ) = typ {
syn::Type::ImplTrait(typ) => { for bound in typ.bounds.iter() {
for bound in typ.bounds.iter() { if let syn::TypeParamBound::Trait(bound) = bound {
match bound { for bound in bound.path.segments.iter() {
syn::TypeParamBound::Trait(bound) => { if bound.ident == "Future" {
for bound in bound.path.segments.iter() { guess = ResourceType::Async;
if bound.ident == "Future" { break;
guess = ResourceType::Async; } else if bound.ident == "Responder" {
break; guess = ResourceType::Sync;
} else if bound.ident == "Responder" { break;
guess = ResourceType::Sync;
break;
}
}
} }
_ => (),
} }
} }
} }
_ => (),
} }
guess guess
} }
impl Args { impl Args {
pub fn new( pub fn new(args: &[syn::NestedMeta], input: TokenStream, guard: GuardType) -> Self {
args: &Vec<syn::NestedMeta>,
input: TokenStream,
guard: GuardType,
) -> Self {
if args.is_empty() { if args.is_empty() {
panic!( panic!(
"invalid server definition, expected: #[{}(\"some path\")]", "invalid server definition, expected: #[{}(\"some path\")]",
@ -164,9 +154,10 @@ impl Args {
ResourceType::Async ResourceType::Async
} else { } else {
match ast.decl.output { match ast.decl.output {
syn::ReturnType::Default => { syn::ReturnType::Default => panic!(
panic!("Function {} has no return type. Cannot be used as handler") "Function {} has no return type. Cannot be used as handler",
} name
),
syn::ReturnType::Type(_, ref typ) => guess_resource_type(typ.as_ref()), syn::ReturnType::Type(_, ref typ) => guess_resource_type(typ.as_ref()),
} }
}; };

View file

@ -21,6 +21,12 @@ pub struct ClientBuilder {
max_redirects: usize, max_redirects: usize,
} }
impl Default for ClientBuilder {
fn default() -> Self {
Self::new()
}
}
impl ClientBuilder { impl ClientBuilder {
pub fn new() -> Self { pub fn new() -> Self {
ClientBuilder { ClientBuilder {

View file

@ -1,3 +1,4 @@
#![allow(clippy::borrow_interior_mutable_const)]
//! An HTTP Client //! An HTTP Client
//! //!
//! ```rust //! ```rust

View file

@ -185,9 +185,7 @@ impl ClientRequest {
{ {
match HeaderName::try_from(key) { match HeaderName::try_from(key) {
Ok(key) => match value.try_into() { Ok(key) => match value.try_into() {
Ok(value) => { Ok(value) => self.head.headers.append(key, value),
let _ = self.head.headers.append(key, value);
}
Err(e) => self.err = Some(e.into()), Err(e) => self.err = Some(e.into()),
}, },
Err(e) => self.err = Some(e.into()), Err(e) => self.err = Some(e.into()),
@ -203,9 +201,7 @@ impl ClientRequest {
{ {
match HeaderName::try_from(key) { match HeaderName::try_from(key) {
Ok(key) => match value.try_into() { Ok(key) => match value.try_into() {
Ok(value) => { Ok(value) => self.head.headers.insert(key, value),
let _ = self.head.headers.insert(key, value);
}
Err(e) => self.err = Some(e.into()), Err(e) => self.err = Some(e.into()),
}, },
Err(e) => self.err = Some(e.into()), Err(e) => self.err = Some(e.into()),
@ -223,9 +219,7 @@ impl ClientRequest {
Ok(key) => { Ok(key) => {
if !self.head.headers.contains_key(&key) { if !self.head.headers.contains_key(&key) {
match value.try_into() { match value.try_into() {
Ok(value) => { Ok(value) => self.head.headers.insert(key, value),
let _ = self.head.headers.insert(key, value);
}
Err(e) => self.err = Some(e.into()), Err(e) => self.err = Some(e.into()),
} }
} }
@ -257,9 +251,7 @@ impl ClientRequest {
HeaderValue: HttpTryFrom<V>, HeaderValue: HttpTryFrom<V>,
{ {
match HeaderValue::try_from(value) { match HeaderValue::try_from(value) {
Ok(value) => { Ok(value) => self.head.headers.insert(header::CONTENT_TYPE, value),
let _ = self.head.headers.insert(header::CONTENT_TYPE, value);
}
Err(e) => self.err = Some(e.into()), Err(e) => self.err = Some(e.into()),
} }
self self
@ -321,7 +313,7 @@ impl ClientRequest {
/// })); /// }));
/// } /// }
/// ``` /// ```
pub fn cookie<'c>(mut self, cookie: Cookie<'c>) -> Self { pub fn cookie(mut self, cookie: Cookie<'_>) -> Self {
if self.cookies.is_none() { if self.cookies.is_none() {
let mut jar = CookieJar::new(); let mut jar = CookieJar::new();
jar.add(cookie.into_owned()); jar.add(cookie.into_owned());
@ -465,7 +457,7 @@ impl ClientRequest {
}); });
// set request timeout // set request timeout
if let Some(timeout) = slf.timeout.or_else(|| config.timeout.clone()) { if let Some(timeout) = slf.timeout.or_else(|| config.timeout) {
Either::B(Either::A(Timeout::new(fut, timeout).map_err(|e| { Either::B(Either::A(Timeout::new(fut, timeout).map_err(|e| {
if let Some(e) = e.into_inner() { if let Some(e) = e.into_inner() {
e e

View file

@ -68,7 +68,7 @@ impl TestResponse {
} }
/// Set cookie for this response /// Set cookie for this response
pub fn cookie<'a>(mut self, cookie: Cookie<'a>) -> Self { pub fn cookie(mut self, cookie: Cookie<'_>) -> Self {
self.cookies.add(cookie.into_owned()); self.cookies.add(cookie.into_owned());
self self
} }

View file

@ -90,7 +90,7 @@ impl WebsocketsRequest {
} }
/// Set a cookie /// Set a cookie
pub fn cookie<'c>(mut self, cookie: Cookie<'c>) -> Self { pub fn cookie(mut self, cookie: Cookie<'_>) -> Self {
if self.cookies.is_none() { if self.cookies.is_none() {
let mut jar = CookieJar::new(); let mut jar = CookieJar::new();
jar.add(cookie.into_owned()); jar.add(cookie.into_owned());

View file

@ -25,11 +25,7 @@ impl ConnectionInfo {
Ref::map(req.extensions(), |e| e.get().unwrap()) Ref::map(req.extensions(), |e| e.get().unwrap())
} }
#[allow( #[allow(clippy::cognitive_complexity)]
clippy::cyclomatic_complexity,
clippy::cognitive_complexity,
clippy::borrow_interior_mutable_const
)]
fn new(req: &RequestHead, cfg: &AppConfig) -> ConnectionInfo { fn new(req: &RequestHead, cfg: &AppConfig) -> ConnectionInfo {
let mut host = None; let mut host = None;
let mut scheme = None; let mut scheme = None;

View file

@ -1,3 +1,4 @@
#![allow(clippy::borrow_interior_mutable_const)]
//! Actix web is a small, pragmatic, and extremely fast web framework //! Actix web is a small, pragmatic, and extremely fast web framework
//! for Rust. //! for Rust.
//! //!

View file

@ -107,7 +107,6 @@ where
self.service.poll_ready() self.service.poll_ready()
} }
#[allow(clippy::borrow_interior_mutable_const)]
fn call(&mut self, req: ServiceRequest) -> Self::Future { fn call(&mut self, req: ServiceRequest) -> Self::Future {
// negotiate content-encoding // negotiate content-encoding
let encoding = if let Some(val) = req.headers().get(&ACCEPT_ENCODING) { let encoding = if let Some(val) = req.headers().get(&ACCEPT_ENCODING) {

View file

@ -125,7 +125,6 @@ where
self.service.poll_ready() self.service.poll_ready()
} }
#[allow(clippy::borrow_interior_mutable_const)]
fn call(&mut self, req: ServiceRequest) -> Self::Future { fn call(&mut self, req: ServiceRequest) -> Self::Future {
let inner = self.inner.clone(); let inner = self.inner.clone();

View file

@ -288,13 +288,13 @@ where
lst, lst,
move || { move || {
let c = cfg.lock(); let c = cfg.lock();
acceptor.clone().map_err(|e| SslError::Ssl(e)).and_then( acceptor.clone().map_err(SslError::Ssl).and_then(
HttpService::build() HttpService::build()
.keep_alive(c.keep_alive) .keep_alive(c.keep_alive)
.client_timeout(c.client_timeout) .client_timeout(c.client_timeout)
.client_disconnect(c.client_shutdown) .client_disconnect(c.client_shutdown)
.finish(factory()) .finish(factory())
.map_err(|e| SslError::Service(e)) .map_err(SslError::Service)
.map_init_err(|_| ()), .map_init_err(|_| ()),
) )
}, },
@ -339,13 +339,13 @@ where
lst, lst,
move || { move || {
let c = cfg.lock(); let c = cfg.lock();
acceptor.clone().map_err(|e| SslError::Ssl(e)).and_then( acceptor.clone().map_err(SslError::Ssl).and_then(
HttpService::build() HttpService::build()
.keep_alive(c.keep_alive) .keep_alive(c.keep_alive)
.client_timeout(c.client_timeout) .client_timeout(c.client_timeout)
.client_disconnect(c.client_shutdown) .client_disconnect(c.client_shutdown)
.finish(factory()) .finish(factory())
.map_err(|e| SslError::Service(e)) .map_err(SslError::Service)
.map_init_err(|_| ()), .map_init_err(|_| ()),
) )
}, },

View file

@ -79,7 +79,7 @@ where
F: FnOnce() -> R, F: FnOnce() -> R,
R: IntoFuture, R: IntoFuture,
{ {
RT.with(move |rt| rt.borrow_mut().get_mut().block_on(lazy(|| f()))) RT.with(move |rt| rt.borrow_mut().get_mut().block_on(lazy(f)))
} }
#[doc(hidden)] #[doc(hidden)]

View file

@ -192,7 +192,6 @@ pub struct UrlEncoded<U> {
impl<U> UrlEncoded<U> { impl<U> UrlEncoded<U> {
/// Create a new future to URL encode a request /// Create a new future to URL encode a request
#[allow(clippy::borrow_interior_mutable_const)]
pub fn new(req: &HttpRequest, payload: &mut Payload) -> UrlEncoded<U> { pub fn new(req: &HttpRequest, payload: &mut Payload) -> UrlEncoded<U> {
// check content type // check content type
if req.content_type().to_lowercase() != "application/x-www-form-urlencoded" { if req.content_type().to_lowercase() != "application/x-www-form-urlencoded" {

View file

@ -298,7 +298,6 @@ where
U: DeserializeOwned + 'static, U: DeserializeOwned + 'static,
{ {
/// Create `JsonBody` for request. /// Create `JsonBody` for request.
#[allow(clippy::borrow_interior_mutable_const)]
pub fn new( pub fn new(
req: &HttpRequest, req: &HttpRequest,
payload: &mut Payload, payload: &mut Payload,

View file

@ -298,7 +298,6 @@ pub struct HttpMessageBody {
impl HttpMessageBody { impl HttpMessageBody {
/// Create `MessageBody` for request. /// Create `MessageBody` for request.
#[allow(clippy::borrow_interior_mutable_const)]
pub fn new(req: &HttpRequest, payload: &mut dev::Payload) -> HttpMessageBody { pub fn new(req: &HttpRequest, payload: &mut dev::Payload) -> HttpMessageBody {
let mut len = None; let mut len = None;
if let Some(l) = req.headers().get(&header::CONTENT_LENGTH) { if let Some(l) = req.headers().get(&header::CONTENT_LENGTH) {

View file

@ -65,7 +65,7 @@ where
F: FnOnce() -> R, F: FnOnce() -> R,
R: IntoFuture, R: IntoFuture,
{ {
RT.with(move |rt| rt.borrow_mut().get_mut().block_on(lazy(|| f()))) RT.with(move |rt| rt.borrow_mut().get_mut().block_on(lazy(f)))
} }
/// The `TestServer` type. /// The `TestServer` type.
@ -107,6 +107,7 @@ pub struct TestServerRuntime {
} }
impl TestServer { impl TestServer {
#[allow(clippy::new_ret_no_self)]
/// Start new test server with application factory /// Start new test server with application factory
pub fn new<F: StreamServiceFactory>(factory: F) -> TestServerRuntime { pub fn new<F: StreamServiceFactory>(factory: F) -> TestServerRuntime {
let (tx, rx) = mpsc::channel(); let (tx, rx) = mpsc::channel();
@ -191,7 +192,7 @@ impl TestServerRuntime {
F: FnOnce() -> R, F: FnOnce() -> R,
R: Future, R: Future,
{ {
self.rt.block_on(lazy(|| f())) self.rt.block_on(lazy(f))
} }
/// Execute function on current core /// Execute function on current core