[Pkg-javascript-commits] [node-to-regex-range] 01/07: Import Upstream version 0.2.0

Praveen Arimbrathodiyil praveen at moszumanska.debian.org
Sun Oct 16 15:27:01 UTC 2016


This is an automated email from the git hooks/post-receive script.

praveen pushed a commit to branch master
in repository node-to-regex-range.

commit 9a5aef22e4909d3e9a3d64e37ac0e623d3b47df6
Author: Praveen Arimbrathodiyil <praveen at debian.org>
Date:   Sun Oct 16 19:01:52 2016 +0530

    Import Upstream version 0.2.0
---
 .editorconfig         |  13 +++
 .eslintrc.json        | 122 +++++++++++++++++++++++++++
 .gitattributes        |  10 +++
 .gitignore            |  21 +++++
 .travis.yml           |  12 +++
 .verb.md              |  41 ++++++++++
 LICENSE               |  21 +++++
 README.md             | 105 ++++++++++++++++++++++++
 bower.json            |  38 +++++++++
 example.js            |  17 ++++
 index.js              | 222 ++++++++++++++++++++++++++++++++++++++++++++++++++
 package.json          |  73 +++++++++++++++++
 test/support/index.js |  14 ++++
 test/test.js          | 174 +++++++++++++++++++++++++++++++++++++++
 14 files changed, 883 insertions(+)

