Created
August 4, 2017 20:25
-
-
Save watilde/f27dbc97eea1ccb64339aef146a69ee1 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){ | |
},{}],2:[function(require,module,exports){ | |
// shim for using process in browser | |
var process = module.exports = {}; | |
// cached from whatever global is present so that test runners that stub it | |
// don't break things. But we need to wrap it in a try catch in case it is | |
// wrapped in strict mode code which doesn't define any globals. It's inside a | |
// function because try/catches deoptimize in certain engines. | |
var cachedSetTimeout; | |
var cachedClearTimeout; | |
function defaultSetTimout() { | |
throw new Error('setTimeout has not been defined'); | |
} | |
function defaultClearTimeout () { | |
throw new Error('clearTimeout has not been defined'); | |
} | |
(function () { | |
try { | |
if (typeof setTimeout === 'function') { | |
cachedSetTimeout = setTimeout; | |
} else { | |
cachedSetTimeout = defaultSetTimout; | |
} | |
} catch (e) { | |
cachedSetTimeout = defaultSetTimout; | |
} | |
try { | |
if (typeof clearTimeout === 'function') { | |
cachedClearTimeout = clearTimeout; | |
} else { | |
cachedClearTimeout = defaultClearTimeout; | |
} | |
} catch (e) { | |
cachedClearTimeout = defaultClearTimeout; | |
} | |
} ()) | |
function runTimeout(fun) { | |
if (cachedSetTimeout === setTimeout) { | |
//normal enviroments in sane situations | |
return setTimeout(fun, 0); | |
} | |
// if setTimeout wasn't available but was latter defined | |
if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) { | |
cachedSetTimeout = setTimeout; | |
return setTimeout(fun, 0); | |
} | |
try { | |
// when when somebody has screwed with setTimeout but no I.E. maddness | |
return cachedSetTimeout(fun, 0); | |
} catch(e){ | |
try { | |
// When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally | |
return cachedSetTimeout.call(null, fun, 0); | |
} catch(e){ | |
// same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error | |
return cachedSetTimeout.call(this, fun, 0); | |
} | |
} | |
} | |
function runClearTimeout(marker) { | |
if (cachedClearTimeout === clearTimeout) { | |
//normal enviroments in sane situations | |
return clearTimeout(marker); | |
} | |
// if clearTimeout wasn't available but was latter defined | |
if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) { | |
cachedClearTimeout = clearTimeout; | |
return clearTimeout(marker); | |
} | |
try { | |
// when when somebody has screwed with setTimeout but no I.E. maddness | |
return cachedClearTimeout(marker); | |
} catch (e){ | |
try { | |
// When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally | |
return cachedClearTimeout.call(null, marker); | |
} catch (e){ | |
// same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error. | |
// Some versions of I.E. have different rules for clearTimeout vs setTimeout | |
return cachedClearTimeout.call(this, marker); | |
} | |
} | |
} | |
var queue = []; | |
var draining = false; | |
var currentQueue; | |
var queueIndex = -1; | |
function cleanUpNextTick() { | |
if (!draining || !currentQueue) { | |
return; | |
} | |
draining = false; | |
if (currentQueue.length) { | |
queue = currentQueue.concat(queue); | |
} else { | |
queueIndex = -1; | |
} | |
if (queue.length) { | |
drainQueue(); | |
} | |
} | |
function drainQueue() { | |
if (draining) { | |
return; | |
} | |
var timeout = runTimeout(cleanUpNextTick); | |
draining = true; | |
var len = queue.length; | |
while(len) { | |
currentQueue = queue; | |
queue = []; | |
while (++queueIndex < len) { | |
if (currentQueue) { | |
currentQueue[queueIndex].run(); | |
} | |
} | |
queueIndex = -1; | |
len = queue.length; | |
} | |
currentQueue = null; | |
draining = false; | |
runClearTimeout(timeout); | |
} | |
process.nextTick = function (fun) { | |
var args = new Array(arguments.length - 1); | |
if (arguments.length > 1) { | |
for (var i = 1; i < arguments.length; i++) { | |
args[i - 1] = arguments[i]; | |
} | |
} | |
queue.push(new Item(fun, args)); | |
if (queue.length === 1 && !draining) { | |
runTimeout(drainQueue); | |
} | |
}; | |
// v8 likes predictible objects | |
function Item(fun, array) { | |
this.fun = fun; | |
this.array = array; | |
} | |
Item.prototype.run = function () { | |
this.fun.apply(null, this.array); | |
}; | |
process.title = 'browser'; | |
process.browser = true; | |
process.env = {}; | |
process.argv = []; | |
process.version = ''; // empty string to avoid regexp issues | |
process.versions = {}; | |
function noop() {} | |
process.on = noop; | |
process.addListener = noop; | |
process.once = noop; | |
process.off = noop; | |
process.removeListener = noop; | |
process.removeAllListeners = noop; | |
process.emit = noop; | |
process.prependListener = noop; | |
process.prependOnceListener = noop; | |
process.listeners = function (name) { return [] } | |
process.binding = function (name) { | |
throw new Error('process.binding is not supported'); | |
}; | |
process.cwd = function () { return '/' }; | |
process.chdir = function (dir) { | |
throw new Error('process.chdir is not supported'); | |
}; | |
process.umask = function() { return 0; }; | |
},{}],3:[function(require,module,exports){ | |
(function (process,global){ | |
var fs = require('fs') | |
var core | |
if (process.platform === 'win32' || global.TESTING_WINDOWS) { | |
core = require('./windows.js') | |
} else { | |
core = require('./mode.js') | |
} | |
module.exports = isexe | |
isexe.sync = sync | |
function isexe (path, options, cb) { | |
if (typeof options === 'function') { | |
cb = options | |
options = {} | |
} | |
if (!cb) { | |
if (typeof Promise !== 'function') { | |
throw new TypeError('callback not provided') | |
} | |
return new Promise(function (resolve, reject) { | |
isexe(path, options || {}, function (er, is) { | |
if (er) { | |
reject(er) | |
} else { | |
resolve(is) | |
} | |
}) | |
}) | |
} | |
core(path, options || {}, function (er, is) { | |
// ignore EACCES because that just means we aren't allowed to run it | |
if (er) { | |
if (er.code === 'EACCES' || options && options.ignoreErrors) { | |
er = null | |
is = false | |
} | |
} | |
cb(er, is) | |
}) | |
} | |
function sync (path, options) { | |
// my kingdom for a filtered catch | |
try { | |
return core.sync(path, options || {}) | |
} catch (er) { | |
if (options && options.ignoreErrors || er.code === 'EACCES') { | |
return false | |
} else { | |
throw er | |
} | |
} | |
} | |
}).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) | |
},{"./mode.js":4,"./windows.js":5,"_process":2,"fs":1}],4:[function(require,module,exports){ | |
(function (process){ | |
module.exports = isexe | |
isexe.sync = sync | |
var fs = require('fs') | |
function isexe (path, options, cb) { | |
fs.stat(path, function (er, stat) { | |
cb(er, er ? false : checkStat(stat, options)) | |
}) | |
} | |
function sync (path, options) { | |
return checkStat(fs.statSync(path), options) | |
} | |
function checkStat (stat, options) { | |
return stat.isFile() && checkMode(stat, options) | |
} | |
function checkMode (stat, options) { | |
var mod = stat.mode | |
var uid = stat.uid | |
var gid = stat.gid | |
var myUid = options.uid !== undefined ? | |
options.uid : process.getuid && process.getuid() | |
var myGid = options.gid !== undefined ? | |
options.gid : process.getgid && process.getgid() | |
var u = parseInt('100', 8) | |
var g = parseInt('010', 8) | |
var o = parseInt('001', 8) | |
var ug = u | g | |
var ret = (mod & o) || | |
(mod & g) && gid === myGid || | |
(mod & u) && uid === myUid || | |
(mod & ug) && myUid === 0 | |
return ret | |
} | |
}).call(this,require('_process')) | |
},{"_process":2,"fs":1}],5:[function(require,module,exports){ | |
(function (process){ | |
module.exports = isexe | |
isexe.sync = sync | |
var fs = require('fs') | |
function checkPathExt (path, options) { | |
var pathext = options.pathExt !== undefined ? | |
options.pathExt : process.env.PATHEXT | |
if (!pathext) { | |
return true | |
} | |
pathext = pathext.split(';') | |
if (pathext.indexOf('') !== -1) { | |
return true | |
} | |
for (var i = 0; i < pathext.length; i++) { | |
var p = pathext[i].toLowerCase() | |
if (p && path.substr(-p.length).toLowerCase() === p) { | |
return true | |
} | |
} | |
return false | |
} | |
function checkStat (stat, path, options) { | |
if (!stat.isSymbolicLink() && !stat.isFile()) { | |
return false | |
} | |
return checkPathExt(path, options) | |
} | |
function isexe (path, options, cb) { | |
fs.stat(path, function (er, stat) { | |
cb(er, er ? false : checkStat(stat, path, options)) | |
}) | |
} | |
function sync (path, options) { | |
return checkStat(fs.statSync(path), path, options) | |
} | |
}).call(this,require('_process')) | |
},{"_process":2,"fs":1}],6:[function(require,module,exports){ | |
(function (process){ | |
// Copyright Joyent, Inc. and other Node contributors. | |
// | |
// 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. | |
// resolves . and .. elements in a path array with directory names there | |
// must be no slashes, empty elements, or device names (c:\) in the array | |
// (so also no leading and trailing slashes - it does not distinguish | |
// relative and absolute paths) | |
function normalizeArray(parts, allowAboveRoot) { | |
// if the path tries to go above the root, `up` ends up > 0 | |
var up = 0; | |
for (var i = parts.length - 1; i >= 0; i--) { | |
var last = parts[i]; | |
if (last === '.') { | |
parts.splice(i, 1); | |
} else if (last === '..') { | |
parts.splice(i, 1); | |
up++; | |
} else if (up) { | |
parts.splice(i, 1); | |
up--; | |
} | |
} | |
// if the path is allowed to go above the root, restore leading ..s | |
if (allowAboveRoot) { | |
for (; up--; up) { | |
parts.unshift('..'); | |
} | |
} | |
return parts; | |
} | |
// Split a filename into [root, dir, basename, ext], unix version | |
// 'root' is just a slash, or nothing. | |
var splitPathRe = | |
/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/; | |
var splitPath = function(filename) { | |
return splitPathRe.exec(filename).slice(1); | |
}; | |
// path.resolve([from ...], to) | |
// posix version | |
exports.resolve = function() { | |
var resolvedPath = '', | |
resolvedAbsolute = false; | |
for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) { | |
var path = (i >= 0) ? arguments[i] : process.cwd(); | |
// Skip empty and invalid entries | |
if (typeof path !== 'string') { | |
throw new TypeError('Arguments to path.resolve must be strings'); | |
} else if (!path) { | |
continue; | |
} | |
resolvedPath = path + '/' + resolvedPath; | |
resolvedAbsolute = path.charAt(0) === '/'; | |
} | |
// At this point the path should be resolved to a full absolute path, but | |
// handle relative paths to be safe (might happen when process.cwd() fails) | |
// Normalize the path | |
resolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) { | |
return !!p; | |
}), !resolvedAbsolute).join('/'); | |
return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.'; | |
}; | |
// path.normalize(path) | |
// posix version | |
exports.normalize = function(path) { | |
var isAbsolute = exports.isAbsolute(path), | |
trailingSlash = substr(path, -1) === '/'; | |
// Normalize the path | |
path = normalizeArray(filter(path.split('/'), function(p) { | |
return !!p; | |
}), !isAbsolute).join('/'); | |
if (!path && !isAbsolute) { | |
path = '.'; | |
} | |
if (path && trailingSlash) { | |
path += '/'; | |
} | |
return (isAbsolute ? '/' : '') + path; | |
}; | |
// posix version | |
exports.isAbsolute = function(path) { | |
return path.charAt(0) === '/'; | |
}; | |
// posix version | |
exports.join = function() { | |
var paths = Array.prototype.slice.call(arguments, 0); | |
return exports.normalize(filter(paths, function(p, index) { | |
if (typeof p !== 'string') { | |
throw new TypeError('Arguments to path.join must be strings'); | |
} | |
return p; | |
}).join('/')); | |
}; | |
// path.relative(from, to) | |
// posix version | |
exports.relative = function(from, to) { | |
from = exports.resolve(from).substr(1); | |
to = exports.resolve(to).substr(1); | |
function trim(arr) { | |
var start = 0; | |
for (; start < arr.length; start++) { | |
if (arr[start] !== '') break; | |
} | |
var end = arr.length - 1; | |
for (; end >= 0; end--) { | |
if (arr[end] !== '') break; | |
} | |
if (start > end) return []; | |
return arr.slice(start, end - start + 1); | |
} | |
var fromParts = trim(from.split('/')); | |
var toParts = trim(to.split('/')); | |
var length = Math.min(fromParts.length, toParts.length); | |
var samePartsLength = length; | |
for (var i = 0; i < length; i++) { | |
if (fromParts[i] !== toParts[i]) { | |
samePartsLength = i; | |
break; | |
} | |
} | |
var outputParts = []; | |
for (var i = samePartsLength; i < fromParts.length; i++) { | |
outputParts.push('..'); | |
} | |
outputParts = outputParts.concat(toParts.slice(samePartsLength)); | |
return outputParts.join('/'); | |
}; | |
exports.sep = '/'; | |
exports.delimiter = ':'; | |
exports.dirname = function(path) { | |
var result = splitPath(path), | |
root = result[0], | |
dir = result[1]; | |
if (!root && !dir) { | |
// No dirname whatsoever | |
return '.'; | |
} | |
if (dir) { | |
// It has a dirname, strip trailing slash | |
dir = dir.substr(0, dir.length - 1); | |
} | |
return root + dir; | |
}; | |
exports.basename = function(path, ext) { | |
var f = splitPath(path)[2]; | |
// TODO: make this comparison case-insensitive on windows? | |
if (ext && f.substr(-1 * ext.length) === ext) { | |
f = f.substr(0, f.length - ext.length); | |
} | |
return f; | |
}; | |
exports.extname = function(path) { | |
return splitPath(path)[3]; | |
}; | |
function filter (xs, f) { | |
if (xs.filter) return xs.filter(f); | |
var res = []; | |
for (var i = 0; i < xs.length; i++) { | |
if (f(xs[i], i, xs)) res.push(xs[i]); | |
} | |
return res; | |
} | |
// String.prototype.substr - negative index don't work in IE8 | |
var substr = 'ab'.substr(-1) === 'b' | |
? function (str, start, len) { return str.substr(start, len) } | |
: function (str, start, len) { | |
if (start < 0) start = str.length + start; | |
return str.substr(start, len); | |
} | |
; | |
}).call(this,require('_process')) | |
},{"_process":2}],7:[function(require,module,exports){ | |
(function (process){ | |
module.exports = which | |
which.sync = whichSync | |
var isWindows = process.platform === 'win32' || | |
process.env.OSTYPE === 'cygwin' || | |
process.env.OSTYPE === 'msys' | |
var path = require('path') | |
var COLON = isWindows ? ';' : ':' | |
var isexe = require('isexe') | |
function getNotFoundError (cmd) { | |
var er = new Error('not found: ' + cmd) | |
er.code = 'ENOENT' | |
return er | |
} | |
function getPathInfo (cmd, opt) { | |
var colon = opt.colon || COLON | |
var pathEnv = opt.path || process.env.PATH || '' | |
var pathExt = [''] | |
pathEnv = pathEnv.split(colon) | |
var pathExtExe = '' | |
if (isWindows) { | |
pathEnv.unshift(process.cwd()) | |
pathExtExe = (opt.pathExt || process.env.PATHEXT || '.EXE;.CMD;.BAT;.COM') | |
pathExt = pathExtExe.split(colon) | |
// Always test the cmd itself first. isexe will check to make sure | |
// it's found in the pathExt set. | |
if (cmd.indexOf('.') !== -1 && pathExt[0] !== '') | |
pathExt.unshift('') | |
} | |
// If it has a slash, then we don't bother searching the pathenv. | |
// just check the file itself, and that's it. | |
if (cmd.match(/\//) || isWindows && cmd.match(/\\/)) | |
pathEnv = [''] | |
return { | |
env: pathEnv, | |
ext: pathExt, | |
extExe: pathExtExe | |
} | |
} | |
function which (cmd, opt, cb) { | |
if (typeof opt === 'function') { | |
cb = opt | |
opt = {} | |
} | |
var info = getPathInfo(cmd, opt) | |
var pathEnv = info.env | |
var pathExt = info.ext | |
var pathExtExe = info.extExe | |
var found = [] | |
;(function F (i, l) { | |
if (i === l) { | |
if (opt.all && found.length) | |
return cb(null, found) | |
else | |
return cb(getNotFoundError(cmd)) | |
} | |
var pathPart = pathEnv[i] | |
if (pathPart.charAt(0) === '"' && pathPart.slice(-1) === '"') | |
pathPart = pathPart.slice(1, -1) | |
var p = path.join(pathPart, cmd) | |
if (!pathPart && (/^\.[\\\/]/).test(cmd)) { | |
p = cmd.slice(0, 2) + p | |
} | |
;(function E (ii, ll) { | |
if (ii === ll) return F(i + 1, l) | |
var ext = pathExt[ii] | |
isexe(p + ext, { pathExt: pathExtExe }, function (er, is) { | |
if (!er && is) { | |
if (opt.all) | |
found.push(p + ext) | |
else | |
return cb(null, p + ext) | |
} | |
return E(ii + 1, ll) | |
}) | |
})(0, pathExt.length) | |
})(0, pathEnv.length) | |
} | |
function whichSync (cmd, opt) { | |
opt = opt || {} | |
var info = getPathInfo(cmd, opt) | |
var pathEnv = info.env | |
var pathExt = info.ext | |
var pathExtExe = info.extExe | |
var found = [] | |
for (var i = 0, l = pathEnv.length; i < l; i ++) { | |
var pathPart = pathEnv[i] | |
if (pathPart.charAt(0) === '"' && pathPart.slice(-1) === '"') | |
pathPart = pathPart.slice(1, -1) | |
var p = path.join(pathPart, cmd) | |
if (!pathPart && /^\.[\\\/]/.test(cmd)) { | |
p = cmd.slice(0, 2) + p | |
} | |
for (var j = 0, ll = pathExt.length; j < ll; j ++) { | |
var cur = p + pathExt[j] | |
var is | |
try { | |
is = isexe.sync(cur, { pathExt: pathExtExe }) | |
if (is) { | |
if (opt.all) | |
found.push(cur) | |
else | |
return cur | |
} | |
} catch (ex) {} | |
} | |
} | |
if (opt.all && found.length) | |
return found | |
if (opt.nothrow) | |
return null | |
throw getNotFoundError(cmd) | |
} | |
}).call(this,require('_process')) | |
},{"_process":2,"isexe":3,"path":6}],8:[function(require,module,exports){ | |
module.exports={ | |
"name": "dep", | |
"version": "0.10.2", | |
"description": "A little Node.js dependency installer", | |
"main": "index.js", | |
"scripts": { | |
"release": "standard-version", | |
"pretest": "standard \"lib/**/*.js\" \"bin/*.js\" \"test/*js\" \"scripts/*.js\"", | |
"test": "tap \"test/*.js\"", | |
"test-ci": "nyc tap 'test/*.js'", | |
"posttest-ci": "npm run coverage", | |
"precoverage": "nyc report --reporter=text-lcov > coverage.lcov", | |
"coverage": "cat coverage.lcov | coveralls", | |
"postcoverage": "rm coverage.lcov", | |
"build": "browserify scripts/install.js > scripts/install", | |
"postbuild": "browserify scripts/uninstall.js > scripts/uninstall" | |
}, | |
"repository": { | |
"type": "git", | |
"url": "git+https://github.com/watilde/dep.git" | |
}, | |
"bin": { | |
"dep": "./bin/dep.js" | |
}, | |
"keywords": [ | |
"npm" | |
], | |
"author": "Daijiro Wachi", | |
"license": "MIT", | |
"bugs": { | |
"url": "https://github.com/watilde/dep/issues" | |
}, | |
"homepage": "https://github.com/watilde/dep#readme", | |
"dependencies": { | |
"dat-node": "^3.5.1", | |
"fs-extra": "^4.0.1", | |
"gunzip-maybe": "^1.4.1", | |
"is-root": "^1.0.0", | |
"mkdirp": "^0.5.1", | |
"node-gyp": "^3.6.2", | |
"npm-package-arg": "^5.1.2", | |
"npm-path": "^2.0.3", | |
"promise-each": "^2.2.0", | |
"request": "^2.81.0", | |
"require-directory": "^2.1.1", | |
"rimraf": "^2.6.1", | |
"semver": "^5.4.1", | |
"tar-fs": "^1.15.3", | |
"tar-stream": "^1.5.4", | |
"update-notifier": "^2.2.0", | |
"which": "^1.3.0", | |
"yargs": "^8.0.2" | |
}, | |
"devDependencies": { | |
"coveralls": "^2.13.1", | |
"nyc": "^11.0.3", | |
"standard": "^10.0.2", | |
"standard-version": "^4.2.0", | |
"strong-npm-ls": "^1.0.10", | |
"tap": "^10.7.0" | |
}, | |
"engine": { | |
"node": ">=4.0.0" | |
} | |
} | |
},{}],9:[function(require,module,exports){ | |
(function (process){ | |
const execFile = require('child_process').execFile | |
const path = require('path') | |
const fs = require('fs') | |
const which = require('which') | |
const execPath = process.execPath | |
const binPath = path.dirname(execPath) | |
const nodeModules = path.join(execPath, '../../lib/node_modules/dep') | |
const pkgJSON = require('../package.json') | |
const repository = pkgJSON.repository.url.replace('git+', '') | |
const bin = path.join(nodeModules, pkgJSON.bin.dep) | |
which('git', (e, git) => { | |
if (e) throw new Error(e) | |
process.stdout.write( | |
'exec: ' + git + [' clone', repository, nodeModules].join(' ') + '\n' | |
) | |
execFile(git, ['clone', repository, nodeModules], (e) => { | |
if (e) throw new Error(e) | |
process.stdout.write('link: ' + bin + '\n') | |
process.stdout.write(' => ' + path.join(binPath, 'dep') + '\n') | |
fs.link(bin, path.join(binPath, 'dep'), (e) => { | |
if (e) throw new Error(e) | |
process.stdout.write('dep was installed successfully\n') | |
}) | |
}) | |
}) | |
}).call(this,require('_process')) | |
},{"../package.json":8,"_process":2,"child_process":1,"fs":1,"path":6,"which":7}]},{},[9]); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment