first commit
This commit is contained in:
144
app_vue/node_modules/@babel/helper-wrap-function/lib/index.js
generated
vendored
Normal file
144
app_vue/node_modules/@babel/helper-wrap-function/lib/index.js
generated
vendored
Normal file
@ -0,0 +1,144 @@
|
||||
"use strict";
|
||||
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = wrapFunction;
|
||||
var _template = require("@babel/template");
|
||||
var _t = require("@babel/types");
|
||||
const {
|
||||
blockStatement,
|
||||
callExpression,
|
||||
functionExpression,
|
||||
isAssignmentPattern,
|
||||
isFunctionDeclaration,
|
||||
isRestElement,
|
||||
returnStatement,
|
||||
isCallExpression,
|
||||
memberExpression,
|
||||
identifier,
|
||||
thisExpression,
|
||||
isPattern
|
||||
} = _t;
|
||||
const buildAnonymousExpressionWrapper = _template.default.expression(`
|
||||
(function () {
|
||||
var REF = FUNCTION;
|
||||
return function NAME(PARAMS) {
|
||||
return REF.apply(this, arguments);
|
||||
};
|
||||
})()
|
||||
`);
|
||||
const buildNamedExpressionWrapper = _template.default.expression(`
|
||||
(function () {
|
||||
var REF = FUNCTION;
|
||||
function NAME(PARAMS) {
|
||||
return REF.apply(this, arguments);
|
||||
}
|
||||
return NAME;
|
||||
})()
|
||||
`);
|
||||
const buildDeclarationWrapper = _template.default.statements(`
|
||||
function NAME(PARAMS) { return REF.apply(this, arguments); }
|
||||
function REF() {
|
||||
REF = FUNCTION;
|
||||
return REF.apply(this, arguments);
|
||||
}
|
||||
`);
|
||||
function classOrObjectMethod(path, callId, ignoreFunctionLength) {
|
||||
const node = path.node;
|
||||
const body = node.body;
|
||||
let params = [];
|
||||
const shoudlForwardParams = node.params.some(p => isPattern(p));
|
||||
if (shoudlForwardParams) {
|
||||
params = node.params;
|
||||
node.params = [];
|
||||
if (!ignoreFunctionLength) {
|
||||
for (const param of params) {
|
||||
if (isAssignmentPattern(param) || isRestElement(param)) {
|
||||
break;
|
||||
}
|
||||
node.params.push(path.scope.generateUidIdentifier("x"));
|
||||
}
|
||||
}
|
||||
}
|
||||
const container = functionExpression(null, params, blockStatement(body.body), true);
|
||||
if (shoudlForwardParams) {
|
||||
body.body = [returnStatement(callExpression(memberExpression(callExpression(callId, [container]), identifier("apply")), [thisExpression(), identifier("arguments")]))];
|
||||
path.get("body.body.0.argument.callee.object.arguments.0").unwrapFunctionEnvironment();
|
||||
} else {
|
||||
body.body = [returnStatement(callExpression(callExpression(callId, [container]), []))];
|
||||
path.get("body.body.0.argument.callee.arguments.0").unwrapFunctionEnvironment();
|
||||
}
|
||||
node.async = false;
|
||||
node.generator = false;
|
||||
}
|
||||
function plainFunction(inPath, callId, noNewArrows, ignoreFunctionLength, hadName) {
|
||||
let path = inPath;
|
||||
let node;
|
||||
let functionId = null;
|
||||
const nodeParams = inPath.node.params;
|
||||
if (path.isArrowFunctionExpression()) {
|
||||
{
|
||||
var _path$arrowFunctionTo;
|
||||
path = (_path$arrowFunctionTo = path.arrowFunctionToExpression({
|
||||
noNewArrows
|
||||
})) != null ? _path$arrowFunctionTo : path;
|
||||
}
|
||||
node = path.node;
|
||||
} else {
|
||||
node = path.node;
|
||||
}
|
||||
const isDeclaration = isFunctionDeclaration(node);
|
||||
let built = node;
|
||||
if (!isCallExpression(node)) {
|
||||
functionId = node.id;
|
||||
node.id = null;
|
||||
node.type = "FunctionExpression";
|
||||
built = callExpression(callId, [node]);
|
||||
}
|
||||
const params = [];
|
||||
for (const param of nodeParams) {
|
||||
if (isAssignmentPattern(param) || isRestElement(param)) {
|
||||
break;
|
||||
}
|
||||
params.push(path.scope.generateUidIdentifier("x"));
|
||||
}
|
||||
const wrapperArgs = {
|
||||
NAME: functionId || null,
|
||||
REF: path.scope.generateUidIdentifier(hadName ? functionId.name : "ref"),
|
||||
FUNCTION: built,
|
||||
PARAMS: params
|
||||
};
|
||||
if (isDeclaration) {
|
||||
const container = buildDeclarationWrapper(wrapperArgs);
|
||||
path.replaceWith(container[0]);
|
||||
path.insertAfter(container[1]);
|
||||
} else {
|
||||
let container;
|
||||
if (hadName) {
|
||||
container = buildNamedExpressionWrapper(wrapperArgs);
|
||||
} else {
|
||||
container = buildAnonymousExpressionWrapper(wrapperArgs);
|
||||
}
|
||||
if (functionId || !ignoreFunctionLength && params.length) {
|
||||
path.replaceWith(container);
|
||||
} else {
|
||||
path.replaceWith(built);
|
||||
}
|
||||
}
|
||||
}
|
||||
function wrapFunction(path, callId, noNewArrows = true, ignoreFunctionLength = false) {
|
||||
if (path.isMethod()) {
|
||||
classOrObjectMethod(path, callId, ignoreFunctionLength);
|
||||
} else {
|
||||
const hadName = "id" in path.node && !!path.node.id;
|
||||
{
|
||||
var _path, _path$ensureFunctionN;
|
||||
(_path$ensureFunctionN = (_path = path).ensureFunctionName) != null ? _path$ensureFunctionN : _path.ensureFunctionName = require("@babel/traverse").NodePath.prototype.ensureFunctionName;
|
||||
}
|
||||
path = path.ensureFunctionName(false);
|
||||
plainFunction(path, callId, noNewArrows, ignoreFunctionLength, hadName);
|
||||
}
|
||||
}
|
||||
|
||||
//# sourceMappingURL=index.js.map
|
Reference in New Issue
Block a user