@aztec/bb.js 1.2.1 → 2.0.0-nightly.20250814

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 (135) hide show
  1. package/dest/browser/barretenberg/backend.d.ts +1 -0
  2. package/dest/browser/barretenberg/backend.d.ts.map +1 -1
  3. package/dest/browser/barretenberg/backend.js +116 -108
  4. package/dest/browser/barretenberg/index.d.ts +13 -0
  5. package/dest/browser/barretenberg/index.d.ts.map +1 -1
  6. package/dest/browser/barretenberg/index.js +40 -2
  7. package/dest/browser/barretenberg/verifier.js +2 -2
  8. package/dest/browser/barretenberg_api/index.d.ts +2 -2
  9. package/dest/browser/barretenberg_api/index.d.ts.map +1 -1
  10. package/dest/browser/barretenberg_api/index.js +5 -5
  11. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +1 -0
  12. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -1
  13. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.js +5 -4
  14. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +2 -0
  15. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -1
  16. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.js +17 -1
  17. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +1 -0
  18. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -1
  19. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +1 -1
  20. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.js +1 -1
  21. package/dest/browser/cbind/generate.d.ts +5 -0
  22. package/dest/browser/cbind/generate.d.ts.map +1 -0
  23. package/dest/browser/cbind/generate.js +64 -0
  24. package/dest/browser/cbind/generated/api_types.d.ts +634 -0
  25. package/dest/browser/cbind/generated/api_types.d.ts.map +1 -0
  26. package/dest/browser/cbind/generated/api_types.js +851 -0
  27. package/dest/browser/cbind/generated/async.d.ts +23 -0
  28. package/dest/browser/cbind/generated/async.d.ts.map +1 -0
  29. package/dest/browser/cbind/generated/async.js +148 -0
  30. package/dest/browser/cbind/generated/native.d.ts +31 -0
  31. package/dest/browser/cbind/generated/native.d.ts.map +1 -0
  32. package/dest/browser/cbind/generated/native.js +234 -0
  33. package/dest/browser/cbind/generated/sync.d.ts +23 -0
  34. package/dest/browser/cbind/generated/sync.d.ts.map +1 -0
  35. package/dest/browser/cbind/generated/sync.js +133 -0
  36. package/dest/browser/cbind/schema_compiler.d.ts +70 -0
  37. package/dest/browser/cbind/schema_compiler.d.ts.map +1 -0
  38. package/dest/browser/cbind/schema_compiler.js +683 -0
  39. package/dest/browser/proof/index.d.ts +2 -0
  40. package/dest/browser/proof/index.d.ts.map +1 -1
  41. package/dest/browser/proof/index.js +3 -3
  42. package/dest/node/barretenberg/backend.d.ts +1 -0
  43. package/dest/node/barretenberg/backend.d.ts.map +1 -1
  44. package/dest/node/barretenberg/backend.js +116 -108
  45. package/dest/node/barretenberg/index.d.ts +13 -0
  46. package/dest/node/barretenberg/index.d.ts.map +1 -1
  47. package/dest/node/barretenberg/index.js +40 -2
  48. package/dest/node/barretenberg/verifier.js +2 -2
  49. package/dest/node/barretenberg_api/index.d.ts +2 -2
  50. package/dest/node/barretenberg_api/index.d.ts.map +1 -1
  51. package/dest/node/barretenberg_api/index.js +5 -5
  52. package/dest/node/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  53. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +1 -0
  54. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -1
  55. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.js +5 -4
  56. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +2 -0
  57. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -1
  58. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.js +17 -1
  59. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +1 -0
  60. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -1
  61. package/dest/node/cbind/generate.d.ts +5 -0
  62. package/dest/node/cbind/generate.d.ts.map +1 -0
  63. package/dest/node/cbind/generate.js +64 -0
  64. package/dest/node/cbind/generated/api_types.d.ts +634 -0
  65. package/dest/node/cbind/generated/api_types.d.ts.map +1 -0
  66. package/dest/node/cbind/generated/api_types.js +851 -0
  67. package/dest/node/cbind/generated/async.d.ts +23 -0
  68. package/dest/node/cbind/generated/async.d.ts.map +1 -0
  69. package/dest/node/cbind/generated/async.js +148 -0
  70. package/dest/node/cbind/generated/native.d.ts +31 -0
  71. package/dest/node/cbind/generated/native.d.ts.map +1 -0
  72. package/dest/node/cbind/generated/native.js +234 -0
  73. package/dest/node/cbind/generated/sync.d.ts +23 -0
  74. package/dest/node/cbind/generated/sync.d.ts.map +1 -0
  75. package/dest/node/cbind/generated/sync.js +133 -0
  76. package/dest/node/cbind/schema_compiler.d.ts +70 -0
  77. package/dest/node/cbind/schema_compiler.d.ts.map +1 -0
  78. package/dest/node/cbind/schema_compiler.js +683 -0
  79. package/dest/node/main.js +3 -3
  80. package/dest/node/proof/index.d.ts +2 -0
  81. package/dest/node/proof/index.d.ts.map +1 -1
  82. package/dest/node/proof/index.js +3 -3
  83. package/dest/node-cjs/barretenberg/backend.d.ts +1 -0
  84. package/dest/node-cjs/barretenberg/backend.d.ts.map +1 -1
  85. package/dest/node-cjs/barretenberg/backend.js +117 -109
  86. package/dest/node-cjs/barretenberg/index.d.ts +13 -0
  87. package/dest/node-cjs/barretenberg/index.d.ts.map +1 -1
  88. package/dest/node-cjs/barretenberg/index.js +40 -2
  89. package/dest/node-cjs/barretenberg/verifier.js +2 -2
  90. package/dest/node-cjs/barretenberg_api/index.d.ts +2 -2
  91. package/dest/node-cjs/barretenberg_api/index.d.ts.map +1 -1
  92. package/dest/node-cjs/barretenberg_api/index.js +5 -5
  93. package/dest/node-cjs/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  94. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +1 -0
  95. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -1
  96. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.js +5 -4
  97. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +2 -0
  98. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -1
  99. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.js +17 -1
  100. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +1 -0
  101. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -1
  102. package/dest/node-cjs/cbind/generate.d.ts +5 -0
  103. package/dest/node-cjs/cbind/generate.d.ts.map +1 -0
  104. package/dest/node-cjs/cbind/generate.js +66 -0
  105. package/dest/node-cjs/cbind/generated/api_types.d.ts +634 -0
  106. package/dest/node-cjs/cbind/generated/api_types.d.ts.map +1 -0
  107. package/dest/node-cjs/cbind/generated/api_types.js +925 -0
  108. package/dest/node-cjs/cbind/generated/async.d.ts +23 -0
  109. package/dest/node-cjs/cbind/generated/async.d.ts.map +1 -0
  110. package/dest/node-cjs/cbind/generated/async.js +152 -0
  111. package/dest/node-cjs/cbind/generated/native.d.ts +31 -0
  112. package/dest/node-cjs/cbind/generated/native.d.ts.map +1 -0
  113. package/dest/node-cjs/cbind/generated/native.js +238 -0
  114. package/dest/node-cjs/cbind/generated/sync.d.ts +23 -0
  115. package/dest/node-cjs/cbind/generated/sync.d.ts.map +1 -0
  116. package/dest/node-cjs/cbind/generated/sync.js +137 -0
  117. package/dest/node-cjs/cbind/schema_compiler.d.ts +70 -0
  118. package/dest/node-cjs/cbind/schema_compiler.d.ts.map +1 -0
  119. package/dest/node-cjs/cbind/schema_compiler.js +691 -0
  120. package/dest/node-cjs/main.js +3 -3
  121. package/dest/node-cjs/proof/index.d.ts +2 -0
  122. package/dest/node-cjs/proof/index.d.ts.map +1 -1
  123. package/dest/node-cjs/proof/index.js +3 -1
  124. package/package.json +4 -3
  125. package/src/barretenberg/backend.ts +129 -137
  126. package/src/barretenberg/index.ts +52 -1
  127. package/src/barretenberg/verifier.ts +1 -1
  128. package/src/barretenberg_api/index.ts +4 -4
  129. package/src/barretenberg_wasm/barretenberg_wasm_base/index.ts +5 -3
  130. package/src/barretenberg_wasm/barretenberg_wasm_main/index.ts +23 -0
  131. package/src/cbind/README.md +1 -0
  132. package/src/cbind/generate.ts +89 -0
  133. package/src/cbind/schema_compiler.ts +833 -0
  134. package/src/main.ts +2 -2
  135. package/src/proof/index.ts +2 -2
