@idlizer/core 2.1.10-arktscgen-5 → 2.1.10-arktscgen-6

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 (104) hide show
  1. package/build/lib/src/Language.js +1 -1
  2. package/build/lib/src/LanguageWriters/ArgConvertors.d.ts +16 -6
  3. package/build/lib/src/LanguageWriters/ArgConvertors.js +80 -92
  4. package/build/lib/src/LanguageWriters/LanguageWriter.d.ts +8 -6
  5. package/build/lib/src/LanguageWriters/LanguageWriter.js +8 -2
  6. package/build/lib/src/LanguageWriters/common.d.ts +1 -0
  7. package/build/lib/src/LanguageWriters/common.js +2 -1
  8. package/build/lib/src/LanguageWriters/convertors/CppConvertors.d.ts +7 -1
  9. package/build/lib/src/LanguageWriters/convertors/CppConvertors.js +53 -15
  10. package/build/lib/src/LanguageWriters/convertors/ETSConvertors.d.ts +1 -0
  11. package/build/lib/src/LanguageWriters/convertors/ETSConvertors.js +10 -8
  12. package/build/lib/src/LanguageWriters/convertors/InteropConvertors.js +1 -1
  13. package/build/lib/src/LanguageWriters/convertors/TSConvertors.js +25 -14
  14. package/build/lib/src/LanguageWriters/index.d.ts +4 -3
  15. package/build/lib/src/LanguageWriters/index.js +9 -11
  16. package/build/lib/src/LanguageWriters/nameConvertor.d.ts +2 -0
  17. package/build/lib/src/LanguageWriters/nameConvertor.js +11 -0
  18. package/build/lib/src/LanguageWriters/writers/CppLanguageWriter.js +1 -1
  19. package/build/lib/src/LanguageWriters/writers/ETSLanguageWriter.d.ts +1 -8
  20. package/build/lib/src/LanguageWriters/writers/ETSLanguageWriter.js +52 -89
  21. package/build/lib/src/LanguageWriters/writers/TsLanguageWriter.d.ts +3 -0
  22. package/build/lib/src/LanguageWriters/writers/TsLanguageWriter.js +24 -7
  23. package/build/lib/src/config.d.ts +2 -1461
  24. package/build/lib/src/config.js +16 -32
  25. package/build/lib/src/configMerge.d.ts +3 -0
  26. package/build/lib/src/configMerge.js +63 -0
  27. package/build/lib/src/diagnostictypes.d.ts +1 -5
  28. package/build/lib/src/diagnostictypes.js +1 -27
  29. package/build/lib/src/from-idl/DtsPrinter.js +12 -5
  30. package/build/lib/src/from-idl/IDLLinter.d.ts +3 -4
  31. package/build/lib/src/from-idl/IDLLinter.js +30 -32
  32. package/build/lib/src/from-idl/deserialize.d.ts +3 -4
  33. package/build/lib/src/from-idl/deserialize.js +29 -641
  34. package/build/lib/src/from-idl/parser.d.ts +20 -2
  35. package/build/lib/src/from-idl/parser.js +97 -29
  36. package/build/lib/src/idl/builders.d.ts +43 -0
  37. package/build/lib/src/idl/builders.js +135 -0
  38. package/build/lib/src/idl/discriminators.d.ts +53 -0
  39. package/build/lib/src/idl/discriminators.js +232 -0
  40. package/build/lib/src/idl/dump.d.ts +48 -0
  41. package/build/lib/src/idl/dump.js +327 -0
  42. package/build/lib/src/idl/index.d.ts +9 -0
  43. package/build/lib/src/idl/index.js +23 -0
  44. package/build/lib/src/idl/keywords.d.ts +2 -0
  45. package/build/lib/src/{options.js → idl/keywords.js} +7 -3
  46. package/build/lib/src/idl/node.d.ts +233 -0
  47. package/build/lib/src/idl/node.js +103 -0
  48. package/build/lib/src/idl/stdlib.d.ts +34 -0
  49. package/build/lib/src/idl/stdlib.js +54 -0
  50. package/build/lib/src/idl/utils.d.ts +44 -0
  51. package/build/lib/src/idl/utils.js +215 -0
  52. package/build/lib/src/idl/visitors.d.ts +15 -0
  53. package/build/lib/src/idl/visitors.js +593 -0
  54. package/build/lib/src/index.d.ts +4 -2
  55. package/build/lib/src/index.js +5 -3
  56. package/build/lib/src/inputPaths.d.ts +11 -0
  57. package/build/lib/src/inputPaths.js +81 -0
  58. package/build/lib/src/languageSpecificKeywords.d.ts +0 -1
  59. package/build/lib/src/languageSpecificKeywords.js +0 -5
  60. package/build/lib/src/peer-generation/LayoutManager.d.ts +1 -1
  61. package/build/lib/src/peer-generation/Materialized.d.ts +8 -2
  62. package/build/lib/src/peer-generation/Materialized.js +24 -12
  63. package/build/lib/src/peer-generation/PeerLibrary.d.ts +10 -15
  64. package/build/lib/src/peer-generation/PeerLibrary.js +35 -215
  65. package/build/lib/src/peer-generation/ReferenceResolver.d.ts +6 -1
  66. package/build/lib/src/peer-generation/ReferenceResolver.js +93 -2
  67. package/build/lib/src/peer-generation/idl/common.d.ts +6 -2
  68. package/build/lib/src/peer-generation/idl/common.js +7 -7
  69. package/build/lib/src/peer-generation/isMaterialized.js +2 -3
  70. package/build/lib/src/peer-generation/modules.js +2 -0
  71. package/build/lib/src/peer-generation/toDeclaration.d.ts +4 -0
  72. package/build/lib/src/peer-generation/toDeclaration.js +53 -0
  73. package/build/lib/src/peer-generation/unions.d.ts +1 -1
  74. package/build/lib/src/peer-generation/unions.js +15 -7
  75. package/build/lib/src/resolveNamedNode.d.ts +1 -0
  76. package/build/lib/src/resolveNamedNode.js +7 -0
  77. package/build/lib/src/transformers/FqnTransformer.d.ts +1 -1
  78. package/build/lib/src/transformers/FqnTransformer.js +20 -12
  79. package/build/lib/src/transformers/GenericTransformer.d.ts +4 -3
  80. package/build/lib/src/transformers/GenericTransformer.js +252 -158
  81. package/build/lib/src/transformers/IdlTransformer.d.ts +6 -0
  82. package/build/lib/src/transformers/IdlTransformer.js +7 -0
  83. package/build/lib/src/transformers/NullTransformer.d.ts +1 -1
  84. package/build/lib/src/transformers/NullTransformer.js +27 -21
  85. package/build/lib/src/transformers/OnSerializeTransformer.d.ts +1 -1
  86. package/build/lib/src/transformers/OnSerializeTransformer.js +28 -13
  87. package/build/lib/src/util.d.ts +4 -0
  88. package/build/lib/src/util.js +22 -0
  89. package/package.json +6 -7
  90. package/build/lib/src/LanguageWriters/convertors/JavaConvertors.d.ts +0 -37
  91. package/build/lib/src/LanguageWriters/convertors/JavaConvertors.js +0 -210
  92. package/build/lib/src/LanguageWriters/writers/JavaLanguageWriter.d.ts +0 -85
  93. package/build/lib/src/LanguageWriters/writers/JavaLanguageWriter.js +0 -306
  94. package/build/lib/src/from-idl/webidl2-utils.d.ts +0 -21
  95. package/build/lib/src/from-idl/webidl2-utils.js +0 -87
  96. package/build/lib/src/idl.d.ts +0 -444
  97. package/build/lib/src/idl.js +0 -1385
  98. package/build/lib/src/idlize.d.ts +0 -25
  99. package/build/lib/src/idlize.js +0 -198
  100. package/build/lib/src/options.d.ts +0 -13
  101. package/build/lib/src/peer-generation/BuilderClass.d.ts +0 -20
  102. package/build/lib/src/peer-generation/BuilderClass.js +0 -68
  103. package/webidl2.js/dist/webidl2.js +0 -4622
  104. package/webidl2.js/package.json +0 -55
