mirror of
https://github.com/status-im/metro.git
synced 2025-01-10 11:06:06 +00:00
Add --verbose
flag to react native packager cli
Reviewed By: martinbigio Differential Revision: D2517347 fb-gh-sync-id: 02e64f99120b6636d6e7649deb11d0b2f58d9285
This commit is contained in:
parent
d4d1608ee6
commit
8c4c679f09
@ -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,
|
||||
});
|
||||
}
|
||||
|
||||
|
67
react-packager/index.js
vendored
67
react-packager/index.js
vendored
@ -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();
|
||||
}
|
||||
|
9
react-packager/src/SocketInterface/index.js
vendored
9
react-packager/src/SocketInterface/index.js
vendored
@ -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)
|
||||
);
|
||||
}
|
||||
});
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user