hermes-estree 0.31.2 → 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.
Files changed (82) hide show
  1. package/dist/HermesAST.js.flow +57 -0
  2. package/dist/HermesASTAdapter.js +192 -0
  3. package/dist/HermesASTAdapter.js.flow +189 -0
  4. package/dist/HermesParser.js +108 -0
  5. package/dist/HermesParser.js.flow +161 -0
  6. package/dist/HermesParserDecodeUTF8String.js +68 -0
  7. package/dist/HermesParserDecodeUTF8String.js.flow +65 -0
  8. package/dist/HermesParserDeserializer.js +242 -0
  9. package/dist/HermesParserDeserializer.js.flow +260 -0
  10. package/dist/HermesParserNodeDeserializers.js +2477 -0
  11. package/dist/HermesParserNodeDeserializers.js.flow +16 -0
  12. package/dist/HermesParserWASM.js +6 -0
  13. package/dist/HermesParserWASM.js.flow +87 -0
  14. package/dist/HermesToESTreeAdapter.js +439 -0
  15. package/dist/HermesToESTreeAdapter.js.flow +421 -0
  16. package/dist/ParserOptions.js +18 -0
  17. package/dist/ParserOptions.js.flow +41 -0
  18. package/dist/babel/TransformESTreeToBabel.js +1123 -0
  19. package/dist/babel/TransformESTreeToBabel.js.flow +1277 -0
  20. package/dist/estree/StripFlowTypes.js +175 -0
  21. package/dist/estree/StripFlowTypes.js.flow +158 -0
  22. package/dist/estree/StripFlowTypesForBabel.js +215 -0
  23. package/dist/estree/StripFlowTypesForBabel.js.flow +216 -0
  24. package/dist/estree/TransformComponentSyntax.js +788 -0
  25. package/dist/estree/TransformComponentSyntax.js.flow +864 -0
  26. package/dist/estree/TransformEnumSyntax.js +106 -0
  27. package/dist/estree/TransformEnumSyntax.js.flow +125 -0
  28. package/dist/estree/TransformMatchSyntax.js +1006 -0
  29. package/dist/estree/TransformMatchSyntax.js.flow +912 -0
  30. package/dist/generated/ESTreeVisitorKeys.js +220 -0
  31. package/dist/generated/ESTreeVisitorKeys.js.flow +15 -0
  32. package/dist/generated/ParserVisitorKeys.js +794 -0
  33. package/dist/generated/ParserVisitorKeys.js.flow +17 -0
  34. package/dist/getModuleDocblock.js +112 -0
  35. package/dist/getModuleDocblock.js.flow +118 -0
  36. package/dist/predicates.js +1 -0
  37. package/dist/predicates.js.flow +1 -0
  38. package/dist/src/HermesASTAdapter.js +192 -0
  39. package/dist/src/HermesParser.js +108 -0
  40. package/dist/src/HermesParserDecodeUTF8String.js +68 -0
  41. package/dist/src/HermesParserDeserializer.js +242 -0
  42. package/dist/src/HermesParserNodeDeserializers.js +2477 -0
  43. package/dist/src/HermesToESTreeAdapter.js +439 -0
  44. package/dist/src/ParserOptions.js +18 -0
  45. package/dist/src/babel/TransformESTreeToBabel.js +1123 -0
  46. package/dist/src/estree/StripFlowTypes.js +175 -0
  47. package/dist/src/estree/StripFlowTypesForBabel.js +215 -0
  48. package/dist/src/estree/TransformComponentSyntax.js +788 -0
  49. package/dist/src/estree/TransformEnumSyntax.js +106 -0
  50. package/dist/src/estree/TransformMatchSyntax.js +1006 -0
  51. package/dist/src/generated/ESTreeVisitorKeys.js +220 -0
  52. package/dist/src/generated/ParserVisitorKeys.js +794 -0
  53. package/dist/src/getModuleDocblock.js +112 -0
  54. package/dist/src/predicates.js +1 -0
  55. package/dist/src/transform/SimpleTransform.js +136 -0
  56. package/dist/src/transform/astArrayMutationHelpers.js +62 -0
  57. package/dist/src/transform/astNodeMutationHelpers.js +200 -0
  58. package/dist/src/traverse/SimpleTraverser.js +137 -0
  59. package/dist/src/traverse/getVisitorKeys.js +37 -0
  60. package/dist/src/utils/Builders.js +191 -0
  61. package/dist/src/utils/GenID.js +41 -0
  62. package/dist/src/utils/createSyntaxError.js +25 -0
  63. package/dist/src/utils/mutateESTreeASTForPrettier.js +127 -0
  64. package/dist/transform/SimpleTransform.js +136 -0
  65. package/dist/transform/SimpleTransform.js.flow +169 -0
  66. package/dist/transform/astArrayMutationHelpers.js +62 -0
  67. package/dist/transform/astArrayMutationHelpers.js.flow +71 -0
  68. package/dist/transform/astNodeMutationHelpers.js +200 -0
  69. package/dist/transform/astNodeMutationHelpers.js.flow +246 -0
  70. package/dist/traverse/SimpleTraverser.js +137 -0
  71. package/dist/traverse/SimpleTraverser.js.flow +133 -0
  72. package/dist/traverse/getVisitorKeys.js +37 -0
  73. package/dist/traverse/getVisitorKeys.js.flow +36 -0
  74. package/dist/utils/Builders.js +191 -0
  75. package/dist/utils/Builders.js.flow +218 -0
  76. package/dist/utils/GenID.js +41 -0
  77. package/dist/utils/GenID.js.flow +38 -0
  78. package/dist/utils/createSyntaxError.js +25 -0
  79. package/dist/utils/createSyntaxError.js.flow +24 -0
  80. package/dist/utils/mutateESTreeASTForPrettier.js +127 -0
  81. package/dist/utils/mutateESTreeASTForPrettier.js.flow +130 -0
  82. package/package.json +1 -1
@@ -0,0 +1,421 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ * @flow strict
8
+ * @format
9
+ */
10
+
11
+ import type {HermesNode} from './HermesAST';
12
+ import type {ParserOptions} from './ParserOptions';
13
+
14
+ import HermesASTAdapter from './HermesASTAdapter';
15
+ import {getModuleDocblock} from './getModuleDocblock';
16
+
17
+ declare var BigInt: ?(value: $FlowFixMe) => mixed;
18
+
19
+ export default class HermesToESTreeAdapter extends HermesASTAdapter {
20
+ +code: string;
21
+
22
+ constructor(options: ParserOptions, code: string) {
23
+ super(options);
24
+ this.code = code;
25
+ }
26
+
27
+ fixSourceLocation(node: HermesNode): void {
28
+ const loc = node.loc;
29
+ if (loc == null) {
30
+ return;
31
+ }
32
+
33
+ node.loc = {
34
+ source: this.sourceFilename ?? null,
35
+ start: loc.start,
36
+ end: loc.end,
37
+ };
38
+
39
+ node.range = [loc.rangeStart, loc.rangeEnd];
40
+
41
+ delete node.start;
42
+ delete node.end;
43
+ }
44
+
45
+ mapNode(node: HermesNode): HermesNode {
46
+ this.fixSourceLocation(node);
47
+ switch (node.type) {
48
+ case 'Program':
49
+ return this.mapProgram(node);
50
+ case 'NullLiteral':
51
+ return this.mapNullLiteral(node);
52
+ case 'BooleanLiteral':
53
+ case 'StringLiteral':
54
+ case 'NumericLiteral':
55
+ case 'JSXStringLiteral':
56
+ return this.mapSimpleLiteral(node);
57
+ case 'BigIntLiteral':
58
+ return this.mapBigIntLiteral(node);
59
+ case 'RegExpLiteral':
60
+ return this.mapRegExpLiteral(node);
61
+ case 'Empty':
62
+ return this.mapEmpty(node);
63
+ case 'TemplateElement':
64
+ return this.mapTemplateElement(node);
65
+ case 'BigIntLiteralTypeAnnotation':
66
+ return this.mapBigIntLiteralTypeAnnotation(node);
67
+ case 'GenericTypeAnnotation':
68
+ return this.mapGenericTypeAnnotation(node);
69
+ case 'ImportDeclaration':
70
+ return this.mapImportDeclaration(node);
71
+ case 'ImportSpecifier':
72
+ return this.mapImportSpecifier(node);
73
+ case 'ExportDefaultDeclaration':
74
+ return this.mapExportDefaultDeclaration(node);
75
+ case 'ExportNamedDeclaration':
76
+ return this.mapExportNamedDeclaration(node);
77
+ case 'ExportAllDeclaration':
78
+ return this.mapExportAllDeclaration(node);
79
+ case 'FunctionDeclaration':
80
+ case 'FunctionExpression':
81
+ case 'ArrowFunctionExpression':
82
+ return this.mapFunction(node);
83
+ case 'PrivateName':
84
+ return this.mapPrivateName(node);
85
+ case 'ClassProperty':
86
+ case 'ClassPrivateProperty':
87
+ return this.mapClassProperty(node);
88
+ case 'MemberExpression':
89
+ case 'OptionalMemberExpression':
90
+ case 'CallExpression':
91
+ case 'OptionalCallExpression':
92
+ return this.mapChainExpression(node);
93
+ case 'BlockStatement':
94
+ return this.mapBlockStatement(node);
95
+ default:
96
+ return this.mapNodeDefault(node);
97
+ }
98
+ }
99
+
100
+ mapProgram(node: HermesNode): HermesNode {
101
+ const nodeDefault = this.mapNodeDefault(node);
102
+ node.sourceType = this.getSourceType();
103
+
104
+ node.docblock = getModuleDocblock(nodeDefault);
105
+
106
+ return nodeDefault;
107
+ }
108
+
109
+ mapSimpleLiteral(node: HermesNode): HermesNode {
110
+ return {
111
+ type: 'Literal',
112
+ loc: node.loc,
113
+ range: node.range,
114
+ value: node.value,
115
+ raw: this.code.slice(node.range[0], node.range[1]),
116
+ literalType: (() => {
117
+ switch (node.type) {
118
+ case 'NullLiteral':
119
+ return 'null';
120
+
121
+ case 'BooleanLiteral':
122
+ return 'boolean';
123
+
124
+ case 'StringLiteral':
125
+ case 'JSXStringLiteral':
126
+ return 'string';
127
+
128
+ case 'NumericLiteral':
129
+ return 'numeric';
130
+
131
+ case 'BigIntLiteral':
132
+ return 'bigint';
133
+
134
+ case 'RegExpLiteral':
135
+ return 'regexp';
136
+ }
137
+ return null;
138
+ })(),
139
+ };
140
+ }
141
+
142
+ mapBigIntLiteral(node: HermesNode): HermesNode {
143
+ const newNode = this.mapSimpleLiteral(node);
144
+ return {
145
+ ...newNode,
146
+ ...this.getBigIntLiteralValue(node.bigint),
147
+ };
148
+ }
149
+
150
+ mapNullLiteral(node: HermesNode): HermesNode {
151
+ return {
152
+ ...this.mapSimpleLiteral(node),
153
+ value: null,
154
+ };
155
+ }
156
+
157
+ mapRegExpLiteral(node: HermesNode): HermesNode {
158
+ const {pattern, flags} = node;
159
+
160
+ // Create RegExp value if possible. This can fail when the flags are invalid.
161
+ let value;
162
+ try {
163
+ value = new RegExp(pattern, flags);
164
+ } catch (e) {
165
+ value = null;
166
+ }
167
+
168
+ return {
169
+ ...this.mapSimpleLiteral(node),
170
+ value,
171
+ regex: {
172
+ pattern,
173
+ flags,
174
+ },
175
+ };
176
+ }
177
+
178
+ mapBigIntLiteralTypeAnnotation(node: HermesNode): HermesNode {
179
+ return {
180
+ ...node,
181
+ ...this.getBigIntLiteralValue(node.raw),
182
+ };
183
+ }
184
+
185
+ mapTemplateElement(node: HermesNode): HermesNode {
186
+ return {
187
+ type: 'TemplateElement',
188
+ loc: node.loc,
189
+ range: node.range,
190
+ tail: node.tail,
191
+ value: {
192
+ cooked: node.cooked,
193
+ raw: node.raw,
194
+ },
195
+ };
196
+ }
197
+
198
+ mapGenericTypeAnnotation(node: HermesNode): HermesNode {
199
+ // Convert simple `this` generic type to ThisTypeAnnotation
200
+ if (
201
+ node.typeParameters == null &&
202
+ node.id.type === 'Identifier' &&
203
+ node.id.name === 'this'
204
+ ) {
205
+ return {
206
+ type: 'ThisTypeAnnotation',
207
+ loc: node.loc,
208
+ range: node.range,
209
+ };
210
+ }
211
+
212
+ return this.mapNodeDefault(node);
213
+ }
214
+
215
+ mapComment(node: HermesNode): HermesNode {
216
+ if (node.type === 'CommentBlock') {
217
+ node.type = 'Block';
218
+ } else if (node.type === 'CommentLine') {
219
+ node.type = 'Line';
220
+ }
221
+
222
+ return node;
223
+ }
224
+
225
+ mapFunction(nodeUnprocessed: HermesNode): HermesNode {
226
+ const node = this.mapNodeDefault(nodeUnprocessed);
227
+
228
+ switch (node.type) {
229
+ // This prop should ideally only live on `ArrowFunctionExpression` but to
230
+ // match espree output we place it on all functions types.
231
+ case 'FunctionDeclaration':
232
+ case 'FunctionExpression':
233
+ node.expression = false;
234
+ return node;
235
+
236
+ case 'ArrowFunctionExpression':
237
+ node.expression = node.body.type !== 'BlockStatement';
238
+ return node;
239
+ }
240
+
241
+ return node;
242
+ }
243
+
244
+ mapChainExpression(nodeUnprocessed: HermesNode): HermesNode {
245
+ /*
246
+ NOTE - In the below comments `MemberExpression` and `CallExpression`
247
+ are completely interchangable. For terseness we just reference
248
+ one each time.
249
+ */
250
+
251
+ /*
252
+ Hermes uses the old babel-style AST:
253
+ ```
254
+ (one?.two).three?.four;
255
+ ^^^^^^^^^^^^^^^^^^^^^^ OptionalMemberExpression
256
+ ^^^^^^^^^^^^^^^^ MemberExpression
257
+ ^^^^^^^^ OptionalMemberExpression
258
+ ```
259
+
260
+ We need to convert it to the ESTree representation:
261
+ ```
262
+ (one?.two).three?.four;
263
+ ^^^^^^^^^^^^^^^^^^^^^^ ChainExpression
264
+ ^^^^^^^^^^^^^^^^^^^^^^ MemberExpression[optional = true]
265
+ ^^^^^^^^^^^^^^^^ MemberExpression[optional = false]
266
+ ^^^^^^^^ ChainExpression
267
+ ^^^^^^^^ MemberExpression[optional = true]
268
+ ```
269
+
270
+ We do this by converting the AST and its children (depth first), and then unwrapping
271
+ the resulting AST as appropriate.
272
+
273
+ Put another way:
274
+ 1) traverse to the leaf
275
+ 2) if the current node is an `OptionalMemberExpression`:
276
+ a) if the `.object` is a `ChainExpression`:
277
+ i) unwrap the child (`node.object = child.expression`)
278
+ b) convert this node to a `MemberExpression[optional = true]`
279
+ c) wrap this node (`node = ChainExpression[expression = node]`)
280
+ 3) if the current node is a `MemberExpression`:
281
+ a) convert this node to a `MemberExpression[optional = true]`
282
+ */
283
+
284
+ const node = this.mapNodeDefault(nodeUnprocessed);
285
+
286
+ const {child, childKey, isOptional} = ((): {
287
+ child: HermesNode,
288
+ childKey: string,
289
+ isOptional: boolean,
290
+ } => {
291
+ const isOptional: boolean = node.optional === true;
292
+ if (node.type.endsWith('MemberExpression')) {
293
+ return {
294
+ child: node.object,
295
+ childKey: 'object',
296
+ isOptional,
297
+ };
298
+ } else if (node.type.endsWith('CallExpression')) {
299
+ return {
300
+ child: node.callee,
301
+ childKey: 'callee',
302
+ isOptional,
303
+ };
304
+ } else {
305
+ return {
306
+ child: node.expression,
307
+ childKey: 'expression',
308
+ isOptional: false,
309
+ };
310
+ }
311
+ })();
312
+
313
+ const isChildUnwrappable =
314
+ child.type === 'ChainExpression' &&
315
+ // (x?.y).z is semantically different to `x?.y.z`.
316
+ // In the un-parenthesised case `.z` is only executed if and only if `x?.y` returns a non-nullish value.
317
+ // In the parenthesised case, `.z` is **always** executed, regardless of the return of `x?.y`.
318
+ // As such the AST is different between the two cases.
319
+ //
320
+ // In the hermes AST - any member part of a non-short-circuited optional chain is represented with `OptionalMemberExpression`
321
+ // so if we see a `MemberExpression`, then we know we've hit a parenthesis boundary.
322
+ node.type !== 'MemberExpression' &&
323
+ node.type !== 'CallExpression';
324
+
325
+ if (node.type.startsWith('Optional')) {
326
+ node.type = node.type.replace('Optional', '');
327
+ node.optional = isOptional;
328
+ } else {
329
+ node.optional = false;
330
+ }
331
+
332
+ if (!isChildUnwrappable && !isOptional) {
333
+ return node;
334
+ }
335
+
336
+ if (isChildUnwrappable) {
337
+ const newChild = child.expression;
338
+ node[childKey] = newChild;
339
+ }
340
+
341
+ return {
342
+ type: 'ChainExpression',
343
+ expression: node,
344
+ loc: node.loc,
345
+ range: node.range,
346
+ };
347
+ }
348
+
349
+ mapClassProperty(nodeUnprocessed: HermesNode): HermesNode {
350
+ const node = this.mapNodeDefault(nodeUnprocessed);
351
+
352
+ const key = (() => {
353
+ if (node.type === 'ClassPrivateProperty') {
354
+ const key = this.mapNodeDefault(node.key);
355
+ return {
356
+ type: 'PrivateIdentifier',
357
+ name: key.name,
358
+ range: key.range,
359
+ loc: key.loc,
360
+ };
361
+ }
362
+
363
+ return node.key;
364
+ })();
365
+
366
+ return {
367
+ ...node,
368
+ computed: node.type === 'ClassPrivateProperty' ? false : node.computed,
369
+ key,
370
+ type: 'PropertyDefinition',
371
+ };
372
+ }
373
+
374
+ mapPrivateName(node: HermesNode): HermesNode {
375
+ return {
376
+ type: 'PrivateIdentifier',
377
+ name: node.id.name,
378
+ // estree the location refers to the entire string including the hash token
379
+ range: node.range,
380
+ loc: node.loc,
381
+ };
382
+ }
383
+
384
+ mapExportNamedDeclaration(nodeUnprocessed: HermesNode): HermesNode {
385
+ const node = super.mapExportNamedDeclaration(nodeUnprocessed);
386
+
387
+ const namespaceSpecifier = node.specifiers.find(
388
+ spec => spec.type === 'ExportNamespaceSpecifier',
389
+ );
390
+ if (namespaceSpecifier != null) {
391
+ if (node.specifiers.length !== 1) {
392
+ // this should already a hermes parser error - but let's be absolutely sure we're aligned with the spec
393
+ throw new Error('Cannot use an export all with any other specifiers');
394
+ }
395
+ return {
396
+ type: 'ExportAllDeclaration',
397
+ source: node.source,
398
+ exportKind: node.exportKind ?? 'value',
399
+ exported: namespaceSpecifier.exported,
400
+ range: node.range,
401
+ loc: node.loc,
402
+ };
403
+ }
404
+
405
+ return node;
406
+ }
407
+
408
+ mapExportAllDeclaration(nodeUnprocessed: HermesNode): HermesNode {
409
+ const node = super.mapExportAllDeclaration(nodeUnprocessed);
410
+ node.exported = node.exported ?? null;
411
+ return node;
412
+ }
413
+
414
+ mapBlockStatement(node: HermesNode): HermesNode {
415
+ if (node.implicit && node.body.length) {
416
+ return this.mapNode(node.body[0]);
417
+ }
418
+ delete node.implicit;
419
+ return this.mapNodeDefault(node);
420
+ }
421
+ }
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.ParserOptionsKeys = void 0;
7
+
8
+ /**
9
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
10
+ *
11
+ * This source code is licensed under the MIT license found in the
12
+ * LICENSE file in the root directory of this source tree.
13
+ *
14
+ *
15
+ * @format
16
+ */
17
+ const ParserOptionsKeys = new Set(['allowReturnOutsideFunction', 'babel', 'flow', 'enableExperimentalComponentSyntax', 'enableExperimentalFlowMatchSyntax', 'reactRuntimeTarget', 'sourceFilename', 'sourceType', 'tokens', 'transformOptions']);
18
+ exports.ParserOptionsKeys = ParserOptionsKeys;
@@ -0,0 +1,41 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ * @flow strict
8
+ * @format
9
+ */
10
+
11
+ import type {Expression} from 'hermes-estree';
12
+
13
+ export type ParserOptions = {
14
+ allowReturnOutsideFunction?: boolean,
15
+ babel?: boolean,
16
+ flow?: 'all' | 'detect',
17
+ enableExperimentalComponentSyntax?: boolean,
18
+ enableExperimentalFlowMatchSyntax?: boolean,
19
+ reactRuntimeTarget?: '18' | '19',
20
+ sourceFilename?: string,
21
+ sourceType?: 'module' | 'script' | 'unambiguous',
22
+ tokens?: boolean,
23
+ transformOptions?: {
24
+ +TransformEnumSyntax?: {
25
+ +getRuntime: () => Expression,
26
+ },
27
+ },
28
+ };
29
+
30
+ export const ParserOptionsKeys: $ReadOnlySet<$Keys<ParserOptions>> = new Set([
31
+ 'allowReturnOutsideFunction',
32
+ 'babel',
33
+ 'flow',
34
+ 'enableExperimentalComponentSyntax',
35
+ 'enableExperimentalFlowMatchSyntax',
36
+ 'reactRuntimeTarget',
37
+ 'sourceFilename',
38
+ 'sourceType',
39
+ 'tokens',
40
+ 'transformOptions',
41
+ ]);