[79a0317] | 1 | "use strict";
|
---|
| 2 |
|
---|
| 3 | Object.defineProperty(exports, "__esModule", {
|
---|
| 4 | value: true
|
---|
| 5 | });
|
---|
| 6 | exports.extractComputedKeys = extractComputedKeys;
|
---|
| 7 | exports.injectInitialization = injectInitialization;
|
---|
| 8 | exports.memoiseComputedKey = memoiseComputedKey;
|
---|
| 9 | var _core = require("@babel/core");
|
---|
| 10 | var _traverse = require("@babel/traverse");
|
---|
| 11 | const findBareSupers = _traverse.visitors.environmentVisitor({
|
---|
| 12 | Super(path) {
|
---|
| 13 | const {
|
---|
| 14 | node,
|
---|
| 15 | parentPath
|
---|
| 16 | } = path;
|
---|
| 17 | if (parentPath.isCallExpression({
|
---|
| 18 | callee: node
|
---|
| 19 | })) {
|
---|
| 20 | this.push(parentPath);
|
---|
| 21 | }
|
---|
| 22 | }
|
---|
| 23 | });
|
---|
| 24 | const referenceVisitor = {
|
---|
| 25 | "TSTypeAnnotation|TypeAnnotation"(path) {
|
---|
| 26 | path.skip();
|
---|
| 27 | },
|
---|
| 28 | ReferencedIdentifier(path, {
|
---|
| 29 | scope
|
---|
| 30 | }) {
|
---|
| 31 | if (scope.hasOwnBinding(path.node.name)) {
|
---|
| 32 | scope.rename(path.node.name);
|
---|
| 33 | path.skip();
|
---|
| 34 | }
|
---|
| 35 | }
|
---|
| 36 | };
|
---|
| 37 | function handleClassTDZ(path, state) {
|
---|
| 38 | if (state.classBinding && state.classBinding === path.scope.getBinding(path.node.name)) {
|
---|
| 39 | const classNameTDZError = state.file.addHelper("classNameTDZError");
|
---|
| 40 | const throwNode = _core.types.callExpression(classNameTDZError, [_core.types.stringLiteral(path.node.name)]);
|
---|
| 41 | path.replaceWith(_core.types.sequenceExpression([throwNode, path.node]));
|
---|
| 42 | path.skip();
|
---|
| 43 | }
|
---|
| 44 | }
|
---|
| 45 | const classFieldDefinitionEvaluationTDZVisitor = {
|
---|
| 46 | ReferencedIdentifier: handleClassTDZ
|
---|
| 47 | };
|
---|
| 48 | function injectInitialization(path, constructor, nodes, renamer, lastReturnsThis) {
|
---|
| 49 | if (!nodes.length) return;
|
---|
| 50 | const isDerived = !!path.node.superClass;
|
---|
| 51 | if (!constructor) {
|
---|
| 52 | const newConstructor = _core.types.classMethod("constructor", _core.types.identifier("constructor"), [], _core.types.blockStatement([]));
|
---|
| 53 | if (isDerived) {
|
---|
| 54 | newConstructor.params = [_core.types.restElement(_core.types.identifier("args"))];
|
---|
| 55 | newConstructor.body.body.push(_core.template.statement.ast`super(...args)`);
|
---|
| 56 | }
|
---|
| 57 | [constructor] = path.get("body").unshiftContainer("body", newConstructor);
|
---|
| 58 | }
|
---|
| 59 | if (renamer) {
|
---|
| 60 | renamer(referenceVisitor, {
|
---|
| 61 | scope: constructor.scope
|
---|
| 62 | });
|
---|
| 63 | }
|
---|
| 64 | if (isDerived) {
|
---|
| 65 | const bareSupers = [];
|
---|
| 66 | constructor.traverse(findBareSupers, bareSupers);
|
---|
| 67 | let isFirst = true;
|
---|
| 68 | for (const bareSuper of bareSupers) {
|
---|
| 69 | if (isFirst) {
|
---|
| 70 | isFirst = false;
|
---|
| 71 | } else {
|
---|
| 72 | nodes = nodes.map(n => _core.types.cloneNode(n));
|
---|
| 73 | }
|
---|
| 74 | if (!bareSuper.parentPath.isExpressionStatement()) {
|
---|
| 75 | const allNodes = [bareSuper.node, ...nodes.map(n => _core.types.toExpression(n))];
|
---|
| 76 | if (!lastReturnsThis) allNodes.push(_core.types.thisExpression());
|
---|
| 77 | bareSuper.replaceWith(_core.types.sequenceExpression(allNodes));
|
---|
| 78 | } else {
|
---|
| 79 | bareSuper.insertAfter(nodes);
|
---|
| 80 | }
|
---|
| 81 | }
|
---|
| 82 | } else {
|
---|
| 83 | constructor.get("body").unshiftContainer("body", nodes);
|
---|
| 84 | }
|
---|
| 85 | }
|
---|
| 86 | function memoiseComputedKey(keyNode, scope, hint) {
|
---|
| 87 | const isUidReference = _core.types.isIdentifier(keyNode) && scope.hasUid(keyNode.name);
|
---|
| 88 | if (isUidReference) {
|
---|
| 89 | return;
|
---|
| 90 | }
|
---|
| 91 | const isMemoiseAssignment = _core.types.isAssignmentExpression(keyNode, {
|
---|
| 92 | operator: "="
|
---|
| 93 | }) && _core.types.isIdentifier(keyNode.left) && scope.hasUid(keyNode.left.name);
|
---|
| 94 | if (isMemoiseAssignment) {
|
---|
| 95 | return _core.types.cloneNode(keyNode);
|
---|
| 96 | } else {
|
---|
| 97 | const ident = _core.types.identifier(hint);
|
---|
| 98 | scope.push({
|
---|
| 99 | id: ident,
|
---|
| 100 | kind: "let"
|
---|
| 101 | });
|
---|
| 102 | return _core.types.assignmentExpression("=", _core.types.cloneNode(ident), keyNode);
|
---|
| 103 | }
|
---|
| 104 | }
|
---|
| 105 | function extractComputedKeys(path, computedPaths, file) {
|
---|
| 106 | const {
|
---|
| 107 | scope
|
---|
| 108 | } = path;
|
---|
| 109 | const declarations = [];
|
---|
| 110 | const state = {
|
---|
| 111 | classBinding: path.node.id && scope.getBinding(path.node.id.name),
|
---|
| 112 | file
|
---|
| 113 | };
|
---|
| 114 | for (const computedPath of computedPaths) {
|
---|
| 115 | const computedKey = computedPath.get("key");
|
---|
| 116 | if (computedKey.isReferencedIdentifier()) {
|
---|
| 117 | handleClassTDZ(computedKey, state);
|
---|
| 118 | } else {
|
---|
| 119 | computedKey.traverse(classFieldDefinitionEvaluationTDZVisitor, state);
|
---|
| 120 | }
|
---|
| 121 | const computedNode = computedPath.node;
|
---|
| 122 | if (!computedKey.isConstantExpression()) {
|
---|
| 123 | const assignment = memoiseComputedKey(computedKey.node, scope, scope.generateUidBasedOnNode(computedKey.node));
|
---|
| 124 | if (assignment) {
|
---|
| 125 | declarations.push(_core.types.expressionStatement(assignment));
|
---|
| 126 | computedNode.key = _core.types.cloneNode(assignment.left);
|
---|
| 127 | }
|
---|
| 128 | }
|
---|
| 129 | }
|
---|
| 130 | return declarations;
|
---|
| 131 | }
|
---|
| 132 |
|
---|
| 133 | //# sourceMappingURL=misc.js.map
|
---|