Browse Source

dedupe external imports in ES6 bundle (fixes #77)

contingency-plan
Rich-Harris 10 years ago
parent
commit
056110dd09
  1. 17
      src/finalisers/es6.js

17
src/finalisers/es6.js

@ -1,4 +1,14 @@
import { keys } from '../utils/object'; import { blank, keys } from '../utils/object';
function uniqueNames ( declarations ) {
let uniques = blank();
declarations
.filter( declaration => !/^(default|\*)$/.test( declaration.name ) )
.forEach( declaration => uniques[ declaration.name ] = true );
return keys( uniques );
}
export default function es6 ( bundle, magicString ) { export default function es6 ( bundle, magicString ) {
const importBlock = bundle.externalModules const importBlock = bundle.externalModules
@ -16,10 +26,7 @@ export default function es6 ( bundle, magicString ) {
} }
if ( module.needsNamed ) { if ( module.needsNamed ) {
specifiers.push( '{ ' + module.importedByBundle specifiers.push( '{ ' + uniqueNames( module.importedByBundle )
.filter( declaration => !/^(default|\*)$/.test( declaration.name ) )
.map( ({ name, localName }) =>
name === localName ? name : `${name} as ${localName}` )
.join( ', ' ) + ' }' ); .join( ', ' ) + ' }' );
} }

Loading…
Cancel
Save