@@ -0,0 +1,15 @@
1
+ import { IDLNodeInitializer } from "./builders";
2
+ import { IDLNode, IDLFunction } from "./node";
3
+ type IDLNodeVisitorVoid = (node: IDLNode) => void;
4
+ type IDLNodeVisitorValue = (node: IDLNode) => () => void;
5
+ type IDLNodeVisitor = IDLNodeVisitorVoid | IDLNodeVisitorValue;
6
+ export declare function forEachChild(node: IDLNode, cbEnter: IDLNodeVisitor, cbLeave?: (entry: IDLNode) => void): void;
7
+ /** Updates tree in place! */
8
+ export declare function updateEachChild(node: IDLNode, op: (node: IDLNode) => IDLNode, cbLeave?: (entry: IDLNode) => void): IDLNode;
9
+ export declare function cloneNodeInitializer(other: IDLNodeInitializer): IDLNodeInitializer;
10
+ export declare function visitChildren(node: IDLNode, mutator: (node: IDLNode) => IDLNode): IDLNode;
11
+ export declare function linkParentBack<T extends IDLNode>(node: T): T;
12
+ export declare function clone<T extends IDLNode>(node: T): T;
13
+ export declare function forEachFunction(node: IDLNode, cb: (node: IDLFunction) => void): void;
14
+ export {};
15
+ //# sourceMappingURL=visitors.d.ts.map
@@ -0,0 +1,593 @@
1
+ /*
2
+ * Copyright (c) 2025 Huawei Device Co., Ltd.
3
+ * Licensed under the Apache License, Version 2.0 (the "License");
4
+ * you may not use this file except in compliance with the License.
5
+ * You may obtain a copy of the License at
6
+ *
7
+ * http://www.apache.org/licenses/LICENSE-2.0
8
+ *
9
+ * Unless required by applicable law or agreed to in writing, software
10
+ * distributed under the License is distributed on an "AS IS" BASIS,
11
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ * See the License for the specific language governing permissions and
13
+ * limitations under the License.
14
+ */
15
+ import { generateSyntheticUnionName } from "../peer-generation/idl/common";
16
+ import { createInterface, createFile, createNamespace, createMethod, createCallable, createCallback, createConstructor, createUnionType, createOptionalType, createConstant, createEnum, createEnumMember, createProperty, createParameter, createTypedef, createContainerType, createReferenceType, createImport, createTypeParameterReference, createVersion } from "./builders";
17
+ import { isType, isNamespace, isInterface, isMethod, isCallback, isTypedef, isEnum, isImport, isVersion, isConstant, isConstructor, isProperty, isCallable, isFile, isReferenceType, isParameter, isUnionType, isOptionalType, isEnumMember, isPrimitiveType, isContainerType, isTypeParameterType } from "./discriminators";
18
+ import { IDLKind } from "./node";
19
+ export function forEachChild(node, cbEnter, cbLeave) {
20
+ var _a, _b, _c;
21
+ const cleanup = cbEnter(node);
22
+ switch (node.kind) {
23
+ case IDLKind.File:
24
+ node.entries.forEach((value) => forEachChild(value, cbEnter, cbLeave));
25
+ break;
26
+ case IDLKind.Namespace:
27
+ node.members.forEach((value) => forEachChild(value, cbEnter, cbLeave));
28
+ break;
29
+ case IDLKind.Interface: {
30
+ let concrete = node;
31
+ concrete.inheritance.forEach((value) => forEachChild(value, cbEnter, cbLeave));
32
+ concrete.constructors.forEach((value) => forEachChild(value, cbEnter, cbLeave));
33
+ concrete.properties.forEach((value) => forEachChild(value, cbEnter, cbLeave));
34
+ concrete.methods.forEach((value) => forEachChild(value, cbEnter, cbLeave));
35
+ concrete.callables.forEach((value) => forEachChild(value, cbEnter, cbLeave));
36
+ break;
37
+ }
38
+ case IDLKind.Method:
39
+ case IDLKind.Callable:
40
+ case IDLKind.Callback:
41
+ case IDLKind.Constructor: {
42
+ let concrete = node;
43
+ (_a = concrete.parameters) === null || _a === void 0 ? void 0 : _a.forEach((value) => forEachChild(value, cbEnter, cbLeave));
44
+ if (concrete.returnType)
45
+ forEachChild(concrete.returnType, cbEnter, cbLeave);
46
+ break;
47
+ }
48
+ case IDLKind.UnionType: {
49
+ let concrete = node;
50
+ (_b = concrete.types) === null || _b === void 0 ? void 0 : _b.forEach((value) => forEachChild(value, cbEnter, cbLeave));
51
+ break;
52
+ }
53
+ case IDLKind.OptionalType: {
54
+ let concrete = node;
55
+ forEachChild(concrete.type, cbEnter, cbLeave);
56
+ break;
57
+ }
58
+ case IDLKind.Const: {
59
+ forEachChild(node.type, cbEnter, cbLeave);
60
+ break;
61
+ }
62
+ case IDLKind.Enum: {
63
+ node.elements.forEach((value) => forEachChild(value, cbEnter, cbLeave));
64
+ break;
65
+ }
66
+ case IDLKind.Property: {
67
+ forEachChild(node.type, cbEnter, cbLeave);
68
+ break;
69
+ }
70
+ case IDLKind.Parameter: {
71
+ const concrete = node;
72
+ if (concrete.type)
73
+ forEachChild(concrete.type, cbEnter, cbLeave);
74
+ break;
75
+ }
76
+ case IDLKind.Typedef: {
77
+ forEachChild(node.type, cbEnter, cbLeave);
78
+ break;
79
+ }
80
+ case IDLKind.ContainerType: {
81
+ node.elementType.forEach((value) => forEachChild(value, cbEnter, cbLeave));
82
+ break;
83
+ }
84
+ case IDLKind.ReferenceType: {
85
+ (_c = node.typeArguments) === null || _c === void 0 ? void 0 : _c.forEach((value) => forEachChild(value, cbEnter, cbLeave));
86
+ break;
87
+ }
88
+ case IDLKind.TypeParameterType:
89
+ case IDLKind.EnumMember:
90
+ case IDLKind.Import:
91
+ case IDLKind.PrimitiveType:
92
+ case IDLKind.Version:
93
+ break;
94
+ default: {
95
+ throw new Error(`Unhandled ${node.kind}`);
96
+ }
97
+ }
98
+ cbLeave === null || cbLeave === void 0 ? void 0 : cbLeave(node);
99
+ cleanup === null || cleanup === void 0 ? void 0 : cleanup();
100
+ }
101
+ /** Updates tree in place! */
102
+ export function updateEachChild(node, op, cbLeave) {
103
+ var _a;
104
+ const old = node;
105
+ node = op(old);
106
+ if (node.kind !== old.kind && !(isType(old) && isType(node))) {
107
+ throw new Error("Kinds must be the same!");
108
+ }
109
+ switch (node.kind) {
110
+ case IDLKind.File: {
111
+ const concrete = node;
112
+ concrete.entries = concrete.entries.map(it => updateEachChild(it, op, cbLeave));
113
+ break;
114
+ }
115
+ case IDLKind.Namespace: {
116
+ const concrete = node;
117
+ concrete.members = concrete.members.map((it) => updateEachChild(it, op, cbLeave));
118
+ break;
119
+ }
120
+ case IDLKind.Interface: {
121
+ const concrete = node;
122
+ concrete.inheritance = concrete.inheritance.map((it) => updateEachChild(it, op, cbLeave));
123
+ concrete.constructors = concrete.constructors.map((it) => updateEachChild(it, op, cbLeave));
124
+ concrete.properties = concrete.properties.map((it) => updateEachChild(it, op, cbLeave));
125
+ concrete.methods = concrete.methods.map((it) => updateEachChild(it, op, cbLeave));
126
+ concrete.callables = concrete.callables.map((it) => updateEachChild(it, op, cbLeave));
127
+ break;
128
+ }
129
+ case IDLKind.Method:
130
+ case IDLKind.Callable:
131
+ case IDLKind.Callback:
132
+ case IDLKind.Constructor: {
133
+ const concrete = node;
134
+ concrete.parameters = concrete.parameters.map((it) => updateEachChild(it, op, cbLeave));
135
+ if (concrete.returnType) {
136
+ concrete.returnType = updateEachChild(concrete.returnType, op, cbLeave);
137
+ }
138
+ break;
139
+ }
140
+ case IDLKind.UnionType: {
141
+ const concrete = node;
142
+ concrete.types = concrete.types.map((it) => updateEachChild(it, op, cbLeave));
143
+ break;
144
+ }
145
+ case IDLKind.OptionalType: {
146
+ const concrete = node;
147
+ concrete.type = updateEachChild(concrete.type, op, cbLeave);
148
+ break;
149
+ }
150
+ case IDLKind.Const: {
151
+ const concrete = node;
152
+ concrete.type = updateEachChild(concrete.type, op, cbLeave);
153
+ break;
154
+ }
155
+ case IDLKind.Enum: {
156
+ const concrete = node;
157
+ concrete.elements = concrete.elements.map((it) => updateEachChild(it, op, cbLeave));
158
+ break;
159
+ }
160
+ case IDLKind.Property: {
161
+ const concrete = node;
162
+ concrete.type = updateEachChild(concrete.type, op, cbLeave);
163
+ break;
164
+ }
165
+ case IDLKind.Parameter: {
166
+ const concrete = node;
167
+ if (concrete.type)
168
+ concrete.type = updateEachChild(concrete.type, op, cbLeave);
169
+ break;
170
+ }
171
+ case IDLKind.Typedef: {
172
+ const concrete = node;
173
+ concrete.type = updateEachChild(concrete.type, op, cbLeave);
174
+ break;
175
+ }
176
+ case IDLKind.ContainerType: {
177
+ const concrete = node;
178
+ concrete.elementType = concrete.elementType.map(it => updateEachChild(it, op, cbLeave));
179
+ break;
180
+ }
181
+ case IDLKind.ReferenceType: {
182
+ const concrete = node;
183
+ concrete.typeArguments = (_a = concrete.typeArguments) === null || _a === void 0 ? void 0 : _a.map(it => updateEachChild(it, op, cbLeave));
184
+ break;
185
+ }
186
+ case IDLKind.TypeParameterType:
187
+ case IDLKind.EnumMember:
188
+ case IDLKind.Import:
189
+ case IDLKind.PrimitiveType:
190
+ case IDLKind.Version:
191
+ break;
192
+ default: {
193
+ throw new Error(`Unhandled ${node.kind}`);
194
+ }
195
+ }
196
+ if (cbLeave) {
197
+ cbLeave === null || cbLeave === void 0 ? void 0 : cbLeave(node);
198
+ }
199
+ return node;
200
+ }
201
+ export function cloneNodeInitializer(other) {
202
+ return {
203
+ documentation: other.documentation,
204
+ extendedAttributes: other.extendedAttributes,
205
+ fileName: other.fileName,
206
+ nameLocation: other.nameLocation,
207
+ nodeLocation: other.nodeLocation,
208
+ valueLocation: other.valueLocation,
209
+ };
210
+ }
211
+ export function visitChildren(node, mutator) {
212
+ function track(visitor) {
213
+ let changed = false;
214
+ let factory = visitor((node) => {
215
+ const newNode = mutator(node);
216
+ changed || (changed = node !== newNode);
217
+ return newNode;
218
+ });
219
+ return changed ? factory() : node;
220
+ }
221
+ function assert(predicate) {
222
+ return (node) => {
223
+ if (predicate(node))
224
+ return node;
225
+ throw new Error(`Unexpected node kind ${node.kind}`);
226
+ };
227
+ }
228
+ function isNamespaceMember(node) {
229
+ return isNamespace(node)
230
+ || isInterface(node)
231
+ || isMethod(node) && node.isFree
232
+ || isCallback(node)
233
+ || isTypedef(node)
234
+ || isEnum(node)
235
+ || isImport(node)
236
+ || isVersion(node)
237
+ || isConstant(node);
238
+ }
239
+ function isInterfaceMember(node) {
240
+ return isConstructor(node)
241
+ || isMethod(node)
242
+ || isConstant(node)
243
+ || isProperty(node)
244
+ || isCallable(node);
245
+ }
246
+ if (isFile(node)) {
247
+ return track((op) => {
248
+ const entries = node.entries.map(op).map(assert(isNamespaceMember));
249
+ return () => createFile(entries, node.fileName, node.packageClause, cloneNodeInitializer(node));
250
+ });
251
+ }
252
+ if (isNamespace(node)) {
253
+ return track((op) => {
254
+ const members = node.members.map(op).map(assert(isNamespaceMember));
255
+ return () => createNamespace(node.name, members, cloneNodeInitializer(node));
256
+ });
257
+ }
258
+ if (isInterface(node)) {
259
+ return track((op) => {
260
+ const inheritance = node.inheritance.map(op).map(assert(isReferenceType));
261
+ const members = [
262
+ ...node.constructors,
263
+ ...node.callables,
264
+ ...node.properties,
265
+ ...node.methods,
266
+ ...node.constants,
267
+ ].map(op).map(assert(isInterfaceMember));
268
+ return () => createInterface(node.name, node.subkind, inheritance, members.filter(isConstructor), members.filter(isConstant), members.filter(isProperty), members.filter(isMethod), members.filter(isCallable), node.typeParameters, cloneNodeInitializer(node));
269
+ });
270
+ }
271
+ if (isMethod(node)) {
272
+ return track(op => {
273
+ const parameters = node.parameters.map(op).map(assert(isParameter));
274
+ const returnType = assert(isType)(op(node.returnType));
275
+ return () => createMethod(node.name, parameters, returnType, { isAsync: node.isAsync, isFree: node.isFree, isOptional: node.isOptional, isStatic: node.isStatic }, cloneNodeInitializer(node), node.typeParameters);
276
+ });
277
+ }
278
+ if (isCallable(node)) {
279
+ return track(op => {
280
+ const parameters = node.parameters.map(op).map(assert(isParameter));
281
+ const returnType = assert(isType)(op(node.returnType));
282
+ return () => createCallable(node.name, parameters, returnType, { isAsync: node.isAsync, isStatic: node.isStatic }, cloneNodeInitializer(node));
283
+ });
284
+ }
285
+ if (isCallback(node)) {
286
+ return track(op => {
287
+ const parameters = node.parameters.map(op).map(assert(isParameter));
288
+ const returnType = assert(isType)(op(node.returnType));
289
+ return () => createCallback(node.name, parameters, returnType, cloneNodeInitializer(node), node.typeParameters);
290
+ });
291
+ }
292
+ if (isConstructor(node)) {
293
+ return track(op => {
294
+ const parameters = node.parameters.map(op).map(assert(isParameter));
295
+ const returnType = node.returnType ? assert(isType)(op(node.returnType)) : undefined;
296
+ return () => createConstructor(parameters, returnType, cloneNodeInitializer(node));
297
+ });
298
+ }
299
+ if (isUnionType(node)) {
300
+ return track(op => {
301
+ const types = node.types.map(op).map(assert(isType));
302
+ const name = types.some((it, index) => it !== node.types[index])
303
+ ? generateSyntheticUnionName(types)
304
+ : node.name;
305
+ return () => createUnionType(types, name, cloneNodeInitializer(node));
306
+ });
307
+ }
308
+ if (isOptionalType(node)) {
309
+ return track(op => {
310
+ const t = assert(isType)(op(node.type));
311
+ return () => createOptionalType(t, cloneNodeInitializer(node));
312
+ });
313
+ }
314
+ if (isConstant(node)) {
315
+ return track(op => {
316
+ const t = assert(isType)(op(node.type));
317
+ return () => createConstant(node.name, t, node.value, cloneNodeInitializer(node));
318
+ });
319
+ }
320
+ if (isEnum(node)) {
321
+ return track(op => {
322
+ const elements = node.elements.map(op).map(assert(isEnumMember));
323
+ return () => createEnum(node.name, elements, cloneNodeInitializer(node));
324
+ });
325
+ }
326
+ if (isEnumMember(node)) {
327
+ return track(op => {
328
+ const t = assert(isPrimitiveType)(op(node.type));
329
+ return () => createEnumMember(node.name, node.parent /* TODO seems strange in that context */, t, node.initializer, cloneNodeInitializer(node));
330
+ });
331
+ }
332
+ if (isProperty(node)) {
333
+ return track(op => {
334
+ const t = assert(isType)(op(node.type));
335
+ return () => createProperty(node.name, t, node.isReadonly, node.isStatic, node.isOptional, cloneNodeInitializer(node));
336
+ });
337
+ }
338
+ if (isParameter(node)) {
339
+ return track(op => {
340
+ const t = assert(isType)(op(node.type));
341
+ return () => createParameter(node.name, t, node.isOptional, node.isVariadic, cloneNodeInitializer(node));
342
+ });
343
+ }
344
+ if (isTypedef(node)) {
345
+ return track(op => {
346
+ const t = assert(isType)(op(node.type));
347
+ return () => createTypedef(node.name, t, node.typeParameters, cloneNodeInitializer(node));
348
+ });
349
+ }
350
+ if (isContainerType(node)) {
351
+ return track(op => {
352
+ const elementType = node.elementType.map(op).map(assert(isType));
353
+ return () => createContainerType(node.containerKind, elementType, cloneNodeInitializer(node));
354
+ });
355
+ }
356
+ if (isReferenceType(node)) {
357
+ return track(op => {
358
+ var _a;
359
+ const typeArguments = (_a = node.typeArguments) === null || _a === void 0 ? void 0 : _a.map(op).map(assert(isType));
360
+ return () => createReferenceType(node.name, typeArguments, cloneNodeInitializer(node));
361
+ });
362
+ }
363
+ if (isTypeParameterType(node)
364
+ || isImport(node)
365
+ || isPrimitiveType(node)
366
+ || isVersion(node)) {
367
+ return node;
368
+ }
369
+ throw new Error(`Not implemented`);
370
+ }
371
+ export function linkParentBack(node) {
372
+ const parentStack = [];
373
+ updateEachChild(node, (node) => {
374
+ if (isPrimitiveType(node)) {
375
+ return node;
376
+ }
377
+ if (parentStack.length) {
378
+ const top = parentStack[parentStack.length - 1];
379
+ if (node.parent !== undefined && node.parent !== top) {
380
+ node = clone(node);
381
+ }
382
+ node.parent = top;
383
+ }
384
+ parentStack.push(node);
385
+ return node;
386
+ }, (node) => {
387
+ if (isPrimitiveType(node)) {
388
+ return;
389
+ }
390
+ parentStack.pop();
391
+ });
392
+ return node;
393
+ }
394
+ export function clone(node) {
395
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
396
+ const make = (newnode) => {
397
+ if (node.nodeLocation) {
398
+ newnode.nodeLocation = node.nodeLocation;
399
+ }
400
+ if (node.nameLocation) {
401
+ newnode.nameLocation = node.nameLocation;
402
+ }
403
+ if (node.valueLocation) {
404
+ newnode.valueLocation = node.valueLocation;
405
+ }
406
+ return newnode;
407
+ };
408
+ const get = (node) => node;
409
+ switch (node.kind) {
410
+ case IDLKind.Interface: {
411
+ const entry = get(node);
412
+ return make(createInterface(entry.name, entry.subkind, (_a = entry.inheritance) === null || _a === void 0 ? void 0 : _a.map(clone), (_b = entry.constructors) === null || _b === void 0 ? void 0 : _b.map(clone), entry.constants.map(clone), entry.properties.map(clone), entry.methods.map(clone), entry.callables.map(clone), (_c = entry.typeParameters) === null || _c === void 0 ? void 0 : _c.map(it => it), {
413
+ documentation: node.documentation,
414
+ extendedAttributes: (_d = node.extendedAttributes) === null || _d === void 0 ? void 0 : _d.slice(),
415
+ fileName: node.fileName
416
+ }));
417
+ }
418
+ case IDLKind.Import: {
419
+ const entry = get(node);
420
+ return make(createImport(entry.clause, entry.name, {
421
+ documentation: entry.documentation,
422
+ extendedAttributes: (_e = entry.extendedAttributes) === null || _e === void 0 ? void 0 : _e.slice(),
423
+ fileName: entry.fileName
424
+ }));
425
+ }
426
+ case IDLKind.Callback: {
427
+ const entry = get(node);
428
+ return make(createCallback(entry.name, entry.parameters.map(clone), clone(entry.returnType), {
429
+ documentation: entry.documentation,
430
+ extendedAttributes: (_f = entry.extendedAttributes) === null || _f === void 0 ? void 0 : _f.slice(),
431
+ fileName: entry.fileName
432
+ }, entry.typeParameters));
433
+ }
434
+ case IDLKind.Const: {
435
+ const entry = get(node);
436
+ return make(createConstant(entry.name, clone(entry.type), entry.value, {
437
+ documentation: entry.documentation,
438
+ extendedAttributes: (_g = entry.extendedAttributes) === null || _g === void 0 ? void 0 : _g.slice(),
439
+ fileName: entry.fileName
440
+ }));
441
+ }
442
+ case IDLKind.Property: {
443
+ const entry = get(node);
444
+ return make(createProperty(entry.name, clone(entry.type), entry.isReadonly, entry.isStatic, entry.isOptional, {
445
+ documentation: entry.documentation,
446
+ extendedAttributes: (_h = entry.extendedAttributes) === null || _h === void 0 ? void 0 : _h.slice(),
447
+ fileName: entry.fileName
448
+ }));
449
+ }
450
+ case IDLKind.Parameter: {
451
+ const entry = get(node);
452
+ return make(createParameter(entry.name, clone(entry.type), entry.isOptional, entry.isVariadic, {
453
+ documentation: entry.documentation,
454
+ extendedAttributes: (_j = entry.extendedAttributes) === null || _j === void 0 ? void 0 : _j.slice(),
455
+ fileName: entry.fileName
456
+ }));
457
+ }
458
+ case IDLKind.Method: {
459
+ const entry = get(node);
460
+ return make(createMethod(entry.name, entry.parameters.map(clone), clone(entry.returnType), {
461
+ isAsync: entry.isAsync,
462
+ isFree: entry.isFree,
463
+ isOptional: entry.isOptional,
464
+ isStatic: entry.isStatic
465
+ }, {
466
+ documentation: entry.documentation,
467
+ extendedAttributes: (_k = entry.extendedAttributes) === null || _k === void 0 ? void 0 : _k.slice(),
468
+ fileName: entry.fileName
469
+ }, entry.typeParameters));
470
+ }
471
+ case IDLKind.Callable: {
472
+ const entry = get(node);
473
+ return make(createCallable(entry.name, entry.parameters.map(clone), clone(entry.returnType), {
474
+ isAsync: entry.isAsync,
475
+ isStatic: entry.isStatic
476
+ }, {
477
+ documentation: entry.documentation,
478
+ extendedAttributes: (_l = entry.extendedAttributes) === null || _l === void 0 ? void 0 : _l.slice(),
479
+ fileName: entry.documentation
480
+ }, entry.typeParameters));
481
+ }
482
+ case IDLKind.Constructor: {
483
+ const entry = get(node);
484
+ return make(createConstructor(entry.parameters.map(clone), entry.returnType ? clone(entry.returnType) : undefined, {
485
+ documentation: entry.documentation,
486
+ extendedAttributes: (_m = entry.extendedAttributes) === null || _m === void 0 ? void 0 : _m.slice(),
487
+ fileName: entry.fileName
488
+ }));
489
+ }
490
+ case IDLKind.Enum: {
491
+ const entry = get(node);
492
+ const cloned = createEnum(entry.name, entry.elements.map(clone), {
493
+ documentation: entry.documentation,
494
+ extendedAttributes: (_o = entry.extendedAttributes) === null || _o === void 0 ? void 0 : _o.slice(),
495
+ fileName: entry.fileName
496
+ });
497
+ cloned.elements.forEach(it => {
498
+ it.parent = cloned;
499
+ });
500
+ return make(cloned);
501
+ }
502
+ case IDLKind.EnumMember: {
503
+ const entry = get(node);
504
+ return make(createEnumMember(entry.name, entry.parent, clone(entry.type), entry.initializer, {
505
+ documentation: entry.documentation,
506
+ extendedAttributes: (_p = entry.extendedAttributes) === null || _p === void 0 ? void 0 : _p.slice(),
507
+ fileName: entry.fileName
508
+ }));
509
+ }
510
+ case IDLKind.Typedef: {
511
+ const entry = get(node);
512
+ return make(createTypedef(entry.name, clone(entry.type), entry.typeParameters, {
513
+ documentation: entry.documentation,
514
+ extendedAttributes: (_q = entry.extendedAttributes) === null || _q === void 0 ? void 0 : _q.slice(),
515
+ fileName: entry.fileName
516
+ }));
517
+ }
518
+ case IDLKind.PrimitiveType: {
519
+ return node;
520
+ }
521
+ case IDLKind.ContainerType: {
522
+ const type = get(node);
523
+ return make(createContainerType(type.containerKind, type.elementType.map(clone), {
524
+ documentation: type.documentation,
525
+ extendedAttributes: (_r = type.extendedAttributes) === null || _r === void 0 ? void 0 : _r.slice(),
526
+ fileName: type.fileName
527
+ }));
528
+ }
529
+ case IDLKind.ReferenceType: {
530
+ const type = get(node);
531
+ return make(createReferenceType(type.name, (_s = type.typeArguments) === null || _s === void 0 ? void 0 : _s.map(clone), {
532
+ documentation: type.documentation,
533
+ extendedAttributes: (_t = type.extendedAttributes) === null || _t === void 0 ? void 0 : _t.slice(),
534
+ fileName: type.fileName
535
+ }));
536
+ }
537
+ case IDLKind.UnionType: {
538
+ const type = get(node);
539
+ return make(createUnionType(type.types.map(clone), type.name, {
540
+ documentation: type.documentation,
541
+ extendedAttributes: (_u = type.extendedAttributes) === null || _u === void 0 ? void 0 : _u.slice(),
542
+ fileName: type.fileName
543
+ }));
544
+ }
545
+ case IDLKind.TypeParameterType: {
546
+ const type = get(node);
547
+ return make(createTypeParameterReference(type.name, {
548
+ documentation: type.documentation,
549
+ extendedAttributes: (_v = type.extendedAttributes) === null || _v === void 0 ? void 0 : _v.slice(),
550
+ fileName: type.fileName
551
+ }));
552
+ }
553
+ case IDLKind.OptionalType: {
554
+ const type = get(node);
555
+ return make(createOptionalType(clone(type.type), {
556
+ documentation: type.documentation,
557
+ extendedAttributes: (_w = type.extendedAttributes) === null || _w === void 0 ? void 0 : _w.slice(),
558
+ fileName: type.fileName
559
+ }));
560
+ }
561
+ case IDLKind.Version: {
562
+ const entry = get(node);
563
+ return make(createVersion(entry.value, {
564
+ documentation: entry.documentation,
565
+ extendedAttributes: (_x = entry.extendedAttributes) === null || _x === void 0 ? void 0 : _x.slice(),
566
+ fileName: entry.fileName
567
+ }));
568
+ }
569
+ case IDLKind.Namespace: {
570
+ const ns = get(node);
571
+ return make(createNamespace(ns.name, ns.members.map(clone), {
572
+ documentation: ns.documentation,
573
+ extendedAttributes: (_y = ns.extendedAttributes) === null || _y === void 0 ? void 0 : _y.slice(),
574
+ fileName: ns.fileName
575
+ }));
576
+ }
577
+ case IDLKind.File: {
578
+ const file = get(node);
579
+ return make(createFile(file.entries.map(clone), file.fileName, file.packageClause, {
580
+ documentation: file.documentation,
581
+ extendedAttributes: (_z = file.extendedAttributes) === null || _z === void 0 ? void 0 : _z.slice(),
582
+ fileName: file.fileName
583
+ }));
584
+ }
585
+ }
586
+ }
587
+ export function forEachFunction(node, cb) {
588
+ forEachChild(node, child => {
589
+ if (child.kind === IDLKind.Method || child.kind === IDLKind.Callable)
590
+ cb(child);
591
+ });
592
+ }
593
+ //# sourceMappingURL=visitors.js.map
@@ -4,6 +4,7 @@ export * from "./resolveNamedNode";
4
4
  export * from "./visitor";
