Browse Source

use plugin names in CLI logs

gh-1187
Rich Harris 8 years ago
parent
commit
be7c90f0c7
  1. 39
      bin/src/logging.js
  2. 10
      src/Bundle.js
  3. 1
      src/utils/transform.js
  4. 2
      test/function/plugin-warn/_config.js

39
bin/src/logging.js

@ -8,40 +8,33 @@ const errorSymbol = process.stderr.isTTY ? `🚨 ` : `Error: `;
// log to stderr to keep `rollup main.js > bundle.js` from breaking // log to stderr to keep `rollup main.js > bundle.js` from breaking
export const stderr = console.error.bind( console ); // eslint-disable-line no-console export const stderr = console.error.bind( console ); // eslint-disable-line no-console
export function handleWarning ( warning ) { function log ( object, symbol ) {
stderr( `${warnSymbol}${chalk.bold( warning.message )}` ); const message = object.plugin ? `(${object.plugin} plugin) ${object.message}` : object.message;
if ( warning.url ) {
stderr( chalk.cyan( warning.url ) );
}
if ( warning.loc ) { stderr( `${symbol}${chalk.bold( message )}` );
stderr( `${relativeId( warning.loc.file )} (${warning.loc.line}:${warning.loc.column})` );
}
if ( warning.frame ) { if ( object.url ) {
stderr( chalk.dim( warning.frame ) ); stderr( chalk.cyan( object.url ) );
} }
stderr( '' ); if ( object.loc ) {
stderr( `${relativeId( object.loc.file )} (${object.loc.line}:${object.loc.column})` );
} else if ( object.id ) {
stderr( relativeId( object.id ) );
} }
export function handleError ( err, recover ) { if ( object.frame ) {
stderr( `${errorSymbol}${chalk.bold( err.message )}` ); stderr( chalk.dim( object.frame ) );
if ( err.url ) {
stderr( chalk.cyan( err.url ) );
} }
if ( err.loc ) { stderr( '' );
stderr( `${relativeId( err.loc.file )} (${err.loc.line}:${err.loc.column})` );
} }
if ( err.frame ) { export function handleWarning ( warning ) {
stderr( chalk.dim( err.frame ) ); log( warning, warnSymbol );
} }
stderr( '' ); export function handleError ( err, recover ) {
log( err, errorSymbol );
if ( !recover ) process.exit( 1 ); if ( !recover ) process.exit( 1 );
} }

10
src/Bundle.js

@ -619,11 +619,13 @@ export default class Bundle {
warn ( warning ) { warn ( warning ) {
warning.toString = () => { warning.toString = () => {
if ( warning.loc ) { let str = '';
return `${relativeId( warning.loc.file )} (${warning.loc.line}:${warning.loc.column}) ${warning.message}`;
} if ( warning.plugin ) str += `(${warning.plugin} plugin) `;
if ( warning.loc ) str += `${relativeId( warning.loc.file )} (${warning.loc.line}:${warning.loc.column}) `;
str += warning.message;
return warning.message; return str;
}; };
this.onwarn( warning ); this.onwarn( warning );

1
src/utils/transform.js

@ -44,6 +44,7 @@ export default function transform ( bundle, source, id, plugins ) {
warn: ( warning, pos ) => { warn: ( warning, pos ) => {
warning = augment( warning, pos, 'PLUGIN_WARNING' ); warning = augment( warning, pos, 'PLUGIN_WARNING' );
warning.plugin = plugin.name; warning.plugin = plugin.name;
warning.id = id;
bundle.warn( warning ); bundle.warn( warning );
}, },

2
test/function/plugin-warn/_config.js

@ -15,11 +15,13 @@ module.exports = {
warnings: [ warnings: [
{ {
code: 'PLUGIN_WARNING', code: 'PLUGIN_WARNING',
id: path.resolve( __dirname, 'main.js' ),
plugin: 'test', plugin: 'test',
message: 'foo' message: 'foo'
}, },
{ {
code: 'PLUGIN_WARNING', code: 'PLUGIN_WARNING',
id: path.resolve( __dirname, 'main.js' ),
plugin: 'test', plugin: 'test',
message: 'bar', message: 'bar',
pos: 22, pos: 22,

Loading…
Cancel
Save