Skip to main content

LimitError

Enum LimitError 

Source
pub enum LimitError {
    FileTooLarge {
        actual_bytes: u64,
        limit_bytes: u64,
    },
    StreamTooLarge {
        actual_bytes: u64,
        limit_bytes: u64,
    },
    ImageTooLarge {
        width: u64,
        height: u64,
        pixels: u64,
        limit_pixels: u64,
    },
    ObjectDepthExceeded {
        depth: u32,
        limit: u32,
    },
    TooManyOperators {
        count: u64,
        limit: u64,
    },
    XfaNestingTooDeep {
        depth: u32,
        limit: u32,
    },
    FormCalcRecursionTooDeep {
        depth: u32,
        limit: u32,
    },
}
Expand description

Error returned when a configured resource limit is exceeded.

A LimitError is a hard stop on the current operation — the caller should either raise the relevant cap on the ProcessingLimits used to construct the engine, or refuse the input. All variants carry both the observed value and the limit so callers can produce useful error messages without re-running detection.

Variants§

§

FileTooLarge

PDF file size exceeded ProcessingLimits::max_file_bytes. Defends against trivially-DoS-ing the parser with an oversized input.

Fields

§actual_bytes: u64

Observed file size in bytes.

§limit_bytes: u64

Configured maximum file size in bytes.

§

StreamTooLarge

A decompressed stream exceeded ProcessingLimits::max_stream_bytes. Defends against “decompression bomb” inputs (Flate, LZW, ASCII85) that expand far beyond their compressed footprint.

Fields

§actual_bytes: u64

Observed decompressed stream size in bytes.

§limit_bytes: u64

Configured maximum stream size in bytes.

§

ImageTooLarge

An image XObject exceeded ProcessingLimits::max_image_pixels. pixels = width * height regardless of color depth. Guards the memory used by rasterization and color-space conversion.

Fields

§width: u64

Observed image width in pixels.

§height: u64

Observed image height in pixels.

§pixels: u64

Observed total pixel count (width * height).

§limit_pixels: u64

Configured maximum pixel count.

§

ObjectDepthExceeded

Indirect-object reference chain exceeded ProcessingLimits::max_object_depth. Defends against cyclic or pathologically nested object graphs that would otherwise blow the parser stack.

Fields

§depth: u32

Observed reference-chain depth.

§limit: u32

Configured maximum reference-chain depth.

§

TooManyOperators

Content-stream operator count exceeded ProcessingLimits::max_operator_count. Caps per-page rendering work so a billion no-op operators can’t pin a CPU.

Fields

§count: u64

Observed operator count.

§limit: u64

Configured maximum operator count.

§

XfaNestingTooDeep

XFA template subform nesting exceeded ProcessingLimits::max_xfa_nesting_depth. Defends the XFA layout engine against pathologically nested templates.

Fields

§depth: u32

Observed XFA subform nesting depth.

§limit: u32

Configured maximum nesting depth.

§

FormCalcRecursionTooDeep

FormCalc expression recursion exceeded ProcessingLimits::max_formcalc_depth. Stops infinite or deeply mutually-recursive expressions from blowing the FormCalc interpreter stack.

Fields

§depth: u32

Observed recursion depth.

§limit: u32

Configured maximum recursion depth.

Trait Implementations§

Source§

impl Clone for LimitError

Source§

fn clone(&self) -> LimitError

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for LimitError

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Display for LimitError

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Error for LimitError

1.30.0 · Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0:

use the Display impl or to_string()

1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0:

replaced by Error::source, which can support downcasting

Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl PartialEq for LimitError

Source§

fn eq(&self, other: &LimitError) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for LimitError

Source§

impl StructuralPartialEq for LimitError

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, S> SimdFrom<T, S> for T
where S: Simd,

Source§

fn simd_from(value: T, _simd: S) -> T

Source§

impl<F, T, S> SimdInto<T, S> for F
where T: SimdFrom<F, S>, S: Simd,

Source§

fn simd_into(self, simd: S) -> T

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T> ToStringFallible for T
where T: Display,

Source§

fn try_to_string(&self) -> Result<String, TryReserveError>

ToString::to_string, but without panic on OOM.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,