Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Babel 7 #1955

Merged
merged 46 commits into from
Sep 16, 2018
Merged

Babel 7 #1955

Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
3853467
WIP: babel 7
devongovett Aug 29, 2018
e0df562
Babel 7: Fix dependency name and upgrade to 7.0.0 (#1956)
prichodko Aug 29, 2018
05c0fb8
remove babel6 from pkg.json, update internal babel configs and update…
DeMoorJasper Aug 29, 2018
89d236b
remove async-super-babel-plugin
DeMoorJasper Aug 29, 2018
4e613c9
remove babel polyfill test for useBuiltins
DeMoorJasper Aug 29, 2018
106c43d
remove babel-template requires
DeMoorJasper Aug 29, 2018
71a75dc
fix html import tests
DeMoorJasper Aug 29, 2018
dd06677
fix formatting
DeMoorJasper Aug 29, 2018
cfad048
work around template string bug in Babel 7?
DeMoorJasper Aug 29, 2018
a1b0f4c
format
DeMoorJasper Aug 29, 2018
bbf0cd4
remove matches-pattern
DeMoorJasper Aug 29, 2018
04617c4
get rid of lint issues
DeMoorJasper Aug 29, 2018
03c88b5
fix comment
DeMoorJasper Aug 29, 2018
3acd84a
merge
DeMoorJasper Aug 29, 2018
4af249a
detect babel 6 configs
DeMoorJasper Aug 29, 2018
b371872
remove babylon 6
DeMoorJasper Aug 30, 2018
ad78546
fix getBabelRc
DeMoorJasper Aug 30, 2018
682175c
babel 7 to babel 6 ast convertor v1
DeMoorJasper Aug 30, 2018
8bdb5b3
remove some random code
DeMoorJasper Aug 30, 2018
15a1421
add babel 6 => babel 7 convertor
DeMoorJasper Aug 30, 2018
762cc00
add js tests back in
DeMoorJasper Aug 30, 2018
74ab5f7
fix typo
DeMoorJasper Aug 30, 2018
b0fa467
add babel-runtime
DeMoorJasper Aug 31, 2018
2173572
add babel-runtime for smaller pkg size
DeMoorJasper Aug 31, 2018
16d9fa7
run babel 7 => babel 6 => babel 7
DeMoorJasper Aug 31, 2018
112ebf3
cleanup & add parsing for Babel 6
DeMoorJasper Aug 31, 2018
0dd2663
cleanup some comments
DeMoorJasper Aug 31, 2018
367d5ec
cleanup the empty babel files
DeMoorJasper Aug 31, 2018
e89f06c
Merge pull request #1958 from parcel-bundler/jasper/remove-babel6
devongovett Sep 4, 2018
4b65127
wip
devongovett Sep 9, 2018
62b5b4f
refactor
devongovett Sep 10, 2018
5a02f3e
remove old transform
devongovett Sep 10, 2018
6ce3fc3
Use internal version of babel if no babelrc
devongovett Sep 12, 2018
b73e9e0
Infer version of babel
devongovett Sep 12, 2018
a398af5
Merge pull request #1999 from parcel-bundler/babel7-tmp
devongovett Sep 12, 2018
a814cf8
Remove unused imports
devongovett Sep 12, 2018
341dc8f
Auto install babel plugins as needed
devongovett Sep 15, 2018
f3bc04c
Support babelignore
devongovett Sep 16, 2018
29e2175
fixes
devongovett Sep 16, 2018
10934f0
Fix tests
devongovett Sep 16, 2018
de1e218
lint + prettier
devongovett Sep 16, 2018
5e126c5
Restore removed test
devongovett Sep 16, 2018
e7468cb
Add more babel version autoinstall tests
devongovett Sep 16, 2018
6a53c00
Resolve plugins relative to the correct dir
devongovett Sep 16, 2018
2e3872a
Test autoinstalling babel plugins
devongovett Sep 16, 2018
00e4ab0
Upgrade browserslist
devongovett Sep 16, 2018
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@ lib
*.min.js
test/integration/**/target
test/integration/**/Cargo.lock
test/**/node_modules
test/**/yarn.lock
test/**/package-lock.json
# Logs
logs
*.log
Expand Down
39 changes: 21 additions & 18 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,21 +15,21 @@
"index.js"
],
"dependencies": {
"@babel/code-frame": "^7.0.0",
"@babel/core": "^7.0.0",
"@babel/generator": "^7.0.0",
"@babel/parser": "^7.0.0",
"@babel/plugin-transform-flow-strip-types": "^7.0.0",
"@babel/plugin-transform-modules-commonjs": "^7.0.0",
"@babel/plugin-transform-react-jsx": "^7.0.0",
"@babel/preset-env": "^7.0.0",
"@babel/runtime": "^7.0.0",
"@babel/template": "^7.0.0",
"@babel/traverse": "^7.0.0",
"@babel/types": "^7.0.0",
"ansi-to-html": "^0.6.4",
"babel-code-frame": "^6.26.0",
"babel-core": "^6.25.0",
"babel-generator": "^6.25.0",
"babel-plugin-transform-es2015-modules-commonjs": "^6.26.0",
"babel-plugin-transform-flow-strip-types": "^6.22.0",
"babel-plugin-transform-object-rest-spread": "^6.26.0",
"babel-plugin-transform-react-jsx": "^6.24.1",
"babel-preset-env": "^1.7.0",
"babel-template": "^6.26.0",
"babel-traverse": "^6.26.0",
"babel-types": "^6.26.0",
"babylon": "^6.17.4",
"babylon-walk": "^1.0.2",
"browserslist": "^3.2.6",
"browserslist": "^4.1.0",
"chalk": "^2.1.0",
"clone": "^2.1.1",
"command-exists": "^1.2.6",
Expand Down Expand Up @@ -73,11 +73,14 @@
"ws": "^5.1.1"
},
"devDependencies": {
"@babel/cli": "^7.0.0",
"@babel/plugin-transform-runtime": "^7.0.0",
"@babel/preset-flow": "^7.0.0",
"@babel/register": "^7.0.0",
"@vue/component-compiler-utils": "^2.0.0",
"babel-cli": "^6.26.0",
"babel-plugin-transform-async-super": "^1.0.0",
"babel-polyfill": "^6.26.0",
"babel-register": "^6.26.0",
"babel-core": "^6.26.3",
"babel-preset-env": "^1.7.0",
"babylon": "^6.18.0",
"bsb-js": "^1.0.1",
"codecov": "^3.0.0",
"coffeescript": "^2.0.3",
Expand Down Expand Up @@ -117,7 +120,7 @@
"build": "yarn minify && babel src -d lib && ncp src/builtins lib/builtins",
"prepublish": "yarn build",
"minify": "terser -c -m -o src/builtins/prelude.min.js src/builtins/prelude.js && terser -c -m -o src/builtins/prelude2.min.js src/builtins/prelude2.js",
"precommit": "npm run lint && lint-staged",
"precommit": "lint-staged",
"lint": "eslint . && prettier \"./{src,bin,test}/**/*.{js,json,md}\" --list-different",
"postinstall": "node -e \"console.log('\\u001b[35m\\u001b[1mLove Parcel? You can now donate to our open collective:\\u001b[22m\\u001b[39m\\n > \\u001b[34mhttps://opencollective.com/parcel/donate\\u001b[0m')\""
},
Expand Down
4 changes: 2 additions & 2 deletions src/.babelrc
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
{
"presets": [["env", {
"presets": [["@babel/preset-env", {
"targets": {
"node": "6"
}
}]],
"plugins": ["transform-async-super"],
"plugins": ["@babel/plugin-transform-runtime"],
"ignore": ["builtins"]
}
2 changes: 1 addition & 1 deletion src/Bundler.js
Original file line number Diff line number Diff line change
Expand Up @@ -499,7 +499,7 @@ class Bundler extends EventEmitter {
// If the module resolved (i.e. wasn't a local file), but the module directory wasn't found, install it.
if (resolved.moduleName && !resolved.moduleDir) {
try {
await installPackage([resolved.moduleName], asset.name, {
await installPackage(resolved.moduleName, asset.name, {
saveDev: false
});
} catch (err) {
Expand Down
67 changes: 26 additions & 41 deletions src/assets/JSAsset.js
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
const {File: BabelFile} = require('babel-core');
const traverse = require('babel-traverse').default;
const codeFrame = require('babel-code-frame');
const traverse = require('@babel/traverse').default;
const codeFrame = require('@babel/code-frame').codeFrameColumns;
const collectDependencies = require('../visitors/dependencies');
const walk = require('babylon-walk');
const Asset = require('../Asset');
const babylon = require('babylon');
const babelParser = require('@babel/parser');
const insertGlobals = require('../visitors/globals');
const fsVisitor = require('../visitors/fs');
const envVisitor = require('../visitors/env');
const babel = require('../transforms/babel');
const generate = require('babel-generator').default;
const babel = require('../transforms/babel/transform');
const babel7 = require('../transforms/babel/babel7');
const generate = require('@babel/generator').default;
const terser = require('../transforms/terser');
const SourceMap = require('../SourceMap');
const hoist = require('../scope-hoisting/hoist');
Expand Down Expand Up @@ -60,44 +60,17 @@ class JSAsset extends Asset {
);
}

async getParserOptions() {
// Babylon options. We enable a few plugins by default.
const options = {
async parse(code) {
return babelParser.parse(code, {
filename: this.name,
allowReturnOutsideFunction: true,
allowHashBang: true,
ecmaVersion: Infinity,
strictMode: false,
sourceType: 'module',
locations: true,
plugins: ['exportExtensions', 'dynamicImport']
};

// Check if there is a babel config file. If so, determine which parser plugins to enable
this.babelConfig = await babel.getConfig(this);
if (this.babelConfig) {
const file = new BabelFile(this.babelConfig);
options.plugins.push(...file.parserOpts.plugins);
}

return options;
}

async parse(code) {
const options = await this.getParserOptions();
return babylon.parse(code, options);
plugins: ['exportDefaultFrom', 'exportNamespaceFrom', 'dynamicImport']
});
}

traverse(visitor) {
// Create a babel File object if one hasn't been created yet.
// This is needed so that cached NodePath objects get a `hub` object on them.
// Plugins like babel-minify depend on this to get the original source code string.
if (!this.babelFile) {
this.babelFile = new BabelFile(this.babelConfig || {});
this.babelFile.addCode(this.contents);
this.babelFile.addAst(this.ast);
}

return traverse(this.ast, visitor, null, this);
}

Expand Down Expand Up @@ -214,7 +187,12 @@ class JSAsset extends Asset {
this.isAstDirty = true;
} else {
if (this.isES6Module) {
await babel(this);
await babel7(this, {
internal: true,
config: {
plugins: [require('@babel/plugin-transform-modules-commonjs')]
}
});
}
}

Expand Down Expand Up @@ -285,11 +263,18 @@ class JSAsset extends Asset {
generateErrorMessage(err) {
const loc = err.loc;
if (loc) {
err.codeFrame = codeFrame(this.contents, loc.line, loc.column + 1);
// Babel 7 adds its own code frame on the error message itself
// We need to remove it and pass it separately.
if (err.message.startsWith(this.name)) {
err.message = err.message
.slice(this.name.length + 1, err.message.indexOf('\n'))
.trim();
}

err.codeFrame = codeFrame(this.contents, {start: loc});
err.highlightedCodeFrame = codeFrame(
this.contents,
loc.line,
loc.column + 1,
{start: loc},
{highlightCode: true}
);
}
Expand Down
9 changes: 5 additions & 4 deletions src/packagers/JSConcatPackager.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,8 @@ const concat = require('../scope-hoisting/concat');
const urlJoin = require('../utils/urlJoin');
const getExisting = require('../utils/getExisting');
const walk = require('babylon-walk');
const babylon = require('babylon');
const t = require('babel-types');
const babylon = require('@babel/parser');
const t = require('@babel/types');
const {getName, getIdentifier} = require('../scope-hoisting/utils');

const prelude = getExisting(
Expand Down Expand Up @@ -530,10 +530,11 @@ class JSConcatPackager extends Packager {
// Add source map url if a map bundle exists
let mapBundle = this.bundle.siblingBundlesMap.get('map');
if (mapBundle) {
output += `\n//# sourceMappingURL=${urlJoin(
let mapUrl = urlJoin(
this.options.publicURL,
path.basename(mapBundle.name)
)}`;
);
output += `\n//# sourceMappingURL=${mapUrl}`;
}
}

Expand Down
9 changes: 4 additions & 5 deletions src/packagers/JSPackager.js
Original file line number Diff line number Diff line change
Expand Up @@ -225,12 +225,11 @@ class JSPackager extends Packager {
// Add source map url if a map bundle exists
let mapBundle = this.bundle.siblingBundlesMap.get('map');
if (mapBundle) {
await this.write(
`\n//# sourceMappingURL=${urlJoin(
this.options.publicURL,
path.basename(mapBundle.name)
)}`
let mapUrl = urlJoin(
this.options.publicURL,
path.basename(mapBundle.name)
);
await this.write(`\n//# sourceMappingURL=${mapUrl}`);
}
}
await this.dest.end();
Expand Down
8 changes: 4 additions & 4 deletions src/scope-hoisting/concat.js
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
const {relative} = require('path');
const template = require('babel-template');
const t = require('babel-types');
const traverse = require('babel-traverse').default;
const generate = require('babel-generator').default;
const template = require('@babel/template').default;
const t = require('@babel/types');
const traverse = require('@babel/traverse').default;
const generate = require('@babel/generator').default;
const treeShake = require('./shake');
const mangleScope = require('./mangler');
const {getName, getIdentifier} = require('./utils');
Expand Down
24 changes: 12 additions & 12 deletions src/scope-hoisting/hoist.js
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
const path = require('path');
const matchesPattern = require('../visitors/matches-pattern');
const mm = require('micromatch');
const t = require('babel-types');
const template = require('babel-template');
const t = require('@babel/types');
const template = require('@babel/template').default;
const rename = require('./renamer');
const {getName, getIdentifier, getExportIdentifier} = require('./utils');

Expand Down Expand Up @@ -76,7 +75,7 @@ module.exports = {

ReturnStatement(path) {
// Wrap in a function if we see a top-level return statement.
if (path.getFunctionParent().isProgram()) {
if (!path.getFunctionParent()) {
shouldWrap = true;
asset.cacheData.isCommonJS = true;
path.replaceWith(
Expand Down Expand Up @@ -175,20 +174,20 @@ module.exports = {
return;
}

if (matchesPattern(path.node, 'module.exports')) {
if (t.matchesPattern(path.node, 'module.exports')) {
path.replaceWith(getExportsIdentifier(asset));
asset.cacheData.isCommonJS = true;
}

if (matchesPattern(path.node, 'module.id')) {
if (t.matchesPattern(path.node, 'module.id')) {
path.replaceWith(t.stringLiteral(asset.id));
}

if (matchesPattern(path.node, 'module.hot')) {
if (t.matchesPattern(path.node, 'module.hot')) {
path.replaceWith(t.identifier('null'));
}

if (matchesPattern(path.node, 'module.bundle')) {
if (t.matchesPattern(path.node, 'module.bundle')) {
path.replaceWith(t.identifier('require'));
}
},
Expand Down Expand Up @@ -332,7 +331,7 @@ module.exports = {
);
}

if (matchesPattern(callee, 'require.resolve')) {
if (t.matchesPattern(callee, 'require.resolve')) {
path.replaceWith(
REQUIRE_RESOLVE_CALL_TEMPLATE({
ID: t.stringLiteral(asset.id),
Expand Down Expand Up @@ -523,9 +522,10 @@ function addExport(asset, path, local, exported) {
LOCAL: identifier
});

let constantViolations = scope
.getBinding(local.name)
.constantViolations.concat(path);
let binding = scope.getBinding(local.name);
let constantViolations = binding
? binding.constantViolations.concat(path)
: [path];

if (!asset.cacheData.exports[exported.name]) {
asset.cacheData.exports[exported.name] = identifier.name;
Expand Down
2 changes: 1 addition & 1 deletion src/scope-hoisting/mangler.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
const rename = require('./renamer');
const t = require('babel-types');
const t = require('@babel/types');

const CHARSET = (
'abcdefghijklmnopqrstuvwxyz' + 'ABCDEFGHIJKLMNOPQRSTUVWXYZ$_'
Expand Down
2 changes: 1 addition & 1 deletion src/scope-hoisting/shake.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const t = require('babel-types');
const t = require('@babel/types');

const EXPORTS_RE = /^\$([^$]+)\$exports$/;

Expand Down
2 changes: 1 addition & 1 deletion src/scope-hoisting/utils.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const t = require('babel-types');
const t = require('@babel/types');

function getName(asset, type, ...rest) {
return (
Expand Down
Loading