#expression #pattern #evaluate #boolean #whether #debugging #match

matches

A macro to evaluate, as a boolean, whether an expression matches a pattern

10 releases

Uses old Rust 2015

0.1.10 Jan 21, 2023
0.1.9 Aug 12, 2021
0.1.8 Aug 22, 2018
0.1.7 Jul 19, 2018
0.1.0 Dec 5, 2014

#33 in #whether

Download history 461517/week @ 2024-07-23 439013/week @ 2024-07-30 481125/week @ 2024-08-06 492569/week @ 2024-08-13 476049/week @ 2024-08-20 471786/week @ 2024-08-27 503869/week @ 2024-09-03 483111/week @ 2024-09-10 432063/week @ 2024-09-17 506505/week @ 2024-09-24 508493/week @ 2024-10-01 504780/week @ 2024-10-08 552829/week @ 2024-10-15 557197/week @ 2024-10-22 509307/week @ 2024-10-29 529042/week @ 2024-11-05

2,227,104 downloads per month
Used in 5,482 crates (220 directly)

MIT license

6KB
55 lines

A macro to evaluate, as a boolean, whether an expression matches a pattern.

For users who build using only Rust 1.42 and newer, consider using std::matches, which is included in the standard library prelude and thus is automatically in scope.


lib.rs:

A macro to evaluate, as a boolean, whether an expression matches a pattern.

For users who build using only Rust 1.42 and newer, consider using std::matches, which is included in the standard library prelude and thus is automatically in scope.

Examples

#[macro_use]
extern crate matches;

#[derive(Debug)]
pub enum Foo<T> {
    A,
    B(T),
}

impl<T> Foo<T> {
    pub fn is_b(&self) -> bool {
        matches!(*self, Foo::B(_))
    }
}

impl<T: core::fmt::Debug> Foo<T> {
    pub fn assert_is_b(&self) {
        assert_matches!(&self, Foo::B(_));
    }
}

No runtime deps