forked from M3-Academy/challenge-algorithms-v2.0
33 lines
718 B
JavaScript
33 lines
718 B
JavaScript
|
"use strict";
|
||
|
|
||
|
Object.defineProperty(exports, "__esModule", {
|
||
|
value: true
|
||
|
});
|
||
|
exports.default = rewriteThis;
|
||
|
|
||
|
var _helperEnvironmentVisitor = require("@babel/helper-environment-visitor");
|
||
|
|
||
|
var _traverse = require("@babel/traverse");
|
||
|
|
||
|
var _t = require("@babel/types");
|
||
|
|
||
|
const {
|
||
|
numericLiteral,
|
||
|
unaryExpression
|
||
|
} = _t;
|
||
|
|
||
|
function rewriteThis(programPath) {
|
||
|
(0, _traverse.default)(programPath.node, Object.assign({}, rewriteThisVisitor, {
|
||
|
noScope: true
|
||
|
}));
|
||
|
}
|
||
|
|
||
|
const rewriteThisVisitor = _traverse.default.visitors.merge([_helperEnvironmentVisitor.default, {
|
||
|
ThisExpression(path) {
|
||
|
path.replaceWith(unaryExpression("void", numericLiteral(0), true));
|
||
|
}
|
||
|
|
||
|
}]);
|
||
|
|
||
|
//# sourceMappingURL=rewrite-this.js.map
|