- Notifications
You must be signed in to change notification settings - Fork41
License
micromatch/anymatch
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
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 falsyvalue. The matcher can also be an array of any or all of these. Useful forallowing 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. Seehttps://github.com/micromatch/micromatch#backslashes for more information.
npm install anymatch
- matchers: (Array|String|RegExp|Function)String to be directly matched, string with glob patterns, regular expressiontest, function that takes the testString as an argument and returns a truthyvalue 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. Ifpassed as an array, the first element of the array will be used as the
testStringfor non-function matchers, while the entire array will be appliedas the arguments for function matchers. - options: (Object [optional]_) Any of thepicomatch options.
- returnIndex: (Boolean [optional]) If true, return the array index ofthe first matcher that that testString matched, or -1 if no match, instead of aboolean result.
constanymatch=require('anymatch');constmatchers=['path/to/file.js','path/anyjs/**/*.js',/foo.js$/,string=>string.includes('bar')&&string.length>10];anymatch(matchers,'path/to/file.js');// trueanymatch(matchers,'path/anyjs/baz.js');// trueanymatch(matchers,'path/to/foo.js');// trueanymatch(matchers,'path/to/bar.js');// trueanymatch(matchers,'bar.js');// false// returnIndex = trueanymatch(matchers,'foo.js',{returnIndex:true});// 2anymatch(matchers,'path/anyjs/foo.js',{returnIndex:true});// 1// any picomatc// using globs to match directories and their childrenanymatch('node_modules','node_modules');// trueanymatch('node_modules','node_modules/somelib/index.js');// falseanymatch('node_modules/**','node_modules/somelib/index.js');// trueanymatch('node_modules/**','/absolute/path/to/node_modules/somelib/index.js');// falseanymatch('**/node_modules/**','/absolute/path/to/node_modules/somelib/index.js');// trueconstmatcher=anymatch(matchers);['foo.js','bar.js'].filter(matcher);// [ 'foo.js' ]anymatchmaster*❯
You can also pass in only your matcher(s) to get a curried function that hasalready been bound to the provided matching criteria. This can be used as anArray#filter callback.
varmatcher=anymatch(matchers);matcher('path/to/file.js');// truematcher('path/anyjs/baz.js',true);// 1['foo.js','bar.js'].filter(matcher);// ['foo.js']
See release notes page on GitHub
- v3.0: Removed
startIndexandendIndexarguments. Node 8.x-only. - v2.0:micromatch moves away from minimatch-parity and inline with Bash. This includes handling backslashes differently (seehttps://github.com/micromatch/micromatch#backslashes for more information).
- v1.2: anymatch usesmicromatchfor glob pattern matching. Issues with glob pattern matching should bereported directly to themicromatch issue tracker.
About
Topics
Resources
License
Code of conduct
Contributing
Security policy
Uh oh!
There was an error while loading.Please reload this page.