summaryrefslogtreecommitdiff
path: root/deps/npm/node_modules/node-gyp/lib/build.js
diff options
context:
space:
mode:
Diffstat (limited to 'deps/npm/node_modules/node-gyp/lib/build.js')
-rw-r--r--deps/npm/node_modules/node-gyp/lib/build.js161
1 files changed, 46 insertions, 115 deletions
diff --git a/deps/npm/node_modules/node-gyp/lib/build.js b/deps/npm/node_modules/node-gyp/lib/build.js
index fdb328b842..24cfe38de2 100644
--- a/deps/npm/node_modules/node-gyp/lib/build.js
+++ b/deps/npm/node_modules/node-gyp/lib/build.js
@@ -1,19 +1,11 @@
+'use strict'
-module.exports = exports = build
-
-/**
- * Module dependencies.
- */
-
-var fs = require('graceful-fs')
- , rm = require('rimraf')
- , path = require('path')
- , glob = require('glob')
- , log = require('npmlog')
- , which = require('which')
- , exec = require('child_process').exec
- , processRelease = require('./process-release')
- , win = process.platform === 'win32'
+const fs = require('graceful-fs')
+const path = require('path')
+const glob = require('glob')
+const log = require('npmlog')
+const which = require('which')
+const win = process.platform === 'win32'
exports.usage = 'Invokes `' + (win ? 'msbuild' : 'make') + '` and builds the module'
@@ -24,21 +16,19 @@ function build (gyp, argv, callback) {
} else if (process.platform.indexOf('bsd') !== -1) {
platformMake = 'gmake'
} else if (win && argv.length > 0) {
- argv = argv.map(function(target) {
+ argv = argv.map(function (target) {
return '/t:' + target
})
}
- var release = processRelease(argv, gyp, process.version, process.release)
- , makeCommand = gyp.opts.make || process.env.MAKE || platformMake
- , command = win ? 'msbuild' : makeCommand
- , buildDir = path.resolve('build')
- , configPath = path.resolve(buildDir, 'config.gypi')
- , jobs = gyp.opts.jobs || process.env.JOBS
- , buildType
- , config
- , arch
- , nodeDir
+ var makeCommand = gyp.opts.make || process.env.MAKE || platformMake
+ var command = win ? 'msbuild' : makeCommand
+ var jobs = gyp.opts.jobs || process.env.JOBS
+ var buildType
+ var config
+ var arch
+ var nodeDir
+ var guessedSolution
loadConfigGypi()
@@ -47,16 +37,18 @@ function build (gyp, argv, callback) {
*/
function loadConfigGypi () {
+ var configPath = path.resolve('build', 'config.gypi')
+
fs.readFile(configPath, 'utf8', function (err, data) {
if (err) {
- if (err.code == 'ENOENT') {
+ if (err.code === 'ENOENT') {
callback(new Error('You must run `node-gyp configure` first!'))
} else {
callback(err)
}
return
}
- config = JSON.parse(data.replace(/\#.+\n/, ''))
+ config = JSON.parse(data.replace(/#.+\n/, ''))
// get the 'arch', 'buildType', and 'nodeDir' vars from the config
buildType = config.target_defaults.default_configuration
@@ -88,7 +80,9 @@ function build (gyp, argv, callback) {
function findSolutionFile () {
glob('build/*.sln', function (err, files) {
- if (err) return callback(err)
+ if (err) {
+ return callback(err)
+ }
if (files.length === 0) {
return callback(new Error('Could not find *.sln file. Did you run "configure"?'))
}
@@ -103,102 +97,42 @@ function build (gyp, argv, callback) {
*/
function doWhich () {
- // First make sure we have the build command in the PATH
- which(command, function (err, execPath) {
- if (err) {
- if (win && /not found/.test(err.message)) {
- // On windows and no 'msbuild' found. Let's guess where it is
- findMsbuild()
- } else {
- // Some other error or 'make' not found on Unix, report that to the user
- callback(err)
- }
- return
+ // On Windows use msbuild provided by node-gyp configure
+ if (win) {
+ if (!config.variables.msbuild_path) {
+ return callback(new Error(
+ 'MSBuild is not set, please run `node-gyp configure`.'))
}
- log.verbose('`which` succeeded for `' + command + '`', execPath)
- doBuild()
- })
- }
-
- /**
- * Search for the location of "msbuild.exe" file on Windows.
- */
-
- function findMsbuild () {
- if (config.variables.msbuild_path) {
command = config.variables.msbuild_path
log.verbose('using MSBuild:', command)
doBuild()
return
}
-
- log.verbose('could not find "msbuild.exe" in PATH - finding location in registry')
- var notfoundErr = 'Can\'t find "msbuild.exe". Do you have Microsoft Visual Studio C++ 2008+ installed?'
- var cmd = 'reg query "HKLM\\Software\\Microsoft\\MSBuild\\ToolsVersions" /s'
- if (process.arch !== 'ia32')
- cmd += ' /reg:32'
- exec(cmd, function (err, stdout, stderr) {
+ // First make sure we have the build command in the PATH
+ which(command, function (err, execPath) {
if (err) {
- return callback(new Error(err.message + '\n' + notfoundErr))
+ // Some other error or 'make' not found on Unix, report that to the user
+ callback(err)
+ return
}
- var reVers = /ToolsVersions\\([^\\]+)$/i
- , rePath = /\r\n[ \t]+MSBuildToolsPath[ \t]+REG_SZ[ \t]+([^\r]+)/i
- , msbuilds = []
- , r
- , msbuildPath
- stdout.split('\r\n\r\n').forEach(function(l) {
- if (!l) return
- l = l.trim()
- if (r = reVers.exec(l.substring(0, l.indexOf('\r\n')))) {
- var ver = parseFloat(r[1], 10)
- if (ver >= 3.5) {
- if (r = rePath.exec(l)) {
- msbuilds.push({
- version: ver,
- path: r[1]
- })
- }
- }
- }
- })
- msbuilds.sort(function (x, y) {
- return (x.version < y.version ? -1 : 1)
- })
- ;(function verifyMsbuild () {
- if (!msbuilds.length) return callback(new Error(notfoundErr))
- msbuildPath = path.resolve(msbuilds.pop().path, 'msbuild.exe')
- fs.stat(msbuildPath, function (err, stat) {
- if (err) {
- if (err.code == 'ENOENT') {
- if (msbuilds.length) {
- return verifyMsbuild()
- } else {
- callback(new Error(notfoundErr))
- }
- } else {
- callback(err)
- }
- return
- }
- command = msbuildPath
- doBuild()
- })
- })()
+ log.verbose('`which` succeeded for `' + command + '`', execPath)
+ doBuild()
})
}
-
/**
* Actually spawn the process and compile the module.
*/
function doBuild () {
-
// Enable Verbose build
var verbose = log.levels[log.level] <= log.levels.verbose
+ var j
+
if (!win && verbose) {
argv.push('V=1')
}
+
if (win && !verbose) {
argv.push('/clp:Verbosity=minimal')
}
@@ -214,12 +148,12 @@ function build (gyp, argv, callback) {
// Since there are many ways to state '32-bit Intel', default to it.
// N.B. msbuild's Condition string equality tests are case-insensitive.
var archLower = arch.toLowerCase()
- var p = archLower === 'x64' ? 'x64' :
- (archLower === 'arm' ? 'ARM' :
- (archLower === 'arm64' ? 'ARM64' : 'Win32'))
+ var p = archLower === 'x64' ? 'x64'
+ : (archLower === 'arm' ? 'ARM'
+ : (archLower === 'arm64' ? 'ARM64' : 'Win32'))
argv.push('/p:Configuration=' + buildType + ';Platform=' + p)
if (jobs) {
- var j = parseInt(jobs, 10)
+ j = parseInt(jobs, 10)
if (!isNaN(j) && j > 0) {
argv.push('/m:' + j)
} else if (jobs.toUpperCase() === 'MAX') {
@@ -232,7 +166,7 @@ function build (gyp, argv, callback) {
argv.push('-C')
argv.push('build')
if (jobs) {
- var j = parseInt(jobs, 10)
+ j = parseInt(jobs, 10)
if (!isNaN(j) && j > 0) {
argv.push('--jobs')
argv.push(j)
@@ -246,7 +180,7 @@ function build (gyp, argv, callback) {
if (win) {
// did the user specify their own .sln file?
var hasSln = argv.some(function (arg) {
- return path.extname(arg) == '.sln'
+ return path.extname(arg) === '.sln'
})
if (!hasSln) {
argv.unshift(gyp.opts.solution || guessedSolution)
@@ -257,10 +191,6 @@ function build (gyp, argv, callback) {
proc.on('exit', onExit)
}
- /**
- * Invoked after the make/msbuild command exits.
- */
-
function onExit (code, signal) {
if (code !== 0) {
return callback(new Error('`' + command + '` failed with exit code: ' + code))
@@ -270,5 +200,6 @@ function build (gyp, argv, callback) {
}
callback()
}
-
}
+
+module.exports = build