Browse Source

Merge pull request #244 from rollup/export-all-bugs

Export all bugs
better-aggressive
Rich Harris 9 years ago
parent
commit
6f1668c5bf
  1. 32
      src/Module.js
  2. 3
      test/function/export-all-multiple/_config.js
  3. 1
      test/function/export-all-multiple/bar.js
  4. 1
      test/function/export-all-multiple/foo.js
  5. 2
      test/function/export-all-multiple/main.js
  6. 7
      test/function/namespace-missing-export/_config.js
  7. 1
      test/function/namespace-missing-export/empty.js
  8. 2
      test/function/namespace-missing-export/main.js

32
src/Module.js

@ -81,10 +81,9 @@ class SyntheticNamespaceDeclaration {
// throw with an informative error message if the reference doesn't exist. // throw with an informative error message if the reference doesn't exist.
if ( !original ) { if ( !original ) {
const err = new Error( `Export '${reference.name}' is not defined by '${this.module.id}'` ); this.module.bundle.onwarn( `Export '${reference.name}' is not defined by '${this.module.id}'` );
err.code = 'MISSING_EXPORT'; reference.isUndefined = true;
err.file = this.module.id; return;
throw err;
} }
original.addReference( reference ); original.addReference( reference );
@ -581,15 +580,20 @@ export default class Module {
let toDeshadow = blank(); let toDeshadow = blank();
statement.references.forEach( reference => { statement.references.forEach( reference => {
const { start, end } = reference;
if ( reference.isUndefined ) {
magicString.overwrite( start, end, 'undefined', true );
}
const declaration = reference.declaration; const declaration = reference.declaration;
if ( declaration ) { if ( declaration ) {
const { start, end } = reference;
const name = declaration.render( es6 ); const name = declaration.render( es6 );
// the second part of this check is necessary because of // the second part of this check is necessary because of
// namespace optimisation – name of `foo.bar` could be `bar` // namespace optimisation – name of `foo.bar` could be `bar`
if ( reference.name === name && name.length === reference.end - reference.start ) return; if ( reference.name === name && name.length === end - start ) return;
reference.rewritten = true; reference.rewritten = true;
@ -690,17 +694,20 @@ export default class Module {
return otherModule.namespace(); return otherModule.namespace();
} }
return otherModule.traceExport( importDeclaration.name, this ); const declaration = otherModule.traceExport( importDeclaration.name );
if ( !declaration ) throw new Error( `Module ${otherModule.id} does not export ${importDeclaration.name} (imported by ${this.id})` );
return declaration;
} }
return null; return null;
} }
traceExport ( name, importer ) { traceExport ( name ) {
// export { foo } from './other.js' // export { foo } from './other.js'
const reexportDeclaration = this.reexports[ name ]; const reexportDeclaration = this.reexports[ name ];
if ( reexportDeclaration ) { if ( reexportDeclaration ) {
return reexportDeclaration.module.traceExport( reexportDeclaration.localName, this ); return reexportDeclaration.module.traceExport( reexportDeclaration.localName );
} }
const exportDeclaration = this.exports[ name ]; const exportDeclaration = this.exports[ name ];
@ -710,14 +717,9 @@ export default class Module {
for ( let i = 0; i < this.exportAllModules.length; i += 1 ) { for ( let i = 0; i < this.exportAllModules.length; i += 1 ) {
const module = this.exportAllModules[i]; const module = this.exportAllModules[i];
const declaration = module.traceExport( name, this ); const declaration = module.traceExport( name );
if ( declaration ) return declaration; if ( declaration ) return declaration;
} }
let errorMessage = `Module ${this.id} does not export ${name}`;
if ( importer ) errorMessage += ` (imported by ${importer.id})`;
throw new Error( errorMessage );
} }
} }

3
test/function/export-all-multiple/_config.js

@ -0,0 +1,3 @@
module.exports = {
description: 'allows multiple export * statements'
};

1
test/function/export-all-multiple/bar.js

@ -0,0 +1 @@
export var BAR = 2;

1
test/function/export-all-multiple/foo.js

@ -0,0 +1 @@
export var FOO = 1;

2
test/function/export-all-multiple/main.js

@ -0,0 +1,2 @@
export * from './foo.js';
export * from './bar.js';

7
test/function/namespace-missing-export/_config.js

@ -2,8 +2,9 @@ var assert = require( 'assert' );
var path = require( 'path' ); var path = require( 'path' );
module.exports = { module.exports = {
error: function ( err ) { options: {
assert.equal( path.normalize( err.file ), path.resolve( __dirname, 'empty.js' ) ); onwarn: function ( msg ) {
assert.ok( /Export 'foo' is not defined by/.test( err.message ) ); assert.ok( /Export 'foo' is not defined by/.test( msg ) );
}
} }
}; };

1
test/function/namespace-missing-export/empty.js

@ -0,0 +1 @@
// this space left intentionally blank

2
test/function/namespace-missing-export/main.js

@ -1,3 +1,3 @@
import * as mod from './empty.js'; import * as mod from './empty.js';
mod.foo(); assert.equal( typeof mod.foo, 'undefined' );

Loading…
Cancel
Save