@naeemo/capnp 0.9.0 → 0.9.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/dist/{cli-DwbiXeKw.js → cli-DGBgLdGK.js} +5 -3
- package/dist/{cli-DwbiXeKw.js.map → cli-DGBgLdGK.js.map} +1 -1
- package/dist/{cli-DHKzE1UX.js → cli-DlZBZozW.js} +2 -2
- package/dist/{cli-DHKzE1UX.js.map → cli-DlZBZozW.js.map} +1 -1
- package/dist/cli-audit-j58Eyd5d.js +380 -0
- package/dist/cli-audit-j58Eyd5d.js.map +1 -0
- package/dist/cli-bench-bkR1vGK8.js +4528 -0
- package/dist/cli-bench-bkR1vGK8.js.map +1 -0
- package/dist/{cli-gen-BF0So0Ig.js → cli-gen-aCkffW1Z.js} +5 -3
- package/dist/{cli-gen-BF0So0Ig.js.map → cli-gen-aCkffW1Z.js.map} +1 -1
- package/dist/cli.js +26 -8
- package/dist/cli.js.map +1 -1
- package/dist/core-DstLMMvA.js +2 -0
- package/dist/index.cjs +37 -2
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +37 -2
- package/dist/index.js.map +1 -1
- package/dist/{message-reader-fw2PY8sU.js → message-reader-_TCBf61G.js} +40 -176
- package/dist/message-reader-_TCBf61G.js.map +1 -0
- package/dist/{schema-types-B6M2jsM7.js → schema-types-GVRD1pwE.js} +1 -1
- package/dist/{schema-types-B6M2jsM7.js.map → schema-types-GVRD1pwE.js.map} +1 -1
- package/dist/segment-yid_PYS5.js +176 -0
- package/dist/segment-yid_PYS5.js.map +1 -0
- package/package.json +2 -1
- package/dist/message-reader-fw2PY8sU.js.map +0 -1
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import { r as ElementSize
|
|
2
|
+
import { r as ElementSize } from "./segment-yid_PYS5.js";
|
|
3
|
+
import { t as MessageReader } from "./message-reader-_TCBf61G.js";
|
|
4
|
+
import "./core-DstLMMvA.js";
|
|
3
5
|
import { parseArgs } from "node:util";
|
|
4
|
-
import { execSync } from "node:child_process";
|
|
5
6
|
import { existsSync, mkdtempSync, readFileSync, rmSync, writeFileSync } from "node:fs";
|
|
6
7
|
import { tmpdir } from "node:os";
|
|
8
|
+
import { execSync } from "node:child_process";
|
|
7
9
|
import { join } from "node:path";
|
|
8
10
|
|
|
9
11
|
//#region src/codegen/generator.ts
|
|
@@ -1320,4 +1322,4 @@ async function run(args) {
|
|
|
1320
1322
|
|
|
1321
1323
|
//#endregion
|
|
1322
1324
|
export { run };
|
|
1323
|
-
//# sourceMappingURL=cli-gen-
|
|
1325
|
+
//# sourceMappingURL=cli-gen-aCkffW1Z.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli-gen-BF0So0Ig.js","names":[],"sources":["../src/codegen/generator.ts","../src/schema/schema-reader.ts","../src/cli-gen.ts"],"sourcesContent":["/**\n * 基于 Binary Schema 的 TypeScript 代码生成器\n *\n * 使用官方 capnp 编译器生成的二进制 schema 来生成 TypeScript 代码\n */\n\nimport type {\n CodeGeneratorRequestReader,\n FieldReader,\n Id,\n NodeReader,\n TypeKind,\n TypeReader,\n} from '../schema/schema-reader.js';\n\n// 导入运行时类型用于代码生成\nimport type { StructBuilder, StructReader } from '../core/index.js';\n\nexport interface GeneratorOptions {\n /** 运行时库导入路径 */\n runtimeImportPath?: string;\n}\n\nconst DEFAULT_OPTIONS: GeneratorOptions = {\n runtimeImportPath: '@naeemo/capnp',\n};\n\n/**\n * Union 字段分组\n */\ninterface UnionGroup {\n discriminantOffset: number;\n fields: FieldReader[];\n}\n\n/**\n * 从 CodeGeneratorRequest 生成 TypeScript 代码\n */\nexport function generateFromRequest(\n request: CodeGeneratorRequestReader,\n options?: GeneratorOptions\n): Map<string, string> {\n const opts = { ...DEFAULT_OPTIONS, ...options };\n const files = new Map<string, string>();\n\n const nodes = request.nodes;\n const requestedFiles = request.requestedFiles;\n\n // 为每个请求的文件生成代码\n for (const file of requestedFiles) {\n const filename = file.filename.replace(/\\.capnp$/, '.ts');\n const code = generateFile(file.id, nodes, opts);\n files.set(filename, code);\n }\n\n return files;\n}\n\n/**\n * 生成单个文件的 TypeScript 代码\n */\nfunction generateFile(fileId: Id, allNodes: NodeReader[], options: GeneratorOptions): string {\n const lines: string[] = [];\n\n // 文件头\n lines.push('// Generated by @naeemo/capnp');\n lines.push('// DO NOT EDIT MANUALLY');\n lines.push('');\n lines.push(\n `import { MessageReader, MessageBuilder, StructReader, StructBuilder, createUnionReader, createUnionBuilder } from \"${options.runtimeImportPath}\";`\n );\n lines.push('');\n\n // 添加 XOR 辅助函数(用于 float 默认值)\n lines.push('// XOR helpers for default value encoding');\n lines.push('function xorFloat32(a: number, b: number): number {');\n lines.push(' const view = new DataView(new ArrayBuffer(4));');\n lines.push(' view.setFloat32(0, a, true);');\n lines.push(' const aBits = view.getUint32(0, true);');\n lines.push(' view.setFloat32(0, b, true);');\n lines.push(' const bBits = view.getUint32(0, true);');\n lines.push(' view.setUint32(0, aBits ^ bBits, true);');\n lines.push(' return view.getFloat32(0, true);');\n lines.push('}');\n lines.push('');\n lines.push('function xorFloat64(a: number, b: number): number {');\n lines.push(' const view = new DataView(new ArrayBuffer(8));');\n lines.push(' view.setFloat64(0, a, true);');\n lines.push(' const aBits = view.getBigUint64(0, true);');\n lines.push(' view.setFloat64(0, b, true);');\n lines.push(' const bBits = view.getBigUint64(0, true);');\n lines.push(' view.setBigUint64(0, aBits ^ bBits, true);');\n lines.push(' return view.getFloat64(0, true);');\n lines.push('}');\n lines.push('');\n\n // 找到属于这个文件的所有节点\n // 包括:\n // 1. scopeId === fileId 的节点(正常定义的 struct/enum/interface)\n // 2. scopeId === 0 且 displayName 包含文件名的节点(auto-generated method params/results)\n let filePrefix = '';\n try {\n const fileNode = allNodes.find((n) => n.id === fileId);\n filePrefix = fileNode?.displayName || '';\n } catch (_e) {\n // Ignore errors reading file node\n }\n\n const fileNodes = allNodes.filter((n) => {\n try {\n if (n.scopeId === fileId) return true;\n // Auto-generated method params/results have scopeId = 0\n if (n.scopeId === 0n && filePrefix && n.displayName.startsWith(`${filePrefix}:`)) {\n // Check if it's a method params/results struct\n const shortName = n.displayName.substring(filePrefix.length + 1);\n return shortName.includes('$');\n }\n } catch (_e) {\n // Skip nodes that can't be read\n }\n return false;\n });\n\n // 生成每个节点的代码\n for (const node of fileNodes) {\n if (node.isStruct) {\n lines.push(generateStruct(node, allNodes));\n } else if (node.isEnum) {\n lines.push(generateEnum(node));\n } else if (node.isInterface) {\n lines.push(generateInterface(node, allNodes));\n }\n lines.push('');\n }\n\n return lines.join('\\n');\n}\n\n/**\n * 生成 Struct 的 TypeScript 代码\n */\nfunction generateStruct(node: NodeReader, allNodes: NodeReader[]): string {\n const lines: string[] = [];\n const structName = getShortName(node.displayName);\n\n // 分析字段:分离 Union 字段、普通字段和 Group 字段\n let unionGroups: UnionGroup[] = [];\n let regularFields: FieldReader[] = [];\n let groupFields: { field: FieldReader; groupNode: NodeReader }[] = [];\n\n try {\n const analysis = analyzeFields(node, allNodes);\n unionGroups = analysis.unionGroups;\n regularFields = analysis.regularFields;\n groupFields = analysis.groupFields;\n } catch (_e) {\n // Some auto-generated structs may have invalid field data\n // Return a minimal struct definition in this case\n lines.push(`export interface ${structName} {`);\n lines.push(' // Note: Could not parse struct fields');\n lines.push('}');\n lines.push('');\n lines.push(`export class ${structName}Reader {`);\n lines.push(' constructor(private reader: StructReader) {}');\n lines.push('}');\n lines.push('');\n lines.push(`export class ${structName}Builder {`);\n lines.push(' constructor(private builder: StructBuilder) {}');\n lines.push('}');\n return lines.join('\\n');\n }\n\n // 生成接口定义\n lines.push(`export interface ${structName} {`);\n\n // 普通字段\n for (const field of regularFields) {\n if (!field.isSlot) continue;\n const tsType = getTypeScriptType(field.slotType, allNodes);\n lines.push(` ${field.name}: ${tsType};`);\n }\n\n // Group 字段 - 内联 Group 的字段\n for (const { field: groupField, groupNode } of groupFields) {\n const groupName = groupField.name;\n try {\n for (const field of groupNode.structFields) {\n if (!field.isSlot) continue;\n const tsType = getTypeScriptType(field.slotType, allNodes);\n lines.push(` ${groupName}${capitalize(field.name)}: ${tsType};`);\n }\n } catch (_e) {\n // Skip invalid group fields\n }\n }\n\n // Union 字段 - 生成 discriminant 和 variant 类型\n for (const [groupIndex, group] of unionGroups.entries()) {\n const unionName =\n group.fields.length > 0 ? `${capitalize(group.fields[0].name)}Union` : `Union${groupIndex}`;\n lines.push(` ${unionName}: ${generateUnionVariantType(group, allNodes)};`);\n }\n\n lines.push('}');\n lines.push('');\n\n // 生成 Reader 类\n lines.push(`export class ${structName}Reader {`);\n lines.push(' constructor(private reader: StructReader) {}');\n lines.push('');\n\n // 普通字段 getters\n for (const field of regularFields) {\n if (!field.isSlot) continue;\n const getter = generateFieldGetter(field);\n lines.push(` ${getter}`);\n lines.push('');\n }\n\n // Group 字段 getters - 内联 Group 的字段\n for (const { field: groupField, groupNode } of groupFields) {\n const groupName = groupField.name;\n try {\n for (const field of groupNode.structFields) {\n if (!field.isSlot) continue;\n const getter = generateGroupFieldGetter(field, groupName);\n lines.push(` ${getter}`);\n lines.push('');\n }\n } catch (_e) {\n // Skip invalid group fields\n }\n }\n\n // Union 方法\n for (const [groupIndex, group] of unionGroups.entries()) {\n const unionName =\n group.fields.length > 0 ? `${capitalize(group.fields[0].name)}Union` : `Union${groupIndex}`;\n const variants: Record<number, string> = {};\n for (const field of group.fields) {\n variants[field.discriminantValue] = field.name;\n }\n const variantsStr = JSON.stringify(variants).replace(/\"/g, \"'\");\n\n lines.push(` get${unionName}Tag(): number {`);\n lines.push(` return this.reader.getUint16(${group.discriminantOffset * 2});`);\n lines.push(' }');\n lines.push('');\n\n lines.push(` get${unionName}Variant(): string | undefined {`);\n lines.push(` const tag = this.get${unionName}Tag();`);\n lines.push(` const variants = ${variantsStr};`);\n lines.push(' return variants[tag];');\n lines.push(' }');\n lines.push('');\n\n // 每个 variant 的 getter\n for (const field of group.fields) {\n const getter = generateUnionFieldGetter(field, unionName, field.discriminantValue);\n lines.push(` ${getter}`);\n lines.push('');\n }\n\n // 每个 variant 的 setter\n for (const field of group.fields) {\n const setter = generateUnionFieldSetter(\n field,\n unionName,\n field.discriminantValue,\n group.discriminantOffset * 2\n );\n lines.push(` ${setter}`);\n lines.push('');\n }\n }\n\n lines.push('}');\n lines.push('');\n\n // 生成 Builder 类\n lines.push(`export class ${structName}Builder {`);\n lines.push(' constructor(private builder: StructBuilder) {}');\n lines.push('');\n\n // 普通字段 setters\n for (const field of regularFields) {\n if (!field.isSlot) continue;\n const setter = generateFieldSetter(field);\n lines.push(` ${setter}`);\n lines.push('');\n }\n\n // Group 字段 setters\n for (const { field: groupField, groupNode } of groupFields) {\n const groupName = groupField.name;\n try {\n for (const field of groupNode.structFields) {\n if (!field.isSlot) continue;\n const setter = generateGroupFieldSetter(field, groupName);\n lines.push(` ${setter}`);\n lines.push('');\n }\n } catch (_e) {\n // Skip invalid group fields\n }\n }\n\n // Union setters\n for (const [groupIndex, group] of unionGroups.entries()) {\n const unionName =\n group.fields.length > 0 ? `${capitalize(group.fields[0].name)}Union` : `Union${groupIndex}`;\n for (const field of group.fields) {\n const setter = generateUnionFieldSetter(\n field,\n unionName,\n field.discriminantValue,\n group.discriminantOffset * 2\n );\n lines.push(` ${setter}`);\n lines.push('');\n }\n }\n\n lines.push('}');\n\n return lines.join('\\n');\n}\n\n/**\n * 分析字段,分离 Union 字段和普通字段,展开 Group 字段\n */\nfunction analyzeFields(\n node: NodeReader,\n allNodes: NodeReader[]\n): {\n unionGroups: UnionGroup[];\n regularFields: FieldReader[];\n groupFields: { field: FieldReader; groupNode: NodeReader }[];\n} {\n const fields = node.structFields;\n const unionGroups: Map<number, UnionGroup> = new Map();\n const regularFields: FieldReader[] = [];\n const groupFields: { field: FieldReader; groupNode: NodeReader }[] = [];\n\n for (const field of fields) {\n // 处理 Group 字段\n if (field.isGroup) {\n const groupNode = allNodes.find((n) => n.id === field.groupTypeId);\n if (groupNode?.isStruct) {\n groupFields.push({ field, groupNode });\n }\n continue;\n }\n\n // 处理 Union 字段\n if (\n node.structDiscriminantCount > 0 &&\n field.discriminantValue !== 65535 &&\n field.discriminantValue !== 0\n ) {\n const discriminantOffset = node.structDiscriminantOffset;\n\n if (!unionGroups.has(discriminantOffset)) {\n unionGroups.set(discriminantOffset, { discriminantOffset, fields: [] });\n }\n unionGroups.get(discriminantOffset)!.fields.push(field);\n } else {\n // 普通字段\n regularFields.push(field);\n }\n }\n\n return {\n unionGroups: Array.from(unionGroups.values()),\n regularFields,\n groupFields,\n };\n}\n\n/**\n * 生成 Union variant 类型\n */\nfunction generateUnionVariantType(group: UnionGroup, allNodes: NodeReader[]): string {\n const variants = group.fields.map((f) => {\n const tsType = f.isSlot ? getTypeScriptType(f.slotType, allNodes) : 'unknown';\n return `{ tag: ${f.discriminantValue}; variant: '${f.name}'; value: ${tsType} }`;\n });\n return variants.join(' | ');\n}\n\n/**\n * 生成 Union 字段的 getter\n */\nfunction generateUnionFieldGetter(\n field: FieldReader,\n unionName: string,\n discriminantValue: number\n): string {\n const name = field.name;\n const type = field.slotType;\n\n if (!type || !field.isSlot) {\n return `get${capitalize(name)}(): unknown | undefined { return this.get${unionName}Tag() === ${discriminantValue} ? undefined : undefined; }`;\n }\n\n const returnType = getTypeScriptTypeForSetter(type);\n\n let body: string;\n switch (type.kind) {\n case 'void':\n body = 'return undefined;';\n break;\n case 'bool':\n body = `return this.reader.getBool(${field.slotOffset * 8});`;\n break;\n case 'int8':\n body = `return this.reader.getInt8(${field.slotOffset});`;\n break;\n case 'int16':\n body = `return this.reader.getInt16(${field.slotOffset * 2});`;\n break;\n case 'int32':\n body = `return this.reader.getInt32(${field.slotOffset * 4});`;\n break;\n case 'int64':\n body = `return this.reader.getInt64(${field.slotOffset * 8});`;\n break;\n case 'uint8':\n body = `return this.reader.getUint8(${field.slotOffset});`;\n break;\n case 'uint16':\n body = `return this.reader.getUint16(${field.slotOffset * 2});`;\n break;\n case 'uint32':\n body = `return this.reader.getUint32(${field.slotOffset * 4});`;\n break;\n case 'uint64':\n body = `return this.reader.getUint64(${field.slotOffset * 8});`;\n break;\n case 'float32':\n body = `return this.reader.getFloat32(${field.slotOffset * 4});`;\n break;\n case 'float64':\n body = `return this.reader.getFloat64(${field.slotOffset * 8});`;\n break;\n case 'text':\n body = `return this.reader.getText(${field.slotOffset});`;\n break;\n case 'data':\n body = `return this.reader.getData(${field.slotOffset});`;\n break;\n default:\n body = 'return undefined;';\n }\n\n return `get${capitalize(name)}(): ${returnType} | undefined {\n if (this.get${unionName}Tag() !== ${discriminantValue}) return undefined;\n ${body}\n }`;\n}\n\n/**\n * 生成 Group 字段的 getter\n * Group 字段在父 struct 的 data/pointer section 中,但命名空间是 Group 的名字\n */\nfunction generateGroupFieldGetter(field: FieldReader, groupName: string): string {\n const name = field.name;\n const type = field.slotType;\n\n if (!type) {\n return `get${capitalize(groupName)}${capitalize(name)}(): unknown { return undefined; }`;\n }\n\n switch (type.kind) {\n case 'void':\n return `get${capitalize(groupName)}${capitalize(name)}(): void { return undefined; }`;\n case 'bool':\n return `get${capitalize(groupName)}${capitalize(name)}(): boolean { return this.reader.getBool(${field.slotOffset * 8}); }`;\n case 'int8':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getInt8(${field.slotOffset}); }`;\n case 'int16':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getInt16(${field.slotOffset * 2}); }`;\n case 'int32':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getInt32(${field.slotOffset * 4}); }`;\n case 'int64':\n return `get${capitalize(groupName)}${capitalize(name)}(): bigint { return this.reader.getInt64(${field.slotOffset * 8}); }`;\n case 'uint8':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getUint8(${field.slotOffset}); }`;\n case 'uint16':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getUint16(${field.slotOffset * 2}); }`;\n case 'uint32':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getUint32(${field.slotOffset * 4}); }`;\n case 'uint64':\n return `get${capitalize(groupName)}${capitalize(name)}(): bigint { return this.reader.getUint64(${field.slotOffset * 8}); }`;\n case 'float32':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getFloat32(${field.slotOffset * 4}); }`;\n case 'float64':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getFloat64(${field.slotOffset * 8}); }`;\n case 'text':\n return `get${capitalize(groupName)}${capitalize(name)}(): string { return this.reader.getText(${field.slotOffset}); }`;\n case 'data':\n return `get${capitalize(groupName)}${capitalize(name)}(): Uint8Array { return this.reader.getData(${field.slotOffset}); }`;\n default:\n return `get${capitalize(groupName)}${capitalize(name)}(): unknown { return undefined; }`;\n }\n}\n\n/**\n * 生成 Group 字段的 setter\n */\nfunction generateGroupFieldSetter(field: FieldReader, groupName: string): string {\n const name = field.name;\n const type = field.slotType;\n const paramType = getTypeScriptTypeForSetter(type);\n\n if (!type || !field.isSlot) {\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { /* TODO */ }`;\n }\n\n switch (type.kind) {\n case 'void':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { }`;\n case 'bool':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setBool(${field.slotOffset * 8}, value); }`;\n case 'int8':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setInt8(${field.slotOffset}, value); }`;\n case 'int16':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setInt16(${field.slotOffset * 2}, value); }`;\n case 'int32':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setInt32(${field.slotOffset * 4}, value); }`;\n case 'int64':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setInt64(${field.slotOffset * 8}, value); }`;\n case 'uint8':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setUint8(${field.slotOffset}, value); }`;\n case 'uint16':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setUint16(${field.slotOffset * 2}, value); }`;\n case 'uint32':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setUint32(${field.slotOffset * 4}, value); }`;\n case 'uint64':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setUint64(${field.slotOffset * 8}, value); }`;\n case 'float32':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setFloat32(${field.slotOffset * 4}, value); }`;\n case 'float64':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setFloat64(${field.slotOffset * 8}, value); }`;\n case 'text':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setText(${field.slotOffset}, value); }`;\n case 'data':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setData(${field.slotOffset}, value); }`;\n default:\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { /* TODO */ }`;\n }\n}\n\n/**\n * 生成 Union 字段的 setter\n */\nfunction generateUnionFieldSetter(\n field: FieldReader,\n _unionName: string,\n discriminantValue: number,\n discriminantOffset: number\n): string {\n const name = field.name;\n const type = field.slotType;\n const paramType = getTypeScriptTypeForSetter(type);\n\n if (!type || !field.isSlot) {\n return `set${capitalize(name)}(value: ${paramType}): void {\n this.builder.setUint16(${discriminantOffset}, ${discriminantValue});\n }`;\n }\n\n let body: string;\n switch (type.kind) {\n case 'void':\n body = '';\n break;\n case 'bool':\n body = `this.builder.setBool(${field.slotOffset * 8}, value);`;\n break;\n case 'int8':\n body = `this.builder.setInt8(${field.slotOffset}, value);`;\n break;\n case 'int16':\n body = `this.builder.setInt16(${field.slotOffset * 2}, value);`;\n break;\n case 'int32':\n body = `this.builder.setInt32(${field.slotOffset * 4}, value);`;\n break;\n case 'int64':\n body = `this.builder.setInt64(${field.slotOffset * 8}, value);`;\n break;\n case 'uint8':\n body = `this.builder.setUint8(${field.slotOffset}, value);`;\n break;\n case 'uint16':\n body = `this.builder.setUint16(${field.slotOffset * 2}, value);`;\n break;\n case 'uint32':\n body = `this.builder.setUint32(${field.slotOffset * 4}, value);`;\n break;\n case 'uint64':\n body = `this.builder.setUint64(${field.slotOffset * 8}, value);`;\n break;\n case 'float32':\n body = `this.builder.setFloat32(${field.slotOffset * 4}, value);`;\n break;\n case 'float64':\n body = `this.builder.setFloat64(${field.slotOffset * 8}, value);`;\n break;\n case 'text':\n body = `this.builder.setText(${field.slotOffset}, value);`;\n break;\n case 'data':\n body = `this.builder.setData(${field.slotOffset}, value);`;\n break;\n default:\n body = '';\n }\n\n return `set${capitalize(name)}(value: ${paramType}): void {\n this.builder.setUint16(${discriminantOffset}, ${discriminantValue});\n ${body}\n }`;\n}\n\n/**\n * 从 ValueReader 提取默认值,用于代码生成\n */\nfunction extractDefaultValue(field: FieldReader): string | undefined {\n const defaultValue = field.defaultValue;\n if (!defaultValue) return undefined;\n\n const type = field.slotType;\n if (!type) return undefined;\n\n switch (type.kind) {\n case 'bool':\n if (defaultValue.isBool) return defaultValue.boolValue ? 'true' : 'false';\n return undefined;\n case 'int8':\n if (defaultValue.isInt8) return `${defaultValue.int8Value}`;\n return undefined;\n case 'int16':\n if (defaultValue.isInt16) return `${defaultValue.int16Value}`;\n return undefined;\n case 'int32':\n if (defaultValue.isInt32) return `${defaultValue.int32Value}`;\n return undefined;\n case 'int64':\n if (defaultValue.isInt64) return `${defaultValue.int64Value}n`;\n return undefined;\n case 'uint8':\n if (defaultValue.isUint8) return `${defaultValue.uint8Value}`;\n return undefined;\n case 'uint16':\n if (defaultValue.isUint16) return `${defaultValue.uint16Value}`;\n return undefined;\n case 'uint32':\n if (defaultValue.isUint32) return `${defaultValue.uint32Value}`;\n return undefined;\n case 'uint64':\n if (defaultValue.isUint64) return `${defaultValue.uint64Value}n`;\n return undefined;\n case 'float32':\n if (defaultValue.isFloat32) {\n const val = defaultValue.float32Value;\n if (Number.isNaN(val)) return 'NaN';\n if (val === Number.POSITIVE_INFINITY) return 'Infinity';\n if (val === Number.NEGATIVE_INFINITY) return '-Infinity';\n return `${val}`;\n }\n return undefined;\n case 'float64':\n if (defaultValue.isFloat64) {\n const val = defaultValue.float64Value;\n if (Number.isNaN(val)) return 'NaN';\n if (val === Number.POSITIVE_INFINITY) return 'Infinity';\n if (val === Number.NEGATIVE_INFINITY) return '-Infinity';\n return `${val}`;\n }\n return undefined;\n case 'enum':\n if (defaultValue.isEnum) return `${defaultValue.enumValue}`;\n return undefined;\n default:\n return undefined;\n }\n}\n\n/**\n * 生成 XOR 解码表达式(用于 getter)\n * stored ^ default = actual\n */\nfunction generateXorDecode(expr: string, defaultValue: string, typeKind: TypeKind): string {\n switch (typeKind) {\n case 'bool':\n // bool: stored !== default\n return `${expr} !== ${defaultValue}`;\n case 'int8':\n case 'int16':\n case 'int32':\n // 有符号整数:先转无符号 XOR,再转回有符号\n return `(${expr} ^ ${defaultValue}) | 0`;\n case 'uint8':\n case 'uint16':\n case 'uint32':\n // 无符号整数:直接 XOR\n return `${expr} ^ ${defaultValue}`;\n case 'int64':\n case 'uint64':\n // bigint:直接 XOR\n return `${expr} ^ ${defaultValue}`;\n case 'float32':\n // float32: 需要位操作转换\n return `xorFloat32(${expr}, ${defaultValue})`;\n case 'float64':\n // float64: 需要位操作转换\n return `xorFloat64(${expr}, ${defaultValue})`;\n case 'enum':\n // enum 作为 uint16 处理\n return `${expr} ^ ${defaultValue}`;\n default:\n return expr;\n }\n}\n\n/**\n * 生成 XOR 编码表达式(用于 setter)\n * actual ^ default = stored\n */\nfunction generateXorEncode(valueExpr: string, defaultValue: string, typeKind: TypeKind): string {\n switch (typeKind) {\n case 'bool':\n // bool: value !== default\n return `${valueExpr} !== ${defaultValue}`;\n case 'int8':\n case 'int16':\n case 'int32':\n // 有符号整数:先转无符号 XOR\n return `(${valueExpr} >>> 0) ^ ${defaultValue}`;\n case 'uint8':\n case 'uint16':\n case 'uint32':\n // 无符号整数:直接 XOR\n return `${valueExpr} ^ ${defaultValue}`;\n case 'int64':\n case 'uint64':\n // bigint:直接 XOR\n return `${valueExpr} ^ ${defaultValue}`;\n case 'float32':\n // float32: 需要位操作转换\n return `xorFloat32(${valueExpr}, ${defaultValue})`;\n case 'float64':\n // float64: 需要位操作转换\n return `xorFloat64(${valueExpr}, ${defaultValue})`;\n case 'enum':\n // enum 作为 uint16 处理\n return `${valueExpr} ^ ${defaultValue}`;\n default:\n return valueExpr;\n }\n}\n\n/**\n * 生成字段 getter\n */\nfunction generateFieldGetter(field: FieldReader): string {\n const name = field.name;\n const type = field.slotType;\n const defaultValue = extractDefaultValue(field);\n\n if (!type) {\n return `get ${name}(): unknown { return undefined; }`;\n }\n\n // 如果有默认值,使用 XOR 解码\n if (defaultValue !== undefined && type.kind !== 'text' && type.kind !== 'data') {\n const readExpr = `this.reader.get${capitalize(type.kind)}(${getByteOffset(field, type.kind)})`;\n const decodedExpr = generateXorDecode(readExpr, defaultValue, type.kind);\n return `get ${name}(): ${getTypeScriptTypeForSetter(type)} { return ${decodedExpr}; }`;\n }\n\n switch (type.kind) {\n case 'void':\n return `get ${name}(): void { return undefined; }`;\n case 'bool':\n return `get ${name}(): boolean { return this.reader.getBool(${field.slotOffset * 8}); }`;\n case 'int8':\n return `get ${name}(): number { return this.reader.getInt8(${field.slotOffset}); }`;\n case 'int16':\n return `get ${name}(): number { return this.reader.getInt16(${field.slotOffset * 2}); }`;\n case 'int32':\n return `get ${name}(): number { return this.reader.getInt32(${field.slotOffset * 4}); }`;\n case 'int64':\n return `get ${name}(): bigint { return this.reader.getInt64(${field.slotOffset * 8}); }`;\n case 'uint8':\n return `get ${name}(): number { return this.reader.getUint8(${field.slotOffset}); }`;\n case 'uint16':\n return `get ${name}(): number { return this.reader.getUint16(${field.slotOffset * 2}); }`;\n case 'uint32':\n return `get ${name}(): number { return this.reader.getUint32(${field.slotOffset * 4}); }`;\n case 'uint64':\n return `get ${name}(): bigint { return this.reader.getUint64(${field.slotOffset * 8}); }`;\n case 'float32':\n return `get ${name}(): number { return this.reader.getFloat32(${field.slotOffset * 4}); }`;\n case 'float64':\n return `get ${name}(): number { return this.reader.getFloat64(${field.slotOffset * 8}); }`;\n case 'text':\n return `get ${name}(): string { return this.reader.getText(${field.slotOffset}); }`;\n case 'data':\n return `get ${name}(): Uint8Array { return this.reader.getData(${field.slotOffset}); }`;\n default:\n return `get ${name}(): unknown { return undefined; }`;\n }\n}\n\n/**\n * 获取字节偏移量\n */\nfunction getByteOffset(field: FieldReader, typeKind: TypeKind): number {\n switch (typeKind) {\n case 'bool':\n return field.slotOffset * 8; // bit offset\n case 'int8':\n case 'uint8':\n return field.slotOffset;\n case 'int16':\n case 'uint16':\n case 'enum':\n return field.slotOffset * 2;\n case 'int32':\n case 'uint32':\n case 'float32':\n return field.slotOffset * 4;\n case 'int64':\n case 'uint64':\n case 'float64':\n return field.slotOffset * 8;\n default:\n return field.slotOffset;\n }\n}\n\n/**\n * 生成字段 setter\n */\nfunction generateFieldSetter(field: FieldReader): string {\n const name = field.name;\n const type = field.slotType;\n const paramType = getTypeScriptTypeForSetter(type);\n const defaultValue = extractDefaultValue(field);\n\n if (!type) {\n return `set${capitalize(name)}(value: unknown): void { /* TODO */ }`;\n }\n\n // 如果有默认值,使用 XOR 编码\n if (defaultValue !== undefined && type.kind !== 'text' && type.kind !== 'data') {\n const encodedExpr = generateXorEncode('value', defaultValue, type.kind);\n const setterMethod = `set${capitalize(type.kind)}`;\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.${setterMethod}(${getByteOffset(field, type.kind)}, ${encodedExpr}); }`;\n }\n\n switch (type.kind) {\n case 'void':\n return `set${capitalize(name)}(value: void): void { /* void */ }`;\n case 'bool':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setBool(${field.slotOffset * 8}, value); }`;\n case 'int8':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setInt8(${field.slotOffset}, value); }`;\n case 'int16':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setInt16(${field.slotOffset * 2}, value); }`;\n case 'int32':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setInt32(${field.slotOffset * 4}, value); }`;\n case 'int64':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setInt64(${field.slotOffset * 8}, value); }`;\n case 'uint8':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setUint8(${field.slotOffset}, value); }`;\n case 'uint16':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setUint16(${field.slotOffset * 2}, value); }`;\n case 'uint32':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setUint32(${field.slotOffset * 4}, value); }`;\n case 'uint64':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setUint64(${field.slotOffset * 8}, value); }`;\n case 'float32':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setFloat32(${field.slotOffset * 4}, value); }`;\n case 'float64':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setFloat64(${field.slotOffset * 8}, value); }`;\n case 'text':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setText(${field.slotOffset}, value); }`;\n case 'data':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setData(${field.slotOffset}, value); }`;\n default:\n return `set${capitalize(name)}(value: ${paramType}): void { /* TODO */ }`;\n }\n}\n\n/**\n * 获取 TypeScript setter 参数类型\n */\nfunction getTypeScriptTypeForSetter(type: TypeReader | null): string {\n if (!type) return 'unknown';\n\n switch (type.kind) {\n case 'void':\n return 'void';\n case 'bool':\n return 'boolean';\n case 'int8':\n case 'int16':\n case 'int32':\n case 'uint8':\n case 'uint16':\n case 'uint32':\n case 'float32':\n case 'float64':\n return 'number';\n case 'int64':\n case 'uint64':\n return 'bigint';\n case 'text':\n return 'string';\n case 'data':\n return 'Uint8Array';\n default:\n return 'unknown';\n }\n}\n\n/**\n * 首字母大写\n */\nfunction capitalize(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\n/**\n * 生成 Enum 的 TypeScript 代码\n */\nfunction generateEnum(node: NodeReader): string {\n const lines: string[] = [];\n const enumName = getShortName(node.displayName);\n\n lines.push(`export enum ${enumName} {`);\n for (const enumerant of node.enumEnumerants) {\n lines.push(` ${enumerant.name} = ${enumerant.codeOrder},`);\n }\n lines.push('}');\n\n return lines.join('\\n');\n}\n\n/**\n * 获取 TypeScript 类型字符串\n */\nfunction getTypeScriptType(type: TypeReader | null, allNodes: NodeReader[]): string {\n if (!type) return 'unknown';\n\n switch (type.kind) {\n case 'void':\n return 'void';\n case 'bool':\n return 'boolean';\n case 'int8':\n case 'int16':\n case 'int32':\n case 'uint8':\n case 'uint16':\n case 'uint32':\n case 'float32':\n case 'float64':\n return 'number';\n case 'int64':\n case 'uint64':\n return 'bigint';\n case 'text':\n return 'string';\n case 'data':\n return 'Uint8Array';\n case 'list': {\n const elementType = type.listElementType;\n if (!elementType) return 'unknown[]';\n const elemTsType = getTypeScriptType(elementType, allNodes);\n return `${elemTsType}[]`;\n }\n case 'struct': {\n const structNode = allNodes.find((n) => n.id === type.typeId);\n if (structNode) {\n return getShortName(structNode.displayName);\n }\n return 'unknown';\n }\n case 'enum': {\n const enumNode = allNodes.find((n) => n.id === type.typeId);\n if (enumNode) {\n return getShortName(enumNode.displayName);\n }\n return 'unknown';\n }\n default:\n return 'unknown';\n }\n}\n\n/**\n * 从 displayName 获取短名称\n * 例如 \"test-schema.capnp:Person\" -> \"Person\"\n * 处理 auto-generated 名称如 \"Calculator.evaluate$Params\" -> \"EvaluateParams\"\n */\nfunction getShortName(displayName: string): string {\n // Handle empty or undefined display names\n if (!displayName) {\n return 'Unknown';\n }\n const colonIndex = displayName.lastIndexOf(':');\n let name = colonIndex >= 0 ? displayName.substring(colonIndex + 1) : displayName;\n\n // Replace invalid characters for TypeScript identifiers\n // Handle auto-generated names like \"Calculator.evaluate$Params\" -> \"EvaluateParams\"\n if (name.includes('.')) {\n const parts = name.split('.');\n if (parts.length === 2 && parts[1].includes('$')) {\n // Interface method params/results: \"Interface.method$Params\" -> \"MethodParams\"\n const methodPart = parts[1];\n const dollarIndex = methodPart.indexOf('$');\n if (dollarIndex > 0) {\n const methodName = methodPart.substring(0, dollarIndex);\n const suffix = methodPart.substring(dollarIndex + 1);\n name = capitalize(methodName) + suffix;\n } else {\n name = capitalize(parts[1]);\n }\n } else {\n name = parts[parts.length - 1];\n }\n }\n\n // Remove any remaining invalid characters\n name = name.replace(/[^a-zA-Z0-9_]/g, '_');\n\n return name;\n}\n\n/**\n * 生成 Interface 的 TypeScript 代码\n * 包括:Method Constants、Client Class、Server Interface、Server Stub\n */\nfunction generateInterface(node: NodeReader, allNodes: NodeReader[]): string {\n const lines: string[] = [];\n const interfaceName = getShortName(node.displayName);\n const methods = node.interfaceMethods;\n\n if (methods.length === 0) {\n return `// Interface ${interfaceName} has no methods`;\n }\n\n // 1. 生成 Method ID 常量\n lines.push(`// ${interfaceName} Method IDs`);\n lines.push(`export const ${interfaceName}InterfaceId = ${node.id}n;`);\n lines.push(`export const ${interfaceName}MethodIds = {`);\n for (const method of methods) {\n lines.push(` ${method.name}: ${method.codeOrder},`);\n }\n lines.push('} as const;');\n lines.push('');\n\n // 2. 生成 Server Interface\n lines.push(`// ${interfaceName} Server Interface`);\n lines.push(`export interface ${interfaceName}Server {`);\n for (const method of methods) {\n const paramType = getTypeNameById(method.paramStructType, allNodes, 'unknown');\n const resultType = getTypeNameById(method.resultStructType, allNodes, 'unknown');\n lines.push(\n ` ${method.name}(context: CallContext<${paramType}Reader, ${resultType}Builder>): Promise<void> | void;`\n );\n }\n lines.push('}');\n lines.push('');\n\n // 3. 生成 Server Stub\n lines.push(`// ${interfaceName} Server Stub`);\n lines.push(`export class ${interfaceName}Stub {`);\n lines.push(` private server: ${interfaceName}Server;`);\n lines.push('');\n lines.push(` constructor(server: ${interfaceName}Server) {`);\n lines.push(' this.server = server;');\n lines.push(' }');\n lines.push('');\n lines.push(` static readonly interfaceId = ${node.id}n;`);\n lines.push('');\n lines.push(' /** Dispatch a method call to the appropriate handler */');\n lines.push(\n ' async dispatch(methodId: number, context: CallContext<unknown, unknown>): Promise<void> {'\n );\n lines.push(' switch (methodId) {');\n\n for (const method of methods) {\n const paramType = getTypeNameById(method.paramStructType, allNodes, 'unknown');\n const resultType = getTypeNameById(method.resultStructType, allNodes, 'unknown');\n lines.push(` case ${interfaceName}MethodIds.${method.name}:`);\n lines.push(\n ` return this.server.${method.name}(context as CallContext<${paramType}Reader, ${resultType}Builder>);`\n );\n }\n\n lines.push(' default:');\n lines.push(' throw new Error(`Unknown method ID: ${methodId}`);');\n lines.push(' }');\n lines.push(' }');\n lines.push('');\n lines.push(' /** Check if a method ID is valid */');\n lines.push(' isValidMethod(methodId: number): boolean {');\n lines.push(' return [');\n for (const method of methods) {\n lines.push(` ${interfaceName}MethodIds.${method.name},`);\n }\n lines.push(' ].includes(methodId);');\n lines.push(' }');\n lines.push('}');\n lines.push('');\n\n // 4. 生成 Client Class\n lines.push(`// ${interfaceName} Client Class`);\n lines.push(`export class ${interfaceName}Client extends BaseCapabilityClient {`);\n lines.push(` static readonly interfaceId = ${node.id}n;`);\n lines.push('');\n\n for (const method of methods) {\n const paramType = getTypeNameById(method.paramStructType, allNodes, 'unknown');\n const resultType = getTypeNameById(method.resultStructType, allNodes, 'unknown');\n\n // 生成方法文档注释\n lines.push(' /**');\n lines.push(` * ${method.name}`);\n lines.push(` * @param params - ${paramType}`);\n lines.push(` * @returns PipelineClient<${resultType}Reader>`);\n lines.push(' */');\n\n // 生成方法签名\n lines.push(\n ` ${method.name}(params: ${paramType}Builder): PipelineClient<${resultType}Reader> {`\n );\n lines.push(' return this._call(');\n lines.push(` ${interfaceName}Client.interfaceId,`);\n lines.push(` ${interfaceName}MethodIds.${method.name},`);\n lines.push(' params');\n lines.push(` ) as PipelineClient<${resultType}Reader>;`);\n lines.push(' }');\n lines.push('');\n }\n\n lines.push('}');\n\n return lines.join('\\n');\n}\n\n/**\n * 根据类型 ID 获取类型名称\n */\nfunction getTypeNameById(id: bigint, allNodes: NodeReader[], fallback: string): string {\n const node = allNodes.find((n) => n.id === id);\n if (!node) return fallback;\n return getShortName(node.displayName);\n}\n","/**\n * Cap'n Proto 编译后 Schema 的 TypeScript Reader\n * 基于官方 schema.capnp 手动编写\n *\n * 这是自举的基础:我们需要先能读取 schema 才能生成 schema 的代码\n *\n * 结构信息来自: capnp compile -ocapnp schema.capnp\n */\n\nimport { MessageReader, type StructReader } from '../core/index.js';\nimport { ElementSize } from '../core/pointer.js';\n\n// ============================================================================\n// 基础类型\n// ============================================================================\n\n/** UInt64 作为 bigint */\nexport type Id = bigint;\n\n// ============================================================================\n// Node\n// ============================================================================\n\nexport class NodeReader {\n constructor(private reader: StructReader) {}\n\n get id(): Id {\n return this.reader.getUint64(0);\n }\n\n get displayName(): string {\n return this.reader.getText(0);\n }\n\n get displayNamePrefixLength(): number {\n return this.reader.getUint32(8);\n }\n\n get scopeId(): Id {\n return this.reader.getUint64(16);\n }\n\n /** union tag 在 bits [96, 112) = bytes [12, 14) */\n private get unionTag(): number {\n return this.reader.getUint16(12);\n }\n\n get isFile(): boolean {\n return this.unionTag === 0;\n }\n\n get isStruct(): boolean {\n return this.unionTag === 1;\n }\n\n get isEnum(): boolean {\n return this.unionTag === 2;\n }\n\n get isInterface(): boolean {\n return this.unionTag === 3;\n }\n\n get isConst(): boolean {\n return this.unionTag === 4;\n }\n\n get isAnnotation(): boolean {\n return this.unionTag === 5;\n }\n\n // --- Struct 相关字段 (union tag = 1) ---\n // struct group 从 bit 112 = byte 14 开始\n\n get structDataWordCount(): number {\n return this.reader.getUint16(14);\n }\n\n get structPointerCount(): number {\n return this.reader.getUint16(24);\n }\n\n get structPreferredListEncoding(): number {\n return this.reader.getUint16(26);\n }\n\n get structIsGroup(): boolean {\n // isGroup @10 :Bool; 在 bit 224 = byte 28\n return this.reader.getBool(224);\n }\n\n get structDiscriminantCount(): number {\n return this.reader.getUint16(30);\n }\n\n get structDiscriminantOffset(): number {\n return this.reader.getUint32(32);\n }\n\n get structFields(): FieldReader[] {\n // fields @13 :List(Field); 是 ptr[3]\n // Field: 24 bytes = 3 words data, 4 pointers\n const listReader = this.reader.getList(3, ElementSize.INLINE_COMPOSITE, {\n dataWords: 3,\n pointerCount: 4,\n });\n if (!listReader) return [];\n\n const fields: FieldReader[] = [];\n for (let i = 0; i < listReader.length; i++) {\n const itemReader = listReader.getStruct(i);\n const field = new FieldReader(itemReader);\n // Stop if we encounter a field with empty name (likely past the actual fields)\n if (!field.name && i > 0) break;\n fields.push(field);\n }\n return fields;\n }\n\n // --- Enum 相关字段 (union tag = 2) ---\n\n get enumEnumerants(): EnumerantReader[] {\n // enumerants @14 :List(Enumerant); 在 enum group 内,ptr[3]\n const listReader = this.reader.getList(3, ElementSize.INLINE_COMPOSITE, {\n dataWords: 1,\n pointerCount: 2,\n });\n if (!listReader) return [];\n\n const enumerants: EnumerantReader[] = [];\n for (let i = 0; i < Math.min(listReader.length, 10); i++) {\n try {\n const itemReader = listReader.getStruct(i);\n const enumerant = new EnumerantReader(itemReader);\n // Stop if we encounter an enumerant with empty name\n if (!enumerant.name) break;\n enumerants.push(enumerant);\n } catch (_e) {\n // Stop on any error (likely past the actual enumerants)\n break;\n }\n }\n return enumerants;\n }\n\n // --- Interface 相关字段 (union tag = 3) ---\n\n get interfaceMethods(): MethodReader[] {\n // methods @15 :List(Method); 在 interface group 内,ptr[3]\n // Method: 5 words data, 2 pointers\n const listReader = this.reader.getList(3, ElementSize.INLINE_COMPOSITE, {\n dataWords: 5,\n pointerCount: 2,\n });\n if (!listReader) return [];\n\n const methods: MethodReader[] = [];\n for (let i = 0; i < listReader.length; i++) {\n try {\n const itemReader = listReader.getStruct(i);\n const method = new MethodReader(itemReader);\n if (!method.name && i > 0) break;\n methods.push(method);\n } catch (_e) {\n break;\n }\n }\n return methods;\n }\n\n // --- NestedNodes ---\n\n get nestedNodes(): NestedNodeReader[] {\n // nestedNodes @4 :List(NestedNode); 是 ptr[1]\n const listReader = this.reader.getList(1, ElementSize.INLINE_COMPOSITE, {\n dataWords: 1,\n pointerCount: 1,\n });\n if (!listReader) return [];\n\n const nodes: NestedNodeReader[] = [];\n for (let i = 0; i < listReader.length; i++) {\n const itemReader = listReader.getStruct(i);\n nodes.push(new NestedNodeReader(itemReader));\n }\n return nodes;\n }\n}\n\n// ============================================================================\n// Field\n// ============================================================================\n\nexport class FieldReader {\n constructor(private reader: StructReader) {}\n\n get name(): string {\n return this.reader.getText(0);\n }\n\n get codeOrder(): number {\n return this.reader.getUint16(0);\n }\n\n get discriminantValue(): number {\n return this.reader.getUint16(2);\n }\n\n /** union tag 在 bits [64, 80) = bytes [8, 10) */\n private get unionTag(): number {\n return this.reader.getUint16(8);\n }\n\n get isSlot(): boolean {\n return this.unionTag === 0;\n }\n\n get isGroup(): boolean {\n return this.unionTag === 1;\n }\n\n // --- Slot 相关 ---\n\n get slotOffset(): number {\n return this.reader.getUint32(4);\n }\n\n get slotType(): TypeReader | null {\n // type @5 :Type; 是 ptr[2]\n const typeReader = this.reader.getStruct(2, 3, 1); // Type: 24 bytes = 3 words, 1 pointer\n return typeReader ? new TypeReader(typeReader) : null;\n }\n\n // --- Group 相关 ---\n\n get groupTypeId(): Id {\n // typeId @7 :UInt64; 在 group group 内,bits [128, 192) = bytes [16, 24)\n return this.reader.getUint64(16);\n }\n\n // --- Default Value ---\n\n get defaultValue(): ValueReader | null {\n // defaultValue @6 :Value; 是 ptr[3]\n const valueReader = this.reader.getStruct(3, 2, 1); // Value: 16 bytes = 2 words, 1 pointer\n return valueReader ? new ValueReader(valueReader) : null;\n }\n}\n\n// ============================================================================\n// Type\n// ============================================================================\n\nexport class TypeReader {\n constructor(private reader: StructReader) {}\n\n get kind(): TypeKind {\n const tag = this.reader.getUint16(0);\n return TYPE_KIND_MAP[tag] ?? 'unknown';\n }\n\n get isPrimitive(): boolean {\n const k = this.kind;\n return (\n k !== 'list' && k !== 'enum' && k !== 'struct' && k !== 'interface' && k !== 'anyPointer'\n );\n }\n\n // --- List ---\n\n get listElementType(): TypeReader | null {\n if (this.kind !== 'list') return null;\n // elementType @14 :Type; 是 ptr[0]\n const elementReader = this.reader.getStruct(0, 3, 1);\n return elementReader ? new TypeReader(elementReader) : null;\n }\n\n // --- Enum/Struct/Interface ---\n\n get typeId(): Id | null {\n const k = this.kind;\n if (k === 'enum' || k === 'struct' || k === 'interface') {\n // typeId 在 bits [64, 128) = bytes [8, 16)\n return this.reader.getUint64(8);\n }\n return null;\n }\n}\n\nexport type TypeKind =\n | 'void'\n | 'bool'\n | 'int8'\n | 'int16'\n | 'int32'\n | 'int64'\n | 'uint8'\n | 'uint16'\n | 'uint32'\n | 'uint64'\n | 'float32'\n | 'float64'\n | 'text'\n | 'data'\n | 'list'\n | 'enum'\n | 'struct'\n | 'interface'\n | 'anyPointer'\n | 'unknown';\n\nconst TYPE_KIND_MAP: Record<number, TypeKind> = {\n 0: 'void',\n 1: 'bool',\n 2: 'int8',\n 3: 'int16',\n 4: 'int32',\n 5: 'int64',\n 6: 'uint8',\n 7: 'uint16',\n 8: 'uint32',\n 9: 'uint64',\n 10: 'float32',\n 11: 'float64',\n 12: 'text',\n 13: 'data',\n 14: 'list',\n 15: 'enum',\n 16: 'struct',\n 17: 'interface',\n 18: 'anyPointer',\n};\n\n// ============================================================================\n// Value - 默认值\n// ============================================================================\n\nexport class ValueReader {\n constructor(private reader: StructReader) {}\n\n /** union tag 在 bits [0, 16) = bytes [0, 2) */\n private get unionTag(): number {\n return this.reader.getUint16(0);\n }\n\n get isVoid(): boolean {\n return this.unionTag === 0;\n }\n get isBool(): boolean {\n return this.unionTag === 1;\n }\n get isInt8(): boolean {\n return this.unionTag === 2;\n }\n get isInt16(): boolean {\n return this.unionTag === 3;\n }\n get isInt32(): boolean {\n return this.unionTag === 4;\n }\n get isInt64(): boolean {\n return this.unionTag === 5;\n }\n get isUint8(): boolean {\n return this.unionTag === 6;\n }\n get isUint16(): boolean {\n return this.unionTag === 7;\n }\n get isUint32(): boolean {\n return this.unionTag === 8;\n }\n get isUint64(): boolean {\n return this.unionTag === 9;\n }\n get isFloat32(): boolean {\n return this.unionTag === 10;\n }\n get isFloat64(): boolean {\n return this.unionTag === 11;\n }\n get isText(): boolean {\n return this.unionTag === 12;\n }\n get isData(): boolean {\n return this.unionTag === 13;\n }\n get isList(): boolean {\n return this.unionTag === 14;\n }\n get isEnum(): boolean {\n return this.unionTag === 15;\n }\n get isStruct(): boolean {\n return this.unionTag === 16;\n }\n get isInterface(): boolean {\n return this.unionTag === 17;\n }\n get isAnyPointer(): boolean {\n return this.unionTag === 18;\n }\n\n // --- 原始值读取 ---\n\n get boolValue(): boolean {\n // boolValue @1 :Bool; 在 bit 16\n return this.reader.getBool(16);\n }\n\n get int8Value(): number {\n // int8Value @2 :Int8; 在 byte 2\n return this.reader.getInt8(2);\n }\n\n get int16Value(): number {\n // int16Value @3 :Int16; 在 bytes [2, 4)\n return this.reader.getInt16(2);\n }\n\n get int32Value(): number {\n // int32Value @4 :Int32; 在 bytes [4, 8)\n return this.reader.getInt32(4);\n }\n\n get int64Value(): bigint {\n // int64Value @5 :Int64; 在 bytes [8, 16)\n return this.reader.getInt64(8);\n }\n\n get uint8Value(): number {\n // uint8Value @6 :UInt8; 在 byte 2\n return this.reader.getUint8(2);\n }\n\n get uint16Value(): number {\n // uint16Value @7 :UInt16; 在 bytes [2, 4)\n return this.reader.getUint16(2);\n }\n\n get uint32Value(): number {\n // uint32Value @8 :UInt32; 在 bytes [4, 8)\n return this.reader.getUint32(4);\n }\n\n get uint64Value(): bigint {\n // uint64Value @9 :UInt64; 在 bytes [8, 16)\n return this.reader.getUint64(8);\n }\n\n get float32Value(): number {\n // float32Value @10 :Float32; 在 bytes [4, 8)\n return this.reader.getFloat32(4);\n }\n\n get float64Value(): number {\n // float64Value @11 :Float64; 在 bytes [8, 16)\n return this.reader.getFloat64(8);\n }\n\n get enumValue(): number {\n // enumValue @15 :UInt16; 在 bytes [2, 4)\n return this.reader.getUint16(2);\n }\n\n // --- 便捷方法:获取特定类型的默认值 ---\n\n getAsNumber(): number | undefined {\n if (this.isInt8) return this.int8Value;\n if (this.isInt16) return this.int16Value;\n if (this.isInt32) return this.int32Value;\n if (this.isUint8) return this.uint8Value;\n if (this.isUint16) return this.uint16Value;\n if (this.isUint32) return this.uint32Value;\n if (this.isFloat32) return this.float32Value;\n if (this.isFloat64) return this.float64Value;\n if (this.isEnum) return this.enumValue;\n return undefined;\n }\n\n getAsBigint(): bigint | undefined {\n if (this.isInt64) return this.int64Value;\n if (this.isUint64) return this.uint64Value;\n return undefined;\n }\n\n getAsBoolean(): boolean | undefined {\n if (this.isBool) return this.boolValue;\n return undefined;\n }\n}\n\n// ============================================================================\n// Method - Interface 方法\n// ============================================================================\n\nexport class MethodReader {\n constructor(private reader: StructReader) {}\n\n get name(): string {\n return this.reader.getText(0);\n }\n\n get codeOrder(): number {\n return this.reader.getUint16(0);\n }\n\n get paramStructType(): Id {\n // paramStructType @2 :Id; 在 bytes [8, 16)\n return this.reader.getUint64(8);\n }\n\n get resultStructType(): Id {\n // resultStructType @3 :Id; 在 bytes [16, 24)\n return this.reader.getUint64(16);\n }\n}\n\n// ============================================================================\n// Enumerant\n// ============================================================================\n\nexport class EnumerantReader {\n constructor(private reader: StructReader) {}\n\n get name(): string {\n return this.reader.getText(0);\n }\n\n get codeOrder(): number {\n return this.reader.getUint16(0);\n }\n}\n\n// ============================================================================\n// NestedNode\n// ============================================================================\n\nexport class NestedNodeReader {\n constructor(private reader: StructReader) {}\n\n get name(): string {\n return this.reader.getText(0);\n }\n\n get id(): Id {\n return this.reader.getUint64(0);\n }\n}\n\n// ============================================================================\n// CodeGeneratorRequest\n// ============================================================================\n\nexport class CodeGeneratorRequestReader {\n constructor(private message: MessageReader) {}\n\n static fromBuffer(buffer: ArrayBuffer): CodeGeneratorRequestReader {\n const message = new MessageReader(buffer);\n return new CodeGeneratorRequestReader(message);\n }\n\n get nodes(): NodeReader[] {\n // CodeGeneratorRequest: 0 data words, 4 pointers\n const root = this.message.getRoot(0, 4);\n // nodes @0 :List(Node);\n const listReader = root.getList(0, ElementSize.INLINE_COMPOSITE, {\n dataWords: 6,\n pointerCount: 6,\n });\n if (!listReader) return [];\n\n const nodes: NodeReader[] = [];\n for (let i = 0; i < listReader.length; i++) {\n const nodeReader = listReader.getStruct(i);\n nodes.push(new NodeReader(nodeReader));\n }\n return nodes;\n }\n\n get requestedFiles(): RequestedFileReader[] {\n const root = this.message.getRoot(0, 4);\n // requestedFiles @1 :List(RequestedFile);\n const listReader = root.getList(1, ElementSize.INLINE_COMPOSITE, {\n dataWords: 1,\n pointerCount: 2,\n });\n if (!listReader) return [];\n\n const files: RequestedFileReader[] = [];\n for (let i = 0; i < listReader.length; i++) {\n try {\n const fileReader = listReader.getStruct(i);\n const file = new RequestedFileReader(fileReader);\n // Stop if we encounter a file with empty filename\n if (!file.filename && files.length > 0) break;\n files.push(file);\n } catch (_e) {\n // Stop on any error (likely past the actual files)\n break;\n }\n }\n return files;\n }\n}\n\n// ============================================================================\n// RequestedFile\n// ============================================================================\n\nexport class RequestedFileReader {\n constructor(private reader: StructReader) {}\n\n get id(): Id {\n return this.reader.getUint64(0);\n }\n\n get filename(): string {\n return this.reader.getText(0);\n }\n}\n","/**\n * Cap'n Proto Code Generator CLI\n *\n * Usage: capnp gen <schema.capnp> [options]\n */\n\nimport { execSync } from 'node:child_process';\nimport { existsSync, readFileSync, writeFileSync } from 'node:fs';\nimport { mkdtempSync, rmSync } from 'node:fs';\nimport { tmpdir } from 'node:os';\nimport { basename, join } from 'node:path';\nimport { parseArgs } from 'node:util';\nimport { type GeneratorOptions, generateFromRequest } from './codegen/generator.js';\nimport { CodeGeneratorRequestReader } from './schema/schema-reader.js';\n\nconst VERSION = '3.0.0';\n\nfunction printUsage() {\n console.log(`\nCap'n Proto TypeScript Code Generator v${VERSION}\n\nUsage: capnp gen <schema.capnp> [options]\n\nOptions:\n -o, --output Output file (default: stdout)\n -d, --outDir Output directory\n -r, --runtimePath Runtime library import path (default: @naeemo/capnp)\n -h, --help Show this help\n -v, --version Show version\n\nExamples:\n capnp gen schema.capnp -o schema.ts\n capnp gen schema.capnp -d ./generated\n`);\n}\n\nfunction checkCapnpTool(): boolean {\n try {\n execSync('capnp --version', { stdio: 'ignore' });\n return true;\n } catch {\n return false;\n }\n}\n\nexport async function run(args: string[]): Promise<void> {\n const { values, positionals } = parseArgs({\n args,\n options: {\n output: { type: 'string', short: 'o' },\n outDir: { type: 'string', short: 'd' },\n runtimePath: { type: 'string', short: 'r' },\n help: { type: 'boolean', short: 'h' },\n version: { type: 'boolean', short: 'v' },\n },\n allowPositionals: true,\n });\n\n if (values.version) {\n console.log(VERSION);\n process.exit(0);\n }\n\n if (values.help || positionals.length === 0) {\n printUsage();\n process.exit(0);\n }\n\n const inputFile = positionals[0];\n\n if (!existsSync(inputFile)) {\n console.error(`Error: File not found: ${inputFile}`);\n process.exit(1);\n }\n\n if (!checkCapnpTool()) {\n console.error(\"Error: capnp tool not found. Please install Cap'n Proto.\");\n process.exit(1);\n }\n\n const tmpDir = mkdtempSync(join(tmpdir(), 'capnp-gen-'));\n const binFile = join(tmpDir, 'schema.bin');\n\n try {\n // Compile schema to binary format using shell\n const { exec } = await import('node:child_process');\n const { promisify } = await import('node:util');\n const execAsync = promisify(exec);\n\n await execAsync(`capnp compile -o- \"${inputFile}\" > \"${binFile}\"`);\n\n // Read and parse\n const buffer = readFileSync(binFile);\n const request = CodeGeneratorRequestReader.fromBuffer(buffer.buffer);\n\n const opts: GeneratorOptions = {\n runtimeImportPath:\n typeof values.runtimePath === 'string' ? values.runtimePath : '@naeemo/capnp',\n };\n\n const files = generateFromRequest(request, opts);\n\n if (values.outDir) {\n // Multiple files mode\n for (const [filename, content] of files) {\n const outPath = join(values.outDir, filename);\n writeFileSync(outPath, content);\n console.log(`Generated: ${outPath}`);\n }\n } else if (values.output) {\n // Single file mode\n const content = Array.from(files.values()).join('\\n');\n writeFileSync(values.output, content);\n console.log(`Generated: ${values.output}`);\n } else {\n // stdout\n const content = Array.from(files.values()).join('\\n');\n console.log(content);\n }\n } catch (err: any) {\n console.error('Error:', err.message);\n process.exit(1);\n } finally {\n rmSync(tmpDir, { recursive: true, force: true });\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"cli-gen-aCkffW1Z.js","names":[],"sources":["../src/codegen/generator.ts","../src/schema/schema-reader.ts","../src/cli-gen.ts"],"sourcesContent":["/**\n * 基于 Binary Schema 的 TypeScript 代码生成器\n *\n * 使用官方 capnp 编译器生成的二进制 schema 来生成 TypeScript 代码\n */\n\nimport type {\n CodeGeneratorRequestReader,\n FieldReader,\n Id,\n NodeReader,\n TypeKind,\n TypeReader,\n} from '../schema/schema-reader.js';\n\n// 导入运行时类型用于代码生成\nimport type { StructBuilder, StructReader } from '../core/index.js';\n\nexport interface GeneratorOptions {\n /** 运行时库导入路径 */\n runtimeImportPath?: string;\n}\n\nconst DEFAULT_OPTIONS: GeneratorOptions = {\n runtimeImportPath: '@naeemo/capnp',\n};\n\n/**\n * Union 字段分组\n */\ninterface UnionGroup {\n discriminantOffset: number;\n fields: FieldReader[];\n}\n\n/**\n * 从 CodeGeneratorRequest 生成 TypeScript 代码\n */\nexport function generateFromRequest(\n request: CodeGeneratorRequestReader,\n options?: GeneratorOptions\n): Map<string, string> {\n const opts = { ...DEFAULT_OPTIONS, ...options };\n const files = new Map<string, string>();\n\n const nodes = request.nodes;\n const requestedFiles = request.requestedFiles;\n\n // 为每个请求的文件生成代码\n for (const file of requestedFiles) {\n const filename = file.filename.replace(/\\.capnp$/, '.ts');\n const code = generateFile(file.id, nodes, opts);\n files.set(filename, code);\n }\n\n return files;\n}\n\n/**\n * 生成单个文件的 TypeScript 代码\n */\nfunction generateFile(fileId: Id, allNodes: NodeReader[], options: GeneratorOptions): string {\n const lines: string[] = [];\n\n // 文件头\n lines.push('// Generated by @naeemo/capnp');\n lines.push('// DO NOT EDIT MANUALLY');\n lines.push('');\n lines.push(\n `import { MessageReader, MessageBuilder, StructReader, StructBuilder, createUnionReader, createUnionBuilder } from \"${options.runtimeImportPath}\";`\n );\n lines.push('');\n\n // 添加 XOR 辅助函数(用于 float 默认值)\n lines.push('// XOR helpers for default value encoding');\n lines.push('function xorFloat32(a: number, b: number): number {');\n lines.push(' const view = new DataView(new ArrayBuffer(4));');\n lines.push(' view.setFloat32(0, a, true);');\n lines.push(' const aBits = view.getUint32(0, true);');\n lines.push(' view.setFloat32(0, b, true);');\n lines.push(' const bBits = view.getUint32(0, true);');\n lines.push(' view.setUint32(0, aBits ^ bBits, true);');\n lines.push(' return view.getFloat32(0, true);');\n lines.push('}');\n lines.push('');\n lines.push('function xorFloat64(a: number, b: number): number {');\n lines.push(' const view = new DataView(new ArrayBuffer(8));');\n lines.push(' view.setFloat64(0, a, true);');\n lines.push(' const aBits = view.getBigUint64(0, true);');\n lines.push(' view.setFloat64(0, b, true);');\n lines.push(' const bBits = view.getBigUint64(0, true);');\n lines.push(' view.setBigUint64(0, aBits ^ bBits, true);');\n lines.push(' return view.getFloat64(0, true);');\n lines.push('}');\n lines.push('');\n\n // 找到属于这个文件的所有节点\n // 包括:\n // 1. scopeId === fileId 的节点(正常定义的 struct/enum/interface)\n // 2. scopeId === 0 且 displayName 包含文件名的节点(auto-generated method params/results)\n let filePrefix = '';\n try {\n const fileNode = allNodes.find((n) => n.id === fileId);\n filePrefix = fileNode?.displayName || '';\n } catch (_e) {\n // Ignore errors reading file node\n }\n\n const fileNodes = allNodes.filter((n) => {\n try {\n if (n.scopeId === fileId) return true;\n // Auto-generated method params/results have scopeId = 0\n if (n.scopeId === 0n && filePrefix && n.displayName.startsWith(`${filePrefix}:`)) {\n // Check if it's a method params/results struct\n const shortName = n.displayName.substring(filePrefix.length + 1);\n return shortName.includes('$');\n }\n } catch (_e) {\n // Skip nodes that can't be read\n }\n return false;\n });\n\n // 生成每个节点的代码\n for (const node of fileNodes) {\n if (node.isStruct) {\n lines.push(generateStruct(node, allNodes));\n } else if (node.isEnum) {\n lines.push(generateEnum(node));\n } else if (node.isInterface) {\n lines.push(generateInterface(node, allNodes));\n }\n lines.push('');\n }\n\n return lines.join('\\n');\n}\n\n/**\n * 生成 Struct 的 TypeScript 代码\n */\nfunction generateStruct(node: NodeReader, allNodes: NodeReader[]): string {\n const lines: string[] = [];\n const structName = getShortName(node.displayName);\n\n // 分析字段:分离 Union 字段、普通字段和 Group 字段\n let unionGroups: UnionGroup[] = [];\n let regularFields: FieldReader[] = [];\n let groupFields: { field: FieldReader; groupNode: NodeReader }[] = [];\n\n try {\n const analysis = analyzeFields(node, allNodes);\n unionGroups = analysis.unionGroups;\n regularFields = analysis.regularFields;\n groupFields = analysis.groupFields;\n } catch (_e) {\n // Some auto-generated structs may have invalid field data\n // Return a minimal struct definition in this case\n lines.push(`export interface ${structName} {`);\n lines.push(' // Note: Could not parse struct fields');\n lines.push('}');\n lines.push('');\n lines.push(`export class ${structName}Reader {`);\n lines.push(' constructor(private reader: StructReader) {}');\n lines.push('}');\n lines.push('');\n lines.push(`export class ${structName}Builder {`);\n lines.push(' constructor(private builder: StructBuilder) {}');\n lines.push('}');\n return lines.join('\\n');\n }\n\n // 生成接口定义\n lines.push(`export interface ${structName} {`);\n\n // 普通字段\n for (const field of regularFields) {\n if (!field.isSlot) continue;\n const tsType = getTypeScriptType(field.slotType, allNodes);\n lines.push(` ${field.name}: ${tsType};`);\n }\n\n // Group 字段 - 内联 Group 的字段\n for (const { field: groupField, groupNode } of groupFields) {\n const groupName = groupField.name;\n try {\n for (const field of groupNode.structFields) {\n if (!field.isSlot) continue;\n const tsType = getTypeScriptType(field.slotType, allNodes);\n lines.push(` ${groupName}${capitalize(field.name)}: ${tsType};`);\n }\n } catch (_e) {\n // Skip invalid group fields\n }\n }\n\n // Union 字段 - 生成 discriminant 和 variant 类型\n for (const [groupIndex, group] of unionGroups.entries()) {\n const unionName =\n group.fields.length > 0 ? `${capitalize(group.fields[0].name)}Union` : `Union${groupIndex}`;\n lines.push(` ${unionName}: ${generateUnionVariantType(group, allNodes)};`);\n }\n\n lines.push('}');\n lines.push('');\n\n // 生成 Reader 类\n lines.push(`export class ${structName}Reader {`);\n lines.push(' constructor(private reader: StructReader) {}');\n lines.push('');\n\n // 普通字段 getters\n for (const field of regularFields) {\n if (!field.isSlot) continue;\n const getter = generateFieldGetter(field);\n lines.push(` ${getter}`);\n lines.push('');\n }\n\n // Group 字段 getters - 内联 Group 的字段\n for (const { field: groupField, groupNode } of groupFields) {\n const groupName = groupField.name;\n try {\n for (const field of groupNode.structFields) {\n if (!field.isSlot) continue;\n const getter = generateGroupFieldGetter(field, groupName);\n lines.push(` ${getter}`);\n lines.push('');\n }\n } catch (_e) {\n // Skip invalid group fields\n }\n }\n\n // Union 方法\n for (const [groupIndex, group] of unionGroups.entries()) {\n const unionName =\n group.fields.length > 0 ? `${capitalize(group.fields[0].name)}Union` : `Union${groupIndex}`;\n const variants: Record<number, string> = {};\n for (const field of group.fields) {\n variants[field.discriminantValue] = field.name;\n }\n const variantsStr = JSON.stringify(variants).replace(/\"/g, \"'\");\n\n lines.push(` get${unionName}Tag(): number {`);\n lines.push(` return this.reader.getUint16(${group.discriminantOffset * 2});`);\n lines.push(' }');\n lines.push('');\n\n lines.push(` get${unionName}Variant(): string | undefined {`);\n lines.push(` const tag = this.get${unionName}Tag();`);\n lines.push(` const variants = ${variantsStr};`);\n lines.push(' return variants[tag];');\n lines.push(' }');\n lines.push('');\n\n // 每个 variant 的 getter\n for (const field of group.fields) {\n const getter = generateUnionFieldGetter(field, unionName, field.discriminantValue);\n lines.push(` ${getter}`);\n lines.push('');\n }\n\n // 每个 variant 的 setter\n for (const field of group.fields) {\n const setter = generateUnionFieldSetter(\n field,\n unionName,\n field.discriminantValue,\n group.discriminantOffset * 2\n );\n lines.push(` ${setter}`);\n lines.push('');\n }\n }\n\n lines.push('}');\n lines.push('');\n\n // 生成 Builder 类\n lines.push(`export class ${structName}Builder {`);\n lines.push(' constructor(private builder: StructBuilder) {}');\n lines.push('');\n\n // 普通字段 setters\n for (const field of regularFields) {\n if (!field.isSlot) continue;\n const setter = generateFieldSetter(field);\n lines.push(` ${setter}`);\n lines.push('');\n }\n\n // Group 字段 setters\n for (const { field: groupField, groupNode } of groupFields) {\n const groupName = groupField.name;\n try {\n for (const field of groupNode.structFields) {\n if (!field.isSlot) continue;\n const setter = generateGroupFieldSetter(field, groupName);\n lines.push(` ${setter}`);\n lines.push('');\n }\n } catch (_e) {\n // Skip invalid group fields\n }\n }\n\n // Union setters\n for (const [groupIndex, group] of unionGroups.entries()) {\n const unionName =\n group.fields.length > 0 ? `${capitalize(group.fields[0].name)}Union` : `Union${groupIndex}`;\n for (const field of group.fields) {\n const setter = generateUnionFieldSetter(\n field,\n unionName,\n field.discriminantValue,\n group.discriminantOffset * 2\n );\n lines.push(` ${setter}`);\n lines.push('');\n }\n }\n\n lines.push('}');\n\n return lines.join('\\n');\n}\n\n/**\n * 分析字段,分离 Union 字段和普通字段,展开 Group 字段\n */\nfunction analyzeFields(\n node: NodeReader,\n allNodes: NodeReader[]\n): {\n unionGroups: UnionGroup[];\n regularFields: FieldReader[];\n groupFields: { field: FieldReader; groupNode: NodeReader }[];\n} {\n const fields = node.structFields;\n const unionGroups: Map<number, UnionGroup> = new Map();\n const regularFields: FieldReader[] = [];\n const groupFields: { field: FieldReader; groupNode: NodeReader }[] = [];\n\n for (const field of fields) {\n // 处理 Group 字段\n if (field.isGroup) {\n const groupNode = allNodes.find((n) => n.id === field.groupTypeId);\n if (groupNode?.isStruct) {\n groupFields.push({ field, groupNode });\n }\n continue;\n }\n\n // 处理 Union 字段\n if (\n node.structDiscriminantCount > 0 &&\n field.discriminantValue !== 65535 &&\n field.discriminantValue !== 0\n ) {\n const discriminantOffset = node.structDiscriminantOffset;\n\n if (!unionGroups.has(discriminantOffset)) {\n unionGroups.set(discriminantOffset, { discriminantOffset, fields: [] });\n }\n unionGroups.get(discriminantOffset)!.fields.push(field);\n } else {\n // 普通字段\n regularFields.push(field);\n }\n }\n\n return {\n unionGroups: Array.from(unionGroups.values()),\n regularFields,\n groupFields,\n };\n}\n\n/**\n * 生成 Union variant 类型\n */\nfunction generateUnionVariantType(group: UnionGroup, allNodes: NodeReader[]): string {\n const variants = group.fields.map((f) => {\n const tsType = f.isSlot ? getTypeScriptType(f.slotType, allNodes) : 'unknown';\n return `{ tag: ${f.discriminantValue}; variant: '${f.name}'; value: ${tsType} }`;\n });\n return variants.join(' | ');\n}\n\n/**\n * 生成 Union 字段的 getter\n */\nfunction generateUnionFieldGetter(\n field: FieldReader,\n unionName: string,\n discriminantValue: number\n): string {\n const name = field.name;\n const type = field.slotType;\n\n if (!type || !field.isSlot) {\n return `get${capitalize(name)}(): unknown | undefined { return this.get${unionName}Tag() === ${discriminantValue} ? undefined : undefined; }`;\n }\n\n const returnType = getTypeScriptTypeForSetter(type);\n\n let body: string;\n switch (type.kind) {\n case 'void':\n body = 'return undefined;';\n break;\n case 'bool':\n body = `return this.reader.getBool(${field.slotOffset * 8});`;\n break;\n case 'int8':\n body = `return this.reader.getInt8(${field.slotOffset});`;\n break;\n case 'int16':\n body = `return this.reader.getInt16(${field.slotOffset * 2});`;\n break;\n case 'int32':\n body = `return this.reader.getInt32(${field.slotOffset * 4});`;\n break;\n case 'int64':\n body = `return this.reader.getInt64(${field.slotOffset * 8});`;\n break;\n case 'uint8':\n body = `return this.reader.getUint8(${field.slotOffset});`;\n break;\n case 'uint16':\n body = `return this.reader.getUint16(${field.slotOffset * 2});`;\n break;\n case 'uint32':\n body = `return this.reader.getUint32(${field.slotOffset * 4});`;\n break;\n case 'uint64':\n body = `return this.reader.getUint64(${field.slotOffset * 8});`;\n break;\n case 'float32':\n body = `return this.reader.getFloat32(${field.slotOffset * 4});`;\n break;\n case 'float64':\n body = `return this.reader.getFloat64(${field.slotOffset * 8});`;\n break;\n case 'text':\n body = `return this.reader.getText(${field.slotOffset});`;\n break;\n case 'data':\n body = `return this.reader.getData(${field.slotOffset});`;\n break;\n default:\n body = 'return undefined;';\n }\n\n return `get${capitalize(name)}(): ${returnType} | undefined {\n if (this.get${unionName}Tag() !== ${discriminantValue}) return undefined;\n ${body}\n }`;\n}\n\n/**\n * 生成 Group 字段的 getter\n * Group 字段在父 struct 的 data/pointer section 中,但命名空间是 Group 的名字\n */\nfunction generateGroupFieldGetter(field: FieldReader, groupName: string): string {\n const name = field.name;\n const type = field.slotType;\n\n if (!type) {\n return `get${capitalize(groupName)}${capitalize(name)}(): unknown { return undefined; }`;\n }\n\n switch (type.kind) {\n case 'void':\n return `get${capitalize(groupName)}${capitalize(name)}(): void { return undefined; }`;\n case 'bool':\n return `get${capitalize(groupName)}${capitalize(name)}(): boolean { return this.reader.getBool(${field.slotOffset * 8}); }`;\n case 'int8':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getInt8(${field.slotOffset}); }`;\n case 'int16':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getInt16(${field.slotOffset * 2}); }`;\n case 'int32':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getInt32(${field.slotOffset * 4}); }`;\n case 'int64':\n return `get${capitalize(groupName)}${capitalize(name)}(): bigint { return this.reader.getInt64(${field.slotOffset * 8}); }`;\n case 'uint8':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getUint8(${field.slotOffset}); }`;\n case 'uint16':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getUint16(${field.slotOffset * 2}); }`;\n case 'uint32':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getUint32(${field.slotOffset * 4}); }`;\n case 'uint64':\n return `get${capitalize(groupName)}${capitalize(name)}(): bigint { return this.reader.getUint64(${field.slotOffset * 8}); }`;\n case 'float32':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getFloat32(${field.slotOffset * 4}); }`;\n case 'float64':\n return `get${capitalize(groupName)}${capitalize(name)}(): number { return this.reader.getFloat64(${field.slotOffset * 8}); }`;\n case 'text':\n return `get${capitalize(groupName)}${capitalize(name)}(): string { return this.reader.getText(${field.slotOffset}); }`;\n case 'data':\n return `get${capitalize(groupName)}${capitalize(name)}(): Uint8Array { return this.reader.getData(${field.slotOffset}); }`;\n default:\n return `get${capitalize(groupName)}${capitalize(name)}(): unknown { return undefined; }`;\n }\n}\n\n/**\n * 生成 Group 字段的 setter\n */\nfunction generateGroupFieldSetter(field: FieldReader, groupName: string): string {\n const name = field.name;\n const type = field.slotType;\n const paramType = getTypeScriptTypeForSetter(type);\n\n if (!type || !field.isSlot) {\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { /* TODO */ }`;\n }\n\n switch (type.kind) {\n case 'void':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { }`;\n case 'bool':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setBool(${field.slotOffset * 8}, value); }`;\n case 'int8':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setInt8(${field.slotOffset}, value); }`;\n case 'int16':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setInt16(${field.slotOffset * 2}, value); }`;\n case 'int32':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setInt32(${field.slotOffset * 4}, value); }`;\n case 'int64':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setInt64(${field.slotOffset * 8}, value); }`;\n case 'uint8':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setUint8(${field.slotOffset}, value); }`;\n case 'uint16':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setUint16(${field.slotOffset * 2}, value); }`;\n case 'uint32':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setUint32(${field.slotOffset * 4}, value); }`;\n case 'uint64':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setUint64(${field.slotOffset * 8}, value); }`;\n case 'float32':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setFloat32(${field.slotOffset * 4}, value); }`;\n case 'float64':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setFloat64(${field.slotOffset * 8}, value); }`;\n case 'text':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setText(${field.slotOffset}, value); }`;\n case 'data':\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { this.builder.setData(${field.slotOffset}, value); }`;\n default:\n return `set${capitalize(groupName)}${capitalize(name)}(value: ${paramType}): void { /* TODO */ }`;\n }\n}\n\n/**\n * 生成 Union 字段的 setter\n */\nfunction generateUnionFieldSetter(\n field: FieldReader,\n _unionName: string,\n discriminantValue: number,\n discriminantOffset: number\n): string {\n const name = field.name;\n const type = field.slotType;\n const paramType = getTypeScriptTypeForSetter(type);\n\n if (!type || !field.isSlot) {\n return `set${capitalize(name)}(value: ${paramType}): void {\n this.builder.setUint16(${discriminantOffset}, ${discriminantValue});\n }`;\n }\n\n let body: string;\n switch (type.kind) {\n case 'void':\n body = '';\n break;\n case 'bool':\n body = `this.builder.setBool(${field.slotOffset * 8}, value);`;\n break;\n case 'int8':\n body = `this.builder.setInt8(${field.slotOffset}, value);`;\n break;\n case 'int16':\n body = `this.builder.setInt16(${field.slotOffset * 2}, value);`;\n break;\n case 'int32':\n body = `this.builder.setInt32(${field.slotOffset * 4}, value);`;\n break;\n case 'int64':\n body = `this.builder.setInt64(${field.slotOffset * 8}, value);`;\n break;\n case 'uint8':\n body = `this.builder.setUint8(${field.slotOffset}, value);`;\n break;\n case 'uint16':\n body = `this.builder.setUint16(${field.slotOffset * 2}, value);`;\n break;\n case 'uint32':\n body = `this.builder.setUint32(${field.slotOffset * 4}, value);`;\n break;\n case 'uint64':\n body = `this.builder.setUint64(${field.slotOffset * 8}, value);`;\n break;\n case 'float32':\n body = `this.builder.setFloat32(${field.slotOffset * 4}, value);`;\n break;\n case 'float64':\n body = `this.builder.setFloat64(${field.slotOffset * 8}, value);`;\n break;\n case 'text':\n body = `this.builder.setText(${field.slotOffset}, value);`;\n break;\n case 'data':\n body = `this.builder.setData(${field.slotOffset}, value);`;\n break;\n default:\n body = '';\n }\n\n return `set${capitalize(name)}(value: ${paramType}): void {\n this.builder.setUint16(${discriminantOffset}, ${discriminantValue});\n ${body}\n }`;\n}\n\n/**\n * 从 ValueReader 提取默认值,用于代码生成\n */\nfunction extractDefaultValue(field: FieldReader): string | undefined {\n const defaultValue = field.defaultValue;\n if (!defaultValue) return undefined;\n\n const type = field.slotType;\n if (!type) return undefined;\n\n switch (type.kind) {\n case 'bool':\n if (defaultValue.isBool) return defaultValue.boolValue ? 'true' : 'false';\n return undefined;\n case 'int8':\n if (defaultValue.isInt8) return `${defaultValue.int8Value}`;\n return undefined;\n case 'int16':\n if (defaultValue.isInt16) return `${defaultValue.int16Value}`;\n return undefined;\n case 'int32':\n if (defaultValue.isInt32) return `${defaultValue.int32Value}`;\n return undefined;\n case 'int64':\n if (defaultValue.isInt64) return `${defaultValue.int64Value}n`;\n return undefined;\n case 'uint8':\n if (defaultValue.isUint8) return `${defaultValue.uint8Value}`;\n return undefined;\n case 'uint16':\n if (defaultValue.isUint16) return `${defaultValue.uint16Value}`;\n return undefined;\n case 'uint32':\n if (defaultValue.isUint32) return `${defaultValue.uint32Value}`;\n return undefined;\n case 'uint64':\n if (defaultValue.isUint64) return `${defaultValue.uint64Value}n`;\n return undefined;\n case 'float32':\n if (defaultValue.isFloat32) {\n const val = defaultValue.float32Value;\n if (Number.isNaN(val)) return 'NaN';\n if (val === Number.POSITIVE_INFINITY) return 'Infinity';\n if (val === Number.NEGATIVE_INFINITY) return '-Infinity';\n return `${val}`;\n }\n return undefined;\n case 'float64':\n if (defaultValue.isFloat64) {\n const val = defaultValue.float64Value;\n if (Number.isNaN(val)) return 'NaN';\n if (val === Number.POSITIVE_INFINITY) return 'Infinity';\n if (val === Number.NEGATIVE_INFINITY) return '-Infinity';\n return `${val}`;\n }\n return undefined;\n case 'enum':\n if (defaultValue.isEnum) return `${defaultValue.enumValue}`;\n return undefined;\n default:\n return undefined;\n }\n}\n\n/**\n * 生成 XOR 解码表达式(用于 getter)\n * stored ^ default = actual\n */\nfunction generateXorDecode(expr: string, defaultValue: string, typeKind: TypeKind): string {\n switch (typeKind) {\n case 'bool':\n // bool: stored !== default\n return `${expr} !== ${defaultValue}`;\n case 'int8':\n case 'int16':\n case 'int32':\n // 有符号整数:先转无符号 XOR,再转回有符号\n return `(${expr} ^ ${defaultValue}) | 0`;\n case 'uint8':\n case 'uint16':\n case 'uint32':\n // 无符号整数:直接 XOR\n return `${expr} ^ ${defaultValue}`;\n case 'int64':\n case 'uint64':\n // bigint:直接 XOR\n return `${expr} ^ ${defaultValue}`;\n case 'float32':\n // float32: 需要位操作转换\n return `xorFloat32(${expr}, ${defaultValue})`;\n case 'float64':\n // float64: 需要位操作转换\n return `xorFloat64(${expr}, ${defaultValue})`;\n case 'enum':\n // enum 作为 uint16 处理\n return `${expr} ^ ${defaultValue}`;\n default:\n return expr;\n }\n}\n\n/**\n * 生成 XOR 编码表达式(用于 setter)\n * actual ^ default = stored\n */\nfunction generateXorEncode(valueExpr: string, defaultValue: string, typeKind: TypeKind): string {\n switch (typeKind) {\n case 'bool':\n // bool: value !== default\n return `${valueExpr} !== ${defaultValue}`;\n case 'int8':\n case 'int16':\n case 'int32':\n // 有符号整数:先转无符号 XOR\n return `(${valueExpr} >>> 0) ^ ${defaultValue}`;\n case 'uint8':\n case 'uint16':\n case 'uint32':\n // 无符号整数:直接 XOR\n return `${valueExpr} ^ ${defaultValue}`;\n case 'int64':\n case 'uint64':\n // bigint:直接 XOR\n return `${valueExpr} ^ ${defaultValue}`;\n case 'float32':\n // float32: 需要位操作转换\n return `xorFloat32(${valueExpr}, ${defaultValue})`;\n case 'float64':\n // float64: 需要位操作转换\n return `xorFloat64(${valueExpr}, ${defaultValue})`;\n case 'enum':\n // enum 作为 uint16 处理\n return `${valueExpr} ^ ${defaultValue}`;\n default:\n return valueExpr;\n }\n}\n\n/**\n * 生成字段 getter\n */\nfunction generateFieldGetter(field: FieldReader): string {\n const name = field.name;\n const type = field.slotType;\n const defaultValue = extractDefaultValue(field);\n\n if (!type) {\n return `get ${name}(): unknown { return undefined; }`;\n }\n\n // 如果有默认值,使用 XOR 解码\n if (defaultValue !== undefined && type.kind !== 'text' && type.kind !== 'data') {\n const readExpr = `this.reader.get${capitalize(type.kind)}(${getByteOffset(field, type.kind)})`;\n const decodedExpr = generateXorDecode(readExpr, defaultValue, type.kind);\n return `get ${name}(): ${getTypeScriptTypeForSetter(type)} { return ${decodedExpr}; }`;\n }\n\n switch (type.kind) {\n case 'void':\n return `get ${name}(): void { return undefined; }`;\n case 'bool':\n return `get ${name}(): boolean { return this.reader.getBool(${field.slotOffset * 8}); }`;\n case 'int8':\n return `get ${name}(): number { return this.reader.getInt8(${field.slotOffset}); }`;\n case 'int16':\n return `get ${name}(): number { return this.reader.getInt16(${field.slotOffset * 2}); }`;\n case 'int32':\n return `get ${name}(): number { return this.reader.getInt32(${field.slotOffset * 4}); }`;\n case 'int64':\n return `get ${name}(): bigint { return this.reader.getInt64(${field.slotOffset * 8}); }`;\n case 'uint8':\n return `get ${name}(): number { return this.reader.getUint8(${field.slotOffset}); }`;\n case 'uint16':\n return `get ${name}(): number { return this.reader.getUint16(${field.slotOffset * 2}); }`;\n case 'uint32':\n return `get ${name}(): number { return this.reader.getUint32(${field.slotOffset * 4}); }`;\n case 'uint64':\n return `get ${name}(): bigint { return this.reader.getUint64(${field.slotOffset * 8}); }`;\n case 'float32':\n return `get ${name}(): number { return this.reader.getFloat32(${field.slotOffset * 4}); }`;\n case 'float64':\n return `get ${name}(): number { return this.reader.getFloat64(${field.slotOffset * 8}); }`;\n case 'text':\n return `get ${name}(): string { return this.reader.getText(${field.slotOffset}); }`;\n case 'data':\n return `get ${name}(): Uint8Array { return this.reader.getData(${field.slotOffset}); }`;\n default:\n return `get ${name}(): unknown { return undefined; }`;\n }\n}\n\n/**\n * 获取字节偏移量\n */\nfunction getByteOffset(field: FieldReader, typeKind: TypeKind): number {\n switch (typeKind) {\n case 'bool':\n return field.slotOffset * 8; // bit offset\n case 'int8':\n case 'uint8':\n return field.slotOffset;\n case 'int16':\n case 'uint16':\n case 'enum':\n return field.slotOffset * 2;\n case 'int32':\n case 'uint32':\n case 'float32':\n return field.slotOffset * 4;\n case 'int64':\n case 'uint64':\n case 'float64':\n return field.slotOffset * 8;\n default:\n return field.slotOffset;\n }\n}\n\n/**\n * 生成字段 setter\n */\nfunction generateFieldSetter(field: FieldReader): string {\n const name = field.name;\n const type = field.slotType;\n const paramType = getTypeScriptTypeForSetter(type);\n const defaultValue = extractDefaultValue(field);\n\n if (!type) {\n return `set${capitalize(name)}(value: unknown): void { /* TODO */ }`;\n }\n\n // 如果有默认值,使用 XOR 编码\n if (defaultValue !== undefined && type.kind !== 'text' && type.kind !== 'data') {\n const encodedExpr = generateXorEncode('value', defaultValue, type.kind);\n const setterMethod = `set${capitalize(type.kind)}`;\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.${setterMethod}(${getByteOffset(field, type.kind)}, ${encodedExpr}); }`;\n }\n\n switch (type.kind) {\n case 'void':\n return `set${capitalize(name)}(value: void): void { /* void */ }`;\n case 'bool':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setBool(${field.slotOffset * 8}, value); }`;\n case 'int8':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setInt8(${field.slotOffset}, value); }`;\n case 'int16':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setInt16(${field.slotOffset * 2}, value); }`;\n case 'int32':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setInt32(${field.slotOffset * 4}, value); }`;\n case 'int64':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setInt64(${field.slotOffset * 8}, value); }`;\n case 'uint8':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setUint8(${field.slotOffset}, value); }`;\n case 'uint16':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setUint16(${field.slotOffset * 2}, value); }`;\n case 'uint32':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setUint32(${field.slotOffset * 4}, value); }`;\n case 'uint64':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setUint64(${field.slotOffset * 8}, value); }`;\n case 'float32':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setFloat32(${field.slotOffset * 4}, value); }`;\n case 'float64':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setFloat64(${field.slotOffset * 8}, value); }`;\n case 'text':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setText(${field.slotOffset}, value); }`;\n case 'data':\n return `set${capitalize(name)}(value: ${paramType}): void { this.builder.setData(${field.slotOffset}, value); }`;\n default:\n return `set${capitalize(name)}(value: ${paramType}): void { /* TODO */ }`;\n }\n}\n\n/**\n * 获取 TypeScript setter 参数类型\n */\nfunction getTypeScriptTypeForSetter(type: TypeReader | null): string {\n if (!type) return 'unknown';\n\n switch (type.kind) {\n case 'void':\n return 'void';\n case 'bool':\n return 'boolean';\n case 'int8':\n case 'int16':\n case 'int32':\n case 'uint8':\n case 'uint16':\n case 'uint32':\n case 'float32':\n case 'float64':\n return 'number';\n case 'int64':\n case 'uint64':\n return 'bigint';\n case 'text':\n return 'string';\n case 'data':\n return 'Uint8Array';\n default:\n return 'unknown';\n }\n}\n\n/**\n * 首字母大写\n */\nfunction capitalize(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\n/**\n * 生成 Enum 的 TypeScript 代码\n */\nfunction generateEnum(node: NodeReader): string {\n const lines: string[] = [];\n const enumName = getShortName(node.displayName);\n\n lines.push(`export enum ${enumName} {`);\n for (const enumerant of node.enumEnumerants) {\n lines.push(` ${enumerant.name} = ${enumerant.codeOrder},`);\n }\n lines.push('}');\n\n return lines.join('\\n');\n}\n\n/**\n * 获取 TypeScript 类型字符串\n */\nfunction getTypeScriptType(type: TypeReader | null, allNodes: NodeReader[]): string {\n if (!type) return 'unknown';\n\n switch (type.kind) {\n case 'void':\n return 'void';\n case 'bool':\n return 'boolean';\n case 'int8':\n case 'int16':\n case 'int32':\n case 'uint8':\n case 'uint16':\n case 'uint32':\n case 'float32':\n case 'float64':\n return 'number';\n case 'int64':\n case 'uint64':\n return 'bigint';\n case 'text':\n return 'string';\n case 'data':\n return 'Uint8Array';\n case 'list': {\n const elementType = type.listElementType;\n if (!elementType) return 'unknown[]';\n const elemTsType = getTypeScriptType(elementType, allNodes);\n return `${elemTsType}[]`;\n }\n case 'struct': {\n const structNode = allNodes.find((n) => n.id === type.typeId);\n if (structNode) {\n return getShortName(structNode.displayName);\n }\n return 'unknown';\n }\n case 'enum': {\n const enumNode = allNodes.find((n) => n.id === type.typeId);\n if (enumNode) {\n return getShortName(enumNode.displayName);\n }\n return 'unknown';\n }\n default:\n return 'unknown';\n }\n}\n\n/**\n * 从 displayName 获取短名称\n * 例如 \"test-schema.capnp:Person\" -> \"Person\"\n * 处理 auto-generated 名称如 \"Calculator.evaluate$Params\" -> \"EvaluateParams\"\n */\nfunction getShortName(displayName: string): string {\n // Handle empty or undefined display names\n if (!displayName) {\n return 'Unknown';\n }\n const colonIndex = displayName.lastIndexOf(':');\n let name = colonIndex >= 0 ? displayName.substring(colonIndex + 1) : displayName;\n\n // Replace invalid characters for TypeScript identifiers\n // Handle auto-generated names like \"Calculator.evaluate$Params\" -> \"EvaluateParams\"\n if (name.includes('.')) {\n const parts = name.split('.');\n if (parts.length === 2 && parts[1].includes('$')) {\n // Interface method params/results: \"Interface.method$Params\" -> \"MethodParams\"\n const methodPart = parts[1];\n const dollarIndex = methodPart.indexOf('$');\n if (dollarIndex > 0) {\n const methodName = methodPart.substring(0, dollarIndex);\n const suffix = methodPart.substring(dollarIndex + 1);\n name = capitalize(methodName) + suffix;\n } else {\n name = capitalize(parts[1]);\n }\n } else {\n name = parts[parts.length - 1];\n }\n }\n\n // Remove any remaining invalid characters\n name = name.replace(/[^a-zA-Z0-9_]/g, '_');\n\n return name;\n}\n\n/**\n * 生成 Interface 的 TypeScript 代码\n * 包括:Method Constants、Client Class、Server Interface、Server Stub\n */\nfunction generateInterface(node: NodeReader, allNodes: NodeReader[]): string {\n const lines: string[] = [];\n const interfaceName = getShortName(node.displayName);\n const methods = node.interfaceMethods;\n\n if (methods.length === 0) {\n return `// Interface ${interfaceName} has no methods`;\n }\n\n // 1. 生成 Method ID 常量\n lines.push(`// ${interfaceName} Method IDs`);\n lines.push(`export const ${interfaceName}InterfaceId = ${node.id}n;`);\n lines.push(`export const ${interfaceName}MethodIds = {`);\n for (const method of methods) {\n lines.push(` ${method.name}: ${method.codeOrder},`);\n }\n lines.push('} as const;');\n lines.push('');\n\n // 2. 生成 Server Interface\n lines.push(`// ${interfaceName} Server Interface`);\n lines.push(`export interface ${interfaceName}Server {`);\n for (const method of methods) {\n const paramType = getTypeNameById(method.paramStructType, allNodes, 'unknown');\n const resultType = getTypeNameById(method.resultStructType, allNodes, 'unknown');\n lines.push(\n ` ${method.name}(context: CallContext<${paramType}Reader, ${resultType}Builder>): Promise<void> | void;`\n );\n }\n lines.push('}');\n lines.push('');\n\n // 3. 生成 Server Stub\n lines.push(`// ${interfaceName} Server Stub`);\n lines.push(`export class ${interfaceName}Stub {`);\n lines.push(` private server: ${interfaceName}Server;`);\n lines.push('');\n lines.push(` constructor(server: ${interfaceName}Server) {`);\n lines.push(' this.server = server;');\n lines.push(' }');\n lines.push('');\n lines.push(` static readonly interfaceId = ${node.id}n;`);\n lines.push('');\n lines.push(' /** Dispatch a method call to the appropriate handler */');\n lines.push(\n ' async dispatch(methodId: number, context: CallContext<unknown, unknown>): Promise<void> {'\n );\n lines.push(' switch (methodId) {');\n\n for (const method of methods) {\n const paramType = getTypeNameById(method.paramStructType, allNodes, 'unknown');\n const resultType = getTypeNameById(method.resultStructType, allNodes, 'unknown');\n lines.push(` case ${interfaceName}MethodIds.${method.name}:`);\n lines.push(\n ` return this.server.${method.name}(context as CallContext<${paramType}Reader, ${resultType}Builder>);`\n );\n }\n\n lines.push(' default:');\n lines.push(' throw new Error(`Unknown method ID: ${methodId}`);');\n lines.push(' }');\n lines.push(' }');\n lines.push('');\n lines.push(' /** Check if a method ID is valid */');\n lines.push(' isValidMethod(methodId: number): boolean {');\n lines.push(' return [');\n for (const method of methods) {\n lines.push(` ${interfaceName}MethodIds.${method.name},`);\n }\n lines.push(' ].includes(methodId);');\n lines.push(' }');\n lines.push('}');\n lines.push('');\n\n // 4. 生成 Client Class\n lines.push(`// ${interfaceName} Client Class`);\n lines.push(`export class ${interfaceName}Client extends BaseCapabilityClient {`);\n lines.push(` static readonly interfaceId = ${node.id}n;`);\n lines.push('');\n\n for (const method of methods) {\n const paramType = getTypeNameById(method.paramStructType, allNodes, 'unknown');\n const resultType = getTypeNameById(method.resultStructType, allNodes, 'unknown');\n\n // 生成方法文档注释\n lines.push(' /**');\n lines.push(` * ${method.name}`);\n lines.push(` * @param params - ${paramType}`);\n lines.push(` * @returns PipelineClient<${resultType}Reader>`);\n lines.push(' */');\n\n // 生成方法签名\n lines.push(\n ` ${method.name}(params: ${paramType}Builder): PipelineClient<${resultType}Reader> {`\n );\n lines.push(' return this._call(');\n lines.push(` ${interfaceName}Client.interfaceId,`);\n lines.push(` ${interfaceName}MethodIds.${method.name},`);\n lines.push(' params');\n lines.push(` ) as PipelineClient<${resultType}Reader>;`);\n lines.push(' }');\n lines.push('');\n }\n\n lines.push('}');\n\n return lines.join('\\n');\n}\n\n/**\n * 根据类型 ID 获取类型名称\n */\nfunction getTypeNameById(id: bigint, allNodes: NodeReader[], fallback: string): string {\n const node = allNodes.find((n) => n.id === id);\n if (!node) return fallback;\n return getShortName(node.displayName);\n}\n","/**\n * Cap'n Proto 编译后 Schema 的 TypeScript Reader\n * 基于官方 schema.capnp 手动编写\n *\n * 这是自举的基础:我们需要先能读取 schema 才能生成 schema 的代码\n *\n * 结构信息来自: capnp compile -ocapnp schema.capnp\n */\n\nimport { MessageReader, type StructReader } from '../core/index.js';\nimport { ElementSize } from '../core/pointer.js';\n\n// ============================================================================\n// 基础类型\n// ============================================================================\n\n/** UInt64 作为 bigint */\nexport type Id = bigint;\n\n// ============================================================================\n// Node\n// ============================================================================\n\nexport class NodeReader {\n constructor(private reader: StructReader) {}\n\n get id(): Id {\n return this.reader.getUint64(0);\n }\n\n get displayName(): string {\n return this.reader.getText(0);\n }\n\n get displayNamePrefixLength(): number {\n return this.reader.getUint32(8);\n }\n\n get scopeId(): Id {\n return this.reader.getUint64(16);\n }\n\n /** union tag 在 bits [96, 112) = bytes [12, 14) */\n private get unionTag(): number {\n return this.reader.getUint16(12);\n }\n\n get isFile(): boolean {\n return this.unionTag === 0;\n }\n\n get isStruct(): boolean {\n return this.unionTag === 1;\n }\n\n get isEnum(): boolean {\n return this.unionTag === 2;\n }\n\n get isInterface(): boolean {\n return this.unionTag === 3;\n }\n\n get isConst(): boolean {\n return this.unionTag === 4;\n }\n\n get isAnnotation(): boolean {\n return this.unionTag === 5;\n }\n\n // --- Struct 相关字段 (union tag = 1) ---\n // struct group 从 bit 112 = byte 14 开始\n\n get structDataWordCount(): number {\n return this.reader.getUint16(14);\n }\n\n get structPointerCount(): number {\n return this.reader.getUint16(24);\n }\n\n get structPreferredListEncoding(): number {\n return this.reader.getUint16(26);\n }\n\n get structIsGroup(): boolean {\n // isGroup @10 :Bool; 在 bit 224 = byte 28\n return this.reader.getBool(224);\n }\n\n get structDiscriminantCount(): number {\n return this.reader.getUint16(30);\n }\n\n get structDiscriminantOffset(): number {\n return this.reader.getUint32(32);\n }\n\n get structFields(): FieldReader[] {\n // fields @13 :List(Field); 是 ptr[3]\n // Field: 24 bytes = 3 words data, 4 pointers\n const listReader = this.reader.getList(3, ElementSize.INLINE_COMPOSITE, {\n dataWords: 3,\n pointerCount: 4,\n });\n if (!listReader) return [];\n\n const fields: FieldReader[] = [];\n for (let i = 0; i < listReader.length; i++) {\n const itemReader = listReader.getStruct(i);\n const field = new FieldReader(itemReader);\n // Stop if we encounter a field with empty name (likely past the actual fields)\n if (!field.name && i > 0) break;\n fields.push(field);\n }\n return fields;\n }\n\n // --- Enum 相关字段 (union tag = 2) ---\n\n get enumEnumerants(): EnumerantReader[] {\n // enumerants @14 :List(Enumerant); 在 enum group 内,ptr[3]\n const listReader = this.reader.getList(3, ElementSize.INLINE_COMPOSITE, {\n dataWords: 1,\n pointerCount: 2,\n });\n if (!listReader) return [];\n\n const enumerants: EnumerantReader[] = [];\n for (let i = 0; i < Math.min(listReader.length, 10); i++) {\n try {\n const itemReader = listReader.getStruct(i);\n const enumerant = new EnumerantReader(itemReader);\n // Stop if we encounter an enumerant with empty name\n if (!enumerant.name) break;\n enumerants.push(enumerant);\n } catch (_e) {\n // Stop on any error (likely past the actual enumerants)\n break;\n }\n }\n return enumerants;\n }\n\n // --- Interface 相关字段 (union tag = 3) ---\n\n get interfaceMethods(): MethodReader[] {\n // methods @15 :List(Method); 在 interface group 内,ptr[3]\n // Method: 5 words data, 2 pointers\n const listReader = this.reader.getList(3, ElementSize.INLINE_COMPOSITE, {\n dataWords: 5,\n pointerCount: 2,\n });\n if (!listReader) return [];\n\n const methods: MethodReader[] = [];\n for (let i = 0; i < listReader.length; i++) {\n try {\n const itemReader = listReader.getStruct(i);\n const method = new MethodReader(itemReader);\n if (!method.name && i > 0) break;\n methods.push(method);\n } catch (_e) {\n break;\n }\n }\n return methods;\n }\n\n // --- NestedNodes ---\n\n get nestedNodes(): NestedNodeReader[] {\n // nestedNodes @4 :List(NestedNode); 是 ptr[1]\n const listReader = this.reader.getList(1, ElementSize.INLINE_COMPOSITE, {\n dataWords: 1,\n pointerCount: 1,\n });\n if (!listReader) return [];\n\n const nodes: NestedNodeReader[] = [];\n for (let i = 0; i < listReader.length; i++) {\n const itemReader = listReader.getStruct(i);\n nodes.push(new NestedNodeReader(itemReader));\n }\n return nodes;\n }\n}\n\n// ============================================================================\n// Field\n// ============================================================================\n\nexport class FieldReader {\n constructor(private reader: StructReader) {}\n\n get name(): string {\n return this.reader.getText(0);\n }\n\n get codeOrder(): number {\n return this.reader.getUint16(0);\n }\n\n get discriminantValue(): number {\n return this.reader.getUint16(2);\n }\n\n /** union tag 在 bits [64, 80) = bytes [8, 10) */\n private get unionTag(): number {\n return this.reader.getUint16(8);\n }\n\n get isSlot(): boolean {\n return this.unionTag === 0;\n }\n\n get isGroup(): boolean {\n return this.unionTag === 1;\n }\n\n // --- Slot 相关 ---\n\n get slotOffset(): number {\n return this.reader.getUint32(4);\n }\n\n get slotType(): TypeReader | null {\n // type @5 :Type; 是 ptr[2]\n const typeReader = this.reader.getStruct(2, 3, 1); // Type: 24 bytes = 3 words, 1 pointer\n return typeReader ? new TypeReader(typeReader) : null;\n }\n\n // --- Group 相关 ---\n\n get groupTypeId(): Id {\n // typeId @7 :UInt64; 在 group group 内,bits [128, 192) = bytes [16, 24)\n return this.reader.getUint64(16);\n }\n\n // --- Default Value ---\n\n get defaultValue(): ValueReader | null {\n // defaultValue @6 :Value; 是 ptr[3]\n const valueReader = this.reader.getStruct(3, 2, 1); // Value: 16 bytes = 2 words, 1 pointer\n return valueReader ? new ValueReader(valueReader) : null;\n }\n}\n\n// ============================================================================\n// Type\n// ============================================================================\n\nexport class TypeReader {\n constructor(private reader: StructReader) {}\n\n get kind(): TypeKind {\n const tag = this.reader.getUint16(0);\n return TYPE_KIND_MAP[tag] ?? 'unknown';\n }\n\n get isPrimitive(): boolean {\n const k = this.kind;\n return (\n k !== 'list' && k !== 'enum' && k !== 'struct' && k !== 'interface' && k !== 'anyPointer'\n );\n }\n\n // --- List ---\n\n get listElementType(): TypeReader | null {\n if (this.kind !== 'list') return null;\n // elementType @14 :Type; 是 ptr[0]\n const elementReader = this.reader.getStruct(0, 3, 1);\n return elementReader ? new TypeReader(elementReader) : null;\n }\n\n // --- Enum/Struct/Interface ---\n\n get typeId(): Id | null {\n const k = this.kind;\n if (k === 'enum' || k === 'struct' || k === 'interface') {\n // typeId 在 bits [64, 128) = bytes [8, 16)\n return this.reader.getUint64(8);\n }\n return null;\n }\n}\n\nexport type TypeKind =\n | 'void'\n | 'bool'\n | 'int8'\n | 'int16'\n | 'int32'\n | 'int64'\n | 'uint8'\n | 'uint16'\n | 'uint32'\n | 'uint64'\n | 'float32'\n | 'float64'\n | 'text'\n | 'data'\n | 'list'\n | 'enum'\n | 'struct'\n | 'interface'\n | 'anyPointer'\n | 'unknown';\n\nconst TYPE_KIND_MAP: Record<number, TypeKind> = {\n 0: 'void',\n 1: 'bool',\n 2: 'int8',\n 3: 'int16',\n 4: 'int32',\n 5: 'int64',\n 6: 'uint8',\n 7: 'uint16',\n 8: 'uint32',\n 9: 'uint64',\n 10: 'float32',\n 11: 'float64',\n 12: 'text',\n 13: 'data',\n 14: 'list',\n 15: 'enum',\n 16: 'struct',\n 17: 'interface',\n 18: 'anyPointer',\n};\n\n// ============================================================================\n// Value - 默认值\n// ============================================================================\n\nexport class ValueReader {\n constructor(private reader: StructReader) {}\n\n /** union tag 在 bits [0, 16) = bytes [0, 2) */\n private get unionTag(): number {\n return this.reader.getUint16(0);\n }\n\n get isVoid(): boolean {\n return this.unionTag === 0;\n }\n get isBool(): boolean {\n return this.unionTag === 1;\n }\n get isInt8(): boolean {\n return this.unionTag === 2;\n }\n get isInt16(): boolean {\n return this.unionTag === 3;\n }\n get isInt32(): boolean {\n return this.unionTag === 4;\n }\n get isInt64(): boolean {\n return this.unionTag === 5;\n }\n get isUint8(): boolean {\n return this.unionTag === 6;\n }\n get isUint16(): boolean {\n return this.unionTag === 7;\n }\n get isUint32(): boolean {\n return this.unionTag === 8;\n }\n get isUint64(): boolean {\n return this.unionTag === 9;\n }\n get isFloat32(): boolean {\n return this.unionTag === 10;\n }\n get isFloat64(): boolean {\n return this.unionTag === 11;\n }\n get isText(): boolean {\n return this.unionTag === 12;\n }\n get isData(): boolean {\n return this.unionTag === 13;\n }\n get isList(): boolean {\n return this.unionTag === 14;\n }\n get isEnum(): boolean {\n return this.unionTag === 15;\n }\n get isStruct(): boolean {\n return this.unionTag === 16;\n }\n get isInterface(): boolean {\n return this.unionTag === 17;\n }\n get isAnyPointer(): boolean {\n return this.unionTag === 18;\n }\n\n // --- 原始值读取 ---\n\n get boolValue(): boolean {\n // boolValue @1 :Bool; 在 bit 16\n return this.reader.getBool(16);\n }\n\n get int8Value(): number {\n // int8Value @2 :Int8; 在 byte 2\n return this.reader.getInt8(2);\n }\n\n get int16Value(): number {\n // int16Value @3 :Int16; 在 bytes [2, 4)\n return this.reader.getInt16(2);\n }\n\n get int32Value(): number {\n // int32Value @4 :Int32; 在 bytes [4, 8)\n return this.reader.getInt32(4);\n }\n\n get int64Value(): bigint {\n // int64Value @5 :Int64; 在 bytes [8, 16)\n return this.reader.getInt64(8);\n }\n\n get uint8Value(): number {\n // uint8Value @6 :UInt8; 在 byte 2\n return this.reader.getUint8(2);\n }\n\n get uint16Value(): number {\n // uint16Value @7 :UInt16; 在 bytes [2, 4)\n return this.reader.getUint16(2);\n }\n\n get uint32Value(): number {\n // uint32Value @8 :UInt32; 在 bytes [4, 8)\n return this.reader.getUint32(4);\n }\n\n get uint64Value(): bigint {\n // uint64Value @9 :UInt64; 在 bytes [8, 16)\n return this.reader.getUint64(8);\n }\n\n get float32Value(): number {\n // float32Value @10 :Float32; 在 bytes [4, 8)\n return this.reader.getFloat32(4);\n }\n\n get float64Value(): number {\n // float64Value @11 :Float64; 在 bytes [8, 16)\n return this.reader.getFloat64(8);\n }\n\n get enumValue(): number {\n // enumValue @15 :UInt16; 在 bytes [2, 4)\n return this.reader.getUint16(2);\n }\n\n // --- 便捷方法:获取特定类型的默认值 ---\n\n getAsNumber(): number | undefined {\n if (this.isInt8) return this.int8Value;\n if (this.isInt16) return this.int16Value;\n if (this.isInt32) return this.int32Value;\n if (this.isUint8) return this.uint8Value;\n if (this.isUint16) return this.uint16Value;\n if (this.isUint32) return this.uint32Value;\n if (this.isFloat32) return this.float32Value;\n if (this.isFloat64) return this.float64Value;\n if (this.isEnum) return this.enumValue;\n return undefined;\n }\n\n getAsBigint(): bigint | undefined {\n if (this.isInt64) return this.int64Value;\n if (this.isUint64) return this.uint64Value;\n return undefined;\n }\n\n getAsBoolean(): boolean | undefined {\n if (this.isBool) return this.boolValue;\n return undefined;\n }\n}\n\n// ============================================================================\n// Method - Interface 方法\n// ============================================================================\n\nexport class MethodReader {\n constructor(private reader: StructReader) {}\n\n get name(): string {\n return this.reader.getText(0);\n }\n\n get codeOrder(): number {\n return this.reader.getUint16(0);\n }\n\n get paramStructType(): Id {\n // paramStructType @2 :Id; 在 bytes [8, 16)\n return this.reader.getUint64(8);\n }\n\n get resultStructType(): Id {\n // resultStructType @3 :Id; 在 bytes [16, 24)\n return this.reader.getUint64(16);\n }\n}\n\n// ============================================================================\n// Enumerant\n// ============================================================================\n\nexport class EnumerantReader {\n constructor(private reader: StructReader) {}\n\n get name(): string {\n return this.reader.getText(0);\n }\n\n get codeOrder(): number {\n return this.reader.getUint16(0);\n }\n}\n\n// ============================================================================\n// NestedNode\n// ============================================================================\n\nexport class NestedNodeReader {\n constructor(private reader: StructReader) {}\n\n get name(): string {\n return this.reader.getText(0);\n }\n\n get id(): Id {\n return this.reader.getUint64(0);\n }\n}\n\n// ============================================================================\n// CodeGeneratorRequest\n// ============================================================================\n\nexport class CodeGeneratorRequestReader {\n constructor(private message: MessageReader) {}\n\n static fromBuffer(buffer: ArrayBuffer): CodeGeneratorRequestReader {\n const message = new MessageReader(buffer);\n return new CodeGeneratorRequestReader(message);\n }\n\n get nodes(): NodeReader[] {\n // CodeGeneratorRequest: 0 data words, 4 pointers\n const root = this.message.getRoot(0, 4);\n // nodes @0 :List(Node);\n const listReader = root.getList(0, ElementSize.INLINE_COMPOSITE, {\n dataWords: 6,\n pointerCount: 6,\n });\n if (!listReader) return [];\n\n const nodes: NodeReader[] = [];\n for (let i = 0; i < listReader.length; i++) {\n const nodeReader = listReader.getStruct(i);\n nodes.push(new NodeReader(nodeReader));\n }\n return nodes;\n }\n\n get requestedFiles(): RequestedFileReader[] {\n const root = this.message.getRoot(0, 4);\n // requestedFiles @1 :List(RequestedFile);\n const listReader = root.getList(1, ElementSize.INLINE_COMPOSITE, {\n dataWords: 1,\n pointerCount: 2,\n });\n if (!listReader) return [];\n\n const files: RequestedFileReader[] = [];\n for (let i = 0; i < listReader.length; i++) {\n try {\n const fileReader = listReader.getStruct(i);\n const file = new RequestedFileReader(fileReader);\n // Stop if we encounter a file with empty filename\n if (!file.filename && files.length > 0) break;\n files.push(file);\n } catch (_e) {\n // Stop on any error (likely past the actual files)\n break;\n }\n }\n return files;\n }\n}\n\n// ============================================================================\n// RequestedFile\n// ============================================================================\n\nexport class RequestedFileReader {\n constructor(private reader: StructReader) {}\n\n get id(): Id {\n return this.reader.getUint64(0);\n }\n\n get filename(): string {\n return this.reader.getText(0);\n }\n}\n","/**\n * Cap'n Proto Code Generator CLI\n *\n * Usage: capnp gen <schema.capnp> [options]\n */\n\nimport { execSync } from 'node:child_process';\nimport { existsSync, readFileSync, writeFileSync } from 'node:fs';\nimport { mkdtempSync, rmSync } from 'node:fs';\nimport { tmpdir } from 'node:os';\nimport { basename, join } from 'node:path';\nimport { parseArgs } from 'node:util';\nimport { type GeneratorOptions, generateFromRequest } from './codegen/generator.js';\nimport { CodeGeneratorRequestReader } from './schema/schema-reader.js';\n\nconst VERSION = '3.0.0';\n\nfunction printUsage() {\n console.log(`\nCap'n Proto TypeScript Code Generator v${VERSION}\n\nUsage: capnp gen <schema.capnp> [options]\n\nOptions:\n -o, --output Output file (default: stdout)\n -d, --outDir Output directory\n -r, --runtimePath Runtime library import path (default: @naeemo/capnp)\n -h, --help Show this help\n -v, --version Show version\n\nExamples:\n capnp gen schema.capnp -o schema.ts\n capnp gen schema.capnp -d ./generated\n`);\n}\n\nfunction checkCapnpTool(): boolean {\n try {\n execSync('capnp --version', { stdio: 'ignore' });\n return true;\n } catch {\n return false;\n }\n}\n\nexport async function run(args: string[]): Promise<void> {\n const { values, positionals } = parseArgs({\n args,\n options: {\n output: { type: 'string', short: 'o' },\n outDir: { type: 'string', short: 'd' },\n runtimePath: { type: 'string', short: 'r' },\n help: { type: 'boolean', short: 'h' },\n version: { type: 'boolean', short: 'v' },\n },\n allowPositionals: true,\n });\n\n if (values.version) {\n console.log(VERSION);\n process.exit(0);\n }\n\n if (values.help || positionals.length === 0) {\n printUsage();\n process.exit(0);\n }\n\n const inputFile = positionals[0];\n\n if (!existsSync(inputFile)) {\n console.error(`Error: File not found: ${inputFile}`);\n process.exit(1);\n }\n\n if (!checkCapnpTool()) {\n console.error(\"Error: capnp tool not found. Please install Cap'n Proto.\");\n process.exit(1);\n }\n\n const tmpDir = mkdtempSync(join(tmpdir(), 'capnp-gen-'));\n const binFile = join(tmpDir, 'schema.bin');\n\n try {\n // Compile schema to binary format using shell\n const { exec } = await import('node:child_process');\n const { promisify } = await import('node:util');\n const execAsync = promisify(exec);\n\n await execAsync(`capnp compile -o- \"${inputFile}\" > \"${binFile}\"`);\n\n // Read and parse\n const buffer = readFileSync(binFile);\n const request = CodeGeneratorRequestReader.fromBuffer(buffer.buffer);\n\n const opts: GeneratorOptions = {\n runtimeImportPath:\n typeof values.runtimePath === 'string' ? values.runtimePath : '@naeemo/capnp',\n };\n\n const files = generateFromRequest(request, opts);\n\n if (values.outDir) {\n // Multiple files mode\n for (const [filename, content] of files) {\n const outPath = join(values.outDir, filename);\n writeFileSync(outPath, content);\n console.log(`Generated: ${outPath}`);\n }\n } else if (values.output) {\n // Single file mode\n const content = Array.from(files.values()).join('\\n');\n writeFileSync(values.output, content);\n console.log(`Generated: ${values.output}`);\n } else {\n // stdout\n const content = Array.from(files.values()).join('\\n');\n console.log(content);\n }\n } catch (err: any) {\n console.error('Error:', err.message);\n process.exit(1);\n } finally {\n rmSync(tmpDir, { recursive: true, force: true });\n }\n}\n"],"mappings":"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"}
|
package/dist/cli.js
CHANGED
|
@@ -12,6 +12,7 @@ import { parseArgs } from "node:util";
|
|
|
12
12
|
* gen Generate TypeScript code from schema
|
|
13
13
|
* json Convert between Cap'n Proto and JSON
|
|
14
14
|
* compat Check schema compatibility
|
|
15
|
+
* audit Security audit message files
|
|
15
16
|
* help Show help for a command
|
|
16
17
|
*/
|
|
17
18
|
const { values, positionals } = parseArgs({
|
|
@@ -26,9 +27,10 @@ const { values, positionals } = parseArgs({
|
|
|
26
27
|
short: "v"
|
|
27
28
|
}
|
|
28
29
|
},
|
|
29
|
-
allowPositionals: true
|
|
30
|
+
allowPositionals: true,
|
|
31
|
+
strict: false
|
|
30
32
|
});
|
|
31
|
-
const VERSION = "0.9.
|
|
33
|
+
const VERSION = "0.9.1";
|
|
32
34
|
function printMainUsage() {
|
|
33
35
|
console.log(`
|
|
34
36
|
Cap'n Proto TypeScript CLI v${VERSION}
|
|
@@ -39,6 +41,8 @@ Commands:
|
|
|
39
41
|
gen Generate TypeScript code from .capnp schema
|
|
40
42
|
json Convert between Cap'n Proto binary and JSON
|
|
41
43
|
compat Check schema compatibility between versions
|
|
44
|
+
audit Security audit message files
|
|
45
|
+
bench Run performance benchmarks
|
|
42
46
|
|
|
43
47
|
Options:
|
|
44
48
|
-h, --help Show this help
|
|
@@ -48,6 +52,8 @@ Examples:
|
|
|
48
52
|
capnp gen schema.capnp -o types.ts
|
|
49
53
|
capnp json to-json -i data.bin -s schema.json
|
|
50
54
|
capnp compat old.json new.json
|
|
55
|
+
capnp audit message.bin
|
|
56
|
+
capnp bench --sizes 1KB,10KB,100KB --vs-json
|
|
51
57
|
|
|
52
58
|
Run 'capnp <command> --help' for more information on a command.
|
|
53
59
|
`);
|
|
@@ -65,26 +71,38 @@ async function main() {
|
|
|
65
71
|
const args = process.argv.slice(3);
|
|
66
72
|
switch (command) {
|
|
67
73
|
case "gen":
|
|
68
|
-
await import("./cli-gen-
|
|
74
|
+
await import("./cli-gen-aCkffW1Z.js").then((m) => m.run(args));
|
|
69
75
|
break;
|
|
70
76
|
case "json":
|
|
71
|
-
await import("./cli-
|
|
77
|
+
await import("./cli-DGBgLdGK.js").then((m) => m.run(args));
|
|
72
78
|
break;
|
|
73
79
|
case "compat":
|
|
74
|
-
await import("./cli-
|
|
80
|
+
await import("./cli-DlZBZozW.js").then((m) => m.run(args));
|
|
81
|
+
break;
|
|
82
|
+
case "audit":
|
|
83
|
+
await import("./cli-audit-j58Eyd5d.js").then((m) => m.run(args));
|
|
84
|
+
break;
|
|
85
|
+
case "bench":
|
|
86
|
+
await import("./cli-bench-bkR1vGK8.js").then((m) => m.run(args));
|
|
75
87
|
break;
|
|
76
88
|
case "help":
|
|
77
89
|
if (positionals[1]) {
|
|
78
90
|
args.push("--help");
|
|
79
91
|
switch (positionals[1]) {
|
|
80
92
|
case "gen":
|
|
81
|
-
await import("./cli-gen-
|
|
93
|
+
await import("./cli-gen-aCkffW1Z.js").then((m) => m.run(args));
|
|
82
94
|
break;
|
|
83
95
|
case "json":
|
|
84
|
-
await import("./cli-
|
|
96
|
+
await import("./cli-DGBgLdGK.js").then((m) => m.run(args));
|
|
85
97
|
break;
|
|
86
98
|
case "compat":
|
|
87
|
-
await import("./cli-
|
|
99
|
+
await import("./cli-DlZBZozW.js").then((m) => m.run(args));
|
|
100
|
+
break;
|
|
101
|
+
case "audit":
|
|
102
|
+
await import("./cli-audit-j58Eyd5d.js").then((m) => m.run(args));
|
|
103
|
+
break;
|
|
104
|
+
case "bench":
|
|
105
|
+
await import("./cli-bench-bkR1vGK8.js").then((m) => m.run(args));
|
|
88
106
|
break;
|
|
89
107
|
default:
|
|
90
108
|
console.error(`Unknown command: ${positionals[1]}`);
|
package/dist/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.js","names":[],"sources":["../src/cli-unified.ts"],"sourcesContent":["#!/usr/bin/env node\n/**\n * Cap'n Proto Unified CLI\n *\n * Usage: capnp <command> [options]\n *\n * Commands:\n * gen Generate TypeScript code from schema\n * json Convert between Cap'n Proto and JSON\n * compat Check schema compatibility\n * help Show help for a command\n */\n\nimport { parseArgs } from 'node:util';\n\nconst { values, positionals } = parseArgs({\n args: process.argv.slice(2),\n options: {\n help: { type: 'boolean', short: 'h' },\n version: { type: 'boolean', short: 'v' },\n },\n allowPositionals: true,\n});\n\nconst VERSION = '0.9.
|
|
1
|
+
{"version":3,"file":"cli.js","names":[],"sources":["../src/cli-unified.ts"],"sourcesContent":["#!/usr/bin/env node\n/**\n * Cap'n Proto Unified CLI\n *\n * Usage: capnp <command> [options]\n *\n * Commands:\n * gen Generate TypeScript code from schema\n * json Convert between Cap'n Proto and JSON\n * compat Check schema compatibility\n * audit Security audit message files\n * help Show help for a command\n */\n\nimport { parseArgs } from 'node:util';\n\nconst { values, positionals } = parseArgs({\n args: process.argv.slice(2),\n options: {\n help: { type: 'boolean', short: 'h' },\n version: { type: 'boolean', short: 'v' },\n },\n allowPositionals: true,\n strict: false,\n});\n\nconst VERSION = '0.9.1';\n\nfunction printMainUsage() {\n console.log(`\nCap'n Proto TypeScript CLI v${VERSION}\n\nUsage: capnp <command> [options]\n\nCommands:\n gen Generate TypeScript code from .capnp schema\n json Convert between Cap'n Proto binary and JSON\n compat Check schema compatibility between versions\n audit Security audit message files\n bench Run performance benchmarks\n\nOptions:\n -h, --help Show this help\n -v, --version Show version\n\nExamples:\n capnp gen schema.capnp -o types.ts\n capnp json to-json -i data.bin -s schema.json\n capnp compat old.json new.json\n capnp audit message.bin\n capnp bench --sizes 1KB,10KB,100KB --vs-json\n\nRun 'capnp <command> --help' for more information on a command.\n`);\n}\n\nasync function main() {\n if (values.version) {\n console.log(VERSION);\n process.exit(0);\n }\n\n if (values.help || positionals.length === 0) {\n printMainUsage();\n process.exit(0);\n }\n\n const command = positionals[0];\n const args = process.argv.slice(3); // Remove 'capnp' and command\n\n switch (command) {\n case 'gen':\n await import('./cli-gen.js').then((m) => m.run(args));\n break;\n case 'json':\n await import('./json/cli.js').then((m) => m.run(args));\n break;\n case 'compat':\n await import('./compat/cli.js').then((m) => m.run(args));\n break;\n case 'audit':\n await import('./cli-audit.js').then((m) => m.run(args));\n break;\n case 'bench':\n await import('./cli-bench.js').then((m) => m.run(args));\n break;\n case 'help':\n if (positionals[1]) {\n // Show help for specific command\n args.push('--help');\n switch (positionals[1]) {\n case 'gen':\n await import('./cli-gen.js').then((m) => m.run(args));\n break;\n case 'json':\n await import('./json/cli.js').then((m) => m.run(args));\n break;\n case 'compat':\n await import('./compat/cli.js').then((m) => m.run(args));\n break;\n case 'audit':\n await import('./cli-audit.js').then((m) => m.run(args));\n break;\n case 'bench':\n await import('./cli-bench.js').then((m) => m.run(args));\n break;\n default:\n console.error(`Unknown command: ${positionals[1]}`);\n process.exit(1);\n }\n } else {\n printMainUsage();\n }\n break;\n default:\n console.error(`Unknown command: ${command}`);\n printMainUsage();\n process.exit(1);\n }\n}\n\nmain().catch((err) => {\n console.error('Error:', err.message);\n process.exit(1);\n});\n"],"mappings":";;;;;;;;;;;;;;;;AAgBA,MAAM,EAAE,QAAQ,gBAAgB,UAAU;CACxC,MAAM,QAAQ,KAAK,MAAM,EAAE;CAC3B,SAAS;EACP,MAAM;GAAE,MAAM;GAAW,OAAO;GAAK;EACrC,SAAS;GAAE,MAAM;GAAW,OAAO;GAAK;EACzC;CACD,kBAAkB;CAClB,QAAQ;CACT,CAAC;AAEF,MAAM,UAAU;AAEhB,SAAS,iBAAiB;AACxB,SAAQ,IAAI;8BACgB,QAAQ;;;;;;;;;;;;;;;;;;;;;;;EAuBpC;;AAGF,eAAe,OAAO;AACpB,KAAI,OAAO,SAAS;AAClB,UAAQ,IAAI,QAAQ;AACpB,UAAQ,KAAK,EAAE;;AAGjB,KAAI,OAAO,QAAQ,YAAY,WAAW,GAAG;AAC3C,kBAAgB;AAChB,UAAQ,KAAK,EAAE;;CAGjB,MAAM,UAAU,YAAY;CAC5B,MAAM,OAAO,QAAQ,KAAK,MAAM,EAAE;AAElC,SAAQ,SAAR;EACE,KAAK;AACH,SAAM,OAAO,yBAAgB,MAAM,MAAM,EAAE,IAAI,KAAK,CAAC;AACrD;EACF,KAAK;AACH,SAAM,OAAO,qBAAiB,MAAM,MAAM,EAAE,IAAI,KAAK,CAAC;AACtD;EACF,KAAK;AACH,SAAM,OAAO,qBAAmB,MAAM,MAAM,EAAE,IAAI,KAAK,CAAC;AACxD;EACF,KAAK;AACH,SAAM,OAAO,2BAAkB,MAAM,MAAM,EAAE,IAAI,KAAK,CAAC;AACvD;EACF,KAAK;AACH,SAAM,OAAO,2BAAkB,MAAM,MAAM,EAAE,IAAI,KAAK,CAAC;AACvD;EACF,KAAK;AACH,OAAI,YAAY,IAAI;AAElB,SAAK,KAAK,SAAS;AACnB,YAAQ,YAAY,IAApB;KACE,KAAK;AACH,YAAM,OAAO,yBAAgB,MAAM,MAAM,EAAE,IAAI,KAAK,CAAC;AACrD;KACF,KAAK;AACH,YAAM,OAAO,qBAAiB,MAAM,MAAM,EAAE,IAAI,KAAK,CAAC;AACtD;KACF,KAAK;AACH,YAAM,OAAO,qBAAmB,MAAM,MAAM,EAAE,IAAI,KAAK,CAAC;AACxD;KACF,KAAK;AACH,YAAM,OAAO,2BAAkB,MAAM,MAAM,EAAE,IAAI,KAAK,CAAC;AACvD;KACF,KAAK;AACH,YAAM,OAAO,2BAAkB,MAAM,MAAM,EAAE,IAAI,KAAK,CAAC;AACvD;KACF;AACE,cAAQ,MAAM,oBAAoB,YAAY,KAAK;AACnD,cAAQ,KAAK,EAAE;;SAGnB,iBAAgB;AAElB;EACF;AACE,WAAQ,MAAM,oBAAoB,UAAU;AAC5C,mBAAgB;AAChB,WAAQ,KAAK,EAAE;;;AAIrB,MAAM,CAAC,OAAO,QAAQ;AACpB,SAAQ,MAAM,UAAU,IAAI,QAAQ;AACpC,SAAQ,KAAK,EAAE;EACf"}
|