5
5
  export * from "./library";
6
6
  export * from "./inheritance";
7
+ export * from "./inputPaths";
7
8
  export * from "./Language";
8
9
  export * from "./languageSpecificKeywords";
9
10
  export * from "./util";
@@ -37,7 +38,6 @@ export * from "./peer-generation/PeerLibrary";
37
38
  export * from "./peer-generation/PeerFile";
38
39
  export * from "./peer-generation/PeerClass";
39
40
  export * from "./peer-generation/PeerMethod";
40
- export * from "./peer-generation/BuilderClass";
41
41
  export * from "./peer-generation/Materialized";
42
42
  export * from "./peer-generation/modules";
43
43
  export * from "./peer-generation/isMaterialized";
@@ -46,17 +46,19 @@ export * from "./peer-generation/isEnumType";
46
46
  export * from "./peer-generation/unions";
47
47
  export * from "./peer-generation/getSuperType";
48
48
  export * from "./peer-generation/ConflictingDeclarations";
49
+ export * from "./peer-generation/toDeclaration";
49
50
  export * from "./transformers/FqnTransformer";
50
51
  export * from "./transformers/GenericTransformer";
51
52
  export * from "./transformers/NullTransformer";
52
53
  export * from "./transformers/OnSerializeTransformer";
54
+ export * from "./transformers/IdlTransformer";
53
55
  export * from "./LanguageWriters";
