| Index: tools/vulcanize/node_modules/vulcanize/node_modules/nopt/node_modules/abbrev/lib/abbrev.js
|
| diff --git a/tools/vulcanize/node_modules/vulcanize/node_modules/nopt/node_modules/abbrev/lib/abbrev.js b/tools/vulcanize/node_modules/vulcanize/node_modules/nopt/node_modules/abbrev/lib/abbrev.js
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..bee4132c92bcfcc02b099dc959837dc22f4fd2ec
|
| --- /dev/null
|
| +++ b/tools/vulcanize/node_modules/vulcanize/node_modules/nopt/node_modules/abbrev/lib/abbrev.js
|
| @@ -0,0 +1,111 @@
|
| +
|
| +module.exports = exports = abbrev.abbrev = abbrev
|
| +
|
| +abbrev.monkeyPatch = monkeyPatch
|
| +
|
| +function monkeyPatch () {
|
| + Object.defineProperty(Array.prototype, 'abbrev', {
|
| + value: function () { return abbrev(this) },
|
| + enumerable: false, configurable: true, writable: true
|
| + })
|
| +
|
| + Object.defineProperty(Object.prototype, 'abbrev', {
|
| + value: function () { return abbrev(Object.keys(this)) },
|
| + enumerable: false, configurable: true, writable: true
|
| + })
|
| +}
|
| +
|
| +function abbrev (list) {
|
| + if (arguments.length !== 1 || !Array.isArray(list)) {
|
| + list = Array.prototype.slice.call(arguments, 0)
|
| + }
|
| + for (var i = 0, l = list.length, args = [] ; i < l ; i ++) {
|
| + args[i] = typeof list[i] === "string" ? list[i] : String(list[i])
|
| + }
|
| +
|
| + // sort them lexicographically, so that they're next to their nearest kin
|
| + args = args.sort(lexSort)
|
| +
|
| + // walk through each, seeing how much it has in common with the next and previous
|
| + var abbrevs = {}
|
| + , prev = ""
|
| + for (var i = 0, l = args.length ; i < l ; i ++) {
|
| + var current = args[i]
|
| + , next = args[i + 1] || ""
|
| + , nextMatches = true
|
| + , prevMatches = true
|
| + if (current === next) continue
|
| + for (var j = 0, cl = current.length ; j < cl ; j ++) {
|
| + var curChar = current.charAt(j)
|
| + nextMatches = nextMatches && curChar === next.charAt(j)
|
| + prevMatches = prevMatches && curChar === prev.charAt(j)
|
| + if (!nextMatches && !prevMatches) {
|
| + j ++
|
| + break
|
| + }
|
| + }
|
| + prev = current
|
| + if (j === cl) {
|
| + abbrevs[current] = current
|
| + continue
|
| + }
|
| + for (var a = current.substr(0, j) ; j <= cl ; j ++) {
|
| + abbrevs[a] = current
|
| + a += current.charAt(j)
|
| + }
|
| + }
|
| + return abbrevs
|
| +}
|
| +
|
| +function lexSort (a, b) {
|
| + return a === b ? 0 : a > b ? 1 : -1
|
| +}
|
| +
|
| +
|
| +// tests
|
| +if (module === require.main) {
|
| +
|
| +var assert = require("assert")
|
| +var util = require("util")
|
| +
|
| +console.log("running tests")
|
| +function test (list, expect) {
|
| + var actual = abbrev(list)
|
| + assert.deepEqual(actual, expect,
|
| + "abbrev("+util.inspect(list)+") === " + util.inspect(expect) + "\n"+
|
| + "actual: "+util.inspect(actual))
|
| + actual = abbrev.apply(exports, list)
|
| + assert.deepEqual(abbrev.apply(exports, list), expect,
|
| + "abbrev("+list.map(JSON.stringify).join(",")+") === " + util.inspect(expect) + "\n"+
|
| + "actual: "+util.inspect(actual))
|
| +}
|
| +
|
| +test([ "ruby", "ruby", "rules", "rules", "rules" ],
|
| +{ rub: 'ruby'
|
| +, ruby: 'ruby'
|
| +, rul: 'rules'
|
| +, rule: 'rules'
|
| +, rules: 'rules'
|
| +})
|
| +test(["fool", "foom", "pool", "pope"],
|
| +{ fool: 'fool'
|
| +, foom: 'foom'
|
| +, poo: 'pool'
|
| +, pool: 'pool'
|
| +, pop: 'pope'
|
| +, pope: 'pope'
|
| +})
|
| +test(["a", "ab", "abc", "abcd", "abcde", "acde"],
|
| +{ a: 'a'
|
| +, ab: 'ab'
|
| +, abc: 'abc'
|
| +, abcd: 'abcd'
|
| +, abcde: 'abcde'
|
| +, ac: 'acde'
|
| +, acd: 'acde'
|
| +, acde: 'acde'
|
| +})
|
| +
|
| +console.log("pass")
|
| +
|
| +}
|
|
|