3 stable releases

1.0.2 Apr 19, 2021
1.0.1 Dec 12, 2020

#884 in Filesystem

Download history 2411/week @ 2024-12-17 1727/week @ 2024-12-24 2641/week @ 2024-12-31 3463/week @ 2025-01-07 4111/week @ 2025-01-14 3725/week @ 2025-01-21 4520/week @ 2025-01-28 3862/week @ 2025-02-04 5082/week @ 2025-02-11 8768/week @ 2025-02-18 5905/week @ 2025-02-25 6077/week @ 2025-03-04 7592/week @ 2025-03-11 4502/week @ 2025-03-18 6061/week @ 2025-03-25 4792/week @ 2025-04-01

23,950 downloads per month
Used in 29 crates (via change-detection)

Unlicense OR MIT

20KB
442 lines

A collection of useful path matchers

Dual-licensed under MIT or the UNLICENSE.

Features

  • Matches path with another path or glob expression.
  • Allows to combine multiple path matchers.

Usage

Add dependency to Cargo.toml:

[dependencies]
path-matchers = "1.0"

Use it where appropriate:

use std::path::PathBuf;
use path_matchers::{any, glob, PathMatcher, PathMatcherExt};

fn main() {
    let path1 = PathBuf::from("images/big/best.png");
    let path2 = PathBuf::from("images/small/32x32/best.jpg");

    // check both paths matches `images/**/best.*`
    let all_best_images = glob("images/**/best.*").unwrap();

    assert!(all_best_images.matches(&path1));
    assert!(all_best_images.matches(&path2));

    let all_jpgs = glob("images/**/*.jpg").unwrap();
    assert!(!all_jpgs.matches(&path1));
    assert!(all_jpgs.matches(&path2));

    let all_pngs = glob("images/**/*.png").unwrap();
    assert!(all_pngs.matches(&path1));
    assert!(!all_pngs.matches(&path2));

    // now we can combine two matchers to match both jpgs and pngs
    let all_pics = all_jpgs.or(all_pngs);
    assert!(all_pics.matches(&path1));
    assert!(all_pics.matches(&path2));

    // you can also use macro for the same
    let all_jpgs = glob("images/**/*.jpg").unwrap();
    let all_pngs = glob("images/**/*.png").unwrap();
    let all_pics = any!(all_jpgs, all_pngs);
    assert!(all_pics.matches(&path1));
    assert!(all_pics.matches(&path2));
}

Dependencies

~50KB