hermes-parser 0.32.0 → 0.32.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -0
- package/dist/HermesASTAdapter.js +1 -1
- package/dist/HermesASTAdapter.js.flow +1 -1
- package/dist/HermesParserDeserializer.js +0 -1
- package/dist/HermesParserDeserializer.js.flow +0 -1
- package/dist/HermesParserWASM.js +1 -1
- package/dist/ParserOptions.js +1 -1
- package/dist/ParserOptions.js.flow +8 -0
- package/dist/babel/TransformESTreeToBabel.js +3 -0
- package/dist/babel/TransformESTreeToBabel.js.flow +3 -0
- package/dist/estree/{StripComponentSyntax.js → TransformComponentSyntax.js} +1 -1
- package/dist/estree/{StripComponentSyntax.js.flow → TransformComponentSyntax.js.flow} +1 -1
- package/dist/estree/TransformEnumSyntax.js +106 -0
- package/dist/estree/TransformEnumSyntax.js.flow +125 -0
- package/dist/index.js +6 -3
- package/dist/index.js.flow +6 -3
- package/dist/src/HermesASTAdapter.js +1 -1
- package/dist/src/HermesParserDeserializer.js +0 -1
- package/dist/src/ParserOptions.js +1 -1
- package/dist/src/babel/TransformESTreeToBabel.js +3 -0
- package/dist/src/estree/{StripComponentSyntax.js → TransformComponentSyntax.js} +1 -1
- package/dist/src/estree/TransformEnumSyntax.js +106 -0
- package/dist/src/index.js +6 -3
- package/dist/src/transform/SimpleTransform.js +20 -4
- package/dist/src/transform/astNodeMutationHelpers.js +7 -2
- package/dist/transform/SimpleTransform.js +20 -4
- package/dist/transform/SimpleTransform.js.flow +34 -8
- package/dist/transform/astNodeMutationHelpers.js +7 -2
- package/dist/transform/astNodeMutationHelpers.js.flow +10 -2
- package/package.json +2 -2
|
@@ -20,8 +20,15 @@ var _astNodeMutationHelpers = require("./astNodeMutationHelpers");
|
|
|
20
20
|
|
|
21
21
|
function setParentPointer(node, parent) {
|
|
22
22
|
if (parent != null) {
|
|
23
|
-
|
|
24
|
-
|
|
23
|
+
if (Array.isArray(node)) {
|
|
24
|
+
for (const item of node) {
|
|
25
|
+
// $FlowExpectedError[cannot-write]
|
|
26
|
+
item.parent = parent;
|
|
27
|
+
}
|
|
28
|
+
} else {
|
|
29
|
+
// $FlowExpectedError[cannot-write]
|
|
30
|
+
node.parent = parent;
|
|
31
|
+
}
|
|
25
32
|
}
|
|
26
33
|
}
|
|
27
34
|
/**
|
|
@@ -51,7 +58,12 @@ class SimpleTransform {
|
|
|
51
58
|
if (resultNode != null) {
|
|
52
59
|
// Ensure the new node has the correct parent pointers before recursing again.
|
|
53
60
|
setParentPointer(resultNode, parent);
|
|
54
|
-
|
|
61
|
+
|
|
62
|
+
if (Array.isArray(resultNode)) {
|
|
63
|
+
traversedResultNode = resultNode.map(item => this.transform(item, options)).filter(item => item != null);
|
|
64
|
+
} else {
|
|
65
|
+
traversedResultNode = this.transform(resultNode, options);
|
|
66
|
+
}
|
|
55
67
|
}
|
|
56
68
|
|
|
57
69
|
if (parent == null) {
|
|
@@ -59,7 +71,11 @@ class SimpleTransform {
|
|
|
59
71
|
throw new Error('SimpleTransform infra error: Parent not set on non root node, this should not be possible');
|
|
60
72
|
}
|
|
61
73
|
|
|
62
|
-
|
|
74
|
+
if (Array.isArray(traversedResultNode)) {
|
|
75
|
+
throw new Error('SimpleTransform: invalid array result for root node');
|
|
76
|
+
} else {
|
|
77
|
+
resultRootNode = traversedResultNode;
|
|
78
|
+
}
|
|
63
79
|
} else if (traversedResultNode == null) {
|
|
64
80
|
(0, _astNodeMutationHelpers.removeNodeOnParent)(node, parent, options.visitorKeys);
|
|
65
81
|
} else {
|
|
@@ -29,7 +29,9 @@ import {
|
|
|
29
29
|
* children are then traversed.
|
|
30
30
|
* - return null, signals the node should be deleted from the AST.
|
|
31
31
|
*/
|
|
32
|
-
export type TransformCallback = (
|
|
32
|
+
export type TransformCallback = (
|
|
33
|
+
node: ESNode,
|
|
34
|
+
) => ESNode | $ReadOnlyArray<ESNode> | null;
|
|
33
35
|
|
|
34
36
|
export type TransformOptions = $ReadOnly<{
|
|
35
37
|
/** The callback function which is called on entering each node. */
|
|
@@ -39,10 +41,20 @@ export type TransformOptions = $ReadOnly<{
|
|
|
39
41
|
visitorKeys?: ?VisitorKeysType,
|
|
40
42
|
}>;
|
|
41
43
|
|
|
42
|
-
function setParentPointer(
|
|
44
|
+
function setParentPointer(
|
|
45
|
+
node: ESNode | $ReadOnlyArray<ESNode>,
|
|
46
|
+
parent: ?ESNode,
|
|
47
|
+
): void {
|
|
43
48
|
if (parent != null) {
|
|
44
|
-
|
|
45
|
-
|
|
49
|
+
if (Array.isArray(node)) {
|
|
50
|
+
for (const item of node) {
|
|
51
|
+
// $FlowExpectedError[cannot-write]
|
|
52
|
+
item.parent = parent;
|
|
53
|
+
}
|
|
54
|
+
} else {
|
|
55
|
+
// $FlowExpectedError[cannot-write]
|
|
56
|
+
node.parent = parent;
|
|
57
|
+
}
|
|
46
58
|
}
|
|
47
59
|
}
|
|
48
60
|
|
|
@@ -63,15 +75,23 @@ export class SimpleTransform {
|
|
|
63
75
|
// Ensure the parent pointers are correctly set before entering the node.
|
|
64
76
|
setParentPointer(node, parent);
|
|
65
77
|
|
|
66
|
-
const resultNode =
|
|
78
|
+
const resultNode: ESNode | $ReadOnlyArray<ESNode> | null =
|
|
79
|
+
options.transform(node);
|
|
67
80
|
if (resultNode !== node) {
|
|
68
|
-
let traversedResultNode
|
|
81
|
+
let traversedResultNode: ESNode | $ReadOnlyArray<ESNode> | null =
|
|
82
|
+
null;
|
|
69
83
|
|
|
70
84
|
if (resultNode != null) {
|
|
71
85
|
// Ensure the new node has the correct parent pointers before recursing again.
|
|
72
86
|
setParentPointer(resultNode, parent);
|
|
73
87
|
|
|
74
|
-
|
|
88
|
+
if (Array.isArray(resultNode)) {
|
|
89
|
+
traversedResultNode = resultNode
|
|
90
|
+
.map(item => this.transform(item, options))
|
|
91
|
+
.filter(item => item != null);
|
|
92
|
+
} else {
|
|
93
|
+
traversedResultNode = this.transform(resultNode, options);
|
|
94
|
+
}
|
|
75
95
|
}
|
|
76
96
|
|
|
77
97
|
if (parent == null) {
|
|
@@ -80,7 +100,13 @@ export class SimpleTransform {
|
|
|
80
100
|
'SimpleTransform infra error: Parent not set on non root node, this should not be possible',
|
|
81
101
|
);
|
|
82
102
|
}
|
|
83
|
-
|
|
103
|
+
if (Array.isArray(traversedResultNode)) {
|
|
104
|
+
throw new Error(
|
|
105
|
+
'SimpleTransform: invalid array result for root node',
|
|
106
|
+
);
|
|
107
|
+
} else {
|
|
108
|
+
resultRootNode = traversedResultNode;
|
|
109
|
+
}
|
|
84
110
|
} else if (traversedResultNode == null) {
|
|
85
111
|
removeNodeOnParent(node, parent, options.visitorKeys);
|
|
86
112
|
} else {
|
|
@@ -34,6 +34,7 @@ function getParentKey(target, parent, visitorKeys) {
|
|
|
34
34
|
for (const key of (0, _getVisitorKeys.getVisitorKeys)(parent, visitorKeys)) {
|
|
35
35
|
if ((0, _getVisitorKeys.isNode)( // $FlowExpectedError[prop-missing]
|
|
36
36
|
parent[key])) {
|
|
37
|
+
// $FlowFixMe[invalid-compare]
|
|
37
38
|
if (parent[key] === target) {
|
|
38
39
|
return {
|
|
39
40
|
type: 'single',
|
|
@@ -73,9 +74,13 @@ function replaceNodeOnParent(originalNode, originalNodeParent, nodeToReplaceWith
|
|
|
73
74
|
if (replacementParent.type === 'array') {
|
|
74
75
|
// $FlowExpectedError[prop-missing]
|
|
75
76
|
parent[replacementParent.key] = (0, _astArrayMutationHelpers.replaceInArray)( // $FlowExpectedError[prop-missing]
|
|
76
|
-
parent[replacementParent.key], replacementParent.targetIndex, [nodeToReplaceWith]);
|
|
77
|
+
parent[replacementParent.key], replacementParent.targetIndex, Array.isArray(nodeToReplaceWith) ? nodeToReplaceWith : [nodeToReplaceWith]);
|
|
77
78
|
} else {
|
|
78
|
-
|
|
79
|
+
if (Array.isArray(nodeToReplaceWith)) {
|
|
80
|
+
throw new Error(`Cannot insert array into non-array parent type: ${parent.type}`);
|
|
81
|
+
} // $FlowExpectedError[prop-missing]
|
|
82
|
+
|
|
83
|
+
|
|
79
84
|
parent[replacementParent.key] = nodeToReplaceWith;
|
|
80
85
|
}
|
|
81
86
|
}
|
|
@@ -48,6 +48,7 @@ function getParentKey(
|
|
|
48
48
|
parent[key],
|
|
49
49
|
)
|
|
50
50
|
) {
|
|
51
|
+
// $FlowFixMe[invalid-compare]
|
|
51
52
|
if (parent[key] === target) {
|
|
52
53
|
return {type: 'single', node: parent, key};
|
|
53
54
|
}
|
|
@@ -74,7 +75,7 @@ function getParentKey(
|
|
|
74
75
|
export function replaceNodeOnParent(
|
|
75
76
|
originalNode: ESNode,
|
|
76
77
|
originalNodeParent: ESNode,
|
|
77
|
-
nodeToReplaceWith: ESNode
|
|
78
|
+
nodeToReplaceWith: ESNode | $ReadOnlyArray<ESNode>,
|
|
78
79
|
visitorKeys?: ?VisitorKeysType,
|
|
79
80
|
): void {
|
|
80
81
|
const replacementParent = getParentKey(
|
|
@@ -89,9 +90,16 @@ export function replaceNodeOnParent(
|
|
|
89
90
|
// $FlowExpectedError[prop-missing]
|
|
90
91
|
parent[replacementParent.key],
|
|
91
92
|
replacementParent.targetIndex,
|
|
92
|
-
|
|
93
|
+
Array.isArray(nodeToReplaceWith)
|
|
94
|
+
? nodeToReplaceWith
|
|
95
|
+
: [nodeToReplaceWith],
|
|
93
96
|
);
|
|
94
97
|
} else {
|
|
98
|
+
if (Array.isArray(nodeToReplaceWith)) {
|
|
99
|
+
throw new Error(
|
|
100
|
+
`Cannot insert array into non-array parent type: ${parent.type}`,
|
|
101
|
+
);
|
|
102
|
+
}
|
|
95
103
|
// $FlowExpectedError[prop-missing]
|
|
96
104
|
parent[replacementParent.key] = nodeToReplaceWith;
|
|
97
105
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "hermes-parser",
|
|
3
|
-
"version": "0.32.
|
|
3
|
+
"version": "0.32.1",
|
|
4
4
|
"description": "A JavaScript parser built from the Hermes engine",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"license": "MIT",
|
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
"url": "git@github.com:facebook/hermes.git"
|
|
10
10
|
},
|
|
11
11
|
"dependencies": {
|
|
12
|
-
"hermes-estree": "0.32.
|
|
12
|
+
"hermes-estree": "0.32.1"
|
|
13
13
|
},
|
|
14
14
|
"devDependencies": {
|
|
15
15
|
"@babel/parser": "7.7.4",
|