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