|
@ -18,6 +18,8 @@ class SyntheticDefaultDeclaration { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
addReference ( reference ) { |
|
|
addReference ( reference ) { |
|
|
|
|
|
this.references.push( reference ); |
|
|
|
|
|
|
|
|
reference.declaration = this; |
|
|
reference.declaration = this; |
|
|
this.name = reference.name; |
|
|
this.name = reference.name; |
|
|
} |
|
|
} |
|
@ -252,6 +254,17 @@ export default class Module { |
|
|
let strongDependencies = blank(); |
|
|
let strongDependencies = blank(); |
|
|
let weakDependencies = blank(); |
|
|
let weakDependencies = blank(); |
|
|
|
|
|
|
|
|
|
|
|
// treat all imports as weak dependencies
|
|
|
|
|
|
this.dependencies.forEach( source => { |
|
|
|
|
|
const id = this.resolvedIds[ source ]; |
|
|
|
|
|
const dependency = this.bundle.moduleById[ id ]; |
|
|
|
|
|
|
|
|
|
|
|
if ( !dependency.isExternal ) { |
|
|
|
|
|
weakDependencies[ dependency.id ] = dependency; |
|
|
|
|
|
} |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
// identify strong dependencies to break ties in case of cycles
|
|
|
this.statements.forEach( statement => { |
|
|
this.statements.forEach( statement => { |
|
|
statement.references.forEach( reference => { |
|
|
statement.references.forEach( reference => { |
|
|
const declaration = reference.declaration; |
|
|
const declaration = reference.declaration; |
|
@ -260,8 +273,6 @@ export default class Module { |
|
|
const module = declaration.statement.module; |
|
|
const module = declaration.statement.module; |
|
|
if ( module === this ) return; |
|
|
if ( module === this ) return; |
|
|
|
|
|
|
|
|
weakDependencies[ module.id ] = module; |
|
|
|
|
|
|
|
|
|
|
|
// TODO handle references inside IIFEs, and disregard
|
|
|
// TODO handle references inside IIFEs, and disregard
|
|
|
// function declarations
|
|
|
// function declarations
|
|
|
if ( !reference.scope.parent ) { |
|
|
if ( !reference.scope.parent ) { |
|
@ -431,7 +442,7 @@ export default class Module { |
|
|
const name = declaration.render( es6 ); |
|
|
const name = declaration.render( es6 ); |
|
|
|
|
|
|
|
|
if ( reference.name !== name ) { |
|
|
if ( reference.name !== name ) { |
|
|
magicString.overwrite( start, start + reference.name.length, name ); |
|
|
magicString.overwrite( start, start + reference.name.length, name, true ); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
}); |
|
|
}); |
|
@ -462,7 +473,14 @@ export default class Module { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
else if ( statement.node.type === 'ExportDefaultDeclaration' ) { |
|
|
else if ( statement.node.type === 'ExportDefaultDeclaration' ) { |
|
|
const defaultName = this.declarations.default.name; |
|
|
const defaultDeclaration = this.declarations.default; |
|
|
|
|
|
const defaultName = defaultDeclaration.name; |
|
|
|
|
|
|
|
|
|
|
|
// prevent `var undefined = sideEffectyDefault(foo)`
|
|
|
|
|
|
if ( !defaultDeclaration.isExported && !defaultDeclaration.references.length ) { |
|
|
|
|
|
magicString.remove( statement.start, statement.node.declaration.start ); |
|
|
|
|
|
return; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
// anonymous functions should be converted into declarations
|
|
|
// anonymous functions should be converted into declarations
|
|
|
if ( statement.node.declaration.type === 'FunctionExpression' ) { |
|
|
if ( statement.node.declaration.type === 'FunctionExpression' ) { |
|
@ -496,7 +514,7 @@ export default class Module { |
|
|
// export { foo } from './other'
|
|
|
// export { foo } from './other'
|
|
|
const reexportDeclaration = this.reexports[ name ]; |
|
|
const reexportDeclaration = this.reexports[ name ]; |
|
|
if ( reexportDeclaration ) { |
|
|
if ( reexportDeclaration ) { |
|
|
return reexportDeclaration.module.traceExport( reexportDeclaration.name ); |
|
|
return reexportDeclaration.module.traceExport( reexportDeclaration.localName ); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const exportDeclaration = this.exports[ name ]; |
|
|
const exportDeclaration = this.exports[ name ]; |
|
|