mirror of
https://github.com/actix/actix-extras.git
synced 2024-11-23 15:51:06 +01:00
reuse BinaryBody for Frame::Payload
This commit is contained in:
parent
c435f16170
commit
4ee2a60d88
@ -7,6 +7,10 @@
|
||||
|
||||
* Refactor `RouteRecognizer` usability
|
||||
|
||||
* Refactor `HttpContext::write`
|
||||
|
||||
* Re-use `BinaryBody` for `Frame::Payload`
|
||||
|
||||
|
||||
## 0.1.0 (2017-10-23)
|
||||
|
||||
|
93
src/body.rs
93
src/body.rs
@ -1,6 +1,6 @@
|
||||
use std::rc::Rc;
|
||||
use std::sync::Arc;
|
||||
use bytes::Bytes;
|
||||
use bytes::{Bytes, BytesMut};
|
||||
|
||||
|
||||
/// Represents various types of http message body.
|
||||
@ -43,45 +43,15 @@ impl Body {
|
||||
}
|
||||
}
|
||||
|
||||
/// Create body from static string
|
||||
/// Create body from slice (copy)
|
||||
pub fn from_slice<'a>(s: &'a [u8]) -> Body {
|
||||
Body::Binary(BinaryBody::Bytes(Bytes::from(s)))
|
||||
}
|
||||
}
|
||||
|
||||
impl From<&'static str> for Body {
|
||||
fn from(s: &'static str) -> Body {
|
||||
Body::Binary(BinaryBody::Slice(s.as_ref()))
|
||||
}
|
||||
}
|
||||
|
||||
impl From<&'static [u8]> for Body {
|
||||
fn from(s: &'static [u8]) -> Body {
|
||||
Body::Binary(BinaryBody::Slice(s))
|
||||
}
|
||||
}
|
||||
|
||||
impl From<Vec<u8>> for Body {
|
||||
fn from(vec: Vec<u8>) -> Body {
|
||||
Body::Binary(BinaryBody::Bytes(Bytes::from(vec)))
|
||||
}
|
||||
}
|
||||
|
||||
impl From<String> for Body {
|
||||
fn from(s: String) -> Body {
|
||||
Body::Binary(BinaryBody::Bytes(Bytes::from(s)))
|
||||
}
|
||||
}
|
||||
|
||||
impl From<Rc<Bytes>> for Body {
|
||||
fn from(body: Rc<Bytes>) -> Body {
|
||||
Body::Binary(BinaryBody::SharedBytes(body))
|
||||
}
|
||||
}
|
||||
|
||||
impl From<Arc<Bytes>> for Body {
|
||||
fn from(body: Arc<Bytes>) -> Body {
|
||||
Body::Binary(BinaryBody::ArcSharedBytes(body))
|
||||
impl<T> From<T> for Body where T: Into<BinaryBody>{
|
||||
fn from(b: T) -> Body {
|
||||
Body::Binary(b.into())
|
||||
}
|
||||
}
|
||||
|
||||
@ -94,6 +64,59 @@ impl BinaryBody {
|
||||
&BinaryBody::ArcSharedBytes(ref bytes) => bytes.len(),
|
||||
}
|
||||
}
|
||||
|
||||
/// Create binary body from slice
|
||||
pub fn from_slice<'a>(s: &'a [u8]) -> BinaryBody {
|
||||
BinaryBody::Bytes(Bytes::from(s))
|
||||
}
|
||||
}
|
||||
|
||||
impl From<&'static str> for BinaryBody {
|
||||
fn from(s: &'static str) -> BinaryBody {
|
||||
BinaryBody::Slice(s.as_ref())
|
||||
}
|
||||
}
|
||||
|
||||
impl From<&'static [u8]> for BinaryBody {
|
||||
fn from(s: &'static [u8]) -> BinaryBody {
|
||||
BinaryBody::Slice(s)
|
||||
}
|
||||
}
|
||||
|
||||
impl From<Vec<u8>> for BinaryBody {
|
||||
fn from(vec: Vec<u8>) -> BinaryBody {
|
||||
BinaryBody::Bytes(Bytes::from(vec))
|
||||
}
|
||||
}
|
||||
|
||||
impl From<String> for BinaryBody {
|
||||
fn from(s: String) -> BinaryBody {
|
||||
BinaryBody::Bytes(Bytes::from(s))
|
||||
}
|
||||
}
|
||||
|
||||
impl From<Bytes> for BinaryBody {
|
||||
fn from(s: Bytes) -> BinaryBody {
|
||||
BinaryBody::Bytes(s)
|
||||
}
|
||||
}
|
||||
|
||||
impl From<BytesMut> for BinaryBody {
|
||||
fn from(s: BytesMut) -> BinaryBody {
|
||||
BinaryBody::Bytes(s.freeze())
|
||||
}
|
||||
}
|
||||
|
||||
impl From<Rc<Bytes>> for BinaryBody {
|
||||
fn from(body: Rc<Bytes>) -> BinaryBody {
|
||||
BinaryBody::SharedBytes(body)
|
||||
}
|
||||
}
|
||||
|
||||
impl From<Arc<Bytes>> for BinaryBody {
|
||||
fn from(body: Arc<Bytes>) -> BinaryBody {
|
||||
BinaryBody::ArcSharedBytes(body)
|
||||
}
|
||||
}
|
||||
|
||||
impl AsRef<[u8]> for BinaryBody {
|
||||
|
@ -4,13 +4,13 @@ use std::collections::VecDeque;
|
||||
use futures::{Async, Stream, Poll};
|
||||
use futures::sync::oneshot::Sender;
|
||||
|
||||
use bytes::Bytes;
|
||||
use actix::{Actor, ActorState, ActorContext, AsyncContext,
|
||||
Handler, Subscriber, ResponseType};
|
||||
use actix::fut::ActorFuture;
|
||||
use actix::dev::{AsyncContextApi, ActorAddressCell, ActorItemsCell, ActorWaitCell, SpawnHandle,
|
||||
Envelope, ToEnvelope, RemoteEnvelope};
|
||||
|
||||
use body::BinaryBody;
|
||||
use route::{Route, Frame};
|
||||
use httpresponse::HttpResponse;
|
||||
|
||||
@ -116,7 +116,7 @@ impl<A> HttpContext<A> where A: Actor<Context=Self> + Route {
|
||||
}
|
||||
|
||||
/// Write payload
|
||||
pub fn write<B: Into<Bytes>>(&mut self, data: B) {
|
||||
pub fn write<B: Into<BinaryBody>>(&mut self, data: B) {
|
||||
self.stream.push_back(Frame::Payload(Some(data.into())))
|
||||
}
|
||||
|
||||
|
@ -3,11 +3,11 @@ use std::rc::Rc;
|
||||
use std::marker::PhantomData;
|
||||
|
||||
use actix::Actor;
|
||||
use bytes::Bytes;
|
||||
use http::{header, Version};
|
||||
use futures::Stream;
|
||||
|
||||
use task::Task;
|
||||
use body::BinaryBody;
|
||||
use context::HttpContext;
|
||||
use resource::Reply;
|
||||
use payload::Payload;
|
||||
@ -20,9 +20,10 @@ use httpcodes::HTTPExpectationFailed;
|
||||
#[cfg_attr(feature="cargo-clippy", allow(large_enum_variant))]
|
||||
pub enum Frame {
|
||||
Message(HttpResponse),
|
||||
Payload(Option<Bytes>),
|
||||
Payload(Option<BinaryBody>),
|
||||
}
|
||||
|
||||
|
||||
/// Trait defines object that could be regestered as resource route
|
||||
#[allow(unused_variables)]
|
||||
pub trait RouteHandler<S>: 'static {
|
||||
|
@ -260,7 +260,7 @@ impl Task {
|
||||
self.encoder.encode(&mut self.buffer, chunk.as_ref());
|
||||
} else {
|
||||
// might be response for EXCEPT
|
||||
self.buffer.extend(chunk)
|
||||
self.buffer.extend_from_slice(chunk.as_ref())
|
||||
}
|
||||
},
|
||||
Frame::Payload(None) => {
|
||||
|
18
src/ws.rs
18
src/ws.rs
@ -62,7 +62,7 @@
|
||||
//! ```
|
||||
use std::vec::Vec;
|
||||
use http::{Method, StatusCode, header};
|
||||
use bytes::{Bytes, BytesMut};
|
||||
use bytes::BytesMut;
|
||||
use futures::{Async, Poll, Stream};
|
||||
|
||||
use actix::{Actor, ResponseType};
|
||||
@ -284,9 +284,7 @@ impl WsWriter {
|
||||
let mut buf = Vec::new();
|
||||
frame.format(&mut buf).unwrap();
|
||||
|
||||
ctx.write(
|
||||
Bytes::from(buf.as_slice())
|
||||
);
|
||||
ctx.write(buf);
|
||||
}
|
||||
|
||||
/// Send binary frame
|
||||
@ -297,9 +295,7 @@ impl WsWriter {
|
||||
let mut buf = Vec::new();
|
||||
frame.format(&mut buf).unwrap();
|
||||
|
||||
ctx.write(
|
||||
Bytes::from(buf.as_slice())
|
||||
);
|
||||
ctx.write(buf);
|
||||
}
|
||||
|
||||
/// Send ping frame
|
||||
@ -311,9 +307,7 @@ impl WsWriter {
|
||||
let mut buf = Vec::new();
|
||||
frame.format(&mut buf).unwrap();
|
||||
|
||||
ctx.write(
|
||||
Bytes::from(buf.as_slice())
|
||||
)
|
||||
ctx.write(buf);
|
||||
}
|
||||
|
||||
/// Send pong frame
|
||||
@ -325,9 +319,7 @@ impl WsWriter {
|
||||
let mut buf = Vec::new();
|
||||
frame.format(&mut buf).unwrap();
|
||||
|
||||
ctx.write(
|
||||
Bytes::from(buf.as_slice())
|
||||
)
|
||||
ctx.write(buf);
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user