From 6af7ae55b1ccffd185eb269b81f9ed1ee9f77cc7 Mon Sep 17 00:00:00 2001 From: Martin Konicek Date: Tue, 5 Jan 2016 16:48:38 +0000 Subject: [PATCH] [global-cli] react-native init [--debug|verbose] `npm install` prints a lot of junk like gyp warnings and the rest of the output is not super useful for tracking progress. Supress the output by default, show the output with --debug, and show verbose output with --verbose. --- react-native-cli/index.js | 35 ++++++++++++++++++++++------------- react-native-cli/package.json | 2 +- 2 files changed, 23 insertions(+), 14 deletions(-) diff --git a/react-native-cli/index.js b/react-native-cli/index.js index 522ec26a005cb0..01c8f0e64a3a69 100755 --- a/react-native-cli/index.js +++ b/react-native-cli/index.js @@ -83,11 +83,16 @@ if (cli) { switch (args[0]) { case 'init': if (args[1]) { - var verbose = process.argv.indexOf('--verbose') >= 0; - init(args[1], verbose); + var logLevel = ''; + if (process.argv.indexOf('--verbose') >= 0) { + logLevel = 'verbose'; + } else if (process.argv.indexOf('--debug') >= 0) { + logLevel = 'debug'; + } + init(args[1], logLevel); } else { console.error( - 'Usage: react-native init [--verbose]' + 'Usage: react-native init [--debug|--verbose]' ); process.exit(1); } @@ -123,17 +128,17 @@ function validatePackageName(name) { } } -function init(name, verbose) { +function init(name, logLevel) { validatePackageName(name); if (fs.existsSync(name)) { - createAfterConfirmation(name, verbose); + createAfterConfirmation(name, logLevel); } else { - createProject(name, verbose); + createProject(name, logLevel); } } -function createAfterConfirmation(name, verbose) { +function createAfterConfirmation(name, logLevel) { prompt.start(); var property = { @@ -146,7 +151,7 @@ function createAfterConfirmation(name, verbose) { prompt.get(property, function (err, result) { if (result.yesno[0] === 'y') { - createProject(name, verbose); + createProject(name, logLevel); } else { console.log('Project initialization canceled'); process.exit(); @@ -154,7 +159,7 @@ function createAfterConfirmation(name, verbose) { }); } -function createProject(name, verbose) { +function createProject(name, logLevel) { var root = path.resolve(name); var projectName = path.basename(root); @@ -180,16 +185,20 @@ function createProject(name, verbose) { console.log('Installing react-native package from npm...'); - run(root, projectName, verbose); + run(root, projectName, logLevel); } -function run(root, projectName, verbose) { +function run(root, projectName, logLevel) { var args = ['install', '--save']; - if (verbose){ + if (logLevel === 'verbose') { args.push('--verbose'); } args.push('react-native'); - var proc = spawn('npm', args, {stdio: 'inherit'}); + var spawnArgs = {}; + if (logLevel === 'debug' || logLevel === 'verbose') { + spawnArgs = {stdio: 'inherit'}; + } + var proc = spawn('npm', args, spawnArgs); proc.on('close', function (code) { if (code !== 0) { console.error('`npm install --save react-native` failed'); diff --git a/react-native-cli/package.json b/react-native-cli/package.json index 6c6bd533c56d01..7b76d4e79ac663 100644 --- a/react-native-cli/package.json +++ b/react-native-cli/package.json @@ -1,6 +1,6 @@ { "name": "react-native-cli", - "version": "0.1.7", + "version": "0.1.8", "license" : "BSD-3-Clause", "description": "The React Native CLI tools", "main": "index.js",