anymatch

:bangbang: Matches strings against configurable strings, globs, regular expressions, and/or functions

Github stars Tracking Chart

anymatch Build Status Coverage Status

Javascript module to match a string against a regular expression, glob, string,
or function that takes the string as an argument and returns a truthy or falsy
value. The matcher can also be an array of any or all of these. Useful for
allowing a very flexible user-defined config to define things like file paths.

Note: This module has Bash-parity, please be aware that Windows-style backslashes are not supported as separators. See https://github.com/micromatch/micromatch#backslashes for more information.

Usage

npm install anymatch

anymatch(matchers, testString, [returnIndex], [options])

  • matchers: (Array, String, RegExp, Function)
    String to be directly matched, string with glob patterns, regular expression
    test, function that takes the testString as an argument and returns a truthy
    value if it should be matched, or an array of any number and mix of these types.
  • testString: (String, Array) The string to test against the matchers. If
    passed as an array, the first element of the array will be used as the
    testString for non-function matchers, while the entire array will be applied
    as the arguments for function matchers.
  • options: (Object [optional]_) Any of the picomatch options.
    • returnIndex: (Boolean [optional]) If true, return the array index of
      the first matcher that that testString matched, or -1 if no match, instead of a
      boolean result.
const anymatch = require('anymatch');

const matchers = [ 'path/to/file.js', 'path/anyjs/**/*.js', /foo.js$/, string => string.includes('bar') && string.length > 10 ] ;

anymatch(matchers, 'path/to/file.js'); // true
anymatch(matchers, 'path/anyjs/baz.js'); // true
anymatch(matchers, 'path/to/foo.js'); // true
anymatch(matchers, 'path/to/bar.js'); // true
anymatch(matchers, 'bar.js'); // false

// returnIndex = true
anymatch(matchers, 'foo.js', {returnIndex: true}); // 2
anymatch(matchers, 'path/anyjs/foo.js', {returnIndex: true}); // 1

// any picomatc

// using globs to match directories and their children
anymatch('node_modules', 'node_modules'); // true
anymatch('node_modules', 'node_modules/somelib/index.js'); // false
anymatch('node_modules/**', 'node_modules/somelib/index.js'); // true
anymatch('node_modules/**', '/absolute/path/to/node_modules/somelib/index.js'); // false
anymatch('**/node_modules/**', '/absolute/path/to/node_modules/somelib/index.js'); // true

const matcher = anymatch(matchers);
['foo.js', 'bar.js'].filter(matcher);  // [ 'foo.js' ]
anymatch master* ❯

anymatch(matchers)

You can also pass in only your matcher(s) to get a curried function that has
already been bound to the provided matching criteria. This can be used as an
Array#filter callback.

var matcher = anymatch(matchers);

matcher('path/to/file.js'); // true
matcher('path/anyjs/baz.js', true); // 1

['foo.js', 'bar.js'].filter(matcher); // ['foo.js']

Changelog

See release notes page on GitHub

License

ISC

Main metrics

Overview
Name With Ownermicromatch/anymatch
Primary LanguageJavaScript
Program languageJavaScript (Language Count: 1)
Platform
License:ISC License
所有者活动
Created At2013-07-16 19:33:13
Pushed At2023-05-18 16:52:59
Last Commit At2022-11-21 11:19:43
Release Count18
Last Release Namev3.1.3 (Posted on 2022-11-21 11:19:43)
First Release Name0.1.0 (Posted on )
用户参与
Stargazers Count396
Watchers Count13
Fork Count41
Commits Count178
Has Issues Enabled
Issues Count23
Issue Open Count4
Pull Requests Count19
Pull Requests Open Count3
Pull Requests Close Count4
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private