54
56
  export * from "./peer-generation/ReferenceResolver";
55
57
  export * from "./peer-generation/idl/common";
56
58
  export * from "./from-idl/IDLLinter";
57
59
  export { fromIDL, scanIDL } from "./from-idl/common";
58
60
  export { idlToDtsString, CustomPrintVisitor } from "./from-idl/DtsPrinter";
59
- export { parseIDLFile, addSyntheticType, resolveSyntheticType } from "./from-idl/deserialize";
61
+ export { parseIDLFile, addSyntheticType, resolveSyntheticType, compareNodes, toIdlType } from "./from-idl/deserialize";
60
62
  export { Parser, FatalParserException } from "./from-idl/parser";
61
63
  export { D, ConfigTypeInfer, ConfigSchema, inspectSchema } from './configDescriber';
62
64
  //# sourceMappingURL=index.d.ts.map
@@ -1,5 +1,5 @@
1
1
  /*
2
- * Copyright (c) 2024 Huawei Device Co., Ltd.
2
+ * Copyright (c) 2024-2025 Huawei Device Co., Ltd.
3
3
  * Licensed under the Apache License, Version 2.0 (the "License");
4
4
  * you may not use this file except in compliance with the License.
5
5
  * You may obtain a copy of the License at
@@ -18,6 +18,7 @@ export * from "./resolveNamedNode";
18
18
  export * from "./visitor";
19
19
  export * from "./library";
20
20
  export * from "./inheritance";
21
+ export * from "./inputPaths";
21
22
  export * from "./Language";
22
23
  export * from "./languageSpecificKeywords";
23
24
  export * from "./util";
@@ -51,7 +52,6 @@ export * from "./peer-generation/PeerLibrary";
51
52
  export * from "./peer-generation/PeerFile";
52
53
  export * from "./peer-generation/PeerClass";
53
54
  export * from "./peer-generation/PeerMethod";
54
- export * from "./peer-generation/BuilderClass";
55
55
  export * from "./peer-generation/Materialized";
56
56
  export * from "./peer-generation/modules";
57
57
  export * from "./peer-generation/isMaterialized";
@@ -60,17 +60,19 @@ export * from "./peer-generation/isEnumType";
60
60
  export * from "./peer-generation/unions";
61
61
  export * from "./peer-generation/getSuperType";
62
62
  export * from "./peer-generation/ConflictingDeclarations";
63
+ export * from "./peer-generation/toDeclaration";
63
64
  export * from "./transformers/FqnTransformer";
64
65
  export * from "./transformers/GenericTransformer";
65
66
  export * from "./transformers/NullTransformer";
66
67
  export * from "./transformers/OnSerializeTransformer";
68
+ export * from "./transformers/IdlTransformer";
67
69
  export * from "./LanguageWriters";
68
70
  export * from "./peer-generation/ReferenceResolver";
69
71
  export * from "./peer-generation/idl/common";
70
72
  export * from "./from-idl/IDLLinter";
71
73
  export { fromIDL, scanIDL } from "./from-idl/common";
72
74
  export { idlToDtsString, CustomPrintVisitor } from "./from-idl/DtsPrinter";
73
- export { parseIDLFile, addSyntheticType, resolveSyntheticType } from "./from-idl/deserialize";
75
+ export { parseIDLFile, addSyntheticType, resolveSyntheticType, compareNodes, toIdlType } from "./from-idl/deserialize";
74
76
  export { Parser, FatalParserException } from "./from-idl/parser";
75
77
  export { D, inspectSchema } from './configDescriber';
76
78
  //# sourceMappingURL=index.js.map