mirror of
				https://github.com/shivammathur/setup-php.git
				synced 2025-10-25 20:55:09 +07:00 
			
		
		
		
	init
This commit is contained in:
		
							
								
								
									
										37
									
								
								node_modules/micromatch/CHANGELOG.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								node_modules/micromatch/CHANGELOG.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,37 @@ | ||||
| ## History | ||||
|  | ||||
| ### key | ||||
|  | ||||
| Changelog entries are classified using the following labels _(from [keep-a-changelog][]_): | ||||
|  | ||||
| - `added`: for new features | ||||
| - `changed`: for changes in existing functionality | ||||
| - `deprecated`: for once-stable features removed in upcoming releases | ||||
| - `removed`: for deprecated features removed in this release | ||||
| - `fixed`: for any bug fixes | ||||
| - `bumped`: updated dependencies, only minor or higher will be listed. | ||||
|  | ||||
| ### [3.0.0] - 2017-04-11 | ||||
|  | ||||
| TODO. There should be no breaking changes. Please report any regressions. I will [reformat these release notes](https://github.com/micromatch/micromatch/pull/76) and add them to the changelog as soon as I have a chance.  | ||||
|  | ||||
| ### [1.0.1] - 2016-12-12 | ||||
|  | ||||
| **Added** | ||||
|  | ||||
| - Support for windows path edge cases where backslashes are used in brackets or other unusual combinations. | ||||
|  | ||||
| ### [1.0.0] - 2016-12-12 | ||||
|  | ||||
| Stable release. | ||||
|  | ||||
| ### [0.1.0] - 2016-10-08 | ||||
|  | ||||
| First release. | ||||
|  | ||||
|  | ||||
| [Unreleased]: https://github.com/jonschlinkert/micromatch/compare/0.1.0...HEAD | ||||
| [0.2.0]: https://github.com/jonschlinkert/micromatch/compare/0.1.0...0.2.0 | ||||
|  | ||||
| [keep-a-changelog]: https://github.com/olivierlacan/keep-a-changelog | ||||
|  | ||||
							
								
								
									
										21
									
								
								node_modules/micromatch/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								node_modules/micromatch/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| The MIT License (MIT) | ||||
|  | ||||
| Copyright (c) 2014-2018, Jon Schlinkert. | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in | ||||
| all copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
| THE SOFTWARE. | ||||
							
								
								
									
										1150
									
								
								node_modules/micromatch/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1150
									
								
								node_modules/micromatch/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										877
									
								
								node_modules/micromatch/index.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										877
									
								
								node_modules/micromatch/index.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,877 @@ | ||||
| 'use strict'; | ||||
|  | ||||
| /** | ||||
|  * Module dependencies | ||||
|  */ | ||||
|  | ||||
| var util = require('util'); | ||||
| var braces = require('braces'); | ||||
| var toRegex = require('to-regex'); | ||||
| var extend = require('extend-shallow'); | ||||
|  | ||||
| /** | ||||
|  * Local dependencies | ||||
|  */ | ||||
|  | ||||
| var compilers = require('./lib/compilers'); | ||||
| var parsers = require('./lib/parsers'); | ||||
| var cache = require('./lib/cache'); | ||||
| var utils = require('./lib/utils'); | ||||
| var MAX_LENGTH = 1024 * 64; | ||||
|  | ||||
| /** | ||||
|  * The main function takes a list of strings and one or more | ||||
|  * glob patterns to use for matching. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm(list, patterns[, options]); | ||||
|  * | ||||
|  * console.log(mm(['a.js', 'a.txt'], ['*.js'])); | ||||
|  * //=> [ 'a.js' ] | ||||
|  * ``` | ||||
|  * @param {Array} `list` A list of strings to match | ||||
|  * @param {String|Array} `patterns` One or more glob patterns to use for matching. | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed | ||||
|  * @return {Array} Returns an array of matches | ||||
|  * @summary false | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| function micromatch(list, patterns, options) { | ||||
|   patterns = utils.arrayify(patterns); | ||||
|   list = utils.arrayify(list); | ||||
|  | ||||
|   var len = patterns.length; | ||||
|   if (list.length === 0 || len === 0) { | ||||
|     return []; | ||||
|   } | ||||
|  | ||||
|   if (len === 1) { | ||||
|     return micromatch.match(list, patterns[0], options); | ||||
|   } | ||||
|  | ||||
|   var omit = []; | ||||
|   var keep = []; | ||||
|   var idx = -1; | ||||
|  | ||||
|   while (++idx < len) { | ||||
|     var pattern = patterns[idx]; | ||||
|  | ||||
|     if (typeof pattern === 'string' && pattern.charCodeAt(0) === 33 /* ! */) { | ||||
|       omit.push.apply(omit, micromatch.match(list, pattern.slice(1), options)); | ||||
|     } else { | ||||
|       keep.push.apply(keep, micromatch.match(list, pattern, options)); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   var matches = utils.diff(keep, omit); | ||||
|   if (!options || options.nodupes !== false) { | ||||
|     return utils.unique(matches); | ||||
|   } | ||||
|  | ||||
|   return matches; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Similar to the main function, but `pattern` must be a string. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.match(list, pattern[, options]); | ||||
|  * | ||||
|  * console.log(mm.match(['a.a', 'a.aa', 'a.b', 'a.c'], '*.a')); | ||||
|  * //=> ['a.a', 'a.aa'] | ||||
|  * ``` | ||||
|  * @param {Array} `list` Array of strings to match | ||||
|  * @param {String} `pattern` Glob pattern to use for matching. | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed | ||||
|  * @return {Array} Returns an array of matches | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.match = function(list, pattern, options) { | ||||
|   if (Array.isArray(pattern)) { | ||||
|     throw new TypeError('expected pattern to be a string'); | ||||
|   } | ||||
|  | ||||
|   var unixify = utils.unixify(options); | ||||
|   var isMatch = memoize('match', pattern, options, micromatch.matcher); | ||||
|   var matches = []; | ||||
|  | ||||
|   list = utils.arrayify(list); | ||||
|   var len = list.length; | ||||
|   var idx = -1; | ||||
|  | ||||
|   while (++idx < len) { | ||||
|     var ele = list[idx]; | ||||
|     if (ele === pattern || isMatch(ele)) { | ||||
|       matches.push(utils.value(ele, unixify, options)); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   // if no options were passed, uniquify results and return | ||||
|   if (typeof options === 'undefined') { | ||||
|     return utils.unique(matches); | ||||
|   } | ||||
|  | ||||
|   if (matches.length === 0) { | ||||
|     if (options.failglob === true) { | ||||
|       throw new Error('no matches found for "' + pattern + '"'); | ||||
|     } | ||||
|     if (options.nonull === true || options.nullglob === true) { | ||||
|       return [options.unescape ? utils.unescape(pattern) : pattern]; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   // if `opts.ignore` was defined, diff ignored list | ||||
|   if (options.ignore) { | ||||
|     matches = micromatch.not(matches, options.ignore, options); | ||||
|   } | ||||
|  | ||||
|   return options.nodupes !== false ? utils.unique(matches) : matches; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if the specified `string` matches the given glob `pattern`. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.isMatch(string, pattern[, options]); | ||||
|  * | ||||
|  * console.log(mm.isMatch('a.a', '*.a')); | ||||
|  * //=> true | ||||
|  * console.log(mm.isMatch('a.b', '*.a')); | ||||
|  * //=> false | ||||
|  * ``` | ||||
|  * @param {String} `string` String to match | ||||
|  * @param {String} `pattern` Glob pattern to use for matching. | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed | ||||
|  * @return {Boolean} Returns true if the string matches the glob pattern. | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.isMatch = function(str, pattern, options) { | ||||
|   if (typeof str !== 'string') { | ||||
|     throw new TypeError('expected a string: "' + util.inspect(str) + '"'); | ||||
|   } | ||||
|  | ||||
|   if (isEmptyString(str) || isEmptyString(pattern)) { | ||||
|     return false; | ||||
|   } | ||||
|  | ||||
|   var equals = utils.equalsPattern(options); | ||||
|   if (equals(str)) { | ||||
|     return true; | ||||
|   } | ||||
|  | ||||
|   var isMatch = memoize('isMatch', pattern, options, micromatch.matcher); | ||||
|   return isMatch(str); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if some of the strings in the given `list` match any of the | ||||
|  * given glob `patterns`. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.some(list, patterns[, options]); | ||||
|  * | ||||
|  * console.log(mm.some(['foo.js', 'bar.js'], ['*.js', '!foo.js'])); | ||||
|  * // true | ||||
|  * console.log(mm.some(['foo.js'], ['*.js', '!foo.js'])); | ||||
|  * // false | ||||
|  * ``` | ||||
|  * @param  {String|Array} `list` The string or array of strings to test. Returns as soon as the first match is found. | ||||
|  * @param {String|Array} `patterns` One or more glob patterns to use for matching. | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed | ||||
|  * @return {Boolean} Returns true if any patterns match `str` | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.some = function(list, patterns, options) { | ||||
|   if (typeof list === 'string') { | ||||
|     list = [list]; | ||||
|   } | ||||
|   for (var i = 0; i < list.length; i++) { | ||||
|     if (micromatch(list[i], patterns, options).length === 1) { | ||||
|       return true; | ||||
|     } | ||||
|   } | ||||
|   return false; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if every string in the given `list` matches | ||||
|  * any of the given glob `patterns`. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.every(list, patterns[, options]); | ||||
|  * | ||||
|  * console.log(mm.every('foo.js', ['foo.js'])); | ||||
|  * // true | ||||
|  * console.log(mm.every(['foo.js', 'bar.js'], ['*.js'])); | ||||
|  * // true | ||||
|  * console.log(mm.every(['foo.js', 'bar.js'], ['*.js', '!foo.js'])); | ||||
|  * // false | ||||
|  * console.log(mm.every(['foo.js'], ['*.js', '!foo.js'])); | ||||
|  * // false | ||||
|  * ``` | ||||
|  * @param  {String|Array} `list` The string or array of strings to test. | ||||
|  * @param {String|Array} `patterns` One or more glob patterns to use for matching. | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed | ||||
|  * @return {Boolean} Returns true if any patterns match `str` | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.every = function(list, patterns, options) { | ||||
|   if (typeof list === 'string') { | ||||
|     list = [list]; | ||||
|   } | ||||
|   for (var i = 0; i < list.length; i++) { | ||||
|     if (micromatch(list[i], patterns, options).length !== 1) { | ||||
|       return false; | ||||
|     } | ||||
|   } | ||||
|   return true; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if **any** of the given glob `patterns` | ||||
|  * match the specified `string`. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.any(string, patterns[, options]); | ||||
|  * | ||||
|  * console.log(mm.any('a.a', ['b.*', '*.a'])); | ||||
|  * //=> true | ||||
|  * console.log(mm.any('a.a', 'b.*')); | ||||
|  * //=> false | ||||
|  * ``` | ||||
|  * @param  {String|Array} `str` The string to test. | ||||
|  * @param {String|Array} `patterns` One or more glob patterns to use for matching. | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed | ||||
|  * @return {Boolean} Returns true if any patterns match `str` | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.any = function(str, patterns, options) { | ||||
|   if (typeof str !== 'string') { | ||||
|     throw new TypeError('expected a string: "' + util.inspect(str) + '"'); | ||||
|   } | ||||
|  | ||||
|   if (isEmptyString(str) || isEmptyString(patterns)) { | ||||
|     return false; | ||||
|   } | ||||
|  | ||||
|   if (typeof patterns === 'string') { | ||||
|     patterns = [patterns]; | ||||
|   } | ||||
|  | ||||
|   for (var i = 0; i < patterns.length; i++) { | ||||
|     if (micromatch.isMatch(str, patterns[i], options)) { | ||||
|       return true; | ||||
|     } | ||||
|   } | ||||
|   return false; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if **all** of the given `patterns` match | ||||
|  * the specified string. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.all(string, patterns[, options]); | ||||
|  * | ||||
|  * console.log(mm.all('foo.js', ['foo.js'])); | ||||
|  * // true | ||||
|  * | ||||
|  * console.log(mm.all('foo.js', ['*.js', '!foo.js'])); | ||||
|  * // false | ||||
|  * | ||||
|  * console.log(mm.all('foo.js', ['*.js', 'foo.js'])); | ||||
|  * // true | ||||
|  * | ||||
|  * console.log(mm.all('foo.js', ['*.js', 'f*', '*o*', '*o.js'])); | ||||
|  * // true | ||||
|  * ``` | ||||
|  * @param  {String|Array} `str` The string to test. | ||||
|  * @param {String|Array} `patterns` One or more glob patterns to use for matching. | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed | ||||
|  * @return {Boolean} Returns true if any patterns match `str` | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.all = function(str, patterns, options) { | ||||
|   if (typeof str !== 'string') { | ||||
|     throw new TypeError('expected a string: "' + util.inspect(str) + '"'); | ||||
|   } | ||||
|   if (typeof patterns === 'string') { | ||||
|     patterns = [patterns]; | ||||
|   } | ||||
|   for (var i = 0; i < patterns.length; i++) { | ||||
|     if (!micromatch.isMatch(str, patterns[i], options)) { | ||||
|       return false; | ||||
|     } | ||||
|   } | ||||
|   return true; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns a list of strings that _**do not match any**_ of the given `patterns`. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.not(list, patterns[, options]); | ||||
|  * | ||||
|  * console.log(mm.not(['a.a', 'b.b', 'c.c'], '*.a')); | ||||
|  * //=> ['b.b', 'c.c'] | ||||
|  * ``` | ||||
|  * @param {Array} `list` Array of strings to match. | ||||
|  * @param {String|Array} `patterns` One or more glob pattern to use for matching. | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed | ||||
|  * @return {Array} Returns an array of strings that **do not match** the given patterns. | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.not = function(list, patterns, options) { | ||||
|   var opts = extend({}, options); | ||||
|   var ignore = opts.ignore; | ||||
|   delete opts.ignore; | ||||
|  | ||||
|   var unixify = utils.unixify(opts); | ||||
|   list = utils.arrayify(list).map(unixify); | ||||
|  | ||||
|   var matches = utils.diff(list, micromatch(list, patterns, opts)); | ||||
|   if (ignore) { | ||||
|     matches = utils.diff(matches, micromatch(list, ignore)); | ||||
|   } | ||||
|  | ||||
|   return opts.nodupes !== false ? utils.unique(matches) : matches; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if the given `string` contains the given pattern. Similar | ||||
|  * to [.isMatch](#isMatch) but the pattern can match any part of the string. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.contains(string, pattern[, options]); | ||||
|  * | ||||
|  * console.log(mm.contains('aa/bb/cc', '*b')); | ||||
|  * //=> true | ||||
|  * console.log(mm.contains('aa/bb/cc', '*d')); | ||||
|  * //=> false | ||||
|  * ``` | ||||
|  * @param {String} `str` The string to match. | ||||
|  * @param {String|Array} `patterns` Glob pattern to use for matching. | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed | ||||
|  * @return {Boolean} Returns true if the patter matches any part of `str`. | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.contains = function(str, patterns, options) { | ||||
|   if (typeof str !== 'string') { | ||||
|     throw new TypeError('expected a string: "' + util.inspect(str) + '"'); | ||||
|   } | ||||
|  | ||||
|   if (typeof patterns === 'string') { | ||||
|     if (isEmptyString(str) || isEmptyString(patterns)) { | ||||
|       return false; | ||||
|     } | ||||
|  | ||||
|     var equals = utils.equalsPattern(patterns, options); | ||||
|     if (equals(str)) { | ||||
|       return true; | ||||
|     } | ||||
|     var contains = utils.containsPattern(patterns, options); | ||||
|     if (contains(str)) { | ||||
|       return true; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   var opts = extend({}, options, {contains: true}); | ||||
|   return micromatch.any(str, patterns, opts); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if the given pattern and options should enable | ||||
|  * the `matchBase` option. | ||||
|  * @return {Boolean} | ||||
|  * @api private | ||||
|  */ | ||||
|  | ||||
| micromatch.matchBase = function(pattern, options) { | ||||
|   if (pattern && pattern.indexOf('/') !== -1 || !options) return false; | ||||
|   return options.basename === true || options.matchBase === true; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Filter the keys of the given object with the given `glob` pattern | ||||
|  * and `options`. Does not attempt to match nested keys. If you need this feature, | ||||
|  * use [glob-object][] instead. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.matchKeys(object, patterns[, options]); | ||||
|  * | ||||
|  * var obj = { aa: 'a', ab: 'b', ac: 'c' }; | ||||
|  * console.log(mm.matchKeys(obj, '*b')); | ||||
|  * //=> { ab: 'b' } | ||||
|  * ``` | ||||
|  * @param {Object} `object` The object with keys to filter. | ||||
|  * @param {String|Array} `patterns` One or more glob patterns to use for matching. | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed | ||||
|  * @return {Object} Returns an object with only keys that match the given patterns. | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.matchKeys = function(obj, patterns, options) { | ||||
|   if (!utils.isObject(obj)) { | ||||
|     throw new TypeError('expected the first argument to be an object'); | ||||
|   } | ||||
|   var keys = micromatch(Object.keys(obj), patterns, options); | ||||
|   return utils.pick(obj, keys); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns a memoized matcher function from the given glob `pattern` and `options`. | ||||
|  * The returned function takes a string to match as its only argument and returns | ||||
|  * true if the string is a match. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.matcher(pattern[, options]); | ||||
|  * | ||||
|  * var isMatch = mm.matcher('*.!(*a)'); | ||||
|  * console.log(isMatch('a.a')); | ||||
|  * //=> false | ||||
|  * console.log(isMatch('a.b')); | ||||
|  * //=> true | ||||
|  * ``` | ||||
|  * @param {String} `pattern` Glob pattern | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed. | ||||
|  * @return {Function} Returns a matcher function. | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.matcher = function matcher(pattern, options) { | ||||
|   if (Array.isArray(pattern)) { | ||||
|     return compose(pattern, options, matcher); | ||||
|   } | ||||
|  | ||||
|   // if pattern is a regex | ||||
|   if (pattern instanceof RegExp) { | ||||
|     return test(pattern); | ||||
|   } | ||||
|  | ||||
|   // if pattern is invalid | ||||
|   if (!utils.isString(pattern)) { | ||||
|     throw new TypeError('expected pattern to be an array, string or regex'); | ||||
|   } | ||||
|  | ||||
|   // if pattern is a non-glob string | ||||
|   if (!utils.hasSpecialChars(pattern)) { | ||||
|     if (options && options.nocase === true) { | ||||
|       pattern = pattern.toLowerCase(); | ||||
|     } | ||||
|     return utils.matchPath(pattern, options); | ||||
|   } | ||||
|  | ||||
|   // if pattern is a glob string | ||||
|   var re = micromatch.makeRe(pattern, options); | ||||
|  | ||||
|   // if `options.matchBase` or `options.basename` is defined | ||||
|   if (micromatch.matchBase(pattern, options)) { | ||||
|     return utils.matchBasename(re, options); | ||||
|   } | ||||
|  | ||||
|   function test(regex) { | ||||
|     var equals = utils.equalsPattern(options); | ||||
|     var unixify = utils.unixify(options); | ||||
|  | ||||
|     return function(str) { | ||||
|       if (equals(str)) { | ||||
|         return true; | ||||
|       } | ||||
|  | ||||
|       if (regex.test(unixify(str))) { | ||||
|         return true; | ||||
|       } | ||||
|       return false; | ||||
|     }; | ||||
|   } | ||||
|  | ||||
|   var fn = test(re); | ||||
|   Object.defineProperty(fn, 'result', { | ||||
|     configurable: true, | ||||
|     enumerable: false, | ||||
|     value: re.result | ||||
|   }); | ||||
|   return fn; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns an array of matches captured by `pattern` in `string, or `null` if the pattern did not match. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.capture(pattern, string[, options]); | ||||
|  * | ||||
|  * console.log(mm.capture('test/*.js', 'test/foo.js')); | ||||
|  * //=> ['foo'] | ||||
|  * console.log(mm.capture('test/*.js', 'foo/bar.css')); | ||||
|  * //=> null | ||||
|  * ``` | ||||
|  * @param {String} `pattern` Glob pattern to use for matching. | ||||
|  * @param {String} `string` String to match | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed | ||||
|  * @return {Boolean} Returns an array of captures if the string matches the glob pattern, otherwise `null`. | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.capture = function(pattern, str, options) { | ||||
|   var re = micromatch.makeRe(pattern, extend({capture: true}, options)); | ||||
|   var unixify = utils.unixify(options); | ||||
|  | ||||
|   function match() { | ||||
|     return function(string) { | ||||
|       var match = re.exec(unixify(string)); | ||||
|       if (!match) { | ||||
|         return null; | ||||
|       } | ||||
|  | ||||
|       return match.slice(1); | ||||
|     }; | ||||
|   } | ||||
|  | ||||
|   var capture = memoize('capture', pattern, options, match); | ||||
|   return capture(str); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Create a regular expression from the given glob `pattern`. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.makeRe(pattern[, options]); | ||||
|  * | ||||
|  * console.log(mm.makeRe('*.js')); | ||||
|  * //=> /^(?:(\.[\\\/])?(?!\.)(?=.)[^\/]*?\.js)$/ | ||||
|  * ``` | ||||
|  * @param {String} `pattern` A glob pattern to convert to regex. | ||||
|  * @param {Object} `options` See available [options](#options) for changing how matches are performed. | ||||
|  * @return {RegExp} Returns a regex created from the given pattern. | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.makeRe = function(pattern, options) { | ||||
|   if (typeof pattern !== 'string') { | ||||
|     throw new TypeError('expected pattern to be a string'); | ||||
|   } | ||||
|  | ||||
|   if (pattern.length > MAX_LENGTH) { | ||||
|     throw new Error('expected pattern to be less than ' + MAX_LENGTH + ' characters'); | ||||
|   } | ||||
|  | ||||
|   function makeRe() { | ||||
|     var result = micromatch.create(pattern, options); | ||||
|     var ast_array = []; | ||||
|     var output = result.map(function(obj) { | ||||
|       obj.ast.state = obj.state; | ||||
|       ast_array.push(obj.ast); | ||||
|       return obj.output; | ||||
|     }); | ||||
|  | ||||
|     var regex = toRegex(output.join('|'), options); | ||||
|     Object.defineProperty(regex, 'result', { | ||||
|       configurable: true, | ||||
|       enumerable: false, | ||||
|       value: ast_array | ||||
|     }); | ||||
|     return regex; | ||||
|   } | ||||
|  | ||||
|   return memoize('makeRe', pattern, options, makeRe); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Expand the given brace `pattern`. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * console.log(mm.braces('foo/{a,b}/bar')); | ||||
|  * //=> ['foo/(a|b)/bar'] | ||||
|  * | ||||
|  * console.log(mm.braces('foo/{a,b}/bar', {expand: true})); | ||||
|  * //=> ['foo/(a|b)/bar'] | ||||
|  * ``` | ||||
|  * @param {String} `pattern` String with brace pattern to expand. | ||||
|  * @param {Object} `options` Any [options](#options) to change how expansion is performed. See the [braces][] library for all available options. | ||||
|  * @return {Array} | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.braces = function(pattern, options) { | ||||
|   if (typeof pattern !== 'string' && !Array.isArray(pattern)) { | ||||
|     throw new TypeError('expected pattern to be an array or string'); | ||||
|   } | ||||
|  | ||||
|   function expand() { | ||||
|     if (options && options.nobrace === true || !/\{.*\}/.test(pattern)) { | ||||
|       return utils.arrayify(pattern); | ||||
|     } | ||||
|     return braces(pattern, options); | ||||
|   } | ||||
|  | ||||
|   return memoize('braces', pattern, options, expand); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Proxy to the [micromatch.braces](#method), for parity with | ||||
|  * minimatch. | ||||
|  */ | ||||
|  | ||||
| micromatch.braceExpand = function(pattern, options) { | ||||
|   var opts = extend({}, options, {expand: true}); | ||||
|   return micromatch.braces(pattern, opts); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Parses the given glob `pattern` and returns an array of abstract syntax | ||||
|  * trees (ASTs), with the compiled `output` and optional source `map` on | ||||
|  * each AST. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.create(pattern[, options]); | ||||
|  * | ||||
|  * console.log(mm.create('abc/*.js')); | ||||
|  * // [{ options: { source: 'string', sourcemap: true }, | ||||
|  * //   state: {}, | ||||
|  * //   compilers: | ||||
|  * //    { ... }, | ||||
|  * //   output: '(\\.[\\\\\\/])?abc\\/(?!\\.)(?=.)[^\\/]*?\\.js', | ||||
|  * //   ast: | ||||
|  * //    { type: 'root', | ||||
|  * //      errors: [], | ||||
|  * //      nodes: | ||||
|  * //       [ ... ], | ||||
|  * //      dot: false, | ||||
|  * //      input: 'abc/*.js' }, | ||||
|  * //   parsingErrors: [], | ||||
|  * //   map: | ||||
|  * //    { version: 3, | ||||
|  * //      sources: [ 'string' ], | ||||
|  * //      names: [], | ||||
|  * //      mappings: 'AAAA,GAAG,EAAC,kBAAC,EAAC,EAAE', | ||||
|  * //      sourcesContent: [ 'abc/*.js' ] }, | ||||
|  * //   position: { line: 1, column: 28 }, | ||||
|  * //   content: {}, | ||||
|  * //   files: {}, | ||||
|  * //   idx: 6 }] | ||||
|  * ``` | ||||
|  * @param {String} `pattern` Glob pattern to parse and compile. | ||||
|  * @param {Object} `options` Any [options](#options) to change how parsing and compiling is performed. | ||||
|  * @return {Object} Returns an object with the parsed AST, compiled string and optional source map. | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.create = function(pattern, options) { | ||||
|   return memoize('create', pattern, options, function() { | ||||
|     function create(str, opts) { | ||||
|       return micromatch.compile(micromatch.parse(str, opts), opts); | ||||
|     } | ||||
|  | ||||
|     pattern = micromatch.braces(pattern, options); | ||||
|     var len = pattern.length; | ||||
|     var idx = -1; | ||||
|     var res = []; | ||||
|  | ||||
|     while (++idx < len) { | ||||
|       res.push(create(pattern[idx], options)); | ||||
|     } | ||||
|     return res; | ||||
|   }); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Parse the given `str` with the given `options`. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.parse(pattern[, options]); | ||||
|  * | ||||
|  * var ast = mm.parse('a/{b,c}/d'); | ||||
|  * console.log(ast); | ||||
|  * // { type: 'root', | ||||
|  * //   errors: [], | ||||
|  * //   input: 'a/{b,c}/d', | ||||
|  * //   nodes: | ||||
|  * //    [ { type: 'bos', val: '' }, | ||||
|  * //      { type: 'text', val: 'a/' }, | ||||
|  * //      { type: 'brace', | ||||
|  * //        nodes: | ||||
|  * //         [ { type: 'brace.open', val: '{' }, | ||||
|  * //           { type: 'text', val: 'b,c' }, | ||||
|  * //           { type: 'brace.close', val: '}' } ] }, | ||||
|  * //      { type: 'text', val: '/d' }, | ||||
|  * //      { type: 'eos', val: '' } ] } | ||||
|  * ``` | ||||
|  * @param {String} `str` | ||||
|  * @param {Object} `options` | ||||
|  * @return {Object} Returns an AST | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.parse = function(pattern, options) { | ||||
|   if (typeof pattern !== 'string') { | ||||
|     throw new TypeError('expected a string'); | ||||
|   } | ||||
|  | ||||
|   function parse() { | ||||
|     var snapdragon = utils.instantiate(null, options); | ||||
|     parsers(snapdragon, options); | ||||
|  | ||||
|     var ast = snapdragon.parse(pattern, options); | ||||
|     utils.define(ast, 'snapdragon', snapdragon); | ||||
|     ast.input = pattern; | ||||
|     return ast; | ||||
|   } | ||||
|  | ||||
|   return memoize('parse', pattern, options, parse); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Compile the given `ast` or string with the given `options`. | ||||
|  * | ||||
|  * ```js | ||||
|  * var mm = require('micromatch'); | ||||
|  * mm.compile(ast[, options]); | ||||
|  * | ||||
|  * var ast = mm.parse('a/{b,c}/d'); | ||||
|  * console.log(mm.compile(ast)); | ||||
|  * // { options: { source: 'string' }, | ||||
|  * //   state: {}, | ||||
|  * //   compilers: | ||||
|  * //    { eos: [Function], | ||||
|  * //      noop: [Function], | ||||
|  * //      bos: [Function], | ||||
|  * //      brace: [Function], | ||||
|  * //      'brace.open': [Function], | ||||
|  * //      text: [Function], | ||||
|  * //      'brace.close': [Function] }, | ||||
|  * //   output: [ 'a/(b|c)/d' ], | ||||
|  * //   ast: | ||||
|  * //    { ... }, | ||||
|  * //   parsingErrors: [] } | ||||
|  * ``` | ||||
|  * @param {Object|String} `ast` | ||||
|  * @param {Object} `options` | ||||
|  * @return {Object} Returns an object that has an `output` property with the compiled string. | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.compile = function(ast, options) { | ||||
|   if (typeof ast === 'string') { | ||||
|     ast = micromatch.parse(ast, options); | ||||
|   } | ||||
|  | ||||
|   return memoize('compile', ast.input, options, function() { | ||||
|     var snapdragon = utils.instantiate(ast, options); | ||||
|     compilers(snapdragon, options); | ||||
|     return snapdragon.compile(ast, options); | ||||
|   }); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Clear the regex cache. | ||||
|  * | ||||
|  * ```js | ||||
|  * mm.clearCache(); | ||||
|  * ``` | ||||
|  * @api public | ||||
|  */ | ||||
|  | ||||
| micromatch.clearCache = function() { | ||||
|   micromatch.cache.caches = {}; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if the given value is effectively an empty string | ||||
|  */ | ||||
|  | ||||
| function isEmptyString(val) { | ||||
|   return String(val) === '' || String(val) === './'; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Compose a matcher function with the given patterns. | ||||
|  * This allows matcher functions to be compiled once and | ||||
|  * called multiple times. | ||||
|  */ | ||||
|  | ||||
| function compose(patterns, options, matcher) { | ||||
|   var matchers; | ||||
|  | ||||
|   return memoize('compose', String(patterns), options, function() { | ||||
|     return function(file) { | ||||
|       // delay composition until it's invoked the first time, | ||||
|       // after that it won't be called again | ||||
|       if (!matchers) { | ||||
|         matchers = []; | ||||
|         for (var i = 0; i < patterns.length; i++) { | ||||
|           matchers.push(matcher(patterns[i], options)); | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       var len = matchers.length; | ||||
|       while (len--) { | ||||
|         if (matchers[len](file) === true) { | ||||
|           return true; | ||||
|         } | ||||
|       } | ||||
|       return false; | ||||
|     }; | ||||
|   }); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Memoize a generated regex or function. A unique key is generated | ||||
|  * from the `type` (usually method name), the `pattern`, and | ||||
|  * user-defined options. | ||||
|  */ | ||||
|  | ||||
| function memoize(type, pattern, options, fn) { | ||||
|   var key = utils.createKey(type + '=' + pattern, options); | ||||
|  | ||||
|   if (options && options.cache === false) { | ||||
|     return fn(pattern, options); | ||||
|   } | ||||
|  | ||||
|   if (cache.has(type, key)) { | ||||
|     return cache.get(type, key); | ||||
|   } | ||||
|  | ||||
|   var val = fn(pattern, options); | ||||
|   cache.set(type, key, val); | ||||
|   return val; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Expose compiler, parser and cache on `micromatch` | ||||
|  */ | ||||
|  | ||||
| micromatch.compilers = compilers; | ||||
| micromatch.parsers = parsers; | ||||
| micromatch.caches = cache.caches; | ||||
|  | ||||
| /** | ||||
|  * Expose `micromatch` | ||||
|  * @type {Function} | ||||
|  */ | ||||
|  | ||||
| module.exports = micromatch; | ||||
							
								
								
									
										
											BIN
										
									
								
								node_modules/micromatch/lib/.DS_Store
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								node_modules/micromatch/lib/.DS_Store
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										1
									
								
								node_modules/micromatch/lib/cache.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/micromatch/lib/cache.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| module.exports = new (require('fragment-cache'))(); | ||||
							
								
								
									
										77
									
								
								node_modules/micromatch/lib/compilers.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								node_modules/micromatch/lib/compilers.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,77 @@ | ||||
| 'use strict'; | ||||
|  | ||||
| var nanomatch = require('nanomatch'); | ||||
| var extglob = require('extglob'); | ||||
|  | ||||
| module.exports = function(snapdragon) { | ||||
|   var compilers = snapdragon.compiler.compilers; | ||||
|   var opts = snapdragon.options; | ||||
|  | ||||
|   // register nanomatch compilers | ||||
|   snapdragon.use(nanomatch.compilers); | ||||
|  | ||||
|   // get references to some specific nanomatch compilers before they | ||||
|   // are overridden by the extglob and/or custom compilers | ||||
|   var escape = compilers.escape; | ||||
|   var qmark = compilers.qmark; | ||||
|   var slash = compilers.slash; | ||||
|   var star = compilers.star; | ||||
|   var text = compilers.text; | ||||
|   var plus = compilers.plus; | ||||
|   var dot = compilers.dot; | ||||
|  | ||||
|   // register extglob compilers or escape exglobs if disabled | ||||
|   if (opts.extglob === false || opts.noext === true) { | ||||
|     snapdragon.compiler.use(escapeExtglobs); | ||||
|   } else { | ||||
|     snapdragon.use(extglob.compilers); | ||||
|   } | ||||
|  | ||||
|   snapdragon.use(function() { | ||||
|     this.options.star = this.options.star || function(/*node*/) { | ||||
|       return '[^\\\\/]*?'; | ||||
|     }; | ||||
|   }); | ||||
|  | ||||
|   // custom micromatch compilers | ||||
|   snapdragon.compiler | ||||
|  | ||||
|     // reset referenced compiler | ||||
|     .set('dot', dot) | ||||
|     .set('escape', escape) | ||||
|     .set('plus', plus) | ||||
|     .set('slash', slash) | ||||
|     .set('qmark', qmark) | ||||
|     .set('star', star) | ||||
|     .set('text', text); | ||||
| }; | ||||
|  | ||||
| function escapeExtglobs(compiler) { | ||||
|   compiler.set('paren', function(node) { | ||||
|     var val = ''; | ||||
|     visit(node, function(tok) { | ||||
|       if (tok.val) val += (/^\W/.test(tok.val) ? '\\' : '') + tok.val; | ||||
|     }); | ||||
|     return this.emit(val, node); | ||||
|   }); | ||||
|  | ||||
|   /** | ||||
|    * Visit `node` with the given `fn` | ||||
|    */ | ||||
|  | ||||
|   function visit(node, fn) { | ||||
|     return node.nodes ? mapVisit(node.nodes, fn) : fn(node); | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Map visit over array of `nodes`. | ||||
|    */ | ||||
|  | ||||
|   function mapVisit(nodes, fn) { | ||||
|     var len = nodes.length; | ||||
|     var idx = -1; | ||||
|     while (++idx < len) { | ||||
|       visit(nodes[idx], fn); | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										83
									
								
								node_modules/micromatch/lib/parsers.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								node_modules/micromatch/lib/parsers.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,83 @@ | ||||
| 'use strict'; | ||||
|  | ||||
| var extglob = require('extglob'); | ||||
| var nanomatch = require('nanomatch'); | ||||
| var regexNot = require('regex-not'); | ||||
| var toRegex = require('to-regex'); | ||||
| var not; | ||||
|  | ||||
| /** | ||||
|  * Characters to use in negation regex (we want to "not" match | ||||
|  * characters that are matched by other parsers) | ||||
|  */ | ||||
|  | ||||
| var TEXT = '([!@*?+]?\\(|\\)|\\[:?(?=.*?:?\\])|:?\\]|[*+?!^$.\\\\/])+'; | ||||
| var createNotRegex = function(opts) { | ||||
|   return not || (not = textRegex(TEXT)); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Parsers | ||||
|  */ | ||||
|  | ||||
| module.exports = function(snapdragon) { | ||||
|   var parsers = snapdragon.parser.parsers; | ||||
|  | ||||
|   // register nanomatch parsers | ||||
|   snapdragon.use(nanomatch.parsers); | ||||
|  | ||||
|   // get references to some specific nanomatch parsers before they | ||||
|   // are overridden by the extglob and/or parsers | ||||
|   var escape = parsers.escape; | ||||
|   var slash = parsers.slash; | ||||
|   var qmark = parsers.qmark; | ||||
|   var plus = parsers.plus; | ||||
|   var star = parsers.star; | ||||
|   var dot = parsers.dot; | ||||
|  | ||||
|   // register extglob parsers | ||||
|   snapdragon.use(extglob.parsers); | ||||
|  | ||||
|   // custom micromatch parsers | ||||
|   snapdragon.parser | ||||
|     .use(function() { | ||||
|       // override "notRegex" created in nanomatch parser | ||||
|       this.notRegex = /^\!+(?!\()/; | ||||
|     }) | ||||
|     // reset the referenced parsers | ||||
|     .capture('escape', escape) | ||||
|     .capture('slash', slash) | ||||
|     .capture('qmark', qmark) | ||||
|     .capture('star', star) | ||||
|     .capture('plus', plus) | ||||
|     .capture('dot', dot) | ||||
|  | ||||
|     /** | ||||
|      * Override `text` parser | ||||
|      */ | ||||
|  | ||||
|     .capture('text', function() { | ||||
|       if (this.isInside('bracket')) return; | ||||
|       var pos = this.position(); | ||||
|       var m = this.match(createNotRegex(this.options)); | ||||
|       if (!m || !m[0]) return; | ||||
|  | ||||
|       // escape regex boundary characters and simple brackets | ||||
|       var val = m[0].replace(/([[\]^$])/g, '\\$1'); | ||||
|  | ||||
|       return pos({ | ||||
|         type: 'text', | ||||
|         val: val | ||||
|       }); | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Create text regex | ||||
|  */ | ||||
|  | ||||
| function textRegex(pattern) { | ||||
|   var notStr = regexNot.create(pattern, {contains: true, strictClose: false}); | ||||
|   var prefix = '(?:[\\^]|\\\\|'; | ||||
|   return toRegex(prefix + notStr + ')', {strictClose: false}); | ||||
| } | ||||
							
								
								
									
										309
									
								
								node_modules/micromatch/lib/utils.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										309
									
								
								node_modules/micromatch/lib/utils.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,309 @@ | ||||
| 'use strict'; | ||||
|  | ||||
| var utils = module.exports; | ||||
| var path = require('path'); | ||||
|  | ||||
| /** | ||||
|  * Module dependencies | ||||
|  */ | ||||
|  | ||||
| var Snapdragon = require('snapdragon'); | ||||
| utils.define = require('define-property'); | ||||
| utils.diff = require('arr-diff'); | ||||
| utils.extend = require('extend-shallow'); | ||||
| utils.pick = require('object.pick'); | ||||
| utils.typeOf = require('kind-of'); | ||||
| utils.unique = require('array-unique'); | ||||
|  | ||||
| /** | ||||
|  * Returns true if the platform is windows, or `path.sep` is `\\`. | ||||
|  * This is defined as a function to allow `path.sep` to be set in unit tests, | ||||
|  * or by the user, if there is a reason to do so. | ||||
|  * @return {Boolean} | ||||
|  */ | ||||
|  | ||||
| utils.isWindows = function() { | ||||
|   return path.sep === '\\' || process.platform === 'win32'; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Get the `Snapdragon` instance to use | ||||
|  */ | ||||
|  | ||||
| utils.instantiate = function(ast, options) { | ||||
|   var snapdragon; | ||||
|   // if an instance was created by `.parse`, use that instance | ||||
|   if (utils.typeOf(ast) === 'object' && ast.snapdragon) { | ||||
|     snapdragon = ast.snapdragon; | ||||
|   // if the user supplies an instance on options, use that instance | ||||
|   } else if (utils.typeOf(options) === 'object' && options.snapdragon) { | ||||
|     snapdragon = options.snapdragon; | ||||
|   // create a new instance | ||||
|   } else { | ||||
|     snapdragon = new Snapdragon(options); | ||||
|   } | ||||
|  | ||||
|   utils.define(snapdragon, 'parse', function(str, options) { | ||||
|     var parsed = Snapdragon.prototype.parse.apply(this, arguments); | ||||
|     parsed.input = str; | ||||
|  | ||||
|     // escape unmatched brace/bracket/parens | ||||
|     var last = this.parser.stack.pop(); | ||||
|     if (last && this.options.strictErrors !== true) { | ||||
|       var open = last.nodes[0]; | ||||
|       var inner = last.nodes[1]; | ||||
|       if (last.type === 'bracket') { | ||||
|         if (inner.val.charAt(0) === '[') { | ||||
|           inner.val = '\\' + inner.val; | ||||
|         } | ||||
|  | ||||
|       } else { | ||||
|         open.val = '\\' + open.val; | ||||
|         var sibling = open.parent.nodes[1]; | ||||
|         if (sibling.type === 'star') { | ||||
|           sibling.loose = true; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     // add non-enumerable parser reference | ||||
|     utils.define(parsed, 'parser', this.parser); | ||||
|     return parsed; | ||||
|   }); | ||||
|  | ||||
|   return snapdragon; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Create the key to use for memoization. The key is generated | ||||
|  * by iterating over the options and concatenating key-value pairs | ||||
|  * to the pattern string. | ||||
|  */ | ||||
|  | ||||
| utils.createKey = function(pattern, options) { | ||||
|   if (utils.typeOf(options) !== 'object') { | ||||
|     return pattern; | ||||
|   } | ||||
|   var val = pattern; | ||||
|   var keys = Object.keys(options); | ||||
|   for (var i = 0; i < keys.length; i++) { | ||||
|     var key = keys[i]; | ||||
|     val += ';' + key + '=' + String(options[key]); | ||||
|   } | ||||
|   return val; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Cast `val` to an array | ||||
|  * @return {Array} | ||||
|  */ | ||||
|  | ||||
| utils.arrayify = function(val) { | ||||
|   if (typeof val === 'string') return [val]; | ||||
|   return val ? (Array.isArray(val) ? val : [val]) : []; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Return true if `val` is a non-empty string | ||||
|  */ | ||||
|  | ||||
| utils.isString = function(val) { | ||||
|   return typeof val === 'string'; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Return true if `val` is a non-empty string | ||||
|  */ | ||||
|  | ||||
| utils.isObject = function(val) { | ||||
|   return utils.typeOf(val) === 'object'; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if the given `str` has special characters | ||||
|  */ | ||||
|  | ||||
| utils.hasSpecialChars = function(str) { | ||||
|   return /(?:(?:(^|\/)[!.])|[*?+()|\[\]{}]|[+@]\()/.test(str); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Escape regex characters in the given string | ||||
|  */ | ||||
|  | ||||
| utils.escapeRegex = function(str) { | ||||
|   return str.replace(/[-[\]{}()^$|*+?.\\\/\s]/g, '\\$&'); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Normalize slashes in the given filepath. | ||||
|  * | ||||
|  * @param {String} `filepath` | ||||
|  * @return {String} | ||||
|  */ | ||||
|  | ||||
| utils.toPosixPath = function(str) { | ||||
|   return str.replace(/\\+/g, '/'); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Strip backslashes before special characters in a string. | ||||
|  * | ||||
|  * @param {String} `str` | ||||
|  * @return {String} | ||||
|  */ | ||||
|  | ||||
| utils.unescape = function(str) { | ||||
|   return utils.toPosixPath(str.replace(/\\(?=[*+?!.])/g, '')); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Strip the prefix from a filepath | ||||
|  * @param {String} `fp` | ||||
|  * @return {String} | ||||
|  */ | ||||
|  | ||||
| utils.stripPrefix = function(str) { | ||||
|   if (str.charAt(0) !== '.') { | ||||
|     return str; | ||||
|   } | ||||
|   var ch = str.charAt(1); | ||||
|   if (utils.isSlash(ch)) { | ||||
|     return str.slice(2); | ||||
|   } | ||||
|   return str; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if the given str is an escaped or | ||||
|  * unescaped path character | ||||
|  */ | ||||
|  | ||||
| utils.isSlash = function(str) { | ||||
|   return str === '/' || str === '\\/' || str === '\\' || str === '\\\\'; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns a function that returns true if the given | ||||
|  * pattern matches or contains a `filepath` | ||||
|  * | ||||
|  * @param {String} `pattern` | ||||
|  * @return {Function} | ||||
|  */ | ||||
|  | ||||
| utils.matchPath = function(pattern, options) { | ||||
|   return (options && options.contains) | ||||
|     ? utils.containsPattern(pattern, options) | ||||
|     : utils.equalsPattern(pattern, options); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if the given (original) filepath or unixified path are equal | ||||
|  * to the given pattern. | ||||
|  */ | ||||
|  | ||||
| utils._equals = function(filepath, unixPath, pattern) { | ||||
|   return pattern === filepath || pattern === unixPath; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns true if the given (original) filepath or unixified path contain | ||||
|  * the given pattern. | ||||
|  */ | ||||
|  | ||||
| utils._contains = function(filepath, unixPath, pattern) { | ||||
|   return filepath.indexOf(pattern) !== -1 || unixPath.indexOf(pattern) !== -1; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns a function that returns true if the given | ||||
|  * pattern is the same as a given `filepath` | ||||
|  * | ||||
|  * @param {String} `pattern` | ||||
|  * @return {Function} | ||||
|  */ | ||||
|  | ||||
| utils.equalsPattern = function(pattern, options) { | ||||
|   var unixify = utils.unixify(options); | ||||
|   options = options || {}; | ||||
|  | ||||
|   return function fn(filepath) { | ||||
|     var equal = utils._equals(filepath, unixify(filepath), pattern); | ||||
|     if (equal === true || options.nocase !== true) { | ||||
|       return equal; | ||||
|     } | ||||
|     var lower = filepath.toLowerCase(); | ||||
|     return utils._equals(lower, unixify(lower), pattern); | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns a function that returns true if the given | ||||
|  * pattern contains a `filepath` | ||||
|  * | ||||
|  * @param {String} `pattern` | ||||
|  * @return {Function} | ||||
|  */ | ||||
|  | ||||
| utils.containsPattern = function(pattern, options) { | ||||
|   var unixify = utils.unixify(options); | ||||
|   options = options || {}; | ||||
|  | ||||
|   return function(filepath) { | ||||
|     var contains = utils._contains(filepath, unixify(filepath), pattern); | ||||
|     if (contains === true || options.nocase !== true) { | ||||
|       return contains; | ||||
|     } | ||||
|     var lower = filepath.toLowerCase(); | ||||
|     return utils._contains(lower, unixify(lower), pattern); | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns a function that returns true if the given | ||||
|  * regex matches the `filename` of a file path. | ||||
|  * | ||||
|  * @param {RegExp} `re` Matching regex | ||||
|  * @return {Function} | ||||
|  */ | ||||
|  | ||||
| utils.matchBasename = function(re) { | ||||
|   return function(filepath) { | ||||
|     return re.test(path.basename(filepath)); | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Determines the filepath to return based on the provided options. | ||||
|  * @return {any} | ||||
|  */ | ||||
|  | ||||
| utils.value = function(str, unixify, options) { | ||||
|   if (options && options.unixify === false) { | ||||
|     return str; | ||||
|   } | ||||
|   return unixify(str); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Returns a function that normalizes slashes in a string to forward | ||||
|  * slashes, strips `./` from beginning of paths, and optionally unescapes | ||||
|  * special characters. | ||||
|  * @return {Function} | ||||
|  */ | ||||
|  | ||||
| utils.unixify = function(options) { | ||||
|   options = options || {}; | ||||
|   return function(filepath) { | ||||
|     if (utils.isWindows() || options.unixify === true) { | ||||
|       filepath = utils.toPosixPath(filepath); | ||||
|     } | ||||
|     if (options.stripPrefix !== false) { | ||||
|       filepath = utils.stripPrefix(filepath); | ||||
|     } | ||||
|     if (options.unescape === true) { | ||||
|       filepath = utils.unescape(filepath); | ||||
|     } | ||||
|     return filepath; | ||||
|   }; | ||||
| }; | ||||
							
								
								
									
										226
									
								
								node_modules/micromatch/package.json
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										226
									
								
								node_modules/micromatch/package.json
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,226 @@ | ||||
| { | ||||
|   "_args": [ | ||||
|     [ | ||||
|       "micromatch@3.1.10", | ||||
|       "E:\\python\\setup-php" | ||||
|     ] | ||||
|   ], | ||||
|   "_development": true, | ||||
|   "_from": "micromatch@3.1.10", | ||||
|   "_id": "micromatch@3.1.10", | ||||
|   "_inBundle": false, | ||||
|   "_integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", | ||||
|   "_location": "/micromatch", | ||||
|   "_phantomChildren": {}, | ||||
|   "_requested": { | ||||
|     "type": "version", | ||||
|     "registry": true, | ||||
|     "raw": "micromatch@3.1.10", | ||||
|     "name": "micromatch", | ||||
|     "escapedName": "micromatch", | ||||
|     "rawSpec": "3.1.10", | ||||
|     "saveSpec": null, | ||||
|     "fetchSpec": "3.1.10" | ||||
|   }, | ||||
|   "_requiredBy": [ | ||||
|     "/@jest/core", | ||||
|     "/@jest/transform", | ||||
|     "/anymatch", | ||||
|     "/jest-config", | ||||
|     "/jest-haste-map", | ||||
|     "/jest-message-util", | ||||
|     "/sane" | ||||
|   ], | ||||
|   "_resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", | ||||
|   "_spec": "3.1.10", | ||||
|   "_where": "E:\\python\\setup-php", | ||||
|   "author": { | ||||
|     "name": "Jon Schlinkert", | ||||
|     "url": "https://github.com/jonschlinkert" | ||||
|   }, | ||||
|   "bugs": { | ||||
|     "url": "https://github.com/micromatch/micromatch/issues" | ||||
|   }, | ||||
|   "contributors": [ | ||||
|     { | ||||
|       "name": "Amila Welihinda", | ||||
|       "url": "amilajack.com" | ||||
|     }, | ||||
|     { | ||||
|       "name": "Bogdan Chadkin", | ||||
|       "url": "https://github.com/TrySound" | ||||
|     }, | ||||
|     { | ||||
|       "name": "Brian Woodward", | ||||
|       "url": "https://twitter.com/doowb" | ||||
|     }, | ||||
|     { | ||||
|       "name": "Devon Govett", | ||||
|       "url": "http://badassjs.com" | ||||
|     }, | ||||
|     { | ||||
|       "name": "Elan Shanker", | ||||
|       "url": "https://github.com/es128" | ||||
|     }, | ||||
|     { | ||||
|       "name": "Fabrício Matté", | ||||
|       "url": "https://ultcombo.js.org" | ||||
|     }, | ||||
|     { | ||||
|       "name": "Jon Schlinkert", | ||||
|       "url": "http://twitter.com/jonschlinkert" | ||||
|     }, | ||||
|     { | ||||
|       "name": "Martin Kolárik", | ||||
|       "url": "https://kolarik.sk" | ||||
|     }, | ||||
|     { | ||||
|       "name": "Olsten Larck", | ||||
|       "url": "https://i.am.charlike.online" | ||||
|     }, | ||||
|     { | ||||
|       "name": "Paul Miller", | ||||
|       "url": "paulmillr.com" | ||||
|     }, | ||||
|     { | ||||
|       "name": "Tom Byrer", | ||||
|       "url": "https://github.com/tomByrer" | ||||
|     }, | ||||
|     { | ||||
|       "name": "Tyler Akins", | ||||
|       "url": "http://rumkin.com" | ||||
|     }, | ||||
|     { | ||||
|       "url": "https://github.com/DianeLooney" | ||||
|     } | ||||
|   ], | ||||
|   "dependencies": { | ||||
|     "arr-diff": "^4.0.0", | ||||
|     "array-unique": "^0.3.2", | ||||
|     "braces": "^2.3.1", | ||||
|     "define-property": "^2.0.2", | ||||
|     "extend-shallow": "^3.0.2", | ||||
|     "extglob": "^2.0.4", | ||||
|     "fragment-cache": "^0.2.1", | ||||
|     "kind-of": "^6.0.2", | ||||
|     "nanomatch": "^1.2.9", | ||||
|     "object.pick": "^1.3.0", | ||||
|     "regex-not": "^1.0.0", | ||||
|     "snapdragon": "^0.8.1", | ||||
|     "to-regex": "^3.0.2" | ||||
|   }, | ||||
|   "description": "Glob matching for javascript/node.js. A drop-in replacement and faster alternative to minimatch and multimatch.", | ||||
|   "devDependencies": { | ||||
|     "bash-match": "^1.0.2", | ||||
|     "for-own": "^1.0.0", | ||||
|     "gulp": "^3.9.1", | ||||
|     "gulp-format-md": "^1.0.0", | ||||
|     "gulp-istanbul": "^1.1.3", | ||||
|     "gulp-mocha": "^5.0.0", | ||||
|     "gulp-unused": "^0.2.1", | ||||
|     "is-windows": "^1.0.2", | ||||
|     "minimatch": "^3.0.4", | ||||
|     "minimist": "^1.2.0", | ||||
|     "mocha": "^3.5.3", | ||||
|     "multimatch": "^2.1.0" | ||||
|   }, | ||||
|   "engines": { | ||||
|     "node": ">=0.10.0" | ||||
|   }, | ||||
|   "files": [ | ||||
|     "index.js", | ||||
|     "lib" | ||||
|   ], | ||||
|   "homepage": "https://github.com/micromatch/micromatch", | ||||
|   "keywords": [ | ||||
|     "bash", | ||||
|     "expand", | ||||
|     "expansion", | ||||
|     "expression", | ||||
|     "file", | ||||
|     "files", | ||||
|     "filter", | ||||
|     "find", | ||||
|     "glob", | ||||
|     "globbing", | ||||
|     "globs", | ||||
|     "globstar", | ||||
|     "match", | ||||
|     "matcher", | ||||
|     "matches", | ||||
|     "matching", | ||||
|     "micromatch", | ||||
|     "minimatch", | ||||
|     "multimatch", | ||||
|     "path", | ||||
|     "pattern", | ||||
|     "patterns", | ||||
|     "regex", | ||||
|     "regexp", | ||||
|     "regular", | ||||
|     "shell", | ||||
|     "wildcard" | ||||
|   ], | ||||
|   "license": "MIT", | ||||
|   "lintDeps": { | ||||
|     "dependencies": { | ||||
|       "options": { | ||||
|         "lock": { | ||||
|           "snapdragon": "^0.8.1" | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|       "files": { | ||||
|         "options": { | ||||
|           "ignore": [ | ||||
|             "benchmark/**" | ||||
|           ] | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   "main": "index.js", | ||||
|   "name": "micromatch", | ||||
|   "repository": { | ||||
|     "type": "git", | ||||
|     "url": "git+https://github.com/micromatch/micromatch.git" | ||||
|   }, | ||||
|   "scripts": { | ||||
|     "test": "mocha" | ||||
|   }, | ||||
|   "verb": { | ||||
|     "toc": "collapsible", | ||||
|     "layout": "default", | ||||
|     "tasks": [ | ||||
|       "readme" | ||||
|     ], | ||||
|     "plugins": [ | ||||
|       "gulp-format-md" | ||||
|     ], | ||||
|     "helpers": [ | ||||
|       "./benchmark/helper.js" | ||||
|     ], | ||||
|     "related": { | ||||
|       "list": [ | ||||
|         "braces", | ||||
|         "expand-brackets", | ||||
|         "extglob", | ||||
|         "fill-range", | ||||
|         "nanomatch" | ||||
|       ] | ||||
|     }, | ||||
|     "lint": { | ||||
|       "reflinks": true | ||||
|     }, | ||||
|     "reflinks": [ | ||||
|       "expand-brackets", | ||||
|       "extglob", | ||||
|       "glob-object", | ||||
|       "minimatch", | ||||
|       "multimatch", | ||||
|       "snapdragon" | ||||
|     ] | ||||
|   }, | ||||
|   "version": "3.1.10" | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Shivam Mathur
					Shivam Mathur