You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					126 lines
				
				3.1 KiB
			
		
		
			
		
	
	
					126 lines
				
				3.1 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								'use strict';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Set the title.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								process.title = 'node-pre-gyp';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const node_pre_gyp = require('../');
							 | 
						||
| 
								 | 
							
								const log = require('npmlog');
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Process and execute the selected commands.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const prog = new node_pre_gyp.Run({ argv: process.argv });
							 | 
						||
| 
								 | 
							
								let completed = false;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								if (prog.todo.length === 0) {
							 | 
						||
| 
								 | 
							
								  if (~process.argv.indexOf('-v') || ~process.argv.indexOf('--version')) {
							 | 
						||
| 
								 | 
							
								    console.log('v%s', prog.version);
							 | 
						||
| 
								 | 
							
								    process.exit(0);
							 | 
						||
| 
								 | 
							
								  } else if (~process.argv.indexOf('-h') || ~process.argv.indexOf('--help')) {
							 | 
						||
| 
								 | 
							
								    console.log('%s', prog.usage());
							 | 
						||
| 
								 | 
							
								    process.exit(0);
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								  console.log('%s', prog.usage());
							 | 
						||
| 
								 | 
							
								  process.exit(1);
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// if --no-color is passed
							 | 
						||
| 
								 | 
							
								if (prog.opts && Object.hasOwnProperty.call(prog, 'color') && !prog.opts.color) {
							 | 
						||
| 
								 | 
							
								  log.disableColor();
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								log.info('it worked if it ends with', 'ok');
							 | 
						||
| 
								 | 
							
								log.verbose('cli', process.argv);
							 | 
						||
| 
								 | 
							
								log.info('using', process.title + '@%s', prog.version);
							 | 
						||
| 
								 | 
							
								log.info('using', 'node@%s | %s | %s', process.versions.node, process.platform, process.arch);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Change dir if -C/--directory was passed.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const dir = prog.opts.directory;
							 | 
						||
| 
								 | 
							
								if (dir) {
							 | 
						||
| 
								 | 
							
								  const fs = require('fs');
							 | 
						||
| 
								 | 
							
								  try {
							 | 
						||
| 
								 | 
							
								    const stat = fs.statSync(dir);
							 | 
						||
| 
								 | 
							
								    if (stat.isDirectory()) {
							 | 
						||
| 
								 | 
							
								      log.info('chdir', dir);
							 | 
						||
| 
								 | 
							
								      process.chdir(dir);
							 | 
						||
| 
								 | 
							
								    } else {
							 | 
						||
| 
								 | 
							
								      log.warn('chdir', dir + ' is not a directory');
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  } catch (e) {
							 | 
						||
| 
								 | 
							
								    if (e.code === 'ENOENT') {
							 | 
						||
| 
								 | 
							
								      log.warn('chdir', dir + ' is not a directory');
							 | 
						||
| 
								 | 
							
								    } else {
							 | 
						||
| 
								 | 
							
								      log.warn('chdir', 'error during chdir() "%s"', e.message);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								function run() {
							 | 
						||
| 
								 | 
							
								  const command = prog.todo.shift();
							 | 
						||
| 
								 | 
							
								  if (!command) {
							 | 
						||
| 
								 | 
							
								    // done!
							 | 
						||
| 
								 | 
							
								    completed = true;
							 | 
						||
| 
								 | 
							
								    log.info('ok');
							 | 
						||
| 
								 | 
							
								    return;
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  // set binary.host when appropriate. host determines the s3 target bucket.
							 | 
						||
| 
								 | 
							
								  const target = prog.setBinaryHostProperty(command.name);
							 | 
						||
| 
								 | 
							
								  if (target && ['install', 'publish', 'unpublish', 'info'].indexOf(command.name) >= 0) {
							 | 
						||
| 
								 | 
							
								    log.info('using binary.host: ' + prog.package_json.binary.host);
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  prog.commands[command.name](command.args, function(err) {
							 | 
						||
| 
								 | 
							
								    if (err) {
							 | 
						||
| 
								 | 
							
								      log.error(command.name + ' error');
							 | 
						||
| 
								 | 
							
								      log.error('stack', err.stack);
							 | 
						||
| 
								 | 
							
								      errorMessage();
							 | 
						||
| 
								 | 
							
								      log.error('not ok');
							 | 
						||
| 
								 | 
							
								      console.log(err.message);
							 | 
						||
| 
								 | 
							
								      return process.exit(1);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    const args_array = [].slice.call(arguments, 1);
							 | 
						||
| 
								 | 
							
								    if (args_array.length) {
							 | 
						||
| 
								 | 
							
								      console.log.apply(console, args_array);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    // now run the next command in the queue
							 | 
						||
| 
								 | 
							
								    process.nextTick(run);
							 | 
						||
| 
								 | 
							
								  });
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								process.on('exit', (code) => {
							 | 
						||
| 
								 | 
							
								  if (!completed && !code) {
							 | 
						||
| 
								 | 
							
								    log.error('Completion callback never invoked!');
							 | 
						||
| 
								 | 
							
								    errorMessage();
							 | 
						||
| 
								 | 
							
								    process.exit(6);
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								});
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								process.on('uncaughtException', (err) => {
							 | 
						||
| 
								 | 
							
								  log.error('UNCAUGHT EXCEPTION');
							 | 
						||
| 
								 | 
							
								  log.error('stack', err.stack);
							 | 
						||
| 
								 | 
							
								  errorMessage();
							 | 
						||
| 
								 | 
							
								  process.exit(7);
							 | 
						||
| 
								 | 
							
								});
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								function errorMessage() {
							 | 
						||
| 
								 | 
							
								  // copied from npm's lib/util/error-handler.js
							 | 
						||
| 
								 | 
							
								  const os = require('os');
							 | 
						||
| 
								 | 
							
								  log.error('System', os.type() + ' ' + os.release());
							 | 
						||
| 
								 | 
							
								  log.error('command', process.argv.map(JSON.stringify).join(' '));
							 | 
						||
| 
								 | 
							
								  log.error('cwd', process.cwd());
							 | 
						||
| 
								 | 
							
								  log.error('node -v', process.version);
							 | 
						||
| 
								 | 
							
								  log.error(process.title + ' -v', 'v' + prog.package.version);
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// start running the given commands!
							 | 
						||
| 
								 | 
							
								run();
							 |