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;
 |