@@ -0,0 +1,683 @@
1
+ /**
2
+ * Unified schema compiler with integrated strategies
3
+ */
4
+ // Helper functions
5
+ function capitalize(s) {
6
+ return s.charAt(0).toUpperCase() + s.substring(1);
7
+ }
8
+ function camelCase(s) {
9
+ return s
10
+ .split('_')
11
+ .map((part, index) => (index === 0 ? part.charAt(0).toLowerCase() + part.substring(1) : capitalize(part)))
12
+ .join('');
13
+ }
14
+ function pascalCase(s) {
15
+ return s.split('_').map(capitalize).join('');
16
+ }
17
+ export class SchemaCompiler {
18
+ constructor(config) {
19
+ this.config = config;
20
+ this.typeCache = new Map();
21
+ this.functionMetadata = [];
22
+ // WORKTODO(bbapi): AI slop fixup - redundant with typeCache, remove
23
+ this.referencedTypes = new Set();
24
+ }
25
+ /**
26
+ * Process API schema and extract function metadata
27
+ */
28
+ processApiSchema(commandsSchema, responsesSchema) {
29
+ // Process types
30
+ this.processSchema(commandsSchema);
31
+ this.processSchema(responsesSchema);
32
+ // Extract function metadata from named unions
33
+ if (!Array.isArray(commandsSchema) || commandsSchema[0] !== 'named_union' ||
34
+ !Array.isArray(responsesSchema) || responsesSchema[0] !== 'named_union') {
35
+ throw new Error('Expected named_union schema format');
36
+ }
37
+ const commands = commandsSchema[1];
38
+ const responses = responsesSchema[1];
39
+ for (let i = 0; i < commands.length; i++) {
40
+ const [commandName] = commands[i];
41
+ const [responseName] = responses[i];
42
+ this.functionMetadata.push({
43
+ name: camelCase(commandName),
44
+ commandType: pascalCase(commandName),
45
+ responseType: pascalCase(responseName),
46
+ });
47
+ }
48
+ }
49
+ /**
50
+ * Process a schema and populate type cache
51
+ */
52
+ processSchema(schema) {
53
+ const key = this.getSchemaKey(schema);
54
+ if (this.typeCache.has(key)) {
55
+ const ret = this.typeCache.get(key);
56
+ if (ret.typeName === 'unknown') {
57
+ throw new Error(`Recursive schema detected at ${key}, please check your schema for circular references.`);
58
+ }
59
+ return ret;
60
+ }
61
+ this.typeCache.set(key, { typeName: 'unknown', msgpackTypeName: '' });
62
+ const typeInfo = this.generateTypeInfo(schema);
63
+ this.typeCache.set(key, typeInfo);
64
+ return typeInfo;
65
+ }
66
+ /**
67
+ * Generate the complete output
68
+ */
69
+ compile() {
70
+ const parts = [
71
+ '// AUTOGENERATED FILE - DO NOT EDIT',
72
+ '',
73
+ ];
74
+ // Generate imports
75
+ parts.push(...this.generateImports());
76
+ parts.push('');
77
+ // Generate type declarations only for 'types' mode
78
+ if (this.config.mode === 'types') {
79
+ const sortedTypes = Array.from(this.typeCache.values())
80
+ .filter(t => t.declaration)
81
+ .sort((a, b) => a.typeName.localeCompare(b.typeName));
82
+ // Group declarations
83
+ const typeAliases = sortedTypes.filter(t => t.declaration?.startsWith('export type') && !t.declaration?.includes('interface'));
84
+ const publicInterfaces = sortedTypes.filter(t => t.declaration?.includes('export interface'));
85
+ const privateInterfaces = sortedTypes.filter(t => t.declaration?.includes('interface Msgpack'));
86
+ // Add type aliases if needed
87
+ if (typeAliases.length > 0) {
88
+ parts.push('// Type aliases');
89
+ for (const type of typeAliases) {
90
+ parts.push(type.declaration);
91
+ }
92
+ parts.push('');
93
+ }
94
+ // Add tuple helper if needed
95
+ if (this.needsTupleHelper()) {
96
+ parts.push('// Tuple type for fixed-size arrays', 'type Tuple<T, N extends number> = N extends N ? (number extends N ? T[] : _TupleOf<T, N, []>) : never;', 'type _TupleOf<T, N extends number, R extends unknown[]> = R[\'length\'] extends N ? R : _TupleOf<T, N, [T, ...R]>;', '', '// Helper functions', 'function mapTuple<T, S, N extends number>(tuple: Tuple<T, N>, fn: (item: T) => S): Tuple<S, N> {', ' return tuple.map(fn) as Tuple<S, N>;', '}', '');
97
+ }
98
+ // Add public interfaces
99
+ if (publicInterfaces.length > 0) {
100
+ parts.push('// Public interfaces (exported)');
101
+ for (const type of publicInterfaces) {
102
+ parts.push(type.declaration, '');
103
+ }
104
+ }
105
+ // Add private interfaces
106
+ if (privateInterfaces.length > 0) {
107
+ parts.push('// Private Msgpack interfaces (not exported)');
108
+ for (const type of privateInterfaces) {
109
+ parts.push(type.declaration, '');
110
+ }
111
+ }
112
+ // Add conversion functions (only for api_types.ts)
113
+ const conversions = sortedTypes.filter(t => t.toMethod || t.fromMethod);
114
+ if (conversions.length > 0) {
115
+ parts.push('// Conversion functions (exported)');
116
+ for (const type of conversions) {
117
+ if (type.toMethod) {
118
+ parts.push('export ' + type.toMethod, '');
119
+ }
120
+ if (type.fromMethod) {
121
+ parts.push('export ' + type.fromMethod, '');
122
+ }
123
+ }
124
+ }
125
+ // Add BbApiBase interface
126
+ if (this.functionMetadata.length > 0) {
127
+ parts.push('', '// Base API interface');
128
+ parts.push(this.generateBbApiBaseInterface());
129
+ }
130
+ }
131
+ // Add API class for non-types modes
132
+ if (this.config.mode !== 'types' && this.functionMetadata.length > 0) {
133
+ parts.push(this.generateApiClass());
134
+ }
135
+ return parts.join('\n') + '\n';
136
+ }
137
+ getSchemaKey(schema) {
138
+ if (typeof schema === 'string')
139
+ return schema;
140
+ if (Array.isArray(schema))
141
+ return JSON.stringify(schema);
142
+ if (typeof schema === 'object')
143
+ return schema.__typename || JSON.stringify(schema);
144
+ return String(schema);
145
+ }
146
+ needsTupleHelper() {
147
+ return Array.from(this.typeCache.values()).some(t => t.typeName.includes('Tuple<'));
148
+ }
149
+ trackTypeUsage(typeName) {
150
+ // Only track for API modes
151
+ if (this.config.mode === 'types')
152
+ return;
153
+ // Extract base types from complex types
154
+ const baseTypes = this.extractBaseTypes(typeName);
155
+ for (const type of baseTypes) {
156
+ // Skip built-in types
157
+ if (['string', 'number', 'boolean', 'Uint8Array'].includes(type)) {
158
+ continue;
159
+ }
160
+ this.referencedTypes.add(type);
161
+ }
162
+ }
163
+ extractBaseTypes(typeName) {
164
+ const types = [];
165
+ // Handle arrays
166
+ const arrayMatch = typeName.match(/^(.+)\[\]$/);
167
+ if (arrayMatch) {
168
+ types.push(...this.extractBaseTypes(arrayMatch[1]));
169
+ return types;
170
+ }
171
+ // Handle Tuple
172
+ const tupleMatch = typeName.match(/^Tuple<(.+),\s*\d+>$/);
173
+ if (tupleMatch) {
174
+ types.push(...this.extractBaseTypes(tupleMatch[1]));
175
+ return types;
176
+ }
177
+ // Handle Record
178
+ const recordMatch = typeName.match(/^Record<(.+),\s*(.+)>$/);
179
+ if (recordMatch) {
180
+ types.push(...this.extractBaseTypes(recordMatch[1]));
181
+ types.push(...this.extractBaseTypes(recordMatch[2]));
182
+ return types;
183
+ }
184
+ // Handle union types
185
+ if (typeName.includes(' | ')) {
186
+ const parts = typeName.split(' | ');
187
+ for (const part of parts) {
188
+ types.push(...this.extractBaseTypes(part.trim()));
189
+ }
190
+ return types;
191
+ }
192
+ // Base case - simple type
193
+ types.push(typeName);
194
+ return types;
195
+ }
196
+ generateTypeInfo(schema) {
197
+ if (Array.isArray(schema)) {
198
+ return this.processArraySchema(schema);
199
+ }
200
+ else if (typeof schema === 'string') {
201
+ return this.processPrimitiveSchema(schema);
202
+ }
203
+ else if (typeof schema === 'object') {
204
+ return this.processObjectSchema(schema);
205
+ }
206
+ throw new Error(`Unsupported schema type: ${schema}`);
207
+ }
208
+ processArraySchema(schema) {
209
+ const [type, ...args] = schema;
210
+ switch (type) {
211
+ case 'array': {
212
+ const [subtype, size] = args[0];
213
+ const subtypeInfo = this.processSchema(subtype);
214
+ return {
215
+ typeName: `Tuple<${subtypeInfo.typeName}, ${size}>`,
216
+ msgpackTypeName: `Tuple<${subtypeInfo.msgpackTypeName || subtypeInfo.typeName}, ${size}>`,
217
+ };
218
+ }
219
+ case 'variant': {
220
+ const variants = args[0];
221
+ const variantInfos = variants.map(v => this.processSchema(v));
222
+ const typeName = variantInfos.map(v => v.typeName).join(' | ');
223
+ const msgpackUnion = variantInfos.map(v => v.msgpackTypeName || v.typeName).join(' | ');
224
+ return {
225
+ typeName,
226
+ msgpackTypeName: `[number, ${msgpackUnion}]`,
227
+ };
228
+ }
229
+ case 'named_union': {
230
+ const namedTypes = args[0];
231
+ const tupleTypes = [];
232
+ for (const [name, schemaOrName] of namedTypes) {
233
+ let typeInfo = this.processSchema(schemaOrName);
234
+ // Track usage of the type
235
+ this.trackTypeUsage(typeInfo.typeName);
236
+ tupleTypes.push(`["${name}", ${typeInfo.typeName}]`);
237
+ }
238
+ return {
239
+ typeName: tupleTypes.join(' | '),
240
+ msgpackTypeName: tupleTypes.join(' | '),
241
+ };
242
+ }
243
+ case 'vector': {
244
+ const [subtype] = args[0];
245
+ if (subtype === 'unsigned char') {
246
+ return { typeName: 'Uint8Array' };
247
+ }
248
+ const subtypeInfo = this.processSchema(subtype);
249
+ return {
250
+ typeName: `${subtypeInfo.typeName}[]`,
251
+ msgpackTypeName: `${subtypeInfo.msgpackTypeName || subtypeInfo.typeName}[]`,
252
+ };
253
+ }
254
+ case 'alias': {
255
+ const [rawTypeName, msgpackName] = args[0];
256
+ const typeName = pascalCase(rawTypeName);
257
+ let targetType;
258
+ if (msgpackName.startsWith('bin')) {
259
+ targetType = 'Uint8Array';
260
+ }
261
+ else if (['int', 'unsigned int', 'unsigned short'].includes(msgpackName)) {
262
+ targetType = 'number';
263
+ }
264
+ else {
265
+ throw new Error(`Unsupported alias type: ${msgpackName}`);
266
+ }
267
+ // Create a proper type alias declaration
268
+ return {
269
+ typeName,
270
+ msgpackTypeName: targetType,
271
+ declaration: `export type ${typeName} = ${targetType};`,
272
+ };
273
+ }
274
+ case 'shared_ptr': {
275
+ const [subtype] = args[0];
276
+ return this.processSchema(subtype);
277
+ }
278
+ case 'map': {
279
+ const [keyType, valueType] = args[0];
280
+ const keyInfo = this.processSchema(keyType);
281
+ const valueInfo = this.processSchema(valueType);
282
+ return {
283
+ typeName: `Record<${keyInfo.typeName}, ${valueInfo.typeName}>`,
284
+ msgpackTypeName: `Record<${keyInfo.msgpackTypeName || keyInfo.typeName}, ${valueInfo.msgpackTypeName || valueInfo.typeName}>`,
285
+ };
286
+ }
287
+ default:
288
+ throw new Error(`Unsupported array schema type: ${type}`);
289
+ }
290
+ }
291
+ processPrimitiveSchema(schema) {
292
+ switch (schema) {
293
+ case 'bool':
294
+ return { typeName: 'boolean' };
295
+ case 'int':
296
+ case 'unsigned int':
297
+ case 'unsigned short':
298
+ case 'unsigned long':
299
+ case 'double':
300
+ return { typeName: 'number' };
301
+ case 'string':
302
+ return { typeName: 'string' };
303
+ case 'bin32':
304
+ return { typeName: 'Uint8Array' };
305
+ default:
306
+ return { typeName: pascalCase(schema) };
307
+ }
308
+ }
309
+ processObjectSchema(schema) {
310
+ const typeName = pascalCase(schema.__typename);
311
+ const msgpackTypeName = 'Msgpack' + typeName;
312
+ const declaration = this.generateInterfaces(typeName, schema);
313
+ const toMethod = this.generateToMethod(typeName, schema);
314
+ const fromMethod = this.generateFromMethod(typeName, schema);
315
+ return {
316
+ typeName,
317
+ msgpackTypeName,
318
+ declaration,
319
+ toMethod,
320
+ fromMethod,
321
+ };
322
+ }
323
+ getOrCreateEmptyType(typeName) {
324
+ const key = `empty_${typeName}`;
325
+ if (this.typeCache.has(key)) {
326
+ return this.typeCache.get(key);
327
+ }
328
+ const typeInfo = {
329
+ typeName,
330
+ msgpackTypeName: 'Msgpack' + typeName,
331
+ declaration: `export interface ${typeName} {}\n\ninterface Msgpack${typeName} {}`,
332
+ toMethod: `function to${typeName}(o: Msgpack${typeName}): ${typeName} {\n return {};\n}`,
333
+ fromMethod: `function from${typeName}(o: ${typeName}): Msgpack${typeName} {\n return {};\n}`,
334
+ };
335
+ this.typeCache.set(key, typeInfo);
336
+ return typeInfo;
337
+ }
338
+ generateInterfaces(name, schema) {
339
+ const publicInterface = this.generatePublicInterface(name, schema);
340
+ const msgpackInterface = this.generateMsgpackInterface(name, schema);
341
+ return publicInterface + '\n\n' + msgpackInterface;
342
+ }
343
+ generatePublicInterface(name, schema) {
344
+ let result = `export interface ${name} {\n`;
345
+ for (const [key, value] of Object.entries(schema)) {
346
+ if (key === '__typename')
347
+ continue;
348
+ const typeInfo = this.processSchema(value);
349
+ // Track type usage
350
+ this.trackTypeUsage(typeInfo.typeName);
351
+ result += ` ${camelCase(key)}: ${typeInfo.typeName};\n`;
352
+ }
353
+ result += '}';
354
+ return result;
355
+ }
356
+ generateMsgpackInterface(name, schema) {
357
+ let result = `interface Msgpack${name} {\n`;
358
+ for (const [key, value] of Object.entries(schema)) {
359
+ if (key === '__typename')
360
+ continue;
361
+ const typeInfo = this.processSchema(value);
362
+ result += ` ${key}: ${typeInfo.msgpackTypeName || typeInfo.typeName};\n`;
363
+ }
364
+ result += '}';
365
+ return result;
366
+ }
367
+ generateToMethod(name, schema) {
368
+ const fields = Object.entries(schema).filter(([key]) => key !== '__typename');
369
+ if (fields.length === 0) {
370
+ return `function to${name}(o: Msgpack${name}): ${name} {\n return {};\n}`;
371
+ }
372
+ const checks = fields.map(([key]) => ` if (o.${key} === undefined) { throw new Error("Expected ${key} in ${name} deserialization"); }`).join('\n');
373
+ const conversions = fields.map(([key, value]) => {
374
+ const typeInfo = this.processSchema(value);
375
+ const converter = this.generateConverter(typeInfo, `o.${key}`, 'to');
376
+ return ` ${camelCase(key)}: ${converter},`;
377
+ }).join('\n');
378
+ return `function to${name}(o: Msgpack${name}): ${name} {
379
+ ${checks};
380
+ return {
381
+ ${conversions}
382
+ };
383
+ }`;
384
+ }
385
+ generateFromMethod(name, schema) {
386
+ const fields = Object.entries(schema).filter(([key]) => key !== '__typename');
387
+ if (fields.length === 0) {
388
+ return `function from${name}(o: ${name}): Msgpack${name} {\n return {};\n}`;
389
+ }
390
+ const checks = fields.map(([key]) => ` if (o.${camelCase(key)} === undefined) { throw new Error("Expected ${camelCase(key)} in ${name} serialization"); }`).join('\n');
391
+ const conversions = fields.map(([key, value]) => {
392
+ const typeInfo = this.processSchema(value);
393
+ const converter = this.generateConverter(typeInfo, `o.${camelCase(key)}`, 'from');
394
+ return ` ${key}: ${converter},`;
395
+ }).join('\n');
396
+ return `function from${name}(o: ${name}): Msgpack${name} {
397
+ ${checks};
398
+ return {
399
+ ${conversions}
400
+ };
401
+ }`;
402
+ }
403
+ generateConverter(typeInfo, value, direction) {
404
+ // Handle arrays/tuples
405
+ if (typeInfo.typeName.includes('[]') || typeInfo.typeName.includes('Tuple<')) {
406
+ const elementType = typeInfo.typeName.match(/^(.+)\[\]$/) || typeInfo.typeName.match(/^Tuple<(.+),/);
407
+ if (elementType) {
408
+ const isTuple = typeInfo.typeName.includes('Tuple<');
409
+ const mapFn = isTuple ? 'mapTuple' : 'map';
410
+ return `${value}.${mapFn}((v: any) => v)`; // Simplified for now
411
+ }
412
+ }
413
+ // Handle custom types
414
+ if (typeInfo.declaration) {
415
+ return `${direction}${typeInfo.typeName}(${value})`;
416
+ }
417
+ return value;
418
+ }
419
+ generateImports() {
420
+ const imports = [];
421
+ // Base imports
422
+ if (this.config.imports) {
423
+ imports.push(...this.config.imports);
424
+ }
425
+ // For API modes, import from api_types
426
+ if (this.config.mode !== 'types') {
427
+ const neededImports = new Set();
428
+ // Add types and conversion functions from function metadata
429
+ for (const metadata of this.functionMetadata) {
430
+ neededImports.add(metadata.commandType);
431
+ neededImports.add(metadata.responseType);
432
+ neededImports.add(`from${metadata.commandType}`);
433
+ neededImports.add(`to${metadata.responseType}`);
434
+ }
435
+ // Add referenced types
436
+ for (const type of this.referencedTypes) {
437
+ neededImports.add(type);
438
+ }
439
+ // Add BbApiBase interface
440
+ neededImports.add('BbApiBase');
441
+ if (neededImports.size > 0) {
442
+ const sortedImports = Array.from(neededImports).sort();
443
+ // Remove duplicates
444
+ const uniqueImports = sortedImports.filter((item, index) => sortedImports.indexOf(item) === index);
445
+ imports.push(`import { ${uniqueImports.join(', ')} } from './api_types.js';`);
446
+ }
447
+ }
448
+ return imports;
449
+ }
450
+ generateBbApiBaseInterface() {
451
+ const methods = this.functionMetadata.map(m => ` ${m.name}(command: ${m.commandType}): Promise<${m.responseType}>;`).join('\n');
452
+ return `export interface BbApiBase {
453
+ ${methods}
454
+ destroy(): Promise<void>;
455
+ }`;
456
+ }
457
+ generateApiClass() {
458
+ const className = this.getApiClassName();
459
+ const methods = this.functionMetadata.map(m => this.generateApiMethod(m)).join('\n\n');
460
+ if (this.config.mode === 'native') {
461
+ return this.generateNativeApiClass(methods);
462
+ }
463
+ // For sync API, don't implement BbApiBase since methods are synchronous
464
+ const implementsClause = this.config.mode === 'sync' ? '' : ' implements BbApiBase';
465
+ const msgpackCallHelper = `${this.config.mode === 'async' ? 'async ' : ''}function msgpackCall(wasm: ${this.getWasmType()}, cbind: string, input: any[]) {` +
466
+ ` const inputBuffer = new Encoder({ useRecords: false }).pack(input);` +
467
+ ` const encodedResult = ${this.config.mode === 'async' ? 'await ' : ''}wasm.cbindCall(cbind, inputBuffer);` +
468
+ ` return new Decoder({ useRecords: false }).unpack(encodedResult);` +
469
+ `}\n`;
470
+ return (msgpackCallHelper +
471
+ `export class ${className}${implementsClause} {
472
+ constructor(protected wasm: ${this.getWasmType()}) {}
473
+
474
+ ${methods}
475
+
476
+ destroy(): Promise<void> {
477
+ return this.wasm.destroy();
478
+ }
479
+ }`);
480
+ }
481
+ getApiClassName() {
482
+ switch (this.config.mode) {
483
+ case 'sync': return 'SyncApi';
484
+ case 'async': return 'AsyncApi';
485
+ case 'native': return 'NativeApi';
486
+ default: throw new Error(`Invalid mode: ${this.config.mode}`);
487
+ }
488
+ }
489
+ getWasmType() {
490
+ switch (this.config.mode) {
491
+ case 'sync': return 'BarretenbergWasmMain';
492
+ case 'async': return 'BarretenbergWasmMainWorker';
493
+ default: return '';
494
+ }
495
+ }
496
+ generateApiMethod(metadata) {
497
+ const { name, commandType, responseType } = metadata;
498
+ if (this.config.mode === 'native') {
499
+ return ` ${name}(command: ${commandType}): Promise<${responseType}> {
500
+ const msgpackCommand = from${commandType}(command);
501
+ return this.sendCommand(['${metadata.commandType}', msgpackCommand]).then(([variantName, result]: [string, any]) => {
502
+ if (variantName !== '${responseType}') {
503
+ throw new Error(\`Expected variant name '${responseType}' but got '\${variantName}'\`);
504
+ }
505
+ return to${responseType}(result);
506
+ });
507
+ }`;
508
+ }
509
+ // For async mode, queue immediately and return promise
510
+ if (this.config.mode === 'async') {
511
+ return ` ${name}(command: ${commandType}): Promise<${responseType}> {
512
+ const msgpackCommand = from${commandType}(command);
513
+ return msgpackCall(this.wasm, 'bbapi', [["${capitalize(name)}", msgpackCommand]]).then(([variantName, result]: [string, any]) => {
514
+ if (variantName !== '${responseType}') {
515
+ throw new Error(\`Expected variant name '${responseType}' but got '\${variantName}'\`);
516
+ }
517
+ return to${responseType}(result);
518
+ });
519
+ }`;
520
+ }
521
+ // For sync mode, keep the synchronous behavior
522
+ return ` ${name}(command: ${commandType}): ${responseType} {
523
+ const msgpackCommand = from${commandType}(command);
524
+ const [variantName, result] = msgpackCall(this.wasm, 'bbapi', [["${capitalize(name)}", msgpackCommand]]);
525
+ if (variantName !== '${responseType}') {
526
+ throw new Error(\`Expected variant name '${responseType}' but got '\${variantName}'\`);
527
+ }
528
+ return to${responseType}(result);
529
+ }`;
530
+ }
531
+ generateNativeApiClass(methods) {
532
+ return `interface NativeApiRequest {
533
+ resolve: (value: any) => void;
534
+ reject: (error: any) => void;
535
+ }
536
+
537
+ class StreamBuffer {
538
+ private buffer = Buffer.alloc(0);
539
+ private expectedLength: number | null = null;
540
+
541
+ addData(data: Buffer): Buffer[] {
542
+ // Create buffer to grow as needed
543
+ const newBuffer = Buffer.allocUnsafe(this.buffer.length + data.length);
544
+ this.buffer.copy(newBuffer, 0);
545
+ data.copy(newBuffer, this.buffer.length);
546
+ this.buffer = newBuffer;
547
+
548
+ const messages: Buffer[] = [];
549
+
550
+ while (true) {
551
+ if (this.expectedLength === null) {
552
+ if (this.buffer.length < 4) break;
553
+ this.expectedLength = this.buffer.readUInt32LE(0);
554
+ this.buffer = this.buffer.subarray(4);
555
+ }
556
+
557
+ if (this.buffer.length < this.expectedLength) break;
558
+
559
+ // Extract complete message
560
+ const messageBuffer = this.buffer.subarray(0, this.expectedLength);
561
+ messages.push(messageBuffer);
562
+ this.buffer = this.buffer.subarray(this.expectedLength);
563
+ this.expectedLength = null;
564
+ }
565
+
566
+ return messages;
567
+ }
568
+ }
569
+
570
+ export class NativeApi implements BbApiBase {
571
+ private decoder = new Decoder({ useRecords: false });
572
+ private encoder = new Encoder({ useRecords: false });
573
+ private pendingRequests: NativeApiRequest[] = [];
574
+
575
+ private constructor(private proc: ChildProcess) {}
576
+
577
+ static async new(bbPath = 'bb', logger = console.log): Promise<NativeApi> {
578
+ const proc = spawn(bbPath, ['msgpack', 'run'], {
579
+ stdio: ['pipe', 'pipe', 'pipe'],
580
+ });
581
+
582
+ if (!proc.stdout || !proc.stdin) {
583
+ throw new Error('Failed to initialize bb process');
584
+ }
585
+
586
+ const api = new NativeApi(proc);
587
+ const streamBuffer = new StreamBuffer();
588
+
589
+ proc.stdout.on('data', (data: Buffer) => {
590
+ const messages = streamBuffer.addData(data);
591
+
592
+ for (const messageBuffer of messages) {
593
+ const pendingRequest = api.pendingRequests.shift();
594
+ if (!pendingRequest) {
595
+ throw new Error('Received response without a pending request');
596
+ }
597
+
598
+ try {
599
+ const decoded = api.decoder.decode(messageBuffer);
600
+ if (!Array.isArray(decoded) || decoded.length !== 2) {
601
+ throw new Error(\`Invalid response format: \${JSON.stringify(decoded)}\`);
602
+ }
603
+ const [variantName, result] = decoded;
604
+ pendingRequest.resolve([variantName, result]);
605
+ } catch (error) {
606
+ pendingRequest.reject(error);
607
+ break;
608
+ }
609
+ }
610
+ });
611
+
612
+ proc.stderr.on('data', (data: Buffer) => {
613
+ logger(data.toString().trim());
614
+ });
615
+
616
+ proc.on('error', err => {
617
+ throw new Error(err.message);
618
+ });
619
+ return api;
620
+ }
621
+
622
+ private sendCommand(command: any): Promise<any> {
623
+ return new Promise((resolve, reject) => {
624
+ this.pendingRequests.push({ resolve, reject });
625
+ const encoded = this.encoder.encode(command);
626
+
627
+ // Write length prefix (4 bytes, little-endian)
628
+ const lengthBuffer = Buffer.allocUnsafe(4);
629
+ lengthBuffer.writeUInt32LE(encoded.length, 0);
630
+
631
+ // Write length prefix followed by the encoded data
632
+ this.proc.stdin!.write(lengthBuffer);
633
+ this.proc.stdin!.write(encoded);
634
+ });
635
+ }
636
+
637
+ async close(): Promise<void> {
638
+ this.proc.kill();
639
+ }
640
+
641
+ destroy(): Promise<void> {
642
+ return this.close();
643
+ }
644
+
645
+ ${methods}
646
+ }`;
647
+ }
648
+ }
649
+ // Factory methods for creating configured compilers
650
+ export function createSharedTypesCompiler() {
651
+ return new SchemaCompiler({
652
+ mode: 'types',
653
+ imports: [],
654
+ });
655
+ }
656
+ export function createSyncApiCompiler() {
657
+ return new SchemaCompiler({
658
+ mode: 'sync',
659
+ imports: [
660
+ `import { BarretenbergWasmMain } from "../../barretenberg_wasm/barretenberg_wasm_main/index.js";`,
661
+ `import { Decoder, Encoder } from 'msgpackr';`,
662
+ ],
663
+ });
664
+ }
665
+ export function createAsyncApiCompiler() {
666
+ return new SchemaCompiler({
667
+ mode: 'async',
668
+ imports: [
669
+ `import { BarretenbergWasmMainWorker } from "../../barretenberg_wasm/barretenberg_wasm_main/index.js";`,
670
+ `import { Decoder, Encoder } from 'msgpackr';`
671
+ ],
672
+ });
673
+ }
674
+ export function createNativeApiCompiler() {
675
+ return new SchemaCompiler({
676
+ mode: 'native',
677
+ imports: [
678
+ `import { spawn, ChildProcess } from 'child_process';`,
679
+ `import { Decoder, Encoder } from 'msgpackr';`
680
+ ],
681
+ });
682
+ }
683
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hX2NvbXBpbGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NiaW5kL3NjaGVtYV9jb21waWxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQXVDSCxtQkFBbUI7QUFDbkIsU0FBUyxVQUFVLENBQUMsQ0FBUztJQUMzQixPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNwRCxDQUFDO0FBRUQsU0FBUyxTQUFTLENBQUMsQ0FBUztJQUMxQixPQUFPLENBQUM7U0FDTCxLQUFLLENBQUMsR0FBRyxDQUFDO1NBQ1YsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1NBQ3pHLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQztBQUNkLENBQUM7QUFFRCxTQUFTLFVBQVUsQ0FBQyxDQUFTO0lBQzNCLE9BQU8sQ0FBQyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0FBQy9DLENBQUM7QUFFRCxNQUFNLE9BQU8sY0FBYztJQU16QixZQUFvQixNQUFzQjtRQUF0QixXQUFNLEdBQU4sTUFBTSxDQUFnQjtRQUxsQyxjQUFTLEdBQUcsSUFBSSxHQUFHLEVBQW9CLENBQUM7UUFDeEMscUJBQWdCLEdBQXVCLEVBQUUsQ0FBQztRQUNsRCxvRUFBb0U7UUFDNUQsb0JBQWUsR0FBRyxJ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