Merge pull request #7436 from loganfsmyth/less-upfront-work

Default to `ast:false` and do less work when loading core
This commit is contained in:
Logan Smyth 2018-02-27 18:03:53 -08:00 committed by GitHub
commit bf8b25289b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 160 additions and 114 deletions

View File

@ -3,7 +3,6 @@
import path from "path"; import path from "path";
import * as context from "../index"; import * as context from "../index";
import Plugin from "./plugin"; import Plugin from "./plugin";
import merge from "lodash/merge";
import { import {
buildRootChain, buildRootChain,
buildPresetChain, buildPresetChain,
@ -13,10 +12,9 @@ import {
} from "./config-chain"; } from "./config-chain";
import type { UnloadedDescriptor } from "./config-descriptors"; import type { UnloadedDescriptor } from "./config-descriptors";
import traverse from "@babel/traverse"; import traverse from "@babel/traverse";
import clone from "lodash/clone";
import { makeWeakCache, type CacheConfigurator } from "./caching"; import { makeWeakCache, type CacheConfigurator } from "./caching";
import { getEnv } from "./helpers/environment"; import { getEnv } from "./helpers/environment";
import { validate } from "./validation/options"; import { validate, type ValidatedOptions } from "./validation/options";
import { validatePluginObject } from "./validation/plugins"; import { validatePluginObject } from "./validation/plugins";
type LoadedDescriptor = { type LoadedDescriptor = {
@ -109,7 +107,7 @@ export default function loadConfig(inputOpts: mixed): ResolvedConfig | null {
if (ignored) return true; if (ignored) return true;
preset.options.forEach(opts => { preset.options.forEach(opts => {
merge(optionDefaults, opts); mergeOptions(optionDefaults, opts);
}); });
} }
} }
@ -129,7 +127,7 @@ export default function loadConfig(inputOpts: mixed): ResolvedConfig | null {
if (ignored) return null; if (ignored) return null;
configChain.options.forEach(opts => { configChain.options.forEach(opts => {
merge(options, opts); mergeOptions(options, opts);
}); });
} catch (e) { } catch (e) {
// There are a few case where thrown errors will try to annotate themselves multiple times, so // There are a few case where thrown errors will try to annotate themselves multiple times, so
@ -141,7 +139,8 @@ export default function loadConfig(inputOpts: mixed): ResolvedConfig | null {
throw e; throw e;
} }
const opts: Object = merge(optionDefaults, options); const opts: Object = optionDefaults;
mergeOptions(opts, options);
// Tack the passes onto the object itself so that, if this object is passed back to Babel a second time, // Tack the passes onto the object itself so that, if this object is passed back to Babel a second time,
// it will be in the right structure to not change behavior. // it will be in the right structure to not change behavior.
@ -161,6 +160,33 @@ export default function loadConfig(inputOpts: mixed): ResolvedConfig | null {
}; };
} }
function mergeOptions(
target: ValidatedOptions,
source: ValidatedOptions,
): void {
for (const k of Object.keys(source)) {
if (k === "parserOpts" && source.parserOpts) {
const parserOpts = source.parserOpts;
const targetObj = (target.parserOpts = target.parserOpts || {});
mergeDefaultFields(targetObj, parserOpts);
} else if (k === "generatorOpts" && source.generatorOpts) {
const generatorOpts = source.generatorOpts;
const targetObj = (target.generatorOpts = target.generatorOpts || {});
mergeDefaultFields(targetObj, generatorOpts);
} else {
const val = source[k];
if (val !== undefined) target[k] = (val: any);
}
}
}
function mergeDefaultFields<T: {}>(target: T, source: T) {
for (const k of Object.keys(source)) {
const val = source[k];
if (val !== undefined) target[k] = (val: any);
}
}
/** /**
* Load a generic plugin/preset from the given descriptor loaded from the config object. * Load a generic plugin/preset from the given descriptor loaded from the config object.
*/ */
@ -238,7 +264,7 @@ const instantiatePlugin = makeWeakCache(
const plugin = Object.assign({}, pluginObj); const plugin = Object.assign({}, pluginObj);
if (plugin.visitor) { if (plugin.visitor) {
plugin.visitor = traverse.explode(clone(plugin.visitor)); plugin.visitor = traverse.explode(Object.assign({}, plugin.visitor));
} }
if (plugin.inherits) { if (plugin.inherits) {

View File

@ -3,19 +3,22 @@ import generator from "@babel/generator";
import template from "@babel/template"; import template from "@babel/template";
import * as t from "@babel/types"; import * as t from "@babel/types";
const buildUmdWrapper = template(` // Wrapped to avoid wasting time parsing this when almost no-one uses
(function (root, factory) { // build-external-helpers.
if (typeof define === "function" && define.amd) { const buildUmdWrapper = replacements =>
define(AMD_ARGUMENTS, factory); template`
} else if (typeof exports === "object") { (function (root, factory) {
factory(COMMON_ARGUMENTS); if (typeof define === "function" && define.amd) {
} else { define(AMD_ARGUMENTS, factory);
factory(BROWSER_ARGUMENTS); } else if (typeof exports === "object") {
} factory(COMMON_ARGUMENTS);
})(UMD_ROOT, function (FACTORY_PARAMETERS) { } else {
FACTORY_BODY factory(BROWSER_ARGUMENTS);
}); }
`); })(UMD_ROOT, function (FACTORY_PARAMETERS) {
FACTORY_BODY
});
`(replacements);
function buildGlobal(whitelist) { function buildGlobal(whitelist) {
const namespace = t.identifier("babelHelpers"); const namespace = t.identifier("babelHelpers");

View File

@ -64,7 +64,7 @@ export function runSync(
return { return {
metadata: file.metadata, metadata: file.metadata,
options: opts, options: opts,
ast: opts.ast !== false ? file.ast : null, ast: opts.ast === true ? file.ast : null,
code: outputCode === undefined ? null : outputCode, code: outputCode === undefined ? null : outputCode,
map: outputMap === undefined ? null : outputMap, map: outputMap === undefined ? null : outputMap,
}; };

View File

@ -34,6 +34,7 @@ describe("parser and generator options", function() {
function newTransform(string) { function newTransform(string) {
return babel.transform(string, { return babel.transform(string, {
ast: true,
parserOpts: { parserOpts: {
parser: recast.parse, parser: recast.parse,
plugins: ["flow"], plugins: ["flow"],
@ -47,7 +48,10 @@ describe("parser and generator options", function() {
it("options", function() { it("options", function() {
const string = "original;"; const string = "original;";
assert.deepEqual(newTransform(string).ast, babel.transform(string).ast); assert.deepEqual(
newTransform(string).ast,
babel.transform(string, { ast: true }).ast,
);
assert.equal(newTransform(string).code, string); assert.equal(newTransform(string).code, string);
}); });
@ -57,6 +61,7 @@ describe("parser and generator options", function() {
assert.deepEqual( assert.deepEqual(
newTransform(experimental).ast, newTransform(experimental).ast,
babel.transform(experimental, { babel.transform(experimental, {
ast: true,
parserOpts: { parserOpts: {
plugins: ["flow"], plugins: ["flow"],
}, },
@ -66,6 +71,7 @@ describe("parser and generator options", function() {
function newTransformWithPlugins(string) { function newTransformWithPlugins(string) {
return babel.transform(string, { return babel.transform(string, {
ast: true,
plugins: [__dirname + "/../../babel-plugin-syntax-flow"], plugins: [__dirname + "/../../babel-plugin-syntax-flow"],
parserOpts: { parserOpts: {
parser: recast.parse, parser: recast.parse,
@ -79,6 +85,7 @@ describe("parser and generator options", function() {
assert.deepEqual( assert.deepEqual(
newTransformWithPlugins(experimental).ast, newTransformWithPlugins(experimental).ast,
babel.transform(experimental, { babel.transform(experimental, {
ast: true,
parserOpts: { parserOpts: {
plugins: ["flow"], plugins: ["flow"],
}, },
@ -93,6 +100,7 @@ describe("parser and generator options", function() {
assert.notEqual( assert.notEqual(
newTransform(experimental).ast, newTransform(experimental).ast,
babel.transform(experimental, { babel.transform(experimental, {
ast: true,
parserOpts: { parserOpts: {
allowImportExportEverywhere: true, allowImportExportEverywhere: true,
}, },
@ -401,6 +409,18 @@ describe("api", function() {
}); });
}); });
it("ast option true", function() {
return transformAsync("foo('bar');", { ast: true }).then(function(result) {
assert.ok(result.ast);
});
});
it("ast option default", function() {
return transformAsync("foo('bar');").then(function(result) {
assert.ok(!result.ast);
});
});
it("auxiliaryComment option", function() { it("auxiliaryComment option", function() {
return transformAsync("class Foo {}", { return transformAsync("class Foo {}", {
auxiliaryCommentBefore: "before", auxiliaryCommentBefore: "before",

View File

@ -5,11 +5,7 @@ import template from "@babel/template";
const helpers = {}; const helpers = {};
export default helpers; export default helpers;
// Helpers never include placeholders, so we disable placeholder pattern helpers.typeof = () => template.program.ast`
// matching to allow us to use pattern-like variable names.
const defineHelper = template.program({ placeholderPattern: false });
helpers.typeof = defineHelper(`
export default function _typeof(obj) { export default function _typeof(obj) {
if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
_typeof = function (obj) { return typeof obj; }; _typeof = function (obj) { return typeof obj; };
@ -23,9 +19,9 @@ helpers.typeof = defineHelper(`
return _typeof(obj); return _typeof(obj);
} }
`); `;
helpers.jsx = defineHelper(` helpers.jsx = () => template.program.ast`
var REACT_ELEMENT_TYPE; var REACT_ELEMENT_TYPE;
export default function _createRawReactElement(type, props, key, children) { export default function _createRawReactElement(type, props, key, children) {
@ -72,9 +68,9 @@ helpers.jsx = defineHelper(`
_owner: null, _owner: null,
}; };
} }
`); `;
helpers.asyncIterator = defineHelper(` helpers.asyncIterator = () => template.program.ast`
export default function _asyncIterator(iterable) { export default function _asyncIterator(iterable) {
if (typeof Symbol === "function") { if (typeof Symbol === "function") {
if (Symbol.asyncIterator) { if (Symbol.asyncIterator) {
@ -87,15 +83,15 @@ helpers.asyncIterator = defineHelper(`
} }
throw new TypeError("Object is not async iterable"); throw new TypeError("Object is not async iterable");
} }
`); `;
helpers.AwaitValue = defineHelper(` helpers.AwaitValue = () => template.program.ast`
export default function _AwaitValue(value) { export default function _AwaitValue(value) {
this.wrapped = value; this.wrapped = value;
} }
`); `;
helpers.AsyncGenerator = defineHelper(` helpers.AsyncGenerator = () => template.program.ast`
import AwaitValue from "AwaitValue"; import AwaitValue from "AwaitValue";
export default function AsyncGenerator(gen) { export default function AsyncGenerator(gen) {
@ -177,9 +173,9 @@ helpers.AsyncGenerator = defineHelper(`
AsyncGenerator.prototype.next = function (arg) { return this._invoke("next", arg); }; AsyncGenerator.prototype.next = function (arg) { return this._invoke("next", arg); };
AsyncGenerator.prototype.throw = function (arg) { return this._invoke("throw", arg); }; AsyncGenerator.prototype.throw = function (arg) { return this._invoke("throw", arg); };
AsyncGenerator.prototype.return = function (arg) { return this._invoke("return", arg); }; AsyncGenerator.prototype.return = function (arg) { return this._invoke("return", arg); };
`); `;
helpers.wrapAsyncGenerator = defineHelper(` helpers.wrapAsyncGenerator = () => template.program.ast`
import AsyncGenerator from "AsyncGenerator"; import AsyncGenerator from "AsyncGenerator";
export default function _wrapAsyncGenerator(fn) { export default function _wrapAsyncGenerator(fn) {
@ -187,17 +183,17 @@ helpers.wrapAsyncGenerator = defineHelper(`
return new AsyncGenerator(fn.apply(this, arguments)); return new AsyncGenerator(fn.apply(this, arguments));
}; };
} }
`); `;
helpers.awaitAsyncGenerator = defineHelper(` helpers.awaitAsyncGenerator = () => template.program.ast`
import AwaitValue from "AwaitValue"; import AwaitValue from "AwaitValue";
export default function _awaitAsyncGenerator(value) { export default function _awaitAsyncGenerator(value) {
return new AwaitValue(value); return new AwaitValue(value);
} }
`); `;
helpers.asyncGeneratorDelegate = defineHelper(` helpers.asyncGeneratorDelegate = () => template.program.ast`
export default function _asyncGeneratorDelegate(inner, awaitWrap) { export default function _asyncGeneratorDelegate(inner, awaitWrap) {
var iter = {}, waiting = false; var iter = {}, waiting = false;
@ -237,9 +233,9 @@ helpers.asyncGeneratorDelegate = defineHelper(`
return iter; return iter;
} }
`); `;
helpers.asyncToGenerator = defineHelper(` helpers.asyncToGenerator = () => template.program.ast`
export default function _asyncToGenerator(fn) { export default function _asyncToGenerator(fn) {
return function () { return function () {
var self = this, args = arguments; var self = this, args = arguments;
@ -267,17 +263,17 @@ helpers.asyncToGenerator = defineHelper(`
}); });
}; };
} }
`); `;
helpers.classCallCheck = defineHelper(` helpers.classCallCheck = () => template.program.ast`
export default function _classCallCheck(instance, Constructor) { export default function _classCallCheck(instance, Constructor) {
if (!(instance instanceof Constructor)) { if (!(instance instanceof Constructor)) {
throw new TypeError("Cannot call a class as a function"); throw new TypeError("Cannot call a class as a function");
} }
} }
`); `;
helpers.createClass = defineHelper(` helpers.createClass = () => template.program.ast`
function _defineProperties(target, props) { function _defineProperties(target, props) {
for (var i = 0; i < props.length; i ++) { for (var i = 0; i < props.length; i ++) {
var descriptor = props[i]; var descriptor = props[i];
@ -293,9 +289,9 @@ helpers.createClass = defineHelper(`
if (staticProps) _defineProperties(Constructor, staticProps); if (staticProps) _defineProperties(Constructor, staticProps);
return Constructor; return Constructor;
} }
`); `;
helpers.defineEnumerableProperties = defineHelper(` helpers.defineEnumerableProperties = () => template.program.ast`
export default function _defineEnumerableProperties(obj, descs) { export default function _defineEnumerableProperties(obj, descs) {
for (var key in descs) { for (var key in descs) {
var desc = descs[key]; var desc = descs[key];
@ -319,9 +315,9 @@ helpers.defineEnumerableProperties = defineHelper(`
} }
return obj; return obj;
} }
`); `;
helpers.defaults = defineHelper(` helpers.defaults = () => template.program.ast`
export default function _defaults(obj, defaults) { export default function _defaults(obj, defaults) {
var keys = Object.getOwnPropertyNames(defaults); var keys = Object.getOwnPropertyNames(defaults);
for (var i = 0; i < keys.length; i++) { for (var i = 0; i < keys.length; i++) {
@ -333,9 +329,9 @@ helpers.defaults = defineHelper(`
} }
return obj; return obj;
} }
`); `;
helpers.defineProperty = defineHelper(` helpers.defineProperty = () => template.program.ast`
export default function _defineProperty(obj, key, value) { export default function _defineProperty(obj, key, value) {
// Shortcircuit the slow defineProperty path when possible. // Shortcircuit the slow defineProperty path when possible.
// We are trying to avoid issues where setters defined on the // We are trying to avoid issues where setters defined on the
@ -354,9 +350,9 @@ helpers.defineProperty = defineHelper(`
} }
return obj; return obj;
} }
`); `;
helpers.extends = defineHelper(` helpers.extends = () => template.program.ast`
export default function _extends() { export default function _extends() {
_extends = Object.assign || function (target) { _extends = Object.assign || function (target) {
for (var i = 1; i < arguments.length; i++) { for (var i = 1; i < arguments.length; i++) {
@ -372,9 +368,9 @@ helpers.extends = defineHelper(`
return _extends.apply(this, arguments); return _extends.apply(this, arguments);
} }
`); `;
helpers.objectSpread = defineHelper(` helpers.objectSpread = () => template.program.ast`
import defineProperty from "defineProperty"; import defineProperty from "defineProperty";
export default function _objectSpread(target) { export default function _objectSpread(target) {
@ -392,9 +388,9 @@ helpers.objectSpread = defineHelper(`
} }
return target; return target;
} }
`); `;
helpers.get = defineHelper(` helpers.get = () => template.program.ast`
export default function _get(object, property, receiver) { export default function _get(object, property, receiver) {
if (object === null) object = Function.prototype; if (object === null) object = Function.prototype;
@ -420,9 +416,9 @@ helpers.get = defineHelper(`
return getter.call(receiver); return getter.call(receiver);
} }
} }
`); `;
helpers.inherits = defineHelper(` helpers.inherits = () => template.program.ast`
export default function _inherits(subClass, superClass) { export default function _inherits(subClass, superClass) {
if (typeof superClass !== "function" && superClass !== null) { if (typeof superClass !== "function" && superClass !== null) {
throw new TypeError("Super expression must either be null or a function"); throw new TypeError("Super expression must either be null or a function");
@ -437,18 +433,18 @@ helpers.inherits = defineHelper(`
}); });
if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;
} }
`); `;
helpers.inheritsLoose = defineHelper(` helpers.inheritsLoose = () => template.program.ast`
export default function _inheritsLoose(subClass, superClass) { export default function _inheritsLoose(subClass, superClass) {
subClass.prototype = Object.create(superClass.prototype); subClass.prototype = Object.create(superClass.prototype);
subClass.prototype.constructor = subClass; subClass.prototype.constructor = subClass;
subClass.__proto__ = superClass; subClass.__proto__ = superClass;
} }
`); `;
// Based on https://github.com/WebReflection/babel-plugin-transform-builtin-classes // Based on https://github.com/WebReflection/babel-plugin-transform-builtin-classes
helpers.wrapNativeSuper = defineHelper(` helpers.wrapNativeSuper = () => template.program.ast`
var _gPO = Object.getPrototypeOf || function _gPO(o) { return o.__proto__ }; var _gPO = Object.getPrototypeOf || function _gPO(o) { return o.__proto__ };
var _sPO = Object.setPrototypeOf || function _sPO(o, p) { o.__proto__ = p; return o }; var _sPO = Object.setPrototypeOf || function _sPO(o, p) { o.__proto__ = p; return o };
var _construct = (typeof Reflect === "object" && Reflect.construct) || var _construct = (typeof Reflect === "object" && Reflect.construct) ||
@ -490,9 +486,9 @@ helpers.wrapNativeSuper = defineHelper(`
) )
); );
} }
`); `;
helpers.instanceof = defineHelper(` helpers.instanceof = () => template.program.ast`
export default function _instanceof(left, right) { export default function _instanceof(left, right) {
if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) { if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
return right[Symbol.hasInstance](left); return right[Symbol.hasInstance](left);
@ -500,15 +496,15 @@ helpers.instanceof = defineHelper(`
return left instanceof right; return left instanceof right;
} }
} }
`); `;
helpers.interopRequireDefault = defineHelper(` helpers.interopRequireDefault = () => template.program.ast`
export default function _interopRequireDefault(obj) { export default function _interopRequireDefault(obj) {
return obj && obj.__esModule ? obj : { default: obj }; return obj && obj.__esModule ? obj : { default: obj };
} }
`); `;
helpers.interopRequireWildcard = defineHelper(` helpers.interopRequireWildcard = () => template.program.ast`
export default function _interopRequireWildcard(obj) { export default function _interopRequireWildcard(obj) {
if (obj && obj.__esModule) { if (obj && obj.__esModule) {
return obj; return obj;
@ -532,23 +528,23 @@ helpers.interopRequireWildcard = defineHelper(`
return newObj; return newObj;
} }
} }
`); `;
helpers.newArrowCheck = defineHelper(` helpers.newArrowCheck = () => template.program.ast`
export default function _newArrowCheck(innerThis, boundThis) { export default function _newArrowCheck(innerThis, boundThis) {
if (innerThis !== boundThis) { if (innerThis !== boundThis) {
throw new TypeError("Cannot instantiate an arrow function"); throw new TypeError("Cannot instantiate an arrow function");
} }
} }
`); `;
helpers.objectDestructuringEmpty = defineHelper(` helpers.objectDestructuringEmpty = () => template.program.ast`
export default function _objectDestructuringEmpty(obj) { export default function _objectDestructuringEmpty(obj) {
if (obj == null) throw new TypeError("Cannot destructure undefined"); if (obj == null) throw new TypeError("Cannot destructure undefined");
} }
`); `;
helpers.objectWithoutProperties = defineHelper(` helpers.objectWithoutProperties = () => template.program.ast`
export default function _objectWithoutProperties(source, excluded) { export default function _objectWithoutProperties(source, excluded) {
if (source == null) return {}; if (source == null) return {};
@ -574,18 +570,18 @@ helpers.objectWithoutProperties = defineHelper(`
return target; return target;
} }
`); `;
helpers.assertThisInitialized = defineHelper(` helpers.assertThisInitialized = () => template.program.ast`
export default function _assertThisInitialized(self) { export default function _assertThisInitialized(self) {
if (self === void 0) { if (self === void 0) {
throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
} }
return self; return self;
} }
`); `;
helpers.possibleConstructorReturn = defineHelper(` helpers.possibleConstructorReturn = () => template.program.ast`
export default function _possibleConstructorReturn(self, call) { export default function _possibleConstructorReturn(self, call) {
if (call && (typeof call === "object" || typeof call === "function")) { if (call && (typeof call === "object" || typeof call === "function")) {
return call; return call;
@ -598,9 +594,9 @@ helpers.possibleConstructorReturn = defineHelper(`
} }
return self; return self;
} }
`); `;
helpers.set = defineHelper(` helpers.set = () => template.program.ast`
export default function _set(object, property, value, receiver) { export default function _set(object, property, value, receiver) {
var desc = Object.getOwnPropertyDescriptor(object, property); var desc = Object.getOwnPropertyDescriptor(object, property);
@ -622,9 +618,9 @@ helpers.set = defineHelper(`
return value; return value;
} }
`); `;
helpers.slicedToArray = defineHelper(` helpers.slicedToArray = () => template.program.ast`
// Broken out into a separate function to avoid deoptimizations due to the try/catch for the // Broken out into a separate function to avoid deoptimizations due to the try/catch for the
// array iterator case. // array iterator case.
function _sliceIterator(arr, i) { function _sliceIterator(arr, i) {
@ -669,9 +665,9 @@ helpers.slicedToArray = defineHelper(`
throw new TypeError("Invalid attempt to destructure non-iterable instance"); throw new TypeError("Invalid attempt to destructure non-iterable instance");
} }
} }
`); `;
helpers.slicedToArrayLoose = defineHelper(` helpers.slicedToArrayLoose = () => template.program.ast`
export default function _slicedToArrayLoose(arr, i) { export default function _slicedToArrayLoose(arr, i) {
if (Array.isArray(arr)) { if (Array.isArray(arr)) {
return arr; return arr;
@ -686,26 +682,26 @@ helpers.slicedToArrayLoose = defineHelper(`
throw new TypeError("Invalid attempt to destructure non-iterable instance"); throw new TypeError("Invalid attempt to destructure non-iterable instance");
} }
} }
`); `;
helpers.taggedTemplateLiteral = defineHelper(` helpers.taggedTemplateLiteral = () => template.program.ast`
export default function _taggedTemplateLiteral(strings, raw) { export default function _taggedTemplateLiteral(strings, raw) {
if (!raw) { raw = strings.slice(0); } if (!raw) { raw = strings.slice(0); }
return Object.freeze(Object.defineProperties(strings, { return Object.freeze(Object.defineProperties(strings, {
raw: { value: Object.freeze(raw) } raw: { value: Object.freeze(raw) }
})); }));
} }
`); `;
helpers.taggedTemplateLiteralLoose = defineHelper(` helpers.taggedTemplateLiteralLoose = () => template.program.ast`
export default function _taggedTemplateLiteralLoose(strings, raw) { export default function _taggedTemplateLiteralLoose(strings, raw) {
if (!raw) { raw = strings.slice(0); } if (!raw) { raw = strings.slice(0); }
strings.raw = raw; strings.raw = raw;
return strings; return strings;
} }
`); `;
helpers.temporalRef = defineHelper(` helpers.temporalRef = () => template.program.ast`
import undef from "temporalUndefined"; import undef from "temporalUndefined";
export default function _temporalRef(val, name) { export default function _temporalRef(val, name) {
@ -715,31 +711,31 @@ helpers.temporalRef = defineHelper(`
return val; return val;
} }
} }
`); `;
helpers.readOnlyError = defineHelper(` helpers.readOnlyError = () => template.program.ast`
export default function _readOnlyError(name) { export default function _readOnlyError(name) {
throw new Error("\\"" + name + "\\" is read-only"); throw new Error("\\"" + name + "\\" is read-only");
} }
`); `;
helpers.classNameTDZError = defineHelper(` helpers.classNameTDZError = () => template.program.ast`
export default function _classNameTDZError(name) { export default function _classNameTDZError(name) {
throw new Error("Class \\"" + name + "\\" cannot be referenced in computed property keys."); throw new Error("Class \\"" + name + "\\" cannot be referenced in computed property keys.");
} }
`); `;
helpers.temporalUndefined = defineHelper(` helpers.temporalUndefined = () => template.program.ast`
export default {}; export default {};
`); `;
helpers.toArray = defineHelper(` helpers.toArray = () => template.program.ast`
export default function _toArray(arr) { export default function _toArray(arr) {
return Array.isArray(arr) ? arr : Array.from(arr); return Array.isArray(arr) ? arr : Array.from(arr);
} }
`); `;
helpers.toConsumableArray = defineHelper(` helpers.toConsumableArray = () => template.program.ast`
export default function _toConsumableArray(arr) { export default function _toConsumableArray(arr) {
if (Array.isArray(arr)) { if (Array.isArray(arr)) {
for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) arr2[i] = arr[i]; for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];
@ -748,9 +744,9 @@ helpers.toConsumableArray = defineHelper(`
return Array.from(arr); return Array.from(arr);
} }
} }
`); `;
helpers.skipFirstGeneratorNext = defineHelper(` helpers.skipFirstGeneratorNext = () => template.program.ast`
export default function _skipFirstGeneratorNext(fn) { export default function _skipFirstGeneratorNext(fn) {
return function () { return function () {
var it = fn.apply(this, arguments); var it = fn.apply(this, arguments);
@ -758,9 +754,9 @@ helpers.skipFirstGeneratorNext = defineHelper(`
return it; return it;
} }
} }
`); `;
helpers.toPropertyKey = defineHelper(` helpers.toPropertyKey = () => template.program.ast`
export default function _toPropertyKey(key) { export default function _toPropertyKey(key) {
if (typeof key === "symbol") { if (typeof key === "symbol") {
return key; return key;
@ -768,13 +764,13 @@ helpers.toPropertyKey = defineHelper(`
return String(key); return String(key);
} }
} }
`); `;
/** /**
* Add a helper that will throw a useful error if the transform fails to detect the class * Add a helper that will throw a useful error if the transform fails to detect the class
* property assignment, so users know something failed. * property assignment, so users know something failed.
*/ */
helpers.initializerWarningHelper = defineHelper(` helpers.initializerWarningHelper = () => template.program.ast`
export default function _initializerWarningHelper(descriptor, context){ export default function _initializerWarningHelper(descriptor, context){
throw new Error( throw new Error(
'Decorating class property failed. Please ensure that ' + 'Decorating class property failed. Please ensure that ' +
@ -783,12 +779,12 @@ helpers.initializerWarningHelper = defineHelper(`
'the next major version of decorators in stage 2.' 'the next major version of decorators in stage 2.'
); );
} }
`); `;
/** /**
* Add a helper to call as a replacement for class property definition. * Add a helper to call as a replacement for class property definition.
*/ */
helpers.initializerDefineProperty = defineHelper(` helpers.initializerDefineProperty = () => template.program.ast`
export default function _initializerDefineProperty(target, property, descriptor, context){ export default function _initializerDefineProperty(target, property, descriptor, context){
if (!descriptor) return; if (!descriptor) return;
@ -799,13 +795,13 @@ helpers.initializerDefineProperty = defineHelper(`
value: descriptor.initializer ? descriptor.initializer.call(context) : void 0, value: descriptor.initializer ? descriptor.initializer.call(context) : void 0,
}); });
} }
`); `;
/** /**
* Add a helper to take an initial descriptor, apply some decorators to it, and optionally * Add a helper to take an initial descriptor, apply some decorators to it, and optionally
* define the property. * define the property.
*/ */
helpers.applyDecoratedDescriptor = defineHelper(` helpers.applyDecoratedDescriptor = () => template.program.ast`
export default function _applyDecoratedDescriptor(target, property, decorators, descriptor, context){ export default function _applyDecoratedDescriptor(target, property, decorators, descriptor, context){
var desc = {}; var desc = {};
Object['ke' + 'ys'](descriptor).forEach(function(key){ Object['ke' + 'ys'](descriptor).forEach(function(key){
@ -835,4 +831,4 @@ helpers.applyDecoratedDescriptor = defineHelper(`
return desc; return desc;
} }
`); `;

View File

@ -5,6 +5,7 @@ test("Doesn't use the same object for two different nodes in the AST", function(
const code = 'import Foo from "bar"; Foo; Foo;'; const code = 'import Foo from "bar"; Foo; Foo;';
const ast = babel.transform(code, { const ast = babel.transform(code, {
ast: true,
plugins: [[require("../"), { loose: true }]], plugins: [[require("../"), { loose: true }]],
}).ast; }).ast;