2011-11-22 01:48:45 +08:00
|
|
|
/*
|
|
|
|
for each pkg in prefix that isn't a git repo
|
|
|
|
look for a new version of pkg that satisfies dep
|
|
|
|
if so, install it.
|
|
|
|
if not, then update it
|
|
|
|
*/
|
|
|
|
|
|
|
|
module.exports = update
|
|
|
|
|
|
|
|
update.usage = "npm update [pkg]"
|
|
|
|
|
|
|
|
var npm = require("./npm.js")
|
|
|
|
, lifecycle = require("./utils/lifecycle.js")
|
|
|
|
, asyncMap = require("slide").asyncMap
|
2012-06-11 12:29:47 +08:00
|
|
|
, log = require("npmlog")
|
2011-11-22 01:48:45 +08:00
|
|
|
|
|
|
|
// load these, just so that we know that they'll be available, in case
|
|
|
|
// npm itself is getting overwritten.
|
|
|
|
, install = require("./install.js")
|
|
|
|
, build = require("./build.js")
|
|
|
|
|
|
|
|
update.completion = npm.commands.outdated.completion
|
|
|
|
|
|
|
|
function update (args, cb) {
|
|
|
|
npm.commands.outdated(args, true, function (er, outdated) {
|
2012-06-11 12:29:47 +08:00
|
|
|
log.info("outdated", "updating", outdated)
|
2011-11-22 01:48:45 +08:00
|
|
|
if (er) return cb(er)
|
|
|
|
|
|
|
|
asyncMap(outdated, function (ww, cb) {
|
2013-06-19 00:42:42 +08:00
|
|
|
// [[ dir, dep, has, want, req ]]
|
2011-11-22 01:48:45 +08:00
|
|
|
var where = ww[0]
|
|
|
|
, dep = ww[1]
|
|
|
|
, want = ww[3]
|
|
|
|
, what = dep + "@" + want
|
2013-06-19 00:42:42 +08:00
|
|
|
, req = ww[4]
|
|
|
|
, url = require('url')
|
2011-11-22 01:48:45 +08:00
|
|
|
|
2013-06-19 00:42:42 +08:00
|
|
|
// use the initial installation method (repo, tar, git) for updating
|
|
|
|
if (url.parse(req).protocol) what = req
|
2011-11-22 01:48:45 +08:00
|
|
|
npm.commands.install(where, what, cb)
|
|
|
|
}, cb)
|
|
|
|
})
|
|
|
|
}
|