Skip to content

Commit 3d053d9

Browse files
committed
support default + named import
1 parent 422cc0d commit 3d053d9

File tree

2 files changed

+17
-16
lines changed

2 files changed

+17
-16
lines changed

test/setup.js

Lines changed: 14 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -8,22 +8,28 @@ require.extensions['.js'] = function(module, filename) {
88
const exports = [];
99

1010
let code = fs.readFileSync(filename, 'utf-8')
11-
.replace(/^import \* as (\w+) from ['"]([^'"]+)['"];?/gm, 'var $1 = require("$2");')
12-
.replace(/^import (\w+) from ['"]([^'"]+)['"];?/gm, 'var {default: $1} = require("$2");')
13-
.replace(/^import {([^}]+)} from ['"](.+)['"];?/gm, 'var {$1} = require("$2");')
14-
.replace(/^export default /gm, 'exports.default = ')
15-
.replace(/^export (const|let|var|class|function) (\w+)/gm, (match, type, name) => {
11+
.replace(/^import\s+\*\s+as\s+(\w+)\s+from\s+(['"])(.+?)\2;?/gm, 'var $1 = require($2$3$2);')
12+
.replace(/^import\s+(\w+)\s+from\s+(['"])(.+?)\2;?/gm, 'var {default: $1} = require($2$3$2);')
13+
.replace(/^import\s+(?:(\w+)\s*,\s*)?{([^}]+)}(?:\s*,\s*(\w+))?\s+from\s+(['"])(.+?)\4;?/gm,
14+
(match, default_name_1, names, default_name_2, quote, source) => {
15+
names = names.replace(/\s+as\s+/g, ': ');
16+
let default_name = default_name_1 || default_name_2;
17+
default_name = default_name ? `default: ${default_name}, ` : '';
18+
return `var {${default_name}${names}} = require(${quote}${source}${quote});`;
19+
})
20+
.replace(/^export\s+default\s+/gm, 'exports.default = ')
21+
.replace(/^export\s+(const|let|var|class|function)\s+(\w+)/gm, (match, type, name) => {
1622
exports.push(name);
1723
return `${type} ${name}`;
1824
})
19-
.replace(/^export \{([^}]+)\}(?: from ['"]([^'"]+)['"];?)?/gm, (match, names, source) => {
25+
.replace(/^export\s+\{([^}]+)\}(?:\s+from\s+(['"])(.+?)\2;?)?/gm, (match, names, quote, source) => {
2026
names.split(',').filter(Boolean).forEach(name => {
2127
exports.push(name);
2228
});
2329

24-
return source ? `const { ${names} } = require("${source}");` : '';
30+
return source ? `const { ${names} } = require(${quote}${source}${quote});` : '';
2531
})
26-
.replace(/^export function (\w+)/gm, 'exports.$1 = function $1');
32+
.replace(/^export\s+function\s+(\w+)/gm, 'exports.$1 = function $1');
2733

2834
exports.forEach(name => {
2935
code += `\nexports.${name} = ${name};`;

test/sourcemaps/samples/sourcemap-sources/_config.js

Lines changed: 3 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,4 @@
1-
import MagicString from 'magic-string';
2-
// eslint warning: import/no-named-as-default-member
3-
4-
//import MagicString, { Bundle } from 'magic-string';
5-
// TODO why does this break mocha?
6-
// SyntaxError: Cannot use import statement outside a module
1+
import MagicString, { Bundle } from 'magic-string';
72

83
function add(bundle, filename, source) {
94
bundle.addSource({
@@ -27,7 +22,7 @@ export default {
2722
preprocess: [
2823
{
2924
script: ({ content, filename }) => {
30-
const bundle = new MagicString.Bundle();
25+
const bundle = new Bundle();
3126

3227
add(bundle, filename, content);
3328
add(bundle, 'foo.js', 'var answer = 42;');
@@ -38,7 +33,7 @@ export default {
3833
},
3934
{
4035
script: ({ content, filename }) => {
41-
const bundle = new MagicString.Bundle();
36+
const bundle = new Bundle();
4237

4338
add(bundle, filename, content);
4439
add(bundle, 'foo2.js', 'var answer2 = 84;');

0 commit comments

Comments
 (0)