mirror of
https://github.com/actix/actix-web.git
synced 2025-01-05 14:58:44 +00:00
expose encoder error
This commit is contained in:
parent
f12f62ba73
commit
8d2abe4b35
3 changed files with 42 additions and 35 deletions
|
@ -1,7 +1,6 @@
|
||||||
//! Stream encoders.
|
//! Stream encoders.
|
||||||
|
|
||||||
use std::{
|
use std::{
|
||||||
error::Error as StdError,
|
|
||||||
future::Future,
|
future::Future,
|
||||||
io::{self, Write as _},
|
io::{self, Write as _},
|
||||||
pin::Pin,
|
pin::Pin,
|
||||||
|
@ -10,7 +9,6 @@ use std::{
|
||||||
|
|
||||||
use actix_rt::task::{spawn_blocking, JoinHandle};
|
use actix_rt::task::{spawn_blocking, JoinHandle};
|
||||||
use bytes::Bytes;
|
use bytes::Bytes;
|
||||||
use derive_more::Display;
|
|
||||||
use futures_core::ready;
|
use futures_core::ready;
|
||||||
use pin_project_lite::pin_project;
|
use pin_project_lite::pin_project;
|
||||||
|
|
||||||
|
@ -23,7 +21,7 @@ use flate2::write::{GzEncoder, ZlibEncoder};
|
||||||
#[cfg(feature = "compress-zstd")]
|
#[cfg(feature = "compress-zstd")]
|
||||||
use zstd::stream::write::Encoder as ZstdEncoder;
|
use zstd::stream::write::Encoder as ZstdEncoder;
|
||||||
|
|
||||||
use super::Writer;
|
use super::{EncoderError, Writer};
|
||||||
use crate::{
|
use crate::{
|
||||||
body::{BodySize, MessageBody},
|
body::{BodySize, MessageBody},
|
||||||
error::BlockingError,
|
error::BlockingError,
|
||||||
|
@ -364,32 +362,3 @@ impl ContentEncoder {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Display)]
|
|
||||||
#[non_exhaustive]
|
|
||||||
pub enum EncoderError {
|
|
||||||
#[display(fmt = "body")]
|
|
||||||
Body(Box<dyn StdError>),
|
|
||||||
|
|
||||||
#[display(fmt = "blocking")]
|
|
||||||
Blocking(BlockingError),
|
|
||||||
|
|
||||||
#[display(fmt = "io")]
|
|
||||||
Io(io::Error),
|
|
||||||
}
|
|
||||||
|
|
||||||
impl StdError for EncoderError {
|
|
||||||
fn source(&self) -> Option<&(dyn StdError + 'static)> {
|
|
||||||
match self {
|
|
||||||
EncoderError::Body(err) => Some(&**err),
|
|
||||||
EncoderError::Blocking(err) => Some(err),
|
|
||||||
EncoderError::Io(err) => Some(err),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<EncoderError> for crate::Error {
|
|
||||||
fn from(err: EncoderError) -> Self {
|
|
||||||
crate::Error::new_encoder().with_cause(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,22 +1,60 @@
|
||||||
//! Content-Encoding support.
|
//! Content-Encoding support.
|
||||||
|
|
||||||
use std::io;
|
use std::{error::Error as StdError, io};
|
||||||
|
|
||||||
use bytes::{Bytes, BytesMut};
|
use bytes::{Bytes, BytesMut};
|
||||||
|
use derive_more::Display;
|
||||||
|
|
||||||
|
use crate::error::BlockingError;
|
||||||
|
|
||||||
|
#[cfg(feature = "__compress")]
|
||||||
mod decoder;
|
mod decoder;
|
||||||
|
#[cfg(feature = "__compress")]
|
||||||
mod encoder;
|
mod encoder;
|
||||||
|
|
||||||
|
#[cfg(feature = "__compress")]
|
||||||
pub use self::decoder::Decoder;
|
pub use self::decoder::Decoder;
|
||||||
pub use self::encoder::{Encoder, EncoderError};
|
#[cfg(feature = "__compress")]
|
||||||
|
pub use self::encoder::Encoder;
|
||||||
|
|
||||||
|
#[derive(Debug, Display)]
|
||||||
|
#[non_exhaustive]
|
||||||
|
pub enum EncoderError {
|
||||||
|
#[display(fmt = "body")]
|
||||||
|
Body(Box<dyn StdError>),
|
||||||
|
|
||||||
|
#[display(fmt = "blocking")]
|
||||||
|
Blocking(BlockingError),
|
||||||
|
|
||||||
|
#[display(fmt = "io")]
|
||||||
|
Io(io::Error),
|
||||||
|
}
|
||||||
|
|
||||||
|
impl StdError for EncoderError {
|
||||||
|
fn source(&self) -> Option<&(dyn StdError + 'static)> {
|
||||||
|
match self {
|
||||||
|
EncoderError::Body(err) => Some(&**err),
|
||||||
|
EncoderError::Blocking(err) => Some(err),
|
||||||
|
EncoderError::Io(err) => Some(err),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<EncoderError> for crate::Error {
|
||||||
|
fn from(err: EncoderError) -> Self {
|
||||||
|
crate::Error::new_encoder().with_cause(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Special-purpose writer for streaming (de-)compression.
|
/// Special-purpose writer for streaming (de-)compression.
|
||||||
///
|
///
|
||||||
/// Pre-allocates 8KiB of capacity.
|
/// Pre-allocates 8KiB of capacity.
|
||||||
|
#[cfg(feature = "__compress")]
|
||||||
pub(self) struct Writer {
|
pub(self) struct Writer {
|
||||||
buf: BytesMut,
|
buf: BytesMut,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "__compress")]
|
||||||
impl Writer {
|
impl Writer {
|
||||||
fn new() -> Writer {
|
fn new() -> Writer {
|
||||||
Writer {
|
Writer {
|
||||||
|
@ -29,6 +67,7 @@ impl Writer {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "__compress")]
|
||||||
impl io::Write for Writer {
|
impl io::Write for Writer {
|
||||||
fn write(&mut self, buf: &[u8]) -> io::Result<usize> {
|
fn write(&mut self, buf: &[u8]) -> io::Result<usize> {
|
||||||
self.buf.extend_from_slice(buf);
|
self.buf.extend_from_slice(buf);
|
||||||
|
|
|
@ -32,7 +32,6 @@ pub mod body;
|
||||||
mod builder;
|
mod builder;
|
||||||
mod config;
|
mod config;
|
||||||
|
|
||||||
#[cfg(feature = "__compress")]
|
|
||||||
pub mod encoding;
|
pub mod encoding;
|
||||||
mod extensions;
|
mod extensions;
|
||||||
pub mod header;
|
pub mod header;
|
||||||
|
|
Loading…
Reference in a new issue