[]Struct avocado::literal::RegexOpts

pub struct RegexOpts { /* fields omitted */ }

Options for matching text against a regular expression. Useful with the $regex operator. E.g.:

let query = doc!{
    "name": {
        "$regex": "^Foo",
        "$options": RegexOpts::LINE_ANCHOR | RegexOpts::IGNORE_CASE,
    },
    "address": {
        "$regex": ".* street$",
        "$options": RegexOpts::default(),
    },
};
assert_eq!(query, doc!{
    "name": {
        "$regex": "^Foo",
        "$options": "im",
    },
    "address": {
        "$regex": ".* street$",
        "$options": "",
    },
});

Methods

impl RegexOpts

pub const IGNORE_CASE: RegexOpts

Case insensitive matching.

pub const LINE_ANCHOR: RegexOpts

^ and $ match the beginning and the end of lines, not the whole string.

pub const EXTENDED: RegexOpts

"extended" syntax, allows embedded whitespace and #-comments

pub const DOT_NEWLINE: RegexOpts

The . character matches newlines too.

pub fn empty() -> RegexOpts

Returns an empty set of flags.

pub fn all() -> RegexOpts

Returns the set containing all flags.

pub fn bits(&self) -> u8

Returns the raw value of the flags currently stored.

pub fn from_bits(bits: u8) -> Option<RegexOpts>

Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.

pub fn from_bits_truncate(bits: u8) -> RegexOpts

Convert from underlying bit representation, dropping any bits that do not correspond to flags.

pub fn is_empty(&self) -> bool

Returns true if no flags are currently stored.

pub fn is_all(&self) -> bool

Returns true if all flags are currently set.

pub fn intersects(&self, other: RegexOpts) -> bool

Returns true if there are flags common to both self and other.

pub fn contains(&self, other: RegexOpts) -> bool

Returns true all of the flags in other are contained within self.

pub fn insert(&mut self, other: RegexOpts)

Inserts the specified flags in-place.

pub fn remove(&mut self, other: RegexOpts)

Removes the specified flags in-place.

pub fn toggle(&mut self, other: RegexOpts)

Toggles the specified flags in-place.

pub fn set(&mut self, other: RegexOpts, value: bool)

Inserts or removes the specified flags depending on the passed value.

Trait Implementations

impl PartialOrd<RegexOpts> for RegexOpts

impl From<RegexOpts> for Bson
[src]

See the explanation for BsonType as to why this impl is possible.

impl Ord for RegexOpts

fn max(self, other: Self) -> Self
1.21.0
[src]

Compares and returns the maximum of two values. Read more

fn min(self, other: Self) -> Self
1.21.0
[src]

Compares and returns the minimum of two values. Read more

impl Eq for RegexOpts

impl Copy for RegexOpts

impl Clone for RegexOpts

fn clone_from(&mut self, source: &Self)
1.0.0
[src]

Performs copy-assignment from source. Read more

impl PartialEq<RegexOpts> for RegexOpts

impl Default for RegexOpts
[src]

impl Extend<RegexOpts> for RegexOpts

impl Debug for RegexOpts

impl Hash for RegexOpts

fn hash_slice<H>(data: &[Self], state: &mut H) where
    H: Hasher
1.3.0
[src]

Feeds a slice of this type into the given [Hasher]. Read more

impl Sub<RegexOpts> for RegexOpts

type Output = RegexOpts

The resulting type after applying the - operator.

fn sub(self, other: RegexOpts) -> RegexOpts

Returns the set difference of the two sets of flags.

impl SubAssign<RegexOpts> for RegexOpts

fn sub_assign(&mut self, other: RegexOpts)

Disables all flags enabled in the set.

impl Not for RegexOpts

type Output = RegexOpts

The resulting type after applying the ! operator.

fn not(self) -> RegexOpts

Returns the complement of this set of flags.

impl BitAnd<RegexOpts> for RegexOpts

type Output = RegexOpts

The resulting type after applying the & operator.

fn bitand(self, other: RegexOpts) -> RegexOpts

Returns the intersection between the two sets of flags.

impl BitOr<RegexOpts> for RegexOpts

type Output = RegexOpts

The resulting type after applying the | operator.

fn bitor(self, other: RegexOpts) -> RegexOpts

Returns the union of the two sets of flags.

impl BitXor<RegexOpts> for RegexOpts

type Output = RegexOpts

The resulting type after applying the ^ operator.

fn bitxor(self, other: RegexOpts) -> RegexOpts

Returns the left flags, but with all the right flags toggled.

impl BitAndAssign<RegexOpts> for RegexOpts

fn bitand_assign(&mut self, other: RegexOpts)

Disables all flags disabled in the set.

impl BitOrAssign<RegexOpts> for RegexOpts

fn bitor_assign(&mut self, other: RegexOpts)

Adds the set of flags.

impl BitXorAssign<RegexOpts> for RegexOpts

fn bitxor_assign(&mut self, other: RegexOpts)

Toggles the set of flags.

impl FromIterator<RegexOpts> for RegexOpts

impl Octal for RegexOpts

impl Binary for RegexOpts

impl LowerHex for RegexOpts

impl UpperHex for RegexOpts

impl<'a> Deserialize<'a> for RegexOpts
[src]

impl Serialize for RegexOpts
[src]

Auto Trait Implementations

impl Send for RegexOpts

impl Sync for RegexOpts

Blanket Implementations

impl<T> From for T
[src]

impl<T, U> Into for T where
    U: From<T>, 
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

impl<T, U> TryFrom for T where
    T: From<U>, 
[src]

type Error = !

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

impl<T> Borrow for T where
    T: ?Sized
[src]

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> BorrowMut for T where
    T: ?Sized
[src]

impl<T, U> TryInto for T where
    U: TryFrom<T>, 
[src]

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

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

impl<T> DeserializeOwned for T where
    T: Deserialize<'de>, 
[src]

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

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

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

impl<T> Same for T

type Output = T

Should always be Self