aboutsummaryrefslogtreecommitdiff
path: root/node_modules/babel-plugin-espower/lib/to-be-captured.js
diff options
context:
space:
mode:
authorFlorian Dold <florian.dold@gmail.com>2017-05-28 00:38:50 +0200
committerFlorian Dold <florian.dold@gmail.com>2017-05-28 00:40:43 +0200
commit7fff4499fd915bcea3fa93b1aa8b35f4fe7a6027 (patch)
tree6de9a1aebd150a23b7f8c273ec657a5d0a18fe3e /node_modules/babel-plugin-espower/lib/to-be-captured.js
parent963b7a41feb29cc4be090a2446bdfe0c1f1bcd81 (diff)
add linting (and some initial fixes)
Diffstat (limited to 'node_modules/babel-plugin-espower/lib/to-be-captured.js')
-rw-r--r--node_modules/babel-plugin-espower/lib/to-be-captured.js56
1 files changed, 56 insertions, 0 deletions
diff --git a/node_modules/babel-plugin-espower/lib/to-be-captured.js b/node_modules/babel-plugin-espower/lib/to-be-captured.js
new file mode 100644
index 000000000..248fe5366
--- /dev/null
+++ b/node_modules/babel-plugin-espower/lib/to-be-captured.js
@@ -0,0 +1,56 @@
+'use strict';
+
+var typesToBeCaptured = [
+ 'Identifier',
+ 'BinaryExpression',
+ 'MemberExpression',
+ 'CallExpression',
+ 'UnaryExpression',
+ 'LogicalExpression',
+ 'ArrayExpression',
+ 'ObjectExpression',
+ 'TemplateLiteral',
+ 'YieldExpression',
+ 'AwaitExpression',
+ 'NewExpression',
+ 'AssignmentExpression',
+ 'UpdateExpression',
+ 'TaggedTemplateExpression'
+];
+
+function isCaputuringTargetType (types, nodePath) {
+ var currentNode = nodePath.node;
+ return typesToBeCaptured.some(function (nodeType) {
+ return types['is' + nodeType](currentNode);
+ });
+}
+
+function isCalleeOfParent(types, nodePath) {
+ var currentKey = nodePath.key;
+ var parentNode = nodePath.parent;
+ return (types.isCallExpression(parentNode) || types.isNewExpression(parentNode)) && currentKey === 'callee';
+}
+
+function isChildOfTaggedTemplateExpression(types, nodePath) {
+ var parentNode = nodePath.parent;
+ return types.isTaggedTemplateExpression(parentNode);
+}
+
+function isYieldOrAwaitArgument(types, nodePath) {
+ var currentKey = nodePath.key;
+ var parentNode = nodePath.parent;
+ // capture the yielded/await result, not the promise
+ return (types.isYieldExpression(parentNode) || types.isAwaitExpression(parentNode)) && currentKey === 'argument';
+}
+
+var blacklist = [
+ isYieldOrAwaitArgument,
+ isCalleeOfParent,
+ isChildOfTaggedTemplateExpression
+];
+
+module.exports = function toBeCaptured (types, nodePath) {
+ return isCaputuringTargetType(types, nodePath) && !blacklist.some(function (predicate) {
+ return predicate(types, nodePath);
+ });
+};