mirror of
https://github.com/status-im/react-native.git
synced 2025-01-17 21:11:45 +00:00
0bbd9f042a
Summary: `metro-bundler` v0.21 contains a rewritten bundling mechanism, with simplified logic and much faster rebuild times, called delta bundler. This release contains a couple of breaking changes: * Now, when using a custom transformer, the list of additional babel plugins to apply are passed to the `transform()` method. These are used in non-dev mode for optimization purposes (Check367a5f5db8 (diff-40653f0c822ac59a5af13d5b4ab31d84)
to see how to handle them from the transformer). * Now, when using a custom transformer outputting `rawMappings`, the transformer does not need to call the `compactMappings` method before returning (checkd74685fd1d (diff-40653f0c822ac59a5af13d5b4ab31d84)
for more info). * We've removed support for two config parameters: `postProcessModules` and `postProcessBundleSourcemap`. Reviewed By: davidaurelio Differential Revision: D6186035 fbshipit-source-id: 242c5c2a954c6b9b6f339d345f888eaa44704579
72 lines
2.4 KiB
JavaScript
72 lines
2.4 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*
|
|
* @format
|
|
*/
|
|
'use strict';
|
|
|
|
const launchChrome = require('../util/launchChrome');
|
|
|
|
const {exec} = require('child_process');
|
|
|
|
function launchChromeDevTools(port, args = '') {
|
|
var debuggerURL = 'http://localhost:' + port + '/debugger-ui' + args;
|
|
console.log('Launching Dev Tools...');
|
|
launchChrome(debuggerURL);
|
|
}
|
|
|
|
function escapePath(pathname) {
|
|
// " Can escape paths with spaces in OS X, Windows, and *nix
|
|
return '"' + pathname + '"';
|
|
}
|
|
|
|
function launchDevTools({port, projectRoots}, isChromeConnected) {
|
|
// Explicit config always wins
|
|
var customDebugger = process.env.REACT_DEBUGGER;
|
|
if (customDebugger) {
|
|
var projects = projectRoots.map(escapePath).join(' ');
|
|
var command = customDebugger + ' ' + projects;
|
|
console.log('Starting custom debugger by executing: ' + command);
|
|
exec(command, function(error, stdout, stderr) {
|
|
if (error !== null) {
|
|
console.log('Error while starting custom debugger: ' + error);
|
|
}
|
|
});
|
|
} else if (!isChromeConnected()) {
|
|
// Dev tools are not yet open; we need to open a session
|
|
launchChromeDevTools(port);
|
|
}
|
|
}
|
|
|
|
module.exports = function(options, isChromeConnected) {
|
|
return function(req, res, next) {
|
|
if (req.url === '/launch-safari-devtools') {
|
|
// TODO: remove `console.log` and dev tools binary
|
|
console.log(
|
|
'We removed support for Safari dev-tools. ' +
|
|
'If you still need this, please let us know.',
|
|
);
|
|
} else if (req.url === '/launch-chrome-devtools') {
|
|
// TODO: Remove this case in the future
|
|
console.log(
|
|
'The method /launch-chrome-devtools is deprecated. You are ' +
|
|
' probably using an application created with an older CLI with the ' +
|
|
' packager of a newer CLI. Please upgrade your application: ' +
|
|
'https://facebook.github.io/react-native/docs/upgrading.html',
|
|
);
|
|
launchDevTools(options, isChromeConnected);
|
|
res.end('OK');
|
|
} else if (req.url === '/launch-js-devtools') {
|
|
launchDevTools(options, isChromeConnected);
|
|
res.end('OK');
|
|
} else {
|
|
next();
|
|
}
|
|
};
|
|
};
|