From a16d0e46d8042b2ffa205d072c2f17a75b86ea66 Mon Sep 17 00:00:00 2001 From: Ben Vinegar Date: Fri, 2 Oct 2015 16:01:18 -0700 Subject: [PATCH] Add --write-sourcemap option to 'bundle' cli command (fixes GH-3202) --- local-cli/bundle.js | 28 +++++++++++++++++++++++----- 1 file changed, 23 insertions(+), 5 deletions(-) diff --git a/local-cli/bundle.js b/local-cli/bundle.js index b060cbe6e..92329f98b 100644 --- a/local-cli/bundle.js +++ b/local-cli/bundle.js @@ -13,10 +13,15 @@ var URL_PATH = { android: '/index.android.bundle?platform=android&dev=', ios: '/index.ios.bundle?platform=ios&dev=' }; +var SOURCEMAP_OUT_PATH = { + android: 'android/index.android.map', + ios: 'ios/index.ios.map' +}; function getBundle(flags) { var platform = flags.platform ? flags.platform : 'ios'; var outPath = flags.out ? flags.out : OUT_PATH[platform]; + var sourceMapOutPath = SOURCEMAP_OUT_PATH[platform]; var projectRoots = [path.resolve(__dirname, '../../..')]; if (flags.root) { @@ -50,12 +55,23 @@ function getBundle(flags) { fs.writeFile(outPath, bundle.getSource({ inlineSourceMap: false, minify: flags.minify - }), function(err) { - if (err) { + }), function(bundleWriteErr) { + if (bundleWriteErr) { console.log(chalk.red('Error saving bundle to disk')); - throw err; - } else { - console.log('Successfully saved bundle to ' + outPath); + throw bundleWriteErr; + } + + console.log('Successfully saved bundle to ' + outPath); + + if (flags.writeSourcemap) { + fs.writeFile(sourceMapOutPath, bundle.getSourceMap(), function(sourceMapWriteErr) { + if (sourceMapWriteErr) { + console.log(chalk.red('Error saving source map to disk')); + throw sourceMapWriteErr; + } else { + console.log('Successfully saved source map to ' + sourceMapOutPath); + } + }); } }); }); @@ -73,6 +89,7 @@ function showHelp() { ' --out\t\tspecify the output file', ' --url\t\tspecify the bundle file url', ' --platform\t\tspecify the platform(android/ios)', + ' --write-sourcemap\t\twrite bundle source map to disk' ].join('\n')); process.exit(1); } @@ -88,6 +105,7 @@ module.exports = { assetRoots: args.indexOf('--assetRoots') !== -1 ? args[args.indexOf('--assetRoots') + 1] : false, out: args.indexOf('--out') !== -1 ? args[args.indexOf('--out') + 1] : false, url: args.indexOf('--url') !== -1 ? args[args.indexOf('--url') + 1] : false, + writeSourcemap: args.indexOf('--write-sourcemap') !== -1, } if (flags.help) {