212 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
		
		
			
		
	
	
			212 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
|  | 'use strict'; | ||
|  | 
 | ||
|  | /** | ||
|  |  * Local dependencies | ||
|  |  */ | ||
|  | 
 | ||
|  | var compilers = require('./lib/compilers'); | ||
|  | var parsers = require('./lib/parsers'); | ||
|  | 
 | ||
|  | /** | ||
|  |  * Module dependencies | ||
|  |  */ | ||
|  | 
 | ||
|  | var debug = require('debug')('expand-brackets'); | ||
|  | var extend = require('extend-shallow'); | ||
|  | var Snapdragon = require('snapdragon'); | ||
|  | var toRegex = require('to-regex'); | ||
|  | 
 | ||
|  | /** | ||
|  |  * Parses the given POSIX character class `pattern` and returns a | ||
|  |  * string that can be used for creating regular expressions for matching. | ||
|  |  * | ||
|  |  * @param {String} `pattern` | ||
|  |  * @param {Object} `options` | ||
|  |  * @return {Object} | ||
|  |  * @api public | ||
|  |  */ | ||
|  | 
 | ||
|  | function brackets(pattern, options) { | ||
|  |   debug('initializing from <%s>', __filename); | ||
|  |   var res = brackets.create(pattern, options); | ||
|  |   return res.output; | ||
|  | } | ||
|  | 
 | ||
|  | /** | ||
|  |  * Takes an array of strings and a POSIX character class pattern, and returns a new | ||
|  |  * array with only the strings that matched the pattern. | ||
|  |  * | ||
|  |  * ```js
 | ||
|  |  * var brackets = require('expand-brackets'); | ||
|  |  * console.log(brackets.match(['1', 'a', 'ab'], '[[:alpha:]]')); | ||
|  |  * //=> ['a']
 | ||
|  |  * | ||
|  |  * console.log(brackets.match(['1', 'a', 'ab'], '[[:alpha:]]+')); | ||
|  |  * //=> ['a', 'ab']
 | ||
|  |  * ```
 | ||
|  |  * @param {Array} `arr` Array of strings to match | ||
|  |  * @param {String} `pattern` POSIX character class pattern(s) | ||
|  |  * @param {Object} `options` | ||
|  |  * @return {Array} | ||
|  |  * @api public | ||
|  |  */ | ||
|  | 
 | ||
|  | brackets.match = function(arr, pattern, options) { | ||
|  |   arr = [].concat(arr); | ||
|  |   var opts = extend({}, options); | ||
|  |   var isMatch = brackets.matcher(pattern, opts); | ||
|  |   var len = arr.length; | ||
|  |   var idx = -1; | ||
|  |   var res = []; | ||
|  | 
 | ||
|  |   while (++idx < len) { | ||
|  |     var ele = arr[idx]; | ||
|  |     if (isMatch(ele)) { | ||
|  |       res.push(ele); | ||
|  |     } | ||
|  |   } | ||
|  | 
 | ||
|  |   if (res.length === 0) { | ||
|  |     if (opts.failglob === true) { | ||
|  |       throw new Error('no matches found for "' + pattern + '"'); | ||
|  |     } | ||
|  | 
 | ||
|  |     if (opts.nonull === true || opts.nullglob === true) { | ||
|  |       return [pattern.split('\\').join('')]; | ||
|  |     } | ||
|  |   } | ||
|  |   return res; | ||
|  | }; | ||
|  | 
 | ||
|  | /** | ||
|  |  * Returns true if the specified `string` matches the given | ||
|  |  * brackets `pattern`. | ||
|  |  * | ||
|  |  * ```js
 | ||
|  |  * var brackets = require('expand-brackets'); | ||
|  |  * | ||
|  |  * console.log(brackets.isMatch('a.a', '[[:alpha:]].[[:alpha:]]')); | ||
|  |  * //=> true
 | ||
|  |  * console.log(brackets.isMatch('1.2', '[[:alpha:]].[[:alpha:]]')); | ||
|  |  * //=> false
 | ||
|  |  * ```
 | ||
|  |  * @param {String} `string` String to match | ||
|  |  * @param {String} `pattern` Poxis pattern | ||
|  |  * @param {String} `options` | ||
|  |  * @return {Boolean} | ||
|  |  * @api public | ||
|  |  */ | ||
|  | 
 | ||
|  | brackets.isMatch = function(str, pattern, options) { | ||
|  |   return brackets.matcher(pattern, options)(str); | ||
|  | }; | ||
|  | 
 | ||
