"use strict";
|
|
Object.defineProperty(exports, "__esModule", {
|
value: true
|
});
|
exports.ForAwaitStatement = exports.NumericLiteralTypeAnnotation = exports.ExistentialTypeParam = exports.SpreadProperty = exports.RestProperty = exports.Flow = exports.Pure = exports.Generated = exports.User = exports.Var = exports.BlockScoped = exports.Referenced = exports.Scope = exports.Expression = exports.Statement = exports.BindingIdentifier = exports.ReferencedMemberExpression = exports.ReferencedIdentifier = void 0;
|
|
function t() {
|
const data = _interopRequireWildcard(require("@babel/types"));
|
|
t = function () {
|
return data;
|
};
|
|
return data;
|
}
|
|
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
|
|
const ReferencedIdentifier = {
|
types: ["Identifier", "JSXIdentifier"],
|
|
checkPath(path, opts) {
|
const {
|
node,
|
parent
|
} = path;
|
|
if (!t().isIdentifier(node, opts) && !t().isJSXMemberExpression(parent, opts)) {
|
if (t().isJSXIdentifier(node, opts)) {
|
if (t().react.isCompatTag(node.name)) return false;
|
} else {
|
return false;
|
}
|
}
|
|
return t().isReferenced(node, parent, path.parentPath.parent);
|
}
|
|
};
|
exports.ReferencedIdentifier = ReferencedIdentifier;
|
const ReferencedMemberExpression = {
|
types: ["MemberExpression"],
|
|
checkPath({
|
node,
|
parent
|
}) {
|
return t().isMemberExpression(node) && t().isReferenced(node, parent);
|
}
|
|
};
|
exports.ReferencedMemberExpression = ReferencedMemberExpression;
|
const BindingIdentifier = {
|
types: ["Identifier"],
|
|
checkPath(path) {
|
const {
|
node,
|
parent
|
} = path;
|
const grandparent = path.parentPath.parent;
|
return t().isIdentifier(node) && t().isBinding(node, parent, grandparent);
|
}
|
|
};
|
exports.BindingIdentifier = BindingIdentifier;
|
const Statement = {
|
types: ["Statement"],
|
|
checkPath({
|
node,
|
parent
|
}) {
|
if (t().isStatement(node)) {
|
if (t().isVariableDeclaration(node)) {
|
if (t().isForXStatement(parent, {
|
left: node
|
})) return false;
|
if (t().isForStatement(parent, {
|
init: node
|
})) return false;
|
}
|
|
return true;
|
} else {
|
return false;
|
}
|
}
|
|
};
|
exports.Statement = Statement;
|
const Expression = {
|
types: ["Expression"],
|
|
checkPath(path) {
|
if (path.isIdentifier()) {
|
return path.isReferencedIdentifier();
|
} else {
|
return t().isExpression(path.node);
|
}
|
}
|
|
};
|
exports.Expression = Expression;
|
const Scope = {
|
types: ["Scopable"],
|
|
checkPath(path) {
|
return t().isScope(path.node, path.parent);
|
}
|
|
};
|
exports.Scope = Scope;
|
const Referenced = {
|
checkPath(path) {
|
return t().isReferenced(path.node, path.parent);
|
}
|
|
};
|
exports.Referenced = Referenced;
|
const BlockScoped = {
|
checkPath(path) {
|
return t().isBlockScoped(path.node);
|
}
|
|
};
|
exports.BlockScoped = BlockScoped;
|
const Var = {
|
types: ["VariableDeclaration"],
|
|
checkPath(path) {
|
return t().isVar(path.node);
|
}
|
|
};
|
exports.Var = Var;
|
const User = {
|
checkPath(path) {
|
return path.node && !!path.node.loc;
|
}
|
|
};
|
exports.User = User;
|
const Generated = {
|
checkPath(path) {
|
return !path.isUser();
|
}
|
|
};
|
exports.Generated = Generated;
|
const Pure = {
|
checkPath(path, opts) {
|
return path.scope.isPure(path.node, opts);
|
}
|
|
};
|
exports.Pure = Pure;
|
const Flow = {
|
types: ["Flow", "ImportDeclaration", "ExportDeclaration", "ImportSpecifier"],
|
|
checkPath({
|
node
|
}) {
|
if (t().isFlow(node)) {
|
return true;
|
} else if (t().isImportDeclaration(node)) {
|
return node.importKind === "type" || node.importKind === "typeof";
|
} else if (t().isExportDeclaration(node)) {
|
return node.exportKind === "type";
|
} else if (t().isImportSpecifier(node)) {
|
return node.importKind === "type" || node.importKind === "typeof";
|
} else {
|
return false;
|
}
|
}
|
|
};
|
exports.Flow = Flow;
|
const RestProperty = {
|
types: ["RestElement"],
|
|
checkPath(path) {
|
return path.parentPath && path.parentPath.isObjectPattern();
|
}
|
|
};
|
exports.RestProperty = RestProperty;
|
const SpreadProperty = {
|
types: ["RestElement"],
|
|
checkPath(path) {
|
return path.parentPath && path.parentPath.isObjectExpression();
|
}
|
|
};
|
exports.SpreadProperty = SpreadProperty;
|
const ExistentialTypeParam = {
|
types: ["ExistsTypeAnnotation"]
|
};
|
exports.ExistentialTypeParam = ExistentialTypeParam;
|
const NumericLiteralTypeAnnotation = {
|
types: ["NumberLiteralTypeAnnotation"]
|
};
|
exports.NumericLiteralTypeAnnotation = NumericLiteralTypeAnnotation;
|
const ForAwaitStatement = {
|
types: ["ForOfStatement"],
|
|
checkPath({
|
node
|
}) {
|
return node.await === true;
|
}
|
|
};
|
exports.ForAwaitStatement = ForAwaitStatement;
|