diff --git a/.editorconfig b/.editorconfig
new file mode 100644
index 0000000..818e072
--- /dev/null
+++ b/.editorconfig
@@ -0,0 +1,13 @@
+root = true
+
+[*]
+indent_style = space
+end_of_line = lf
+charset = utf-8
+indent_size = 2
+trim_trailing_whitespace = true
+insert_final_newline = true
+
+[{**/{actual,fixtures,expected,templates}/**,*.md}]
+trim_trailing_whitespace = false
+insert_final_newline = false
\ No newline at end of file
diff --git a/.eslintrc.json b/.eslintrc.json
new file mode 100644
index 0000000..948dbdb
--- /dev/null
+++ b/.eslintrc.json
@@ -0,0 +1,122 @@
+{
+  "ecmaFeatures": {
+    "modules": true,
+    "experimentalObjectRestSpread": true
+  },
+
+  "env": {
+    "browser": false,
+    "es6": true,
+    "node": true,
+    "mocha": true
+  },
+
+  "globals": {
+    "document": false,
+    "navigator": false,
+    "window": false
+  },
+
+  "rules": {
+    "accessor-pairs": 2,
+    "arrow-spacing": [2, { "before": true, "after": true }],
+    "block-spacing": [2, "always"],
+    "brace-style": [2, "1tbs", { "allowSingleLine": true }],
+    "comma-dangle": [2, "never"],
+    "comma-spacing": [2, { "before": false, "after": true }],
+    "comma-style": [2, "last"],
+    "constructor-super": 2,
+    "curly": [2, "multi-line"],
+    "dot-location": [2, "property"],
+    "eol-last": 2,
+    "eqeqeq": [2, "allow-null"],
+    "generator-star-spacing": [2, { "before": true, "after": true }],
+    "handle-callback-err": [2, "^(err|error)$" ],
+    "indent": [2, 2, { "SwitchCase": 1 }],
+    "key-spacing": [2, { "beforeColon": false, "afterColon": true }],
+    "keyword-spacing": [2, { "before": true, "after": true }],
+    "new-cap": [2, { "newIsCap": true, "capIsNew": false }],
+    "new-parens": 2,
+    "no-array-constructor": 2,
+    "no-caller": 2,
+    "no-class-assign": 2,
+    "no-cond-assign": 2,
+    "no-const-assign": 2,
+    "no-control-regex": 2,
+    "no-debugger": 2,
+    "no-delete-var": 2,
+    "no-dupe-args": 2,
+    "no-dupe-class-members": 2,
+    "no-dupe-keys": 2,
+    "no-duplicate-case": 2,
+    "no-empty-character-class": 2,
+    "no-eval": 2,
+    "no-ex-assign": 2,
+    "no-extend-native": 2,
+    "no-extra-bind": 2,
+    "no-extra-boolean-cast": 2,
+    "no-extra-parens": [2, "functions"],
+    "no-fallthrough": 2,
+    "no-floating-decimal": 2,
+    "no-func-assign": 2,
+    "no-implied-eval": 2,
+    "no-inner-declarations": [2, "functions"],
+    "no-invalid-regexp": 2,
+    "no-irregular-whitespace": 2,
+    "no-iterator": 2,
+    "no-label-var": 2,
+    "no-labels": 2,
+    "no-lone-blocks": 2,
+    "no-mixed-spaces-and-tabs": 2,
+    "no-multi-spaces": 2,
+    "no-multi-str": 2,
+    "no-multiple-empty-lines": [2, { "max": 1 }],
+    "no-native-reassign": 0,
+    "no-negated-in-lhs": 2,
+    "no-new": 2,
+    "no-new-func": 2,
+    "no-new-object": 2,
+    "no-new-require": 2,
+    "no-new-wrappers": 2,
+    "no-obj-calls": 2,
+    "no-octal": 2,
+    "no-octal-escape": 2,
+    "no-proto": 0,
+    "no-redeclare": 2,
+    "no-regex-spaces": 2,
+    "no-return-assign": 2,
+    "no-self-compare": 2,
+    "no-sequences": 2,
+    "no-shadow-restricted-names": 2,
+    "no-spaced-func": 2,
+    "no-sparse-arrays": 2,
+    "no-this-before-super": 2,
+    "no-throw-literal": 2,
+    "no-trailing-spaces": 0,
+    "no-undef": 2,
+    "no-undef-init": 2,
+    "no-unexpected-multiline": 2,
+    "no-unneeded-ternary": [2, { "defaultAssignment": false }],
+    "no-unreachable": 2,
+    "no-unused-vars": [2, { "vars": "all", "args": "none" }],
+    "no-useless-call": 0,
+    "no-with": 2,
+    "one-var": [0, { "initialized": "never" }],
+    "operator-linebreak": [0, "after", { "overrides": { "?": "before", ":": "before" } }],
+    "padded-blocks": [0, "never"],
+    "quotes": [2, "single", "avoid-escape"],
+    "radix": 2,
+    "semi": [2, "always"],
+    "semi-spacing": [2, { "before": false, "after": true }],
+    "space-before-blocks": [2, "always"],
+    "space-before-function-paren": [2, "never"],
+    "space-in-parens": [2, "never"],
+    "space-infix-ops": 2,
+    "space-unary-ops": [2, { "words": true, "nonwords": false }],
+    "spaced-comment": [0, "always", { "markers": ["global", "globals", "eslint", "eslint-disable", "*package", "!", ","] }],
+    "use-isnan": 2,
+    "valid-typeof": 2,
+    "wrap-iife": [2, "any"],
+    "yoda": [2, "never"]
+  }
+}
diff --git a/.gitattributes b/.gitattributes
new file mode 100644
index 0000000..660957e
--- /dev/null
+++ b/.gitattributes
@@ -0,0 +1,10 @@
+# Enforce Unix newlines
+* text eol=lf
+
+# binaries
+*.ai binary
+*.psd binary
+*.jpg binary
+*.gif binary
+*.png binary
+*.jpeg binary
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..7988154
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,21 @@
+# always ignore files
+*.DS_Store
+*.sublime-*
+
+# test related, or directories generated by tests
+test/actual
+actual
+coverage
+
+# npm
+node_modules
+npm-debug.log
+
+# misc
+_gh_pages
+benchmark
+bower_components
+vendor
+temp
+tmp
+TODO.md
diff --git a/.travis.yml b/.travis.yml
new file mode 100644
index 0000000..04a029e
--- /dev/null
+++ b/.travis.yml
@@ -0,0 +1,12 @@
+sudo: false
+language: node_js
+node_js:
+  - node
+  - '6'
+  - '5'
+  - '0.12'
+matrix:
+  fast_finish: true
+  allow_failures:
+    - node_js: '4'
+    - node_js: '0.12'
diff --git a/.verb.md b/.verb.md
new file mode 100644
index 0000000..3bd4294
--- /dev/null
+++ b/.verb.md
@@ -0,0 +1,41 @@
+## Bower
+
+{%= include("install-bower", {save: true}) %}
+
+## Notes
+
+Inspired by the python lib [range-regex](https://github.com/dimka665/range-regex), it has never been easier to validate numbers and number ranges with regex!
+
+The [unit tests generate 850,000 patterns](./test/test.js) to provide brute-force validation that the generated regex-ranges are correct.
+
+## Usage
+
+```js
+var toRegexRange = require('{%= name %}');
+
+var re = new RegExp(toRegexRange('1', '99'));
+re.test('50');
+//=> true
+```
+
+**Examples**
+
+```js
+toRegexRange('111', '555');
+//=> '11[1-9]|1[2-9]\d|[2-4]\d{2}|5[0-4]\d|55[0-5]'
+toRegexRange('5', '5');
+//=> '5'
+toRegexRange('5', '6');
+//=> '[5-6]'
+toRegexRange('51', '229');
+//=> '5[1-9]|[6-9]\d|1\d{2}|2[0-2]\d'
+```
+
+When the `min` is larger than the `max`, a regex logical `or` is returned:
+
+```js
+toRegexRange('51', '29');
+//=> '51|29'
+```
+
+Currently this does not support steps (increments) or zero-padding.
diff --git a/LICENSE b/LICENSE
new file mode 100644
index 0000000..1e49edf
--- /dev/null
+++ b/LICENSE
@@ -0,0 +1,21 @@
+The MIT License (MIT)
+
+Copyright (c) 2015-2016, 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.
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..a414318
--- /dev/null
+++ b/README.md
@@ -0,0 +1,105 @@
+# to-regex-range [![NPM version](https://img.shields.io/npm/v/to-regex-range.svg?style=flat)](https://www.npmjs.com/package/to-regex-range) [![NPM downloads](https://img.shields.io/npm/dm/to-regex-range.svg?style=flat)](https://npmjs.org/package/to-regex-range) [![Build Status](https://img.shields.io/travis/jonschlinkert/to-regex-range.svg?style=flat)](https://travis-ci.org/jonschlinkert/to-regex-range)
+
+> Returns a regex-compatible range from two numbers, min and max, with 855,412 generated unit tests to validate it's accuracy! Useful for creating regular expressions to validate numbers, ranges, years, etc. Returns a string, allowing the returned value to be used in regular expressions generated by other libraries.
+
+## Install
+
+Install with [npm](https://www.npmjs.com/):
+
+```sh
+$ npm install --save to-regex-range
+```
+
+## Bower
+
+Install with [bower](http://bower.io/)
+
+```sh
+$ bower install to-regex-range --save
+```
+
+## Notes
+
+Inspired by the python lib [range-regex](https://github.com/dimka665/range-regex), it has never been easier to validate numbers and number ranges with regex!
+
+The [unit tests generate 850,000 patterns](./test/test.js) to provide brute-force validation that the generated regex-ranges are correct.
+
+## Usage
+
+```js
+var toRegexRange = require('to-regex-range');
+
+var re = new RegExp(toRegexRange('1', '99'));
+re.test('50');
+//=> true
+```
+
+**Examples**
+
+```js
+toRegexRange('111', '555');
+//=> '11[1-9]|1[2-9]\d|[2-4]\d{2}|5[0-4]\d|55[0-5]'
+toRegexRange('5', '5');
+//=> '5'
+toRegexRange('5', '6');
+//=> '[5-6]'
+toRegexRange('51', '229');
+//=> '5[1-9]|[6-9]\d|1\d{2}|2[0-2]\d'
+```
+
+When the `min` is larger than the `max`, a regex logical `or` is returned:
+
+```js
+toRegexRange('51', '29');
+//=> '51|29'
+```
+
+Currently this does not support steps (increments) or zero-padding.
+
+## About
+
+### Related projects
+
+* [expand-range](https://www.npmjs.com/package/expand-range): Fast, bash-like range expansion. Expand a range of numbers or letters, uppercase or lowercase. See… [more](https://github.com/jonschlinkert/expand-range) | [homepage](https://github.com/jonschlinkert/expand-range "Fast, bash-like range expansion. Expand a range of numbers or letters, uppercase or lowercase. See the benchmarks. Used by micromatch.")
+* [fill-range](https://www.npmjs.com/package/fill-range): Fill in a range of numbers or letters, optionally passing an increment or multiplier to… [more](https://github.com/jonschlinkert/fill-range) | [homepage](https://github.com/jonschlinkert/fill-range "Fill in a range of numbers or letters, optionally passing an increment or multiplier to use.")
+* [micromatch](https://www.npmjs.com/package/micromatch): Glob matching for javascript/node.js. A drop-in replacement and faster alternative to minimatch and multimatch. | [homepage](https://github.com/jonschlinkert/micromatch "Glob matching for javascript/node.js. A drop-in replacement and faster alternative to minimatch and multimatch.")
+* [repeat-element](https://www.npmjs.com/package/repeat-element): Create an array by repeating the given value n times. | [homepage](https://github.com/jonschlinkert/repeat-element "Create an array by repeating the given value n times.")
+* [repeat-string](https://www.npmjs.com/package/repeat-string): Repeat the given string n times. Fastest implementation for repeating a string. | [homepage](https://github.com/jonschlinkert/repeat-string "Repeat the given string n times. Fastest implementation for repeating a string.")
+
+### Contributing
+
+Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new).
+
+### Building docs
+
+_(This document was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme) (a [verb](https://github.com/verbose/verb) generator), please don't edit the readme directly. Any changes to the readme must be made in [.verb.md](.verb.md).)_
+
+To generate the readme and API documentation with [verb](https://github.com/verbose/verb):
+
+```sh
+$ npm install -g verb verb-generate-readme && verb
+```
+
+### Running tests
+
+Install dev dependencies:
+
+```sh
+$ npm install -d && npm test
+```
+
+### Author
+
+**Jon Schlinkert**
+
+* [github/jonschlinkert](https://github.com/jonschlinkert)
+* [twitter/jonschlinkert](http://twitter.com/jonschlinkert)
+
+### License
+
+Copyright © 2016, [Jon Schlinkert](https://github.com/jonschlinkert).
+Released under the [MIT license](https://github.com/jonschlinkert/to-regex-range/blob/master/LICENSE).
+
+***
+
+_This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.1.30, on September 14, 2016._
\ No newline at end of file
diff --git a/bower.json b/bower.json
new file mode 100644
index 0000000..28ae064
--- /dev/null
+++ b/bower.json
@@ -0,0 +1,38 @@
+{
+  "name": "to-regex-range",
+  "description": "Returns a regex-compatible range from two numbers, min and max. Useful for creating regular expressions to validate numbers, ranges, years, etc.",
+  "repository": "jonschlinkert/to-regex-range",
+  "license": "MIT",
+  "homepage": "https://github.com/jonschlinkert/to-regex-range",
+  "authors": [
+    "Jon Schlinkert (https://github.com/jonschlinkert)"
+  ],
+  "main": [
+    "index.js"
+  ],
+  "dependencies": {
+    "is-number": "^2.0.2",
+    "repeat-string": "^1.5.2"
+  },
+  "devDependencies": {
+    "mocha": "*",
+    "should": "*"
+  },
+  "keywords": [
+    "alpha",
+    "alphabetical",
+    "bash",
+    "brace",
+    "expand",
+    "expansion",
+    "glob",
+    "match",
+    "matches",
+    "matching",
+    "number",
+    "numerical",
+    "range",
+    "ranges",
+    "sh"
+  ]
+}
diff --git a/example.js b/example.js
new file mode 100644
index 0000000..c927ace
--- /dev/null
+++ b/example.js
@@ -0,0 +1,17 @@
+var toRegexRange = require('./');
+
+console.log(toRegexRange('111', '555'));
+//=> '11[1-9]|1[2-9]\d|[2-4]\d{2}|5[0-4]\d|55[0-5]'
+console.log(toRegexRange('5', '5'));
+//=> '5'
+console.log(toRegexRange('5', '6'));
+//=> '[5-6]'
+console.log(toRegexRange('51', '229'));
+//=> '5[1-9]|[6-9]\d|1\d{2}|2[0-2]\d'
+console.log(toRegexRange('51', '29'));
+//=> '51|29'
+
+console.log(toRegexRange('1991', '2015'));
+var re = new RegExp(toRegexRange('1', '99'));
+console.log(re.test('50'));
+// => true
diff --git a/index.js b/index.js
new file mode 100644
index 0000000..d7487c6
--- /dev/null
+++ b/index.js
@@ -0,0 +1,222 @@
+/*!
+ * to-regex-range <https://github.com/jonschlinkert/to-regex-range>
+ *
+ * Copyright (c) 2015, Jon Schlinkert.
+ * Licensed under the MIT License.
+ */
+
+'use strict';
+
+var repeat = require('repeat-string');
+var isNumber = require('is-number');
+var cache = {range: {}, rangeToPattern: {}};
+
+function toRegexRange(min, max) {
+  if (isNumber(min) === false) {
+    throw new RangeError('toRegexRange: first argument is invalid.');
+  }
+
+  if (typeof max === 'undefined') {
+    return '' + min;
+  }
+
+  if (isNumber(max) === false) {
+    throw new RangeError('toRegexRange: second argument is invalid.');
+  }
+
+  var key = min + ':' + max;
+  if (cache.range.hasOwnProperty(key)) {
+    return cache.range[key];
+  }
+
+  var a = min;
+  var b = max;
+
+  if (min > 0 && max > 0) {
+    a = Math.min(min, max);
+    b = Math.max(min, max);
+  }
+
+  if (a === b) {
+    return a;
+  }
+
+  if (a > b) {
+    return a + '|' + b;
+  }
+
+  a = String(a);
+  b = String(b);
+  var positives = [];
+  var negatives = [];
+
+  if (a < 0) {
+    var newMin = 1;
+    if (b < 0) {
+      newMin = Math.abs(b);
+    }
+
+    var newMax = Math.abs(a);
+    negatives = splitToPatterns(newMin, newMax);
+    a = 0;
+  }
+  if (b >= 0) {
+    positives = splitToPatterns(a, b);
+  }
+
+  var res = siftPatterns(negatives, positives);
+  cache.range[key] = res;
+  return res;
+}
+
+function siftPatterns(negatives, positives) {
+  var onlyNegative = filterPatterns(negatives, positives, '-');
+  var onlyPositive = filterPatterns(positives, negatives, '');
+  var intersected = filterPatterns(negatives, positives, '-?', true);
+  var subpatterns = onlyNegative.concat(intersected || []).concat(onlyPositive || []);
+  return subpatterns.join('|');
+}
+
+function splitToRanges(min, max) {
+  min = +min;
+  max = +max;
+
+  var nines = 1;
+  var stops = [max];
+  var stop = +countNines(min, nines);
+
+  while (min <= stop && stop <= max) {
+    stops = add(stops, stop);
+    nines += 1;
+    stop = +countNines(min, nines);
+  }
+
+  var zeros = 1;
+  stop = countZeros(max + 1, zeros) - 1;
+
+  while (min < stop && stop <= max) {
+    stops = add(stops, stop);
+    zeros += 1;
+    stop = countZeros(max + 1, zeros) - 1;
+  }
+
+  stops.sort(compare);
+  return stops;
+}
+
+function rangeToPattern(start, stop) {
+  var key = start + ':' + stop;
+
+  if (cache.rangeToPattern.hasOwnProperty(key)) {
+    return cache.rangeToPattern[key];
+  }
+
+  var zipped = zip(String(start), String(stop));
+  var len = zipped.length, i = -1;
+
+  var pattern = '';
+  var digits = 0;
+
+  while (++i < len) {
+    var current = zipped[i];
+    var startDigit = current[0];
+    var stopDigit = current[1];
+
+    if (startDigit === stopDigit) {
+      pattern += startDigit;
+
+    } else if (startDigit !== '0' || stopDigit !== '9') {
+      pattern += toCharacterClass(startDigit, stopDigit);
+
+    } else {
+      digits += 1;
+    }
+  }
+
+  if (digits) {
+    pattern += '[0-9]';
+  }
+
+  if (digits > 1) {
+    pattern += limit(digits);
+  }
+
+  cache.rangeToPattern[key] = pattern;
+  return pattern;
+}
+
+/**
+ * Zip strings (`for in` can be used on string characters)
+ */
+
+function zip(a, b) {
+  var arr = [];
+  for (var ch in a) arr.push([a[ch], b[ch]]);
+  return arr;
+}
+
+function splitToPatterns(min, max) {
+  var ranges = splitToRanges(min, max);
+  var len = ranges.length;
+  var idx = -1;
+
+  var start = min;
+  var subpatterns = new Array(len);
+
+  while (++idx < len) {
+    var range = ranges[idx];
+    subpatterns[idx] = rangeToPattern(start, range);
+    start = range + 1;
+  }
+  return subpatterns;
+}
+
+function filterPatterns(arr, comparison, prefix, intersection) {
+  var len = arr.length, i = -1;
+  var intersected = [];
+  var res = [];
+
+  while (++i < len) {
+    var ele = arr[i];
+    if (!intersection && comparison.indexOf(ele) === -1) {
+      res.push(prefix + ele);
+    }
+    if (intersection && comparison.indexOf(ele) !== -1) {
+      intersected.push(prefix + ele);
+    }
+  }
+  return intersection ? intersected : res;
+}
+
+function countNines(num, len) {
+  return String(num).slice(0, -len) + repeat('9', len);
+}
+
+function countZeros(integer, zeros) {
+  return integer - (integer % Math.pow(10, zeros));
+}
+
+function limit(str) {
+  return '{' + str + '}';
+}
+
+function toCharacterClass(a, b) {
+  return '[' + a + '-' + b + ']';
+}
+
+function compare(a, b) {
+  return a - b;
+}
+
+function add(arr, ele) {
+  if (arr.indexOf(ele) === -1) {
+    arr.push(ele);
+  }
+  return arr;
+}
+
+/**
+ * Expose `toRegexRange`
+ */
+
+module.exports = toRegexRange;
diff --git a/package.json b/package.json
new file mode 100644
index 0000000..9c1bd1f
--- /dev/null
+++ b/package.json
@@ -0,0 +1,73 @@
+{
+  "name": "to-regex-range",
+  "description": "Returns a regex-compatible range from two numbers, min and max, with 855,412 generated unit tests to validate it's accuracy! Useful for creating regular expressions to validate numbers, ranges, years, etc. Returns a string, allowing the returned value to be used in regular expressions generated by other libraries.",
+  "version": "0.2.0",
+  "homepage": "https://github.com/jonschlinkert/to-regex-range",
+  "author": "Jon Schlinkert (https://github.com/jonschlinkert)",
+  "repository": "jonschlinkert/to-regex-range",
+  "bugs": {
+    "url": "https://github.com/jonschlinkert/to-regex-range/issues"
+  },
+  "license": "MIT",
+  "files": [
+    "index.js"
+  ],
+  "main": "index.js",
+  "engines": {
+    "node": ">=0.10.0"
+  },
+  "scripts": {
+    "test": "mocha"
+  },
+  "dependencies": {
+    "is-number": "^2.1.0",
+    "repeat-string": "^1.5.4"
+  },
+  "devDependencies": {
+    "gulp-format-md": "^0.1.9",
+    "mocha": "^2.4.5"
+  },
+  "keywords": [
+    "alpha",
+    "alphabetical",
+    "bash",
+    "brace",
+    "expand",
+    "expansion",
+    "glob",
+    "match",
+    "matches",
+    "matching",
+    "number",
+    "numerical",
+    "range",
+    "ranges",
+    "regex",
+    "sh"
+  ],
+  "verb": {
+    "related": {
+      "list": [
+        "expand-range",
+        "fill-range",
+        "micromatch",
+        "repeat-element",
+        "repeat-string"
+      ]
+    },
+    "toc": false,
+    "layout": "default",
+    "tasks": [
+      "readme"
+    ],
+    "plugins": [
+      "gulp-format-md"
+    ],
+    "lint": {
+      "reflinks": true
+    },
+    "reflinks": [
+      "verb"
+    ]
+  }
+}
diff --git a/test/support/index.js b/test/support/index.js
new file mode 100644
index 0000000..619e13d
--- /dev/null
+++ b/test/support/index.js
@@ -0,0 +1,14 @@
+
+var utils = module.exports;
+
+// TODO: publish as lib
+utils.toRange = function toRange(start, stop, step) {
+  step = step || 1;
+  var arr = new Array((stop - start) / step);
+  var num = 0;
+
+  for (var i = start; i <= stop; i += step) {
+    arr[num++] = i;
+  }
+  return arr;
+};
diff --git a/test/test.js b/test/test.js
new file mode 100644
index 0000000..b7dcdff
--- /dev/null
+++ b/test/test.js
@@ -0,0 +1,174 @@
+'use strict';
+
+require('mocha');
+var assert = require('assert');
+var utils = require('./support');
+var toRange = require('..');
+var count = 0;
+
+function toRegex(min, max) {
+  return new RegExp('^(' + toRange(min, max) + ')$');
+}
+
+function match(min, max) {
+  var regex = toRegex(min, max);
+  return function(num) {
+    return regex.test(String(num));
+  };
+}
+
+function verifyRange(min, max, from, to) {
+  var isMatch = match(min, max);
+  var range = utils.toRange(from, to);
+  var len = range.length, i = -1;
+
+  while (++i < len) {
+    var num = range[i];
+    if (min <= num && num <= max) {
+      assert(isMatch(num));
+    } else {
+      assert(!isMatch(num));
+    }
+    count++;
+  }
+}
+
+describe('range', function() {
+  it('should throw an error when the first arg is invalid:', function() {
+    assert.throws(function() {
+      toRange();
+    }, /toRegexRange: first argument is invalid/);
+  });
+
+  it('should throw an error when the second arg is invalid:', function() {
+    assert.throws(function() {
+      toRange(1, {});
+    }, /toRegexRange: second argument is invalid/);
+  });
+});
+
+describe('minimum / maximum', function() {
+  it('should reverse `min/max` when the min is larger than the max:', function() {
+    assert.equal(toRange(55, 10), '1[0-9]|[2-4][0-9]|5[0-5]');
+  });
+});
+
+describe('ranges', function() {
+  it('should return the number when only one argument is passed:', function() {
+    assert.equal(toRange(5), '5');
+  });
+
+  it('should not return a range when both numbers are the same:', function() {
+    assert.equal(toRange(5, 5), '5');
+  });
+
+  it('should support ranges than 10:', function() {
+    assert.equal(toRange(1, 5), '[1-5]');
+  });
+
+  it('should support strings:', function() {
+    assert.equal(toRange('1', '5'), '[1-5]');
+    assert.equal(toRange('10', '50'), '1[0-9]|[2-4][0-9]|50');
+  });
+
+  it('should generate regular expressions from the given pattern', function() {
+    assert.equal(toRange(1, 1), '1');
+    assert.equal(toRange(0, 1), '[0-1]');
+    assert.equal(toRange(-1, -1), '-1');
+    assert.equal(toRange(-1, -10), '-1|-10');
+    assert.equal(toRange(-1, 0), '-1|0');
+    assert.equal(toRange(-1, 1), '-1|[0-1]');
+    assert.equal(toRange(-4, -2), '-[2-4]');
+    assert.equal(toRange(-3, 1), '-[1-3]|[0-1]');
+    assert.equal(toRange(-2, 0), '-[1-2]|0');
+    assert.equal(toRange(0, 2), '[0-2]');
+    assert.equal(toRange(-1, 3), '-1|[0-3]');
+    assert.equal(toRange(65666, 65667), '6566[6-7]');
+    assert.equal(toRange(12, 3456), '1[2-9]|[2-9][0-9]|[1-9][0-9]{2}|[1-2][0-9]{3}|3[0-3][0-9]{2}|34[0-4][0-9]|345[0-6]');
+    assert.equal(toRange(1, 3456), '[1-9]|[1-9][0-9]|[1-9][0-9]{2}|[1-2][0-9]{3}|3[0-3][0-9]{2}|34[0-4][0-9]|345[0-6]');
+    assert.equal(toRange(1, 10), '[1-9]|10');
+    assert.equal(toRange(1, 19), '[1-9]|1[0-9]');
+    assert.equal(toRange(1, 99), '[1-9]|[1-9][0-9]');
+  });
+
+  it('should optimize regexes', function() {
+    assert.equal(toRange(-9, 9), '-[1-9]|[0-9]');
+    assert.equal(toRange(-19, 19), '-[1-9]|-?1[0-9]|[0-9]');
+    assert.equal(toRange(-29, 29), '-[1-9]|-?[1-2][0-9]|[0-9]');
+    assert.equal(toRange(-99, 99), '-[1-9]|-?[1-9][0-9]|[0-9]');
+    assert.equal(toRange(-999, 999), '-[1-9]|-?[1-9][0-9]|-?[1-9][0-9]{2}|[0-9]');
+    assert.equal(toRange(-9999, 9999), '-[1-9]|-?[1-9][0-9]|-?[1-9][0-9]{2}|-?[1-9][0-9]{3}|[0-9]');
+  });
+});
+
+describe('validate ranges', function() {
+  after(function() {
+    var num = (+(+(count).toFixed(2))).toLocaleString();
+    console.log();
+    console.log('   ', num, 'patterns tested');
+  });
+
+  it('should support equal numbers:', function() {
+    verifyRange(1, 1, 0, 100);
+    verifyRange(65443, 65443, 65000, 66000);
+    verifyRange(192, 1000, 0, 1000);
+  });
+
+  it('should support large numbers:', function() {
+    verifyRange(100019999300000, 100020000300000, 100019999999999, 100020000100000);
+  });
+
+  it('should support repeated digits:', function() {
+    verifyRange(10331, 20381, 0, 99999);
+  });
+
+  it('should support repeated zeros:', function() {
+    verifyRange(10031, 20081, 0, 59999);
+    verifyRange(10000, 20000, 0, 59999);
+  });
+
+  it('should support zero one:', function() {
+    verifyRange(10301, 20101, 0, 99999);
+  });
+
+  it('should support repetead ones:', function() {
+    verifyRange(102, 111, 0, 1000);
+  });
+
+  it('should support small diffs:', function() {
+    verifyRange(102, 110, 0, 1000);
+    verifyRange(102, 130, 0, 1000);
+  });
+
+  it('should support random ranges:', function() {
+    verifyRange(4173, 7981, 0, 99999);
+  });
+
+  it('should support one digit numbers:', function() {
+    verifyRange(3, 7, 0, 99);
+  });
+
+  it('should support one digit at bounds:', function() {
+    verifyRange(1, 9, 0, 1000);
+  });
+
+  it('should support power of ten:', function() {
+    verifyRange(1000, 8632, 0, 99999);
+  });
+
+  it('should work with numbers of varying lengths:', function() {
+    verifyRange(1030, 20101, 0, 99999);
+    verifyRange(13, 8632, 0, 10000);
+  });
+
+  it('should support small ranges:', function() {
+    verifyRange(9, 11, 0, 100);
+    verifyRange(19, 21, 0, 100);
+  });
+
+  it('should support big ranges:', function() {
+    verifyRange(90, 98009, 0, 98999);
+    verifyRange(999, 10000, 1, 20000);
+  });
+});
+

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-javascript/node-to-regex-range.git



More information about the Pkg-javascript-commits mailing list