|  | /** | ||
|  |  * Takes a POSIX character class pattern and returns a matcher function. The returned | ||
|  |  * function takes the string to match as its only argument. | ||
|  |  * | ||
|  |  * ```js
 | ||
|  |  * var brackets = require('expand-brackets'); | ||
|  |  * var isMatch = brackets.matcher('[[:lower:]].[[:upper:]]'); | ||
|  |  * | ||
|  |  * console.log(isMatch('a.a')); | ||
|  |  * //=> false
 | ||
|  |  * console.log(isMatch('a.A')); | ||
|  |  * //=> true
 | ||
|  |  * ```
 | ||
|  |  * @param {String} `pattern` Poxis pattern | ||
|  |  * @param {String} `options` | ||
|  |  * @return {Boolean} | ||
|  |  * @api public | ||
|  |  */ | ||
|  | 
 | ||
|  | brackets.matcher = function(pattern, options) { | ||
|  |   var re = brackets.makeRe(pattern, options); | ||
|  |   return function(str) { | ||
|  |     return re.test(str); | ||
|  |   }; | ||
|  | }; | ||
|  | 
 | ||
|  | /** | ||
|  |  * Create a regular expression from the given `pattern`. | ||
|  |  * | ||
|  |  * ```js
 | ||
|  |  * var brackets = require('expand-brackets'); | ||
|  |  * var re = brackets.makeRe('[[:alpha:]]'); | ||
|  |  * console.log(re); | ||
|  |  * //=> /^(?:[a-zA-Z])$/
 | ||
|  |  * ```
 | ||
|  |  * @param {String} `pattern` The pattern to convert to regex. | ||
|  |  * @param {Object} `options` | ||
|  |  * @return {RegExp} | ||
|  |  * @api public | ||
|  |  */ | ||
|  | 
 | ||
|  | brackets.makeRe = function(pattern, options) { | ||
|  |   var res = brackets.create(pattern, options); | ||
|  |   var opts = extend({strictErrors: false}, options); | ||
|  |   return toRegex(res.output, opts); | ||
|  | }; | ||
|  | 
 | ||
|  | /** | ||
|  |  * Parses the given POSIX character class `pattern` and returns an object | ||
|  |  * with the compiled `output` and optional source `map`. | ||
|  |  * | ||
|  |  * ```js
 | ||
|  |  * var brackets = require('expand-brackets'); | ||
|  |  * console.log(brackets('[[:alpha:]]')); | ||
|  |  * // { options: { source: 'string' },
 | ||
|  |  * //   input: '[[:alpha:]]',
 | ||
|  |  * //   state: {},
 | ||
|  |  * //   compilers:
 | ||
|  |  * //    { eos: [Function],
 | ||
|  |  * //      noop: [Function],
 | ||
|  |  * //      bos: [Function],
 | ||
|  |  * //      not: [Function],
 | ||
|  |  * //      escape: [Function],
 | ||
|  |  * //      text: [Function],
 | ||
|  |  * //      posix: [Function],
 | ||
|  |  * //      bracket: [Function],
 | ||
|  |  * //      'bracket.open': [Function],
 | ||
|  |  * //      'bracket.inner': [Function],
 | ||
|  |  * //      'bracket.literal': [Function],
 | ||
|  |  * //      'bracket.close': [Function] },
 | ||
|  |  * //   output: '[a-zA-Z]',
 | ||
|  |  * //   ast:
 | ||
|  |  * //    { type: 'root',
 | ||
|  |  * //      errors: [],
 | ||
|  |  * //      nodes: [ [Object], [Object], [Object] ] },
 | ||
|  |  * //   parsingErrors: [] }
 | ||
|  |  * ```
 | ||
|  |  * @param {String} `pattern` | ||
|  |  * @param {Object} `options` | ||
|  |  * @return {Object} | ||
|  |  * @api public | ||
|  |  */ | ||
|  | 
 | ||
|  | brackets.create = function(pattern, options) { | ||
|  |   var snapdragon = (options && options.snapdragon) || new Snapdragon(options); | ||
|  |   compilers(snapdragon); | ||
|  |   parsers(snapdragon); | ||
|  | 
 | ||
|  |   var ast = snapdragon.parse(pattern, options); | ||
|  |   ast.input = pattern; | ||
|  |   var res = snapdragon.compile(ast, options); | ||
|  |   res.input = pattern; | ||
|  |   return res; | ||
|  | }; | ||
|  | 
 | ||
|  | /** | ||
|  |  * Expose `brackets` constructor, parsers and compilers | ||
|  |  */ | ||
|  | 
 | ||
|  | brackets.compilers = compilers; | ||
|  | brackets.parsers = parsers; | ||
|  | 
 | ||
|  | /** | ||
|  |  * Expose `brackets` | ||
|  |  * @type {Function} | ||
|  |  */ | ||
|  | 
 | ||
|  | module.exports = brackets; |