#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

#39 in #whether

Download history 509387/week @ 2024-10-30 521918/week @ 2024-11-06 553602/week @ 2024-11-13 501908/week @ 2024-11-20 401283/week @ 2024-11-27 529872/week @ 2024-12-04 543284/week @ 2024-12-11 352389/week @ 2024-12-18 179358/week @ 2024-12-25 345099/week @ 2025-01-01 514552/week @ 2025-01-08 469078/week @ 2025-01-15 455570/week @ 2025-01-22 479558/week @ 2025-01-29 628601/week @ 2025-02-05 370927/week @ 2025-02-12

2,015,435 downloads per month
Used in 5,520 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