455 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			455 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # minimatch
 | |
| 
 | |
| A minimal matching utility.
 | |
| 
 | |
| This is the matching library used internally by npm.
 | |
| 
 | |
| It works by converting glob expressions into JavaScript `RegExp`
 | |
| objects.
 | |
| 
 | |
| ## Usage
 | |
| 
 | |
| ```js
 | |
| // hybrid module, load with require() or import
 | |
| import { minimatch } from 'minimatch'
 | |
| // or:
 | |
| const { minimatch } = require('minimatch')
 | |
| 
 | |
| minimatch('bar.foo', '*.foo') // true!
 | |
| minimatch('bar.foo', '*.bar') // false!
 | |
| minimatch('bar.foo', '*.+(bar|foo)', { debug: true }) // true, and noisy!
 | |
| ```
 | |
| 
 | |
| ## Features
 | |
| 
 | |
| Supports these glob features:
 | |
| 
 | |
| - Brace Expansion
 | |
| - Extended glob matching
 | |
| - "Globstar" `**` matching
 | |
| - [Posix character
 | |
|   classes](https://www.gnu.org/software/bash/manual/html_node/Pattern-Matching.html),
 | |
|   like `[[:alpha:]]`, supporting the full range of Unicode
 | |
|   characters. For example, `[[:alpha:]]` will match against
 | |
|   `'é'`, though `[a-zA-Z]` will not. Collating symbol and set
 | |
|   matching is not supported, so `[[=e=]]` will _not_ match `'é'`
 | |
|   and `[[.ch.]]` will not match `'ch'` in locales where `ch` is
 | |
|   considered a single character.
 | |
| 
 | |
| See:
 | |
| 
 | |
| - `man sh`
 | |
| - `man bash` [Pattern
 | |
|   Matching](https://www.gnu.org/software/bash/manual/html_node/Pattern-Matching.html)
 | |
| - `man 3 fnmatch`
 | |
| - `man 5 gitignore`
 | |
| 
 | |
| ## Windows
 | |
| 
 | |
| **Please only use forward-slashes in glob expressions.**
 | |
| 
 | |
| Though windows uses either `/` or `\` as its path separator, only `/`
 | |
| characters are used by this glob implementation. You must use
 | |
| forward-slashes **only** in glob expressions. Back-slashes in patterns
 | |
| will always be interpreted as escape characters, not path separators.
 | |
| 
 | |
| Note that `\` or `/` _will_ be interpreted as path separators in paths on
 | |
| Windows, and will match against `/` in glob expressions.
 | |
| 
 | |
| So just always use `/` in patterns.
 | |
| 
 | |
| ### UNC Paths
 | |
| 
 | |
| On Windows, UNC paths like `//?/c:/...` or
 | |
| `//ComputerName/Share/...` are handled specially.
 | |
| 
 | |
| - Patterns starting with a double-slash followed by some
 | |
|   non-slash characters will preserve their double-slash. As a
 | |
|   result, a pattern like `//*` will match `//x`, but not `/x`.
 | |
| - Patterns staring with `//?/<drive letter>:` will _not_ treat
 | |
|   the `?` as a wildcard character. Instead, it will be treated
 | |
|   as a normal string.
 | |
| - Patterns starting with `//?/<drive letter>:/...` will match
 | |
|   file paths starting with `<drive letter>:/...`, and vice versa,
 | |
|   as if the `//?/` was not present. This behavior only is
 | |
|   present when the drive letters are a case-insensitive match to
 | |
|   one another. The remaining portions of the path/pattern are
 | |
|   compared case sensitively, unless `nocase:true` is set.
 | |
| 
 | |
| Note that specifying a UNC path using `\` characters as path
 | |
| separators is always allowed in the file path argument, but only
 | |
| allowed in the pattern argument when `windowsPathsNoEscape: true`
 | |
| is set in the options.
 | |
| 
 | |
| ## Minimatch Class
 | |
| 
 | |
| Create a minimatch object by instantiating the `minimatch.Minimatch` class.
 | |
| 
 | |
| ```javascript
 | |
| var Minimatch = require('minimatch').Minimatch
 | |
| var mm = new Minimatch(pattern, options)
 | |
| ```
 | |
| 
 | |
| ### Properties
 | |
| 
 | |
| - `pattern` The original pattern the minimatch object represents.
 | |
| - `options` The options supplied to the constructor.
 | |
| - `set` A 2-dimensional array of regexp or string expressions.
 | |
|   Each row in the
 | |
|   array corresponds to a brace-expanded pattern. Each item in the row
 | |
|   corresponds to a single path-part. For example, the pattern
 | |
|   `{a,b/c}/d` would expand to a set of patterns like:
 | |
| 
 | |
|         [ [ a, d ]
 | |
|         , [ b, c, d ] ]
 | |
| 
 | |
|   If a portion of the pattern doesn't have any "magic" in it
 | |
|   (that is, it's something like `"foo"` rather than `fo*o?`), then it
 | |
|   will be left as a string rather than converted to a regular
 | |
|   expression.
 | |
| 
 | |
| - `regexp` Created by the `makeRe` method. A single regular expression
 | |
|   expressing the entire pattern. This is useful in cases where you wish
 | |
|   to use the pattern somewhat like `fnmatch(3)` with `FNM_PATH` enabled.
 | |
| - `negate` True if the pattern is negated.
 | |
| - `comment` True if the pattern is a comment.
 | |
| - `empty` True if the pattern is `""`.
 | |
| 
 | |
| ### Methods
 | |
| 
 | |
| - `makeRe()` Generate the `regexp` member if necessary, and return it.
 | |
|   Will return `false` if the pattern is invalid.
 | |
| - `match(fname)` Return true if the filename matches the pattern, or
 | |
|   false otherwise.
 | |
| - `matchOne(fileArray, patternArray, partial)` Take a `/`-split
 | |
|   filename, and match it against a single row in the `regExpSet`. This
 | |
|   method is mainly for internal use, but is exposed so that it can be
 | |
|   used by a glob-walker that needs to avoid excessive filesystem calls.
 | |
| - `hasMagic()` Returns true if the parsed pattern contains any
 | |
|   magic characters. Returns false if all comparator parts are
 | |
|   string literals. If the `magicalBraces` option is set on the
 | |
|   constructor, then it will consider brace expansions which are
 | |
|   not otherwise magical to be magic. If not set, then a pattern
 | |
|   like `a{b,c}d` will return `false`, because neither `abd` nor
 | |
|   `acd` contain any special glob characters.
 | |
| 
 | |
|   This does **not** mean that the pattern string can be used as a
 | |
|   literal filename, as it may contain magic glob characters that
 | |
|   are escaped. For example, the pattern `\\*` or `[*]` would not
 | |
|   be considered to have magic, as the matching portion parses to
 | |
|   the literal string `'*'` and would match a path named `'*'`,
 | |
|   not `'\\*'` or `'[*]'`. The `minimatch.unescape()` method may
 | |
|   be used to remove escape characters.
 | |
| 
 | |
| All other methods are internal, and will be called as necessary.
 | |
| 
 | |
| ### minimatch(path, pattern, options)
 | |
| 
 | |
| Main export. Tests a path against the pattern using the options.
 | |
| 
 | |
| ```javascript
 | |
| var isJS = minimatch(file, '*.js', { matchBase: true })
 | |
| ```
 | |
| 
 | |
| ### minimatch.filter(pattern, options)
 | |
| 
 | |
| Returns a function that tests its
 | |
| supplied argument, suitable for use with `Array.filter`. Example:
 | |
| 
 | |
| ```javascript
 | |
| var javascripts = fileList.filter(minimatch.filter('*.js', { matchBase: true }))
 | |
| ```
 | |
| 
 | |
| ### minimatch.escape(pattern, options = {})
 | |
| 
 | |
| Escape all magic characters in a glob pattern, so that it will
 | |
| only ever match literal strings
 | |
| 
 | |
| If the `windowsPathsNoEscape` option is used, then characters are
 | |
| escaped by wrapping in `[]`, because a magic character wrapped in
 | |
| a character class can only be satisfied by that exact character.
 | |
| 
 | |
| Slashes (and backslashes in `windowsPathsNoEscape` mode) cannot
 | |
| be escaped or unescaped.
 | |
| 
 | |
| ### minimatch.unescape(pattern, options = {})
 | |
| 
 | |
| Un-escape a glob string that may contain some escaped characters.
 | |
| 
 | |
| If the `windowsPathsNoEscape` option is used, then square-brace
 | |
| escapes are removed, but not backslash escapes. For example, it
 | |
| will turn the string `'[*]'` into `*`, but it will not turn
 | |
| `'\\*'` into `'*'`, because `\` is a path separator in
 | |
| `windowsPathsNoEscape` mode.
 | |
| 
 | |
| When `windowsPathsNoEscape` is not set, then both brace escapes
 | |
| and backslash escapes are removed.
 | |
| 
 | |
| Slashes (and backslashes in `windowsPathsNoEscape` mode) cannot
 | |
| be escaped or unescaped.
 | |
| 
 | |
| ### minimatch.match(list, pattern, options)
 | |
| 
 | |
| Match against the list of
 | |
| files, in the style of fnmatch or glob. If nothing is matched, and
 | |
| options.nonull is set, then return a list containing the pattern itself.
 | |
| 
 | |
| ```javascript
 | |
| var javascripts = minimatch.match(fileList, '*.js', { matchBase: true })
 | |
| ```
 | |
| 
 | |
| ### minimatch.makeRe(pattern, options)
 | |
| 
 | |
| Make a regular expression object from the pattern.
 | |
| 
 | |
| ## Options
 | |
| 
 | |
| All options are `false` by default.
 | |
| 
 | |
| ### debug
 | |
| 
 | |
| Dump a ton of stuff to stderr.
 | |
| 
 | |
| ### nobrace
 | |
| 
 | |
| Do not expand `{a,b}` and `{1..3}` brace sets.
 | |
| 
 | |
| ### noglobstar
 | |
| 
 | |
| Disable `**` matching against multiple folder names.
 | |
| 
 | |
| ### dot
 | |
| 
 | |
| Allow patterns to match filenames starting with a period, even if
 | |
| the pattern does not explicitly have a period in that spot.
 | |
| 
 | |
| Note that by default, `a/**/b` will **not** match `a/.d/b`, unless `dot`
 | |
| is set.
 | |
| 
 | |
| ### noext
 | |
| 
 | |
| Disable "extglob" style patterns like `+(a|b)`.
 | |
| 
 | |
| ### nocase
 | |
| 
 | |
| Perform a case-insensitive match.
 | |
| 
 | |
| ### nocaseMagicOnly
 | |
| 
 | |
| When used with `{nocase: true}`, create regular expressions that
 | |
| are case-insensitive, but leave string match portions untouched.
 | |
| Has no effect when used without `{nocase: true}`
 | |
| 
 | |
| Useful when some other form of case-insensitive matching is used,
 | |
| or if the original string representation is useful in some other
 | |
| way.
 | |
| 
 | |
| ### nonull
 | |
| 
 | |
| When a match is not found by `minimatch.match`, return a list containing
 | |
| the pattern itself if this option is set. When not set, an empty list
 | |
| is returned if there are no matches.
 | |
| 
 | |
| ### magicalBraces
 | |
| 
 | |
| This only affects the results of the `Minimatch.hasMagic` method.
 | |
| 
 | |
| If the pattern contains brace expansions, such as `a{b,c}d`, but
 | |
| no other magic characters, then the `Minimatch.hasMagic()` method
 | |
| will return `false` by default. When this option set, it will
 | |
| return `true` for brace expansion as well as other magic glob
 | |
| characters.
 | |
| 
 | |
| ### matchBase
 | |
| 
 | |
| If set, then patterns without slashes will be matched
 | |
| against the basename of the path if it contains slashes. For example,
 | |
| `a?b` would match the path `/xyz/123/acb`, but not `/xyz/acb/123`.
 | |
| 
 | |
| ### nocomment
 | |
| 
 | |
| Suppress the behavior of treating `#` at the start of a pattern as a
 | |
| comment.
 | |
| 
 | |
| ### nonegate
 | |
| 
 | |
| Suppress the behavior of treating a leading `!` character as negation.
 | |
| 
 | |
| ### flipNegate
 | |
| 
 | |
| Returns from negate expressions the same as if they were not negated.
 | |
| (Ie, true on a hit, false on a miss.)
 | |
| 
 | |
| ### partial
 | |
| 
 | |
| Compare a partial path to a pattern. As long as the parts of the path that
 | |
| are present are not contradicted by the pattern, it will be treated as a
 | |
| match. This is useful in applications where you're walking through a
 | |
| folder structure, and don't yet have the full path, but want to ensure that
 | |
| you do not walk down paths that can never be a match.
 | |
| 
 | |
| For example,
 | |
| 
 | |
| ```js
 | |
| minimatch('/a/b', '/a/*/c/d', { partial: true }) // true, might be /a/b/c/d
 | |
| minimatch('/a/b', '/**/d', { partial: true }) // true, might be /a/b/.../d
 | |
| minimatch('/x/y/z', '/a/**/z', { partial: true }) // false, because x !== a
 | |
| ```
 | |
| 
 | |
| ### windowsPathsNoEscape
 | |
| 
 | |
| Use `\\` as a path separator _only_, and _never_ as an escape
 | |
| character. If set, all `\\` characters are replaced with `/` in
 | |
| the pattern. Note that this makes it **impossible** to match
 | |
| against paths containing literal glob pattern characters, but
 | |
| allows matching with patterns constructed using `path.join()` and
 | |
| `path.resolve()` on Windows platforms, mimicking the (buggy!)
 | |
| behavior of earlier versions on Windows. Please use with
 | |
| caution, and be mindful of [the caveat about Windows
 | |
| paths](#windows).
 | |
| 
 | |
| For legacy reasons, this is also set if
 | |
| `options.allowWindowsEscape` is set to the exact value `false`.
 | |
| 
 | |
| ### windowsNoMagicRoot
 | |
| 
 | |
| When a pattern starts with a UNC path or drive letter, and in
 | |
| `nocase:true` mode, do not convert the root portions of the
 | |
| pattern into a case-insensitive regular expression, and instead
 | |
| leave them as strings.
 | |
| 
 | |
| This is the default when the platform is `win32` and
 | |
| `nocase:true` is set.
 | |
| 
 | |
| ### preserveMultipleSlashes
 | |
| 
 | |
| By default, multiple `/` characters (other than the leading `//`
 | |
| in a UNC path, see "UNC Paths" above) are treated as a single
 | |
| `/`.
 | |
| 
 | |
| That is, a pattern like `a///b` will match the file path `a/b`.
 | |
| 
 | |
| Set `preserveMultipleSlashes: true` to suppress this behavior.
 | |
| 
 | |
| ### optimizationLevel
 | |
| 
 | |
| A number indicating the level of optimization that should be done
 | |
| to the pattern prior to parsing and using it for matches.
 | |
| 
 | |
| Globstar parts `**` are always converted to `*` when `noglobstar`
 | |
| is set, and multiple adjacent `**` parts are converted into a
 | |
| single `**` (ie, `a/**/**/b` will be treated as `a/**/b`, as this
 | |
| is equivalent in all cases).
 | |
| 
 | |
| - `0` - Make no further changes. In this mode, `.` and `..` are
 | |
|   maintained in the pattern, meaning that they must also appear
 | |
|   in the same position in the test path string. Eg, a pattern
 | |
|   like `a/*/../c` will match the string `a/b/../c` but not the
 | |
|   string `a/c`.
 | |
| - `1` - (default) Remove cases where a double-dot `..` follows a
 | |
|   pattern portion that is not `**`, `.`, `..`, or empty `''`. For
 | |
|   example, the pattern `./a/b/../*` is converted to `./a/*`, and
 | |
|   so it will match the path string `./a/c`, but not the path
 | |
|   string `./a/b/../c`. Dots and empty path portions in the
 | |
|   pattern are preserved.
 | |
| - `2` (or higher) - Much more aggressive optimizations, suitable
 | |
|   for use with file-walking cases:
 | |
| 
 | |
|   - Remove cases where a double-dot `..` follows a pattern
 | |
|     portion that is not `**`, `.`, or empty `''`. Remove empty
 | |
|     and `.` portions of the pattern, where safe to do so (ie,
 | |
|     anywhere other than the last position, the first position, or
 | |
|     the second position in a pattern starting with `/`, as this
 | |
|     may indicate a UNC path on Windows).
 | |
|   - Convert patterns containing `<pre>/**/../<p>/<rest>` into the
 | |
|     equivalent `<pre>/{..,**}/<p>/<rest>`, where `<p>` is a
 | |
|     a pattern portion other than `.`, `..`, `**`, or empty
 | |
|     `''`.
 | |
|   - Dedupe patterns where a `**` portion is present in one and
 | |
|     omitted in another, and it is not the final path portion, and
 | |
|     they are otherwise equivalent. So `{a/**/b,a/b}` becomes
 | |
|     `a/**/b`, because `**` matches against an empty path portion.
 | |
|   - Dedupe patterns where a `*` portion is present in one, and a
 | |
|     non-dot pattern other than `**`, `.`, `..`, or `''` is in the
 | |
|     same position in the other. So `a/{*,x}/b` becomes `a/*/b`,
 | |
|     because `*` can match against `x`.
 | |
| 
 | |
|   While these optimizations improve the performance of
 | |
|   file-walking use cases such as [glob](http://npm.im/glob) (ie,
 | |
|   the reason this module exists), there are cases where it will
 | |
|   fail to match a literal string that would have been matched in
 | |
|   optimization level 1 or 0.
 | |
| 
 | |
|   Specifically, while the `Minimatch.match()` method will
 | |
|   optimize the file path string in the same ways, resulting in
 | |
|   the same matches, it will fail when tested with the regular
 | |
|   expression provided by `Minimatch.makeRe()`, unless the path
 | |
|   string is first processed with
 | |
|   `minimatch.levelTwoFileOptimize()` or similar.
 | |
| 
 | |
| ### platform
 | |
| 
 | |
| When set to `win32`, this will trigger all windows-specific
 | |
| behaviors (special handling for UNC paths, and treating `\` as
 | |
| separators in file paths for comparison.)
 | |
| 
 | |
| Defaults to the value of `process.platform`.
 | |
| 
 | |
| ## Comparisons to other fnmatch/glob implementations
 | |
| 
 | |
| While strict compliance with the existing standards is a
 | |
| worthwhile goal, some discrepancies exist between minimatch and
 | |
| other implementations. Some are intentional, and some are
 | |
| unavoidable.
 | |
| 
 | |
| If the pattern starts with a `!` character, then it is negated. Set the
 | |
| `nonegate` flag to suppress this behavior, and treat leading `!`
 | |
| characters normally. This is perhaps relevant if you wish to start the
 | |
| pattern with a negative extglob pattern like `!(a|B)`. Multiple `!`
 | |
| characters at the start of a pattern will negate the pattern multiple
 | |
| times.
 | |
| 
 | |
| If a pattern starts with `#`, then it is treated as a comment, and
 | |
| will not match anything. Use `\#` to match a literal `#` at the
 | |
| start of a line, or set the `nocomment` flag to suppress this behavior.
 | |
| 
 | |
| The double-star character `**` is supported by default, unless the
 | |
| `noglobstar` flag is set. This is supported in the manner of bsdglob
 | |
| and bash 4.1, where `**` only has special significance if it is the only
 | |
| thing in a path part. That is, `a/**/b` will match `a/x/y/b`, but
 | |
| `a/**b` will not.
 | |
| 
 | |
| If an escaped pattern has no matches, and the `nonull` flag is set,
 | |
| then minimatch.match returns the pattern as-provided, rather than
 | |
| interpreting the character escapes. For example,
 | |
| `minimatch.match([], "\\*a\\?")` will return `"\\*a\\?"` rather than
 | |
| `"*a?"`. This is akin to setting the `nullglob` option in bash, except
 | |
| that it does not resolve escaped pattern characters.
 | |
| 
 | |
| If brace expansion is not disabled, then it is performed before any
 | |
| other interpretation of the glob pattern. Thus, a pattern like
 | |
| `+(a|{b),c)}`, which would not be valid in bash or zsh, is expanded
 | |
| **first** into the set of `+(a|b)` and `+(a|c)`, and those patterns are
 | |
| checked for validity. Since those two are valid, matching proceeds.
 | |
| 
 | |
| Negated extglob patterns are handled as closely as possible to
 | |
| Bash semantics, but there are some cases with negative extglobs
 | |
| which are exceedingly difficult to express in a JavaScript
 | |
| regular expression. In particular the negated pattern
 | |
| `<start>!(<pattern>*|)*` will in bash match anything that does
 | |
| not start with `<start><pattern>`. However,
 | |
| `<start>!(<pattern>*)*` _will_ match paths starting with
 | |
| `<start><pattern>`, because the empty string can match against
 | |
| the negated portion. In this library, `<start>!(<pattern>*|)*`
 | |
| will _not_ match any pattern starting with `<start>`, due to a
 | |
| difference in precisely which patterns are considered "greedy" in
 | |
| Regular Expressions vs bash path expansion. This may be fixable,
 | |
| but not without incurring some complexity and performance costs,
 | |
| and the trade-off seems to not be worth pursuing.
 | |
| 
 | |
| Note that `fnmatch(3)` in libc is an extremely naive string comparison
 | |
| matcher, which does not do anything special for slashes. This library is
 | |
| designed to be used in glob searching and file walkers, and so it does do
 | |
| special things with `/`. Thus, `foo*` will not match `foo/bar` in this
 | |
| library, even though it would in `fnmatch(3)`.
 |