From 4ab91c715906be4679dee8766a4e316a9baa708a Mon Sep 17 00:00:00 2001 From: Adrian Heine Date: Tue, 26 Dec 2017 11:34:24 +0100 Subject: [PATCH 1/2] Add back test Originally added in 9687b2db3d64e88ae629017d4d44846bb59a3991, removed in c191a130190811f9e498e1805f16294a8a38e383. --- test/test.js | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/test/test.js b/test/test.js index 37655c2..04941e7 100644 --- a/test/test.js +++ b/test/test.js @@ -252,6 +252,20 @@ describe( 'rollup-plugin-commonjs', () => { assert.equal( (await executeBundle( bundle )).exports, 42 ); }); + it( 'identifies named exports from object literals', async () => { + const bundle = await rollup({ + input: 'samples/named-exports-from-object-literal/main.js', + plugins: [ commonjs() ] + }); + + const { code } = await bundle.generate({ + format: 'cjs' + }); + + const fn = new Function ( 'module', 'assert', code ); + fn( {}, assert ); + }); + it( 'can ignore references to `global`', async () => { const bundle = await rollup({ input: 'samples/ignore-global/main.js', @@ -450,4 +464,4 @@ describe( 'rollup-plugin-commonjs', () => { assert.equal( warns.length, 0 ); }); }); -}); \ No newline at end of file +}); From 7e8a8c45b5f937bd5ede6180eee06589d8003cba Mon Sep 17 00:00:00 2001 From: Adrian Heine Date: Tue, 26 Dec 2017 12:26:21 +0100 Subject: [PATCH 2/2] Add back support for module.exports objects This was broken in 8a3e99e9d554161348a0a2c4db721bb18822299f. Closes #267. --- src/transform.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/transform.js b/src/transform.js index eb12e45..b6fd675 100644 --- a/src/transform.js +++ b/src/transform.js @@ -359,10 +359,6 @@ export function transformCommonjs ( code, id, isEntry, ignoreGlobal, ignoreRequi wrapperStart = `var ${moduleName} = ${HELPERS_NAME}.createCommonjsModule(function (${args}) {\n`; wrapperEnd = `\n});`; - - Object.keys( namedExports ) - .filter( key => !blacklist[ key ] ) - .forEach( addExport ); } else { const names = []; @@ -396,6 +392,7 @@ export function transformCommonjs ( code, id, isEntry, ignoreGlobal, ignoreRequi str: declaration, name }); + delete namedExports[name]; } defaultExportPropertyAssignments.push( `${moduleName}.${name} = ${deconflicted};` ); @@ -409,6 +406,9 @@ export function transformCommonjs ( code, id, isEntry, ignoreGlobal, ignoreRequi }\n};`; } } + Object.keys( namedExports ) + .filter( key => !blacklist[ key ] ) + .forEach( addExport ); const defaultExport = /__esModule/.test( code ) ? `export default ${HELPERS_NAME}.unwrapExports(${moduleName});` :