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

Merge pull request #368 from Diggsey/master

Remove reimplementation of `LazyCell`
This commit is contained in:
Nikolay Kim 2018-07-07 09:46:44 +06:00 committed by GitHub
commit 00c97504b6
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 19 additions and 25 deletions

View file

@ -75,6 +75,7 @@ time = "0.1"
encoding = "0.2"
language-tags = "0.2"
lazy_static = "1.0"
lazycell = "1.0.0"
parking_lot = "0.6"
url = { version="1.7", features=["query_encoding"] }
cookie = { version="0.10", features=["percent-encode"] }

View file

@ -107,6 +107,7 @@ extern crate htmlescape;
extern crate http as modhttp;
extern crate httparse;
extern crate language_tags;
extern crate lazycell;
extern crate mime;
extern crate mime_guess;
extern crate mio;

View file

@ -2,13 +2,14 @@ use std::cell::{Cell, RefCell, RefMut, UnsafeCell};
use std::collections::VecDeque;
use std::fmt::Write;
use std::rc::Rc;
use std::{env, fmt, mem, net};
use std::{env, fmt, net};
use bytes::BytesMut;
use futures_cpupool::CpuPool;
use http::StatusCode;
use parking_lot::Mutex;
use time;
use lazycell::LazyCell;
use super::channel::Node;
use super::message::{Request, RequestPool};
@ -41,7 +42,7 @@ pub struct ServerSettings {
addr: Option<net::SocketAddr>,
secure: bool,
host: String,
cpu_pool: UnsafeCell<Option<CpuPool>>,
cpu_pool: LazyCell<CpuPool>,
responses: &'static HttpResponsePool,
}
@ -51,7 +52,7 @@ impl Clone for ServerSettings {
addr: self.addr,
secure: self.secure,
host: self.host.clone(),
cpu_pool: UnsafeCell::new(None),
cpu_pool: LazyCell::new(),
responses: HttpResponsePool::get_pool(),
}
}
@ -64,7 +65,7 @@ impl Default for ServerSettings {
secure: false,
host: "localhost:8080".to_owned(),
responses: HttpResponsePool::get_pool(),
cpu_pool: UnsafeCell::new(None),
cpu_pool: LazyCell::new(),
}
}
}
@ -81,7 +82,7 @@ impl ServerSettings {
} else {
"localhost".to_owned()
};
let cpu_pool = UnsafeCell::new(None);
let cpu_pool = LazyCell::new();
let responses = HttpResponsePool::get_pool();
ServerSettings {
addr,
@ -102,7 +103,7 @@ impl ServerSettings {
addr,
host,
secure,
cpu_pool: UnsafeCell::new(None),
cpu_pool: LazyCell::new(),
responses: HttpResponsePool::get_pool(),
}
}
@ -124,15 +125,7 @@ impl ServerSettings {
/// Returns default `CpuPool` for server
pub fn cpu_pool(&self) -> &CpuPool {
// Unsafe: ServerSetting is !Sync, DEFAULT_CPUPOOL is protected by Mutex
unsafe {
let val = &mut *self.cpu_pool.get();
if val.is_none() {
let pool = DEFAULT_CPUPOOL.lock().clone();
*val = Some(pool);
}
val.as_ref().unwrap()
}
self.cpu_pool.borrow_with(|| DEFAULT_CPUPOOL.lock().clone())
}
#[inline]
@ -236,16 +229,15 @@ impl<H> WorkerSettings<H> {
pub fn set_date(&self, dst: &mut BytesMut, full: bool) {
// Unsafe: WorkerSetting is !Sync and !Send
unsafe {
if full {
let mut buf: [u8; 39] = mem::uninitialized();
buf[..6].copy_from_slice(b"date: ");
buf[6..35].copy_from_slice(&(*self.date.get()).bytes);
buf[35..].copy_from_slice(b"\r\n\r\n");
dst.extend_from_slice(&buf);
} else {
dst.extend_from_slice(&(*self.date.get()).bytes);
}
let date_bytes = unsafe { &(*self.date.get()).bytes };
if full {
let mut buf: [u8; 39] = [0; 39];
buf[..6].copy_from_slice(b"date: ");
buf[6..35].copy_from_slice(date_bytes);
buf[35..].copy_from_slice(b"\r\n\r\n");
dst.extend_from_slice(&buf);
} else {
dst.extend_from_slice(date_bytes);
}
}
}