BinValidator

Struct BinValidator 

Source
pub struct BinValidator {
Show 15 fields pub comment: String, pub bits_clr: ByteBuf, pub bits_set: ByteBuf, pub max: ByteBuf, pub min: ByteBuf, pub ex_max: bool, pub ex_min: bool, pub max_len: u32, pub min_len: u32, pub in_list: Vec<ByteBuf>, pub nin_list: Vec<ByteBuf>, pub query: bool, pub bit: bool, pub ord: bool, pub size: bool,
}
Expand description

Validator for byte sequences.

This validator type will only pass binary values (a sequence of bytes). A binary sequence can also be treated as a little-endian arbitrary-length unsigned integer. Validation passes if:

  • The bits set in bits_clr are cleared in the byte sequence.
  • The bits set in bits_set are set in the byte sequence.
  • If max has 1 or more bytes, the value is less than the maximum in max, or equal to it if ex_max is not set to true.
  • The value is greater than the minimum in min, or equal to it if ex_min is not set to true.
  • The value’s length in bytes is less than or equal to the value in max_len.
  • The value’s length in bytes is greater than or equal to the value in min_len.
  • If the in list is not empty, the value must be among the values in the list.
  • The value must not be among the values in the nin list.

§Defaults

Fields that aren’t specified for the validator use their defaults instead. The defaults for each field are:

  • comment: “”
  • bits_clr: empty
  • bits_set: empty
  • max: empty
  • min: empty
  • ex_max: false
  • ex_min: false
  • max_len: u32::MAX
  • min_len: 0
  • in_list: empty
  • nin_list: empty
  • query: false
  • bit: false
  • ord: false
  • size: false

Fields§

§comment: String

An optional comment explaining the validator.

§bits_clr: ByteBuf

A byte sequence used as a bit field. Any bits set in it must be cleared in an allowed value.

§bits_set: ByteBuf

A byte sequence used as a bit field. Any bits set in it must be set in an allowed value.

§max: ByteBuf

The maximum allowed value, as a little-endian arbitrary-length unsigned integer. If no bytes are present, there is no maximum.

§min: ByteBuf

The minimum allowed value, as a little-endian arbitrary-length unsigned integer.

§ex_max: bool

Changes max into an exclusive maximum.

§ex_min: bool

Changes min into an exclusive maximum.

§max_len: u32

Set the maximum allowed number of bytes.

§min_len: u32

Set the minimum allowed number of bytes.

§in_list: Vec<ByteBuf>

A vector of specific allowed values, stored under the in field. If empty, this vector is not checked against.

§nin_list: Vec<ByteBuf>

A vector of specific unallowed values, stored under the nin field.

§query: bool

If true, queries against matching spots may have values in the in or nin lists.

§bit: bool

If true, queries against matching spots may set the bits_clr and bits_set values to be non-zero.

§ord: bool

If true, queries against matching spots may set the max, min, ex_max, and ex_min values to non-defaults.

§size: bool

If true, queries against matching spots may set the min_len and max_len values to non-defaults.

Implementations§

Source§

impl BinValidator

Source

pub fn new() -> Self

Make a new validator with the default configuration.

Source

pub fn comment(self, comment: impl Into<String>) -> Self

Set a comment for the validator.

Source

pub fn bits_set(self, bits_set: impl Into<Vec<u8>>) -> Self

Choose which bits must be set.

Source

pub fn bits_clr(self, bits_clr: impl Into<Vec<u8>>) -> Self

Choose which bits must be cleared.

Source

pub fn max(self, max: impl Into<Vec<u8>>) -> Self

Set the maximum allowed value.

Source

pub fn min(self, min: impl Into<Vec<u8>>) -> Self

Set the minimum allowed value.

Source

pub fn ex_max(self, ex_max: bool) -> Self

Set whether or or not max is an exclusive maximum.

Source

pub fn ex_min(self, ex_min: bool) -> Self

Set whether or or not min is an exclusive maximum.

Source

pub fn max_len(self, max_len: u32) -> Self

Set the maximum number of allowed bytes.

Source

pub fn min_len(self, min_len: u32) -> Self

Set the minimum number of allowed bytes.

Source

pub fn in_add(self, add: impl Into<Vec<u8>>) -> Self

Add a value to the in list.

Source

pub fn nin_add(self, add: impl Into<Vec<u8>>) -> Self

Add a value to the nin list.

Source

pub fn query(self, query: bool) -> Self

Set whether or not queries can use the in and nin lists.

Source

pub fn bit(self, bit: bool) -> Self

Set whether or not queries can use the bits_clr and bits_set values.

Source

pub fn ord(self, ord: bool) -> Self

Set whether or not queries can use the max, min, ex_max, and ex_min values.

Source

pub fn size(self, size: bool) -> Self

Set whether or not queries can use the max_len and min_len values.

Source

pub fn build(self) -> Validator

Build this into a Validator enum.

Trait Implementations§

Source§

impl Clone for BinValidator

Source§

fn clone(&self) -> BinValidator

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for BinValidator

Source§

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

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

impl Default for BinValidator

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for BinValidator

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl PartialEq for BinValidator

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · 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 Serialize for BinValidator

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl StructuralPartialEq for BinValidator

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

Source§

type Output = T

Should always be Self
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, 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<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,