Update with working working version (#12)

* Fix workflow

* Trigger

* [auto] Update compiled version

* [auto] Commit modules

* Push Windows changes

* Fix

* [auto] Update compiled version

* Try removing cwd

* [auto] Update compiled version

* Try with path module

* [auto] Update compiled version

* Fix path

* [auto] Update compiled version

* Use raw path

* [auto] Update compiled version

* Other path

* [auto] Update compiled version

* Avoid @action/exec

* [auto] Update compiled version

* test

* [auto] Update compiled version

* test

* [auto] Update compiled version

* test

* [auto] Update compiled version

* test

* [auto] Update compiled version

* Try with shelljs

* [auto] Update compiled version

* Fix my stupidity

* Copy scripts to local dir

* [auto] Update compiled version

* Still use path

* [auto] Update compiled version

* Delete entrypoint.sh

* [auto] Update compiled version

* Make file executable

* [auto] Update compiled version

* Try using bash

* [auto] Update compiled version
This commit is contained in:
Federico Grandi
2019-12-14 21:47:13 +01:00
committed by GitHub
parent d81e04e96c
commit f118062594
4276 changed files with 1075004 additions and 40 deletions

9
node_modules/babel-helper-mark-eval-scopes/README.md generated vendored Normal file
View File

@@ -0,0 +1,9 @@
# babel-helper-mark-eval-scopes
Traverse through input path and mark all scopes that contain Direct eval (`eval("")`) calls.
## Installation
```sh
npm install babel-helper-mark-eval-scopes --save-dev
```

View File

@@ -0,0 +1,48 @@
jest.autoMockOff();
const babel = require("@babel/core");
const helper = require("../src");
function getPath(source) {
let path;
babel.transform(source, {
babelrc: false,
plugins: [
function({ traverse }) {
(traverse.clearCache || traverse.cache.clear)();
return {
visitor: {
Program(programPath) {
path = programPath;
}
}
};
}
]
});
return path;
}
describe("babel-helper-mark-eval-scopes", () => {
it("getEvalScopes - should give a set of scopes which contains eval", () => {
const source = `
function foo() {
function bar() {
eval(";");
}
function baz() {
noeval();
}
}
`;
const program = getPath(source);
const evalScopes = [...helper.getEvalScopes(program)];
expect(evalScopes).toContain(program.scope);
expect(evalScopes).toContain(program.get("body.0.body.body.0").scope);
expect(evalScopes).not.toContain(program.get("body.0.body.body.1").scope);
});
});

View File

@@ -0,0 +1,53 @@
"use strict";
const EVAL_SCOPE_MARKER = Symbol("evalInScope");
module.exports = {
EVAL_SCOPE_MARKER,
getEvalScopes,
markEvalScopes,
isMarked,
hasEval
};
function getEvalScopes(path) {
const evalScopes = new Set();
function add(scope) {
let evalScope = scope;
do {
evalScopes.add(evalScope);
} while (evalScope = evalScope.parent);
}
path.traverse({
CallExpression(evalPath) {
const callee = evalPath.get("callee");
if (callee.isIdentifier() && callee.node.name === "eval" && !callee.scope.getBinding("eval")) {
add(callee.scope);
}
}
});
return evalScopes;
}
function markEvalScopes(path, key = EVAL_SCOPE_MARKER) {
const evalScopes = getEvalScopes(path);
[...evalScopes].forEach(scope => {
scope[key] = true;
});
}
function isMarked(scope, key = EVAL_SCOPE_MARKER) {
return Object.prototype.hasOwnProperty.call(scope, key);
}
function hasEval(scope, key = EVAL_SCOPE_MARKER) {
if (!isMarked(scope, key)) {
markEvalScopes(scope, key);
}
return scope[key];
}

View File

@@ -0,0 +1,52 @@
{
"_args": [
[
"babel-helper-mark-eval-scopes@0.4.3",
"/home/runner/work/add-and-commit/add-and-commit"
]
],
"_development": true,
"_from": "babel-helper-mark-eval-scopes@0.4.3",
"_id": "babel-helper-mark-eval-scopes@0.4.3",
"_inBundle": false,
"_integrity": "sha1-0kSjvvmESHJgP/tG4izorN9VFWI=",
"_location": "/babel-helper-mark-eval-scopes",
"_phantomChildren": {},
"_requested": {
"type": "version",
"registry": true,
"raw": "babel-helper-mark-eval-scopes@0.4.3",
"name": "babel-helper-mark-eval-scopes",
"escapedName": "babel-helper-mark-eval-scopes",
"rawSpec": "0.4.3",
"saveSpec": null,
"fetchSpec": "0.4.3"
},
"_requiredBy": [
"/babel-plugin-minify-dead-code-elimination",
"/babel-plugin-minify-mangle-names"
],
"_resolved": "https://registry.npmjs.org/babel-helper-mark-eval-scopes/-/babel-helper-mark-eval-scopes-0.4.3.tgz",
"_spec": "0.4.3",
"_where": "/home/runner/work/add-and-commit/add-and-commit",
"author": {
"name": "boopathi"
},
"bugs": {
"url": "https://github.com/babel/minify/issues"
},
"description": "Mark scopes for deopt which contain a direct eval call",
"homepage": "https://github.com/babel/minify#readme",
"keywords": [
"babel-minify",
"babel-plugin"
],
"license": "MIT",
"main": "lib/index.js",
"name": "babel-helper-mark-eval-scopes",
"repository": {
"type": "git",
"url": "https://github.com/babel/minify/tree/master/packages/babel-helper-mark-eval-scopes"
},
"version": "0.4.3"
}

View File

@@ -0,0 +1,56 @@
"use strict";
const EVAL_SCOPE_MARKER = Symbol("evalInScope");
module.exports = {
EVAL_SCOPE_MARKER,
getEvalScopes,
markEvalScopes,
isMarked,
hasEval
};
function getEvalScopes(path) {
const evalScopes = new Set();
function add(scope) {
let evalScope = scope;
do {
evalScopes.add(evalScope);
} while ((evalScope = evalScope.parent));
}
path.traverse({
CallExpression(evalPath) {
const callee = evalPath.get("callee");
if (
callee.isIdentifier() &&
callee.node.name === "eval" &&
!callee.scope.getBinding("eval")
) {
add(callee.scope);
}
}
});
return evalScopes;
}
function markEvalScopes(path, key = EVAL_SCOPE_MARKER) {
const evalScopes = getEvalScopes(path);
[...evalScopes].forEach(scope => {
scope[key] = true;
});
}
function isMarked(scope, key = EVAL_SCOPE_MARKER) {
return Object.prototype.hasOwnProperty.call(scope, key);
}
function hasEval(scope, key = EVAL_SCOPE_MARKER) {
if (!isMarked(scope, key)) {
markEvalScopes(scope, key);
}
return scope[key];
}