Struct DebugValidationPolicy

Source
pub struct DebugValidationPolicy<P: ValidationPolicy>(/* private fields */);
Expand description

A validation policy that is active only in debug builds.

This struct acts as a wrapper around another ValidationPolicy.

  • In debug builds (#[cfg(debug_assertions)]), it delegates validation directly to the inner policy P.
  • In release builds (#[cfg(not(debug_assertions))]), it becomes a “no-op” (no operation), meaning its validate and validate_ref methods do nothing and always return Ok.

This is useful for enforcing strict, potentially expensive validations during development and testing, while eliminating their performance overhead in production code.

§Generic Parameters

§Example

use num_valid::validation::{DebugValidationPolicy, StrictFinitePolicy};
use try_create::ValidationPolicy;

// Define a policy that uses StrictFinitePolicy only in debug builds.
type MyPolicy = DebugValidationPolicy<Native64RawRealStrictFinitePolicy>;

let nan_value = f64::NAN;
let result = MyPolicy::validate(nan_value);

#[cfg(debug_assertions)]
{
    // In debug mode, the validation fails because StrictFinitePolicy catches NaN.
    assert!(result.is_err());
}

#[cfg(not(debug_assertions))]
{
    // In release mode, the validation is skipped and always succeeds.
    assert!(result.is_ok());
}

Trait Implementations§

Source§

impl<P: ValidationPolicy> ValidationPolicy for DebugValidationPolicy<P>

Source§

type Value = <P as ValidationPolicy>::Value

The type of the value to be validated.
Source§

type Error = <P as ValidationPolicy>::Error

The type of the error returned if validation fails.
Source§

fn validate_ref(value: &Self::Value) -> Result<(), Self::Error>

Validates a value by reference. Read more
Source§

fn validate(v: Self::Value) -> Result<Self::Value, Self::Error>

Validates a value by consuming it. Read more
Source§

impl<P> ValidationPolicyComplex for DebugValidationPolicy<P>

Source§

const PRECISION: u32 = P::PRECISION

Source§

impl<P> ValidationPolicyReal for DebugValidationPolicy<P>

Source§

const PRECISION: u32 = P::PRECISION

Auto Trait Implementations§

§

impl<P> Freeze for DebugValidationPolicy<P>

§

impl<P> RefUnwindSafe for DebugValidationPolicy<P>
where P: RefUnwindSafe,

§

impl<P> Send for DebugValidationPolicy<P>
where P: Send,

§

impl<P> Sync for DebugValidationPolicy<P>
where P: Sync,

§

impl<P> Unpin for DebugValidationPolicy<P>
where P: Unpin,

§

impl<P> UnwindSafe for DebugValidationPolicy<P>
where P: UnwindSafe,

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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, 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