- `mutableTemplateObject` and `ignoreToPrimitiveHint` (#12408) - `setClassMethods` (#12407) - `setComputedProperties` (#12490) - `ignoreFunctionLength` (#12491) - `noDocumentAll` (#12481) - `iterableIsArray` and `arrayLikeIsIterable` (#12489) - `pureGetters` (#12504) - `skipForOfIteratorClosing` (#12496) - `objectRestNoSymbols`, `setSpreadProperties` and `pureGetters` (#12505) - `noNewArrows` (#12613, #12793) - `setPublicClassFields` and `privateFieldsAsProperties` (#12497) - `constantReexports` and `enumerableModuleMeta` (#12618) - `constantSuper`, `superIsCallableConstructor` and `noClassCalls` (#12726) Co-authored-by: Justin Ridgewell <justin@ridgewell.name> Co-authored-by: Huáng Jùnliàng <JLHwung@users.noreply.github.com>
33 lines
1.0 KiB
JavaScript
33 lines
1.0 KiB
JavaScript
import { declare } from "@babel/helper-plugin-utils";
|
|
import type NodePath from "@babel/traverse";
|
|
|
|
export default declare((api, options) => {
|
|
api.assertVersion(7);
|
|
|
|
const noNewArrows = api.assumption("noNewArrows") ?? !options.spec;
|
|
|
|
return {
|
|
name: "transform-arrow-functions",
|
|
|
|
visitor: {
|
|
ArrowFunctionExpression(
|
|
path: NodePath<BabelNodeArrowFunctionExpression>,
|
|
) {
|
|
// In some conversion cases, it may have already been converted to a function while this callback
|
|
// was queued up.
|
|
if (!path.isArrowFunctionExpression()) return;
|
|
|
|
path.arrowFunctionToExpression({
|
|
// While other utils may be fine inserting other arrows to make more transforms possible,
|
|
// the arrow transform itself absolutely cannot insert new arrow functions.
|
|
allowInsertArrow: false,
|
|
noNewArrows,
|
|
|
|
// TODO(Babel 8): This is only needed for backward compat with @babel/traverse <7.13.0
|
|
specCompliant: !noNewArrows,
|
|
});
|
|
},
|
|
},
|
|
};
|
|
});
|