Add --verbose flag to react native packager cli

Reviewed By: martinbigio

Differential Revision: D2517347

fb-gh-sync-id: 02e64f99120b6636d6e7649deb11d0b2f58d9285
This commit is contained in:
David Aurelio 2015-10-20 11:51:15 -07:00 committed by facebook-github-bot-4
parent d4d1608ee6
commit 8c4c679f09
3 changed files with 67 additions and 14 deletions

View File

@ -68,6 +68,10 @@ var options = parseCommandLine([{
command: 'reset-cache',
description: 'Removes cached files',
default: false,
}, {
command: 'verbose',
description: 'Enables logging',
default: false,
}]);
if (options.projectRoots) {
@ -187,6 +191,7 @@ function getAppMiddleware(options) {
'../Libraries/JavaScriptAppEngine/polyfills/document.js'
),
],
verbose: options.verbose,
});
}

View File

@ -12,12 +12,12 @@ require('../babelRegisterOnly')([/react-packager\/src/]);
useGracefulFs();
var debug = require('debug');
var omit = require('underscore').omit;
var Activity = require('./src/Activity');
var Server = require('./src/Server');
var SocketInterface = require('./src/SocketInterface');
exports.middleware = function(options) {
var server = new Server(options);
var server = createServer(options);
return server.processRequest.bind(server);
};
@ -27,7 +27,7 @@ exports.Activity = Activity;
// compat.
exports.buildPackage =
exports.buildBundle = function(options, bundleOptions) {
var server = createServer(options);
var server = createNonPersistentServer(options);
return server.buildBundle(bundleOptions)
.then(function(p) {
server.end();
@ -37,7 +37,7 @@ exports.buildBundle = function(options, bundleOptions) {
exports.buildPackageFromUrl =
exports.buildBundleFromUrl = function(options, reqUrl) {
var server = createServer(options);
var server = createNonPersistentServer(options);
return server.buildBundleFromUrl(reqUrl)
.then(function(p) {
server.end();
@ -46,7 +46,7 @@ exports.buildBundleFromUrl = function(options, reqUrl) {
};
exports.getDependencies = function(options, bundleOptions) {
var server = createServer(options);
var server = createNonPersistentServer(options);
return server.getDependencies(bundleOptions)
.then(function(r) {
server.end();
@ -55,23 +55,70 @@ exports.getDependencies = function(options, bundleOptions) {
};
exports.createClientFor = function(options) {
return SocketInterface.getOrCreateSocketFor(options);
if (options.verbose) {
enableDebug();
}
startSocketInterface();
return (
require('./src/SocketInterface')
.getOrCreateSocketFor(omit(options, ['verbose']))
);
};
SocketInterface.listenOnServerMessages();
function useGracefulFs() {
var fs = require('fs');
var gracefulFs = require('graceful-fs');
gracefulFs.gracefulify(fs);
}
function enableDebug() {
// react-packager logs debug messages using the 'debug' npm package, and uses
// the following prefix throughout.
// To enable debugging, we need to set our pattern or append it to any
// existing pre-configured pattern to avoid disabling logging for
// other packages
var debugPattern = 'ReactNativePackager:*';
var existingPattern = debug.load();
if (existingPattern) {
debugPattern += ',' + existingPattern;
}
debug.enable(debugPattern);
}
function createServer(options) {
// the debug module is configured globally, we need to enable debugging
// *before* requiring any packages that use `debug` for logging
if (options.verbose) {
enableDebug();
}
startSocketInterface();
var Server = require('./src/Server');
return new Server(omit(options, ['verbose']));
}
function createNonPersistentServer(options) {
Activity.disable();
// Don't start the filewatcher or the cache.
if (options.nonPersistent == null) {
options.nonPersistent = true;
}
return new Server(options);
return createServer(options);
}
// we need to listen on a socket as soon as a server is created, but only once.
// This file also serves as entry point when spawning a socket server; in that
// case we need to start the server immediately.
var didStartSocketInterface = false;
function startSocketInterface() {
if (didStartSocketInterface) {
return;
}
didStartSocketInterface = true;
require('./src/SocketInterface').listenOnServerMessages();
}
if (require.main === module) { // used as entry point
startSocketInterface();
}

View File

@ -27,10 +27,11 @@ const SocketInterface = {
return new Promise((resolve, reject) => {
const hash = crypto.createHash('md5');
Object.keys(options).sort().forEach(key => {
if (options[key] && typeof options[key] !== 'string') {
hash.update(JSON.stringify(options[key]));
} else {
hash.update(options[key]);
const value = options[key];
if (value) {
hash.update(
typeof value === 'string' ? value : JSON.stringify(value)
);
}
});