str-match

Crates.iostr-match
lib.rsstr-match
version0.1.2
sourcesrc
created_at2022-09-17 18:32:49.614287
updated_at2024-02-17 09:14:55.386637
descriptionFormat pattern like str match macro
homepage
repositoryhttps://github.com/kazatsuyu/str-match
max_upload_size
id668276
size18,953
白山風露 (kazatsuyu)

documentation

README

str-match

Match str with pattern like format!.

Usage

use str_match::str_match;

fn f(a: &str) -> &str{
    str_match! {
        match a {
            "abc{a}ghi" => a,
            "aaa{bb}" => bb,
            "{{{x}}}" => x,
            _ => "!",
        }
    }
}

assert_eq!(f("abcdefghi"), "def");
assert_eq!(f("aaabbbccc"), "bbbccc");
assert_eq!(f("{000}"), "000");
assert_eq!(f("xyz"), "!");

You can use "attribute" features in nightly.

// with `str-match.features = ["attribute"]` in Cargo.toml
#![feature(stmt_expr_attributes, proc_macro_hygiene)]
use str_match::str_match;

fn f(a: &str) -> &str{
    #[str_match]
    match a {
        "abc{x}ghi" => x,
        "aaa{x}" => x,
        "{{{x}}}" => x,
        _ => "!",
    }
}

Limitations

This macro converts &str to &[u8] and use match slice pattern. For example, "abc{x}ghi" pattern is converted to [b'a', b'b', b'c', x @ .., b'g', b'h', b'i' ]. Because two or more variadic patterns are not allowed in slice pattern, only zero or one placeholder in str pattern is also allowed.

This macro can use single &str matching, complex pattern (like (&str, &str)) is not supported.

Commit count: 12

cargo fmt