@soda-gql/codegen 0.5.0 → 0.5.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/{generator-4a-rsLCK.cjs → generator-DlTMMIez.cjs} +117 -83
- package/dist/generator-DlTMMIez.cjs.map +1 -0
- package/dist/{generator-D3GwI2ri.cjs → generator-Dr445O16.cjs} +1 -1
- package/dist/generator-LDU9eA31.mjs +3 -0
- package/dist/{generator-DEyKWZwB.mjs → generator-swiNL05K.mjs} +117 -83
- package/dist/generator-swiNL05K.mjs.map +1 -0
- package/dist/index.cjs +2 -2
- package/dist/index.mjs +2 -2
- package/package.json +3 -3
- package/dist/generator-4a-rsLCK.cjs.map +0 -1
- package/dist/generator-CI8NZ_bh.mjs +0 -3
- package/dist/generator-DEyKWZwB.mjs.map +0 -1
|
@@ -319,47 +319,31 @@ const renderInputFields = (schema, fields) => {
|
|
|
319
319
|
indentSize: 6
|
|
320
320
|
});
|
|
321
321
|
};
|
|
322
|
-
const
|
|
322
|
+
const renderScalarVar = (schemaName, record) => {
|
|
323
323
|
const typeInfo = builtinScalarTypes.get(record.name) ?? {
|
|
324
324
|
input: "string",
|
|
325
325
|
output: "string"
|
|
326
326
|
};
|
|
327
|
-
return
|
|
327
|
+
return `const scalar_${schemaName}_${record.name} = { name: "${record.name}", $type: {} as { input: ${typeInfo.input}; output: ${typeInfo.output}; inputProfile: { kind: "scalar"; name: "${record.name}"; value: ${typeInfo.input} }; outputProfile: { kind: "scalar"; name: "${record.name}"; value: ${typeInfo.output} } } } as const;`;
|
|
328
328
|
};
|
|
329
|
-
const
|
|
330
|
-
const record = schema.objects.get(typeName);
|
|
331
|
-
if (!record) {
|
|
332
|
-
return "";
|
|
333
|
-
}
|
|
334
|
-
const fields = renderObjectFields(schema, record.fields);
|
|
335
|
-
return `${record.name}: { name: "${record.name}", fields: ${fields} }`;
|
|
336
|
-
};
|
|
337
|
-
const renderInputDefinition = (schema, typeName) => {
|
|
338
|
-
const record = schema.inputs.get(typeName);
|
|
339
|
-
if (!record) {
|
|
340
|
-
return "";
|
|
341
|
-
}
|
|
342
|
-
const fields = renderInputFields(schema, record.fields);
|
|
343
|
-
return `${record.name}: { name: "${record.name}", fields: ${fields} }`;
|
|
344
|
-
};
|
|
345
|
-
const renderEnumDefinition = (schema, typeName) => {
|
|
346
|
-
const record = schema.enums.get(typeName);
|
|
347
|
-
if (!record) {
|
|
348
|
-
return "";
|
|
349
|
-
}
|
|
329
|
+
const renderEnumVar = (schemaName, record) => {
|
|
350
330
|
const valueNames = Array.from(record.values.values()).sort((left, right) => left.name.value.localeCompare(right.name.value)).map((value) => value.name.value);
|
|
351
331
|
const valuesObj = valueNames.length === 0 ? "{}" : `{ ${valueNames.map((v) => `${v}: true`).join(", ")} }`;
|
|
352
332
|
const valueUnion = valueNames.length === 0 ? "never" : valueNames.map((v) => `"${v}"`).join(" | ");
|
|
353
|
-
return
|
|
333
|
+
return `const enum_${schemaName}_${record.name} = { name: "${record.name}", values: ${valuesObj}, $type: {} as { name: "${record.name}"; inputProfile: { kind: "enum"; name: "${record.name}"; value: ${valueUnion} }; outputProfile: { kind: "enum"; name: "${record.name}"; value: ${valueUnion} } } } as const;`;
|
|
354
334
|
};
|
|
355
|
-
const
|
|
356
|
-
const
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
335
|
+
const renderInputVar = (schemaName, schema, record) => {
|
|
336
|
+
const fields = renderInputFields(schema, record.fields);
|
|
337
|
+
return `const input_${schemaName}_${record.name} = { name: "${record.name}", fields: ${fields} } as const;`;
|
|
338
|
+
};
|
|
339
|
+
const renderObjectVar = (schemaName, schema, record) => {
|
|
340
|
+
const fields = renderObjectFields(schema, record.fields);
|
|
341
|
+
return `const object_${schemaName}_${record.name} = { name: "${record.name}", fields: ${fields} } as const;`;
|
|
342
|
+
};
|
|
343
|
+
const renderUnionVar = (schemaName, record) => {
|
|
360
344
|
const memberNames = Array.from(record.members.values()).sort((left, right) => left.name.value.localeCompare(right.name.value)).map((member) => member.name.value);
|
|
361
345
|
const typesObj = memberNames.length === 0 ? "{}" : `{ ${memberNames.map((m) => `${m}: true`).join(", ")} }`;
|
|
362
|
-
return
|
|
346
|
+
return `const union_${schemaName}_${record.name} = { name: "${record.name}", types: ${typesObj} } as const;`;
|
|
363
347
|
};
|
|
364
348
|
const collectObjectTypeNames = (schema) => Array.from(schema.objects.keys()).filter((name) => !name.startsWith("__")).sort((left, right) => left.localeCompare(right));
|
|
365
349
|
const renderFragmentBuildersType = (objectTypeNames, schemaName, adapterTypeName) => {
|
|
@@ -430,7 +414,6 @@ const multiRuntimeTemplate = ($$) => {
|
|
|
430
414
|
const gqlEntries = [];
|
|
431
415
|
for (const [name, config] of Object.entries($$.schemas)) {
|
|
432
416
|
const schemaVar = `${name}Schema`;
|
|
433
|
-
const scalarBlock = $$.injection.mode === "inject" ? scalarAliases.get(name) : config.scalarBlock;
|
|
434
417
|
const adapterVar = adapterAliases.get(name);
|
|
435
418
|
const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`];
|
|
436
419
|
if (adapterVar) {
|
|
@@ -441,19 +424,55 @@ const multiRuntimeTemplate = ($$) => {
|
|
|
441
424
|
const factoryVar = `createMethod_${name}`;
|
|
442
425
|
const defaultDepthBlock = config.defaultInputDepth !== undefined && config.defaultInputDepth !== 3 ? `\n __defaultInputDepth: ${config.defaultInputDepth},` : "";
|
|
443
426
|
const depthOverridesBlock = config.inputDepthOverrides && Object.keys(config.inputDepthOverrides).length > 0 ? `\n __inputDepthOverrides: ${JSON.stringify(config.inputDepthOverrides)},` : "";
|
|
427
|
+
const scalarVarsBlock = config.scalarVars.join("\n");
|
|
428
|
+
const enumVarsBlock = config.enumVars.length > 0 ? config.enumVars.join("\n") : "// (no enums)";
|
|
429
|
+
const inputVarsBlock = config.inputVars.length > 0 ? config.inputVars.join("\n") : "// (no inputs)";
|
|
430
|
+
const objectVarsBlock = config.objectVars.length > 0 ? config.objectVars.join("\n") : "// (no objects)";
|
|
431
|
+
const unionVarsBlock = config.unionVars.length > 0 ? config.unionVars.join("\n") : "// (no unions)";
|
|
432
|
+
const scalarAssembly = $$.injection.mode === "inject" ? scalarAliases.get(name) ?? "{}" : config.scalarNames.length > 0 ? `{ ${config.scalarNames.map((n) => `${n}: scalar_${name}_${n}`).join(", ")} }` : "{}";
|
|
433
|
+
const enumAssembly = config.enumNames.length > 0 ? `{ ${config.enumNames.map((n) => `${n}: enum_${name}_${n}`).join(", ")} }` : "{}";
|
|
434
|
+
const inputAssembly = config.inputNames.length > 0 ? `{ ${config.inputNames.map((n) => `${n}: input_${name}_${n}`).join(", ")} }` : "{}";
|
|
435
|
+
const objectAssembly = config.objectNames.length > 0 ? `{ ${config.objectNames.map((n) => `${n}: object_${name}_${n}`).join(", ")} }` : "{}";
|
|
436
|
+
const unionAssembly = config.unionNames.length > 0 ? `{ ${config.unionNames.map((n) => `${n}: union_${name}_${n}`).join(", ")} }` : "{}";
|
|
437
|
+
const scalarVarsSection = $$.injection.mode === "inject" ? "// (scalars imported)" : scalarVarsBlock;
|
|
438
|
+
const scalarAssemblyLine = $$.injection.mode === "inject" ? `// scalar_${name} is imported directly` : `const scalar_${name} = ${scalarAssembly} as const;`;
|
|
439
|
+
const scalarRef = $$.injection.mode === "inject" ? scalarAliases.get(name) ?? `scalar_${name}` : `scalar_${name}`;
|
|
444
440
|
schemaBlocks.push(`
|
|
441
|
+
// Individual scalar definitions
|
|
442
|
+
${scalarVarsSection}
|
|
443
|
+
|
|
444
|
+
// Individual enum definitions
|
|
445
|
+
${enumVarsBlock}
|
|
446
|
+
|
|
447
|
+
// Individual input definitions
|
|
448
|
+
${inputVarsBlock}
|
|
449
|
+
|
|
450
|
+
// Individual object definitions
|
|
451
|
+
${objectVarsBlock}
|
|
452
|
+
|
|
453
|
+
// Individual union definitions
|
|
454
|
+
${unionVarsBlock}
|
|
455
|
+
|
|
456
|
+
// Category assembly
|
|
457
|
+
${scalarAssemblyLine}
|
|
458
|
+
const enum_${name} = ${enumAssembly} as const;
|
|
459
|
+
const input_${name} = ${inputAssembly} as const;
|
|
460
|
+
const object_${name} = ${objectAssembly} as const;
|
|
461
|
+
const union_${name} = ${unionAssembly} as const;
|
|
462
|
+
|
|
463
|
+
// Schema assembly
|
|
445
464
|
const ${schemaVar} = {
|
|
446
|
-
label: "${name}",
|
|
447
|
-
operations: { query: "${config.queryType}", mutation: "${config.mutationType}", subscription: "${config.subscriptionType}" },
|
|
448
|
-
scalar: ${
|
|
449
|
-
enum: ${
|
|
450
|
-
input: ${
|
|
451
|
-
object: ${
|
|
452
|
-
union: ${
|
|
465
|
+
label: "${name}" as const,
|
|
466
|
+
operations: { query: "${config.queryType}", mutation: "${config.mutationType}", subscription: "${config.subscriptionType}" } as const,
|
|
467
|
+
scalar: ${scalarRef},
|
|
468
|
+
enum: enum_${name},
|
|
469
|
+
input: input_${name},
|
|
470
|
+
object: object_${name},
|
|
471
|
+
union: union_${name},${defaultDepthBlock}${depthOverridesBlock}
|
|
453
472
|
} as const;
|
|
454
473
|
|
|
455
474
|
const ${factoryVar} = createVarMethodFactory<typeof ${schemaVar}>();
|
|
456
|
-
const ${inputTypeMethodsVar} = ${config.inputTypeMethodsBlock}
|
|
475
|
+
const ${inputTypeMethodsVar} = ${config.inputTypeMethodsBlock};
|
|
457
476
|
|
|
458
477
|
${typeExports.join("\n")}`);
|
|
459
478
|
if (adapterVar) {
|
|
@@ -468,7 +487,6 @@ ${typeExports.join("\n")}`);
|
|
|
468
487
|
import {
|
|
469
488
|
type ExtractMetadataAdapter,
|
|
470
489
|
type FragmentBuilderFor,
|
|
471
|
-
type InputTypeMethods,
|
|
472
490
|
createGqlElementComposer,
|
|
473
491
|
createVarMethodFactory,
|
|
474
492
|
} from "@soda-gql/core";
|
|
@@ -490,43 +508,54 @@ const generateMultiSchemaModule = (schemas, options) => {
|
|
|
490
508
|
};
|
|
491
509
|
for (const [name, document] of schemas.entries()) {
|
|
492
510
|
const schema = createSchemaIndex(document);
|
|
493
|
-
const builtinScalarDefinitions = Array.from(builtinScalarTypes.keys()).map((name$1) => renderScalarDefinition(schema.scalars.get(name$1) ?? {
|
|
494
|
-
name: name$1,
|
|
495
|
-
directives: []
|
|
496
|
-
}));
|
|
497
|
-
const customScalarDefinitions = collectScalarNames(schema).filter((name$1) => !builtinScalarTypes.has(name$1)).map((name$1) => {
|
|
498
|
-
const record = schema.scalars.get(name$1);
|
|
499
|
-
return record ? renderScalarDefinition(record) : "";
|
|
500
|
-
}).filter((definition) => definition.length > 0);
|
|
501
|
-
const allScalarDefinitions = builtinScalarDefinitions.concat(customScalarDefinitions);
|
|
502
511
|
const objectTypeNames = collectObjectTypeNames(schema);
|
|
503
512
|
const enumTypeNames = collectEnumTypeNames(schema);
|
|
504
513
|
const inputTypeNames = collectInputTypeNames(schema);
|
|
505
514
|
const unionTypeNames = collectUnionTypeNames(schema);
|
|
506
|
-
const
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
const
|
|
511
|
-
const
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
}
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
515
|
+
const customScalarNames = collectScalarNames(schema).filter((n) => !builtinScalarTypes.has(n));
|
|
516
|
+
const scalarVars = [];
|
|
517
|
+
const enumVars = [];
|
|
518
|
+
const inputVars = [];
|
|
519
|
+
const objectVars = [];
|
|
520
|
+
const unionVars = [];
|
|
521
|
+
for (const scalarName of builtinScalarTypes.keys()) {
|
|
522
|
+
const record = schema.scalars.get(scalarName) ?? {
|
|
523
|
+
name: scalarName,
|
|
524
|
+
directives: []
|
|
525
|
+
};
|
|
526
|
+
scalarVars.push(renderScalarVar(name, record));
|
|
527
|
+
}
|
|
528
|
+
for (const scalarName of customScalarNames) {
|
|
529
|
+
const record = schema.scalars.get(scalarName);
|
|
530
|
+
if (record) {
|
|
531
|
+
scalarVars.push(renderScalarVar(name, record));
|
|
532
|
+
}
|
|
533
|
+
}
|
|
534
|
+
for (const enumName of enumTypeNames) {
|
|
535
|
+
const record = schema.enums.get(enumName);
|
|
536
|
+
if (record) {
|
|
537
|
+
enumVars.push(renderEnumVar(name, record));
|
|
538
|
+
}
|
|
539
|
+
}
|
|
540
|
+
for (const inputName of inputTypeNames) {
|
|
541
|
+
const record = schema.inputs.get(inputName);
|
|
542
|
+
if (record) {
|
|
543
|
+
inputVars.push(renderInputVar(name, schema, record));
|
|
544
|
+
}
|
|
545
|
+
}
|
|
546
|
+
for (const objectName of objectTypeNames) {
|
|
547
|
+
const record = schema.objects.get(objectName);
|
|
548
|
+
if (record) {
|
|
549
|
+
objectVars.push(renderObjectVar(name, schema, record));
|
|
550
|
+
}
|
|
551
|
+
}
|
|
552
|
+
for (const unionName of unionTypeNames) {
|
|
553
|
+
const record = schema.unions.get(unionName);
|
|
554
|
+
if (record) {
|
|
555
|
+
unionVars.push(renderUnionVar(name, record));
|
|
556
|
+
}
|
|
557
|
+
}
|
|
558
|
+
const allScalarNames = [...builtinScalarTypes.keys(), ...customScalarNames];
|
|
530
559
|
const factoryVar = `createMethod_${name}`;
|
|
531
560
|
const inputTypeMethodsBlock = renderInputTypeMethods(schema, factoryVar);
|
|
532
561
|
const adapterTypeName = options?.injection?.get(name)?.adapterImportPath ? `Adapter_${name}` : undefined;
|
|
@@ -538,20 +567,25 @@ const generateMultiSchemaModule = (schemas, options) => {
|
|
|
538
567
|
queryType,
|
|
539
568
|
mutationType,
|
|
540
569
|
subscriptionType,
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
570
|
+
scalarVars,
|
|
571
|
+
enumVars,
|
|
572
|
+
inputVars,
|
|
573
|
+
objectVars,
|
|
574
|
+
unionVars,
|
|
575
|
+
scalarNames: allScalarNames,
|
|
576
|
+
enumNames: enumTypeNames,
|
|
577
|
+
inputNames: inputTypeNames,
|
|
578
|
+
objectNames: objectTypeNames,
|
|
579
|
+
unionNames: unionTypeNames,
|
|
546
580
|
inputTypeMethodsBlock,
|
|
547
581
|
fragmentBuildersTypeBlock,
|
|
548
582
|
defaultInputDepth: options?.defaultInputDepth?.get(name),
|
|
549
583
|
inputDepthOverrides: options?.inputDepthOverrides?.get(name)
|
|
550
584
|
};
|
|
551
|
-
allStats.objects +=
|
|
552
|
-
allStats.enums +=
|
|
553
|
-
allStats.inputs +=
|
|
554
|
-
allStats.unions +=
|
|
585
|
+
allStats.objects += objectVars.length;
|
|
586
|
+
allStats.enums += enumVars.length;
|
|
587
|
+
allStats.inputs += inputVars.length;
|
|
588
|
+
allStats.unions += unionVars.length;
|
|
555
589
|
}
|
|
556
590
|
const injection = options?.injection ? {
|
|
557
591
|
mode: "inject",
|
|
@@ -580,4 +614,4 @@ Object.defineProperty(exports, 'generateMultiSchemaModule', {
|
|
|
580
614
|
return generateMultiSchemaModule;
|
|
581
615
|
}
|
|
582
616
|
});
|
|
583
|
-
//# sourceMappingURL=generator-
|
|
617
|
+
//# sourceMappingURL=generator-DlTMMIez.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generator-DlTMMIez.cjs","names":["operationTypes: OperationTypeNames","Kind","kind: \"scalar\" | \"enum\" | \"input\"","kind: \"scalar\" | \"enum\" | \"union\" | \"object\"","imports: string[]","schemaBlocks: string[]","gqlEntries: string[]","schemaConfigs: Record<string, any>","scalarVars: string[]","enumVars: string[]","inputVars: string[]","objectVars: string[]","unionVars: string[]","injection: RuntimeTemplateInjection"],"sources":["../src/generator.ts"],"sourcesContent":["import {\n type ConstDirectiveNode,\n type ConstValueNode,\n type DocumentNode,\n type EnumValueDefinitionNode,\n type FieldDefinitionNode,\n type InputValueDefinitionNode,\n Kind,\n type NamedTypeNode,\n type SchemaDefinitionNode,\n type SchemaExtensionNode,\n type TypeNode,\n} from \"graphql\";\n\nconst builtinScalarTypes = new Map<string, { readonly input: string; readonly output: string }>([\n [\"ID\", { input: \"string\", output: \"string\" }],\n [\"String\", { input: \"string\", output: \"string\" }],\n [\"Int\", { input: \"number\", output: \"number\" }],\n [\"Float\", { input: \"number\", output: \"number\" }],\n [\"Boolean\", { input: \"boolean\", output: \"boolean\" }],\n]);\n\ntype OperationTypeNames = {\n query?: string;\n mutation?: string;\n subscription?: string;\n};\n\ntype ObjectRecord = {\n readonly name: string;\n readonly fields: Map<string, FieldDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype InputRecord = {\n readonly name: string;\n readonly fields: Map<string, InputValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype EnumRecord = {\n readonly name: string;\n readonly values: Map<string, EnumValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype UnionRecord = {\n readonly name: string;\n readonly members: Map<string, NamedTypeNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype ScalarRecord = {\n readonly name: string;\n directives: ConstDirectiveNode[];\n};\n\ntype SchemaIndex = {\n readonly objects: Map<string, ObjectRecord>;\n readonly inputs: Map<string, InputRecord>;\n readonly enums: Map<string, EnumRecord>;\n readonly unions: Map<string, UnionRecord>;\n readonly scalars: Map<string, ScalarRecord>;\n readonly operationTypes: OperationTypeNames;\n};\n\nconst ensureRecord = <T>(collection: Map<string, T>, key: string, factory: (name: string) => T): T => {\n const existing = collection.get(key);\n if (existing) {\n return existing;\n }\n\n const created = factory(key);\n collection.set(key, created);\n return created;\n};\n\nconst addObjectFields = (target: Map<string, FieldDefinitionNode>, fields: readonly FieldDefinitionNode[] | undefined): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addInputFields = (\n target: Map<string, InputValueDefinitionNode>,\n fields: readonly InputValueDefinitionNode[] | undefined,\n): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addEnumValues = (\n target: Map<string, EnumValueDefinitionNode>,\n values: readonly EnumValueDefinitionNode[] | undefined,\n): void => {\n if (!values) {\n return;\n }\n\n for (const value of values) {\n target.set(value.name.value, value);\n }\n};\n\nconst addUnionMembers = (target: Map<string, NamedTypeNode>, members: readonly NamedTypeNode[] | undefined): void => {\n if (!members) {\n return;\n }\n\n for (const member of members) {\n target.set(member.name.value, member);\n }\n};\n\nconst mergeDirectives = (\n existing: ConstDirectiveNode[] | undefined,\n incoming: readonly ConstDirectiveNode[] | undefined,\n precedence: \"definition\" | \"extension\",\n): ConstDirectiveNode[] => {\n const current = existing ?? [];\n const next = incoming ? Array.from(incoming) : [];\n return precedence === \"definition\" ? [...next, ...current] : [...current, ...next];\n};\n\nconst updateOperationTypes = (\n operationTypes: OperationTypeNames,\n definition: SchemaDefinitionNode | SchemaExtensionNode,\n): void => {\n for (const operation of definition.operationTypes ?? []) {\n const typeName = operation.type.name.value;\n switch (operation.operation) {\n case \"query\":\n operationTypes.query = typeName;\n break;\n case \"mutation\":\n operationTypes.mutation = typeName;\n break;\n case \"subscription\":\n operationTypes.subscription = typeName;\n break;\n default:\n break;\n }\n }\n};\n\nexport const createSchemaIndex = (document: DocumentNode): SchemaIndex => {\n const objects = new Map<string, ObjectRecord>();\n const inputs = new Map<string, InputRecord>();\n const enums = new Map<string, EnumRecord>();\n const unions = new Map<string, UnionRecord>();\n const scalars = new Map<string, ScalarRecord>();\n const operationTypes: OperationTypeNames = {};\n\n for (const definition of document.definitions) {\n switch (definition.kind) {\n case Kind.OBJECT_TYPE_DEFINITION:\n case Kind.OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(objects, definition.name.value, (name) => ({\n name,\n fields: new Map<string, FieldDefinitionNode>(),\n directives: [],\n }));\n addObjectFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.INPUT_OBJECT_TYPE_DEFINITION:\n case Kind.INPUT_OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.INPUT_OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(inputs, definition.name.value, (name) => ({\n name,\n fields: new Map<string, InputValueDefinitionNode>(),\n directives: [],\n }));\n addInputFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.ENUM_TYPE_DEFINITION:\n case Kind.ENUM_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.ENUM_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(enums, definition.name.value, (name) => ({\n name,\n values: new Map<string, EnumValueDefinitionNode>(),\n directives: [],\n }));\n addEnumValues(record.values, definition.values);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.UNION_TYPE_DEFINITION:\n case Kind.UNION_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.UNION_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(unions, definition.name.value, (name) => ({\n name,\n members: new Map<string, NamedTypeNode>(),\n directives: [],\n }));\n addUnionMembers(record.members, definition.types);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCALAR_TYPE_DEFINITION:\n case Kind.SCALAR_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.SCALAR_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(scalars, definition.name.value, (name) => ({\n name,\n directives: [],\n }));\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCHEMA_DEFINITION:\n case Kind.SCHEMA_EXTENSION:\n updateOperationTypes(operationTypes, definition);\n break;\n default:\n break;\n }\n }\n\n if (!operationTypes.query && objects.has(\"Query\")) {\n operationTypes.query = \"Query\";\n }\n if (!operationTypes.mutation && objects.has(\"Mutation\")) {\n operationTypes.mutation = \"Mutation\";\n }\n if (!operationTypes.subscription && objects.has(\"Subscription\")) {\n operationTypes.subscription = \"Subscription\";\n }\n\n return {\n objects,\n inputs,\n enums,\n unions,\n scalars,\n operationTypes,\n } satisfies SchemaIndex;\n};\n\ntype TypeLevel = {\n readonly kind: \"list\" | \"named\";\n readonly nonNull: boolean;\n};\n\nconst collectTypeLevels = (\n type: TypeNode,\n nonNull = false,\n levels: TypeLevel[] = [],\n): { readonly name: string; readonly levels: TypeLevel[] } => {\n if (type.kind === Kind.NON_NULL_TYPE) {\n return collectTypeLevels(type.type, true, levels);\n }\n\n if (type.kind === Kind.LIST_TYPE) {\n levels.push({ kind: \"list\", nonNull });\n return collectTypeLevels(type.type, false, levels);\n }\n\n levels.push({ kind: \"named\", nonNull });\n return { name: type.name.value, levels };\n};\n\nconst buildTypeModifier = (levels: TypeLevel[]): string => {\n let modifier = \"?\";\n\n for (const level of levels.slice().reverse()) {\n if (level.kind === \"named\") {\n // Inner type: always explicit nullable marker\n modifier = level.nonNull ? \"!\" : \"?\";\n continue;\n }\n\n // List type: append []? or []! based on list's nullability\n const listSuffix = level.nonNull ? \"[]!\" : \"[]?\";\n modifier = `${modifier}${listSuffix}`;\n }\n\n return modifier;\n};\n\nconst parseTypeReference = (type: TypeNode): { readonly name: string; readonly modifier: string } => {\n const { name, levels } = collectTypeLevels(type);\n return { name, modifier: buildTypeModifier(levels) };\n};\n\nconst isScalarName = (schema: SchemaIndex, name: string): boolean => builtinScalarTypes.has(name) || schema.scalars.has(name);\nconst isEnumName = (schema: SchemaIndex, name: string): boolean => schema.enums.has(name);\nconst _isInputName = (schema: SchemaIndex, name: string): boolean => schema.inputs.has(name);\nconst isUnionName = (schema: SchemaIndex, name: string): boolean => schema.unions.has(name);\nconst isObjectName = (schema: SchemaIndex, name: string): boolean => schema.objects.has(name);\n\nconst renderConstValue = (value: ConstValueNode): string => {\n switch (value.kind) {\n case Kind.NULL:\n return \"null\";\n case Kind.INT:\n case Kind.FLOAT:\n return value.value;\n case Kind.STRING:\n case Kind.ENUM:\n return JSON.stringify(value.value);\n case Kind.BOOLEAN:\n return value.value ? \"true\" : \"false\";\n case Kind.LIST:\n return `[${value.values.map((item) => renderConstValue(item)).join(\", \")}]`;\n case Kind.OBJECT: {\n if (value.fields.length === 0) {\n return \"{}\";\n }\n const entries = value.fields.map((field) => `${field.name.value}: ${renderConstValue(field.value)}`);\n return `{ ${entries.join(\", \")} }`;\n }\n }\n};\n\nconst renderConstArgumentMap = (\n args: readonly { readonly name: { readonly value: string }; readonly value: ConstValueNode }[] | undefined,\n): string => {\n const entries = (args ?? []).map((arg) => `${arg.name.value}: ${renderConstValue(arg.value)}`);\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDirectives = (directives: readonly ConstDirectiveNode[] | undefined): string => {\n const entries = (directives ?? []).map(\n (directive) => `${directive.name.value}: ${renderConstArgumentMap(directive.arguments)}`,\n );\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDefaultValue = (value: ConstValueNode | null | undefined): string =>\n value ? `() => (${renderConstValue(value)})` : \"null\";\n\nconst renderInputRef = (schema: SchemaIndex, definition: InputValueDefinitionNode): string => {\n const { name, modifier } = parseTypeReference(definition.type);\n const defaultValue = renderDefaultValue(definition.defaultValue ?? null);\n const directives = renderDirectives(definition.directives);\n\n let kind: \"scalar\" | \"enum\" | \"input\";\n if (isScalarName(schema, name)) {\n kind = \"scalar\";\n } else if (isEnumName(schema, name)) {\n kind = \"enum\";\n } else {\n kind = \"input\";\n }\n\n return `{ kind: \"${kind}\", name: \"${name}\", modifier: \"${modifier}\", defaultValue: ${defaultValue}, directives: ${directives} }`;\n};\n\nconst renderArgumentMap = (schema: SchemaIndex, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const entries = [...(args ?? [])]\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((arg) => `${arg.name.value}: ${renderInputRef(schema, arg)}`);\n\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderOutputRef = (schema: SchemaIndex, type: TypeNode, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const { name, modifier } = parseTypeReference(type);\n const argumentMap = renderArgumentMap(schema, args);\n\n let kind: \"scalar\" | \"enum\" | \"union\" | \"object\";\n if (isScalarName(schema, name)) {\n kind = \"scalar\";\n } else if (isEnumName(schema, name)) {\n kind = \"enum\";\n } else if (isUnionName(schema, name)) {\n kind = \"union\";\n } else if (isObjectName(schema, name)) {\n kind = \"object\";\n } else {\n kind = \"scalar\"; // fallback for unknown types\n }\n\n return `{ kind: \"${kind}\", name: \"${name}\", modifier: \"${modifier}\", arguments: ${argumentMap} }`;\n};\n\nconst renderPropertyLines = ({ entries, indentSize }: { entries: string[]; indentSize: number }) => {\n if (entries.length === 0) {\n return \"{}\";\n }\n\n const indent = \" \".repeat(indentSize);\n const lastIndent = \" \".repeat(indentSize - 2);\n return [\"{\", `${indent}${entries.join(`,\\n${indent}`)},`, `${lastIndent}}`].join(`\\n`);\n};\n\nconst renderObjectFields = (schema: SchemaIndex, fields: Map<string, FieldDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderOutputRef(schema, field.type, field.arguments)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\nconst renderInputFields = (schema: SchemaIndex, fields: Map<string, InputValueDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderInputRef(schema, field)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\n// Granular render functions - each type as its own const variable\nconst renderScalarVar = (schemaName: string, record: ScalarRecord): string => {\n const typeInfo = builtinScalarTypes.get(record.name) ?? { input: \"string\", output: \"string\" };\n return `const scalar_${schemaName}_${record.name} = { name: \"${record.name}\", $type: {} as { input: ${typeInfo.input}; output: ${typeInfo.output}; inputProfile: { kind: \"scalar\"; name: \"${record.name}\"; value: ${typeInfo.input} }; outputProfile: { kind: \"scalar\"; name: \"${record.name}\"; value: ${typeInfo.output} } } } as const;`;\n};\n\nconst renderEnumVar = (schemaName: string, record: EnumRecord): string => {\n const valueNames = Array.from(record.values.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((value) => value.name.value);\n const valuesObj = valueNames.length === 0 ? \"{}\" : `{ ${valueNames.map((v) => `${v}: true`).join(\", \")} }`;\n const valueUnion = valueNames.length === 0 ? \"never\" : valueNames.map((v) => `\"${v}\"`).join(\" | \");\n return `const enum_${schemaName}_${record.name} = { name: \"${record.name}\", values: ${valuesObj}, $type: {} as { name: \"${record.name}\"; inputProfile: { kind: \"enum\"; name: \"${record.name}\"; value: ${valueUnion} }; outputProfile: { kind: \"enum\"; name: \"${record.name}\"; value: ${valueUnion} } } } as const;`;\n};\n\nconst renderInputVar = (schemaName: string, schema: SchemaIndex, record: InputRecord): string => {\n const fields = renderInputFields(schema, record.fields);\n return `const input_${schemaName}_${record.name} = { name: \"${record.name}\", fields: ${fields} } as const;`;\n};\n\nconst renderObjectVar = (schemaName: string, schema: SchemaIndex, record: ObjectRecord): string => {\n const fields = renderObjectFields(schema, record.fields);\n return `const object_${schemaName}_${record.name} = { name: \"${record.name}\", fields: ${fields} } as const;`;\n};\n\nconst renderUnionVar = (schemaName: string, record: UnionRecord): string => {\n const memberNames = Array.from(record.members.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((member) => member.name.value);\n const typesObj = memberNames.length === 0 ? \"{}\" : `{ ${memberNames.map((m) => `${m}: true`).join(\", \")} }`;\n return `const union_${schemaName}_${record.name} = { name: \"${record.name}\", types: ${typesObj} } as const;`;\n};\n\nconst collectObjectTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.objects.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst renderFragmentBuildersType = (objectTypeNames: string[], schemaName: string, adapterTypeName?: string): string => {\n if (objectTypeNames.length === 0) {\n return `type FragmentBuilders_${schemaName} = Record<string, never>;`;\n }\n\n const adapterPart = adapterTypeName ? `, ExtractMetadataAdapter<${adapterTypeName}>` : \"\";\n const entries = objectTypeNames.map(\n (name) => ` readonly ${name}: FragmentBuilderFor<Schema_${schemaName}, \"${name}\"${adapterPart}>`,\n );\n return `type FragmentBuilders_${schemaName} = {\\n${entries.join(\";\\n\")};\\n};`;\n};\n\nconst collectInputTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.inputs.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectEnumTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.enums.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectUnionTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.unions.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectScalarNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.scalars.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst renderInputTypeMethod = (factoryVar: string, kind: \"scalar\" | \"enum\" | \"input\", typeName: string): string =>\n `${typeName}: ${factoryVar}(\"${kind}\", \"${typeName}\")`;\n\nconst renderInputTypeMethods = (schema: SchemaIndex, factoryVar: string): string => {\n const scalarMethods = Array.from(builtinScalarTypes.keys())\n .concat(collectScalarNames(schema).filter((name) => !builtinScalarTypes.has(name)))\n .map((name) => renderInputTypeMethod(factoryVar, \"scalar\", name));\n\n const enumMethods = collectEnumTypeNames(schema).map((name) => renderInputTypeMethod(factoryVar, \"enum\", name));\n\n const inputMethods = collectInputTypeNames(schema).map((name) => renderInputTypeMethod(factoryVar, \"input\", name));\n\n const allMethods = [...scalarMethods, ...enumMethods, ...inputMethods].sort((left, right) => {\n const leftName = left.split(\":\")[0] ?? \"\";\n const rightName = right.split(\":\")[0] ?? \"\";\n return leftName.localeCompare(rightName);\n });\n\n return renderPropertyLines({ entries: allMethods, indentSize: 2 });\n};\n\nexport type GeneratedModule = {\n readonly code: string;\n readonly stats: {\n readonly objects: number;\n readonly enums: number;\n readonly inputs: number;\n readonly unions: number;\n };\n};\n\ntype PerSchemaInjection = {\n readonly scalarImportPath: string;\n readonly adapterImportPath?: string;\n};\n\ntype RuntimeTemplateInjection =\n | { readonly mode: \"inline\" }\n | {\n readonly mode: \"inject\";\n readonly perSchema: Map<string, PerSchemaInjection>;\n };\n\nexport type RuntimeGenerationOptions = {\n readonly injection?: Map<string, PerSchemaInjection>;\n readonly defaultInputDepth?: Map<string, number>;\n readonly inputDepthOverrides?: Map<string, Readonly<Record<string, number>>>;\n};\n\ntype MultiRuntimeTemplateOptions = {\n readonly schemas: Record<\n string,\n {\n readonly queryType: string;\n readonly mutationType: string;\n readonly subscriptionType: string;\n // Granular: individual variable declarations\n readonly scalarVars: string[];\n readonly enumVars: string[];\n readonly inputVars: string[];\n readonly objectVars: string[];\n readonly unionVars: string[];\n // Granular: type name lists for assembly\n readonly scalarNames: string[];\n readonly enumNames: string[];\n readonly inputNames: string[];\n readonly objectNames: string[];\n readonly unionNames: string[];\n readonly inputTypeMethodsBlock: string;\n readonly fragmentBuildersTypeBlock: string;\n readonly defaultInputDepth?: number;\n readonly inputDepthOverrides?: Readonly<Record<string, number>>;\n }\n >;\n readonly injection: RuntimeTemplateInjection;\n};\n\nconst multiRuntimeTemplate = ($$: MultiRuntimeTemplateOptions) => {\n // Build imports based on injection mode\n const imports: string[] = [];\n const scalarAliases = new Map<string, string>();\n const adapterAliases = new Map<string, string>();\n\n if ($$.injection.mode === \"inject\") {\n // Group imports by file path\n const importsByPath = new Map<string, string[]>();\n\n for (const [schemaName, injection] of $$.injection.perSchema) {\n const scalarAlias = `scalar_${schemaName}`;\n scalarAliases.set(schemaName, scalarAlias);\n\n // Group scalar import\n const scalarSpecifiers = importsByPath.get(injection.scalarImportPath) ?? [];\n if (!importsByPath.has(injection.scalarImportPath)) {\n importsByPath.set(injection.scalarImportPath, scalarSpecifiers);\n }\n scalarSpecifiers.push(`scalar as ${scalarAlias}`);\n\n // Group adapter import (optional)\n if (injection.adapterImportPath) {\n const adapterAlias = `adapter_${schemaName}`;\n adapterAliases.set(schemaName, adapterAlias);\n const adapterSpecifiers = importsByPath.get(injection.adapterImportPath) ?? [];\n if (!importsByPath.has(injection.adapterImportPath)) {\n importsByPath.set(injection.adapterImportPath, adapterSpecifiers);\n }\n adapterSpecifiers.push(`adapter as ${adapterAlias}`);\n }\n }\n\n // Generate grouped imports\n for (const [path, specifiers] of importsByPath) {\n if (specifiers.length === 1) {\n imports.push(`import { ${specifiers[0]} } from \"${path}\";`);\n } else {\n imports.push(`import {\\n ${specifiers.join(\",\\n \")},\\n} from \"${path}\";`);\n }\n }\n }\n\n const extraImports = imports.length > 0 ? `${imports.join(\"\\n\")}\\n` : \"\";\n\n // Generate per-schema definitions (granular pattern)\n const schemaBlocks: string[] = [];\n const gqlEntries: string[] = [];\n\n for (const [name, config] of Object.entries($$.schemas)) {\n const schemaVar = `${name}Schema`;\n\n // Get optional adapter\n const adapterVar = adapterAliases.get(name);\n\n // Build type exports with fragment builders type\n const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`];\n if (adapterVar) {\n typeExports.push(`export type Adapter_${name} = typeof ${adapterVar} & { _?: never };`);\n }\n typeExports.push(config.fragmentBuildersTypeBlock);\n\n const inputTypeMethodsVar = `inputTypeMethods_${name}`;\n const factoryVar = `createMethod_${name}`;\n\n // Generate __defaultInputDepth block if non-default value\n const defaultDepthBlock =\n config.defaultInputDepth !== undefined && config.defaultInputDepth !== 3\n ? `\\n __defaultInputDepth: ${config.defaultInputDepth},`\n : \"\";\n\n // Generate __inputDepthOverrides block if there are overrides\n const depthOverridesBlock =\n config.inputDepthOverrides && Object.keys(config.inputDepthOverrides).length > 0\n ? `\\n __inputDepthOverrides: ${JSON.stringify(config.inputDepthOverrides)},`\n : \"\";\n\n // Granular: generate individual variable declarations\n const scalarVarsBlock = config.scalarVars.join(\"\\n\");\n const enumVarsBlock = config.enumVars.length > 0 ? config.enumVars.join(\"\\n\") : \"// (no enums)\";\n const inputVarsBlock = config.inputVars.length > 0 ? config.inputVars.join(\"\\n\") : \"// (no inputs)\";\n const objectVarsBlock = config.objectVars.length > 0 ? config.objectVars.join(\"\\n\") : \"// (no objects)\";\n const unionVarsBlock = config.unionVars.length > 0 ? config.unionVars.join(\"\\n\") : \"// (no unions)\";\n\n // Granular: generate assembly references\n // For injection mode, use imported scalar object; otherwise assemble from individual vars\n const scalarAssembly =\n $$.injection.mode === \"inject\"\n ? (scalarAliases.get(name) ?? \"{}\")\n : config.scalarNames.length > 0\n ? `{ ${config.scalarNames.map((n) => `${n}: scalar_${name}_${n}`).join(\", \")} }`\n : \"{}\";\n const enumAssembly =\n config.enumNames.length > 0 ? `{ ${config.enumNames.map((n) => `${n}: enum_${name}_${n}`).join(\", \")} }` : \"{}\";\n const inputAssembly =\n config.inputNames.length > 0 ? `{ ${config.inputNames.map((n) => `${n}: input_${name}_${n}`).join(\", \")} }` : \"{}\";\n const objectAssembly =\n config.objectNames.length > 0 ? `{ ${config.objectNames.map((n) => `${n}: object_${name}_${n}`).join(\", \")} }` : \"{}\";\n const unionAssembly =\n config.unionNames.length > 0 ? `{ ${config.unionNames.map((n) => `${n}: union_${name}_${n}`).join(\", \")} }` : \"{}\";\n\n // Granular: skip individual scalar vars when using injection (scalars come from import)\n const scalarVarsSection = $$.injection.mode === \"inject\" ? \"// (scalars imported)\" : scalarVarsBlock;\n\n // When injecting scalars, use the imported alias directly; otherwise use the assembled category object\n const scalarAssemblyLine =\n $$.injection.mode === \"inject\"\n ? `// scalar_${name} is imported directly`\n : `const scalar_${name} = ${scalarAssembly} as const;`;\n const scalarRef = $$.injection.mode === \"inject\" ? (scalarAliases.get(name) ?? `scalar_${name}`) : `scalar_${name}`;\n\n schemaBlocks.push(`\n// Individual scalar definitions\n${scalarVarsSection}\n\n// Individual enum definitions\n${enumVarsBlock}\n\n// Individual input definitions\n${inputVarsBlock}\n\n// Individual object definitions\n${objectVarsBlock}\n\n// Individual union definitions\n${unionVarsBlock}\n\n// Category assembly\n${scalarAssemblyLine}\nconst enum_${name} = ${enumAssembly} as const;\nconst input_${name} = ${inputAssembly} as const;\nconst object_${name} = ${objectAssembly} as const;\nconst union_${name} = ${unionAssembly} as const;\n\n// Schema assembly\nconst ${schemaVar} = {\n label: \"${name}\" as const,\n operations: { query: \"${config.queryType}\", mutation: \"${config.mutationType}\", subscription: \"${config.subscriptionType}\" } as const,\n scalar: ${scalarRef},\n enum: enum_${name},\n input: input_${name},\n object: object_${name},\n union: union_${name},${defaultDepthBlock}${depthOverridesBlock}\n} as const;\n\nconst ${factoryVar} = createVarMethodFactory<typeof ${schemaVar}>();\nconst ${inputTypeMethodsVar} = ${config.inputTypeMethodsBlock};\n\n${typeExports.join(\"\\n\")}`);\n\n // Build gql entry with options - inputTypeMethods is always required\n // Include FragmentBuilders type for codegen optimization\n if (adapterVar) {\n const typeParams = `<Schema_${name}, FragmentBuilders_${name}, Adapter_${name}>`;\n gqlEntries.push(\n ` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { adapter: ${adapterVar}, inputTypeMethods: ${inputTypeMethodsVar} })`,\n );\n } else {\n const typeParams = `<Schema_${name}, FragmentBuilders_${name}>`;\n gqlEntries.push(\n ` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { inputTypeMethods: ${inputTypeMethodsVar} })`,\n );\n }\n }\n\n return `\\\nimport {\n type ExtractMetadataAdapter,\n type FragmentBuilderFor,\n createGqlElementComposer,\n createVarMethodFactory,\n} from \"@soda-gql/core\";\n${extraImports}\n${schemaBlocks.join(\"\\n\")}\n\nexport const gql = {\n${gqlEntries.join(\",\\n\")}\n};\n`;\n};\n\nexport const generateMultiSchemaModule = (\n schemas: Map<string, DocumentNode>,\n options?: RuntimeGenerationOptions,\n): GeneratedModule => {\n // biome-ignore lint/suspicious/noExplicitAny: complex schema config type\n const schemaConfigs: Record<string, any> = {};\n const allStats = {\n objects: 0,\n enums: 0,\n inputs: 0,\n unions: 0,\n };\n\n for (const [name, document] of schemas.entries()) {\n const schema = createSchemaIndex(document);\n\n // Collect type names\n const objectTypeNames = collectObjectTypeNames(schema);\n const enumTypeNames = collectEnumTypeNames(schema);\n const inputTypeNames = collectInputTypeNames(schema);\n const unionTypeNames = collectUnionTypeNames(schema);\n const customScalarNames = collectScalarNames(schema).filter((n) => !builtinScalarTypes.has(n));\n\n // Generate individual variable declarations (granular pattern)\n const scalarVars: string[] = [];\n const enumVars: string[] = [];\n const inputVars: string[] = [];\n const objectVars: string[] = [];\n const unionVars: string[] = [];\n\n // Builtin scalars\n for (const scalarName of builtinScalarTypes.keys()) {\n const record = schema.scalars.get(scalarName) ?? { name: scalarName, directives: [] };\n scalarVars.push(renderScalarVar(name, record));\n }\n\n // Custom scalars\n for (const scalarName of customScalarNames) {\n const record = schema.scalars.get(scalarName);\n if (record) {\n scalarVars.push(renderScalarVar(name, record));\n }\n }\n\n // Enums\n for (const enumName of enumTypeNames) {\n const record = schema.enums.get(enumName);\n if (record) {\n enumVars.push(renderEnumVar(name, record));\n }\n }\n\n // Inputs\n for (const inputName of inputTypeNames) {\n const record = schema.inputs.get(inputName);\n if (record) {\n inputVars.push(renderInputVar(name, schema, record));\n }\n }\n\n // Objects\n for (const objectName of objectTypeNames) {\n const record = schema.objects.get(objectName);\n if (record) {\n objectVars.push(renderObjectVar(name, schema, record));\n }\n }\n\n // Unions\n for (const unionName of unionTypeNames) {\n const record = schema.unions.get(unionName);\n if (record) {\n unionVars.push(renderUnionVar(name, record));\n }\n }\n\n // Type name lists for assembly\n const allScalarNames = [...builtinScalarTypes.keys(), ...customScalarNames];\n\n const factoryVar = `createMethod_${name}`;\n const inputTypeMethodsBlock = renderInputTypeMethods(schema, factoryVar);\n // Pass adapter type name if injection has adapter for this schema\n const adapterTypeName = options?.injection?.get(name)?.adapterImportPath ? `Adapter_${name}` : undefined;\n const fragmentBuildersTypeBlock = renderFragmentBuildersType(objectTypeNames, name, adapterTypeName);\n\n const queryType = schema.operationTypes.query ?? \"Query\";\n const mutationType = schema.operationTypes.mutation ?? \"Mutation\";\n const subscriptionType = schema.operationTypes.subscription ?? \"Subscription\";\n\n schemaConfigs[name] = {\n queryType,\n mutationType,\n subscriptionType,\n // Granular: individual variable declarations\n scalarVars,\n enumVars,\n inputVars,\n objectVars,\n unionVars,\n // Granular: type name lists for assembly\n scalarNames: allScalarNames,\n enumNames: enumTypeNames,\n inputNames: inputTypeNames,\n objectNames: objectTypeNames,\n unionNames: unionTypeNames,\n inputTypeMethodsBlock,\n fragmentBuildersTypeBlock,\n defaultInputDepth: options?.defaultInputDepth?.get(name),\n inputDepthOverrides: options?.inputDepthOverrides?.get(name),\n };\n\n // Accumulate stats\n allStats.objects += objectVars.length;\n allStats.enums += enumVars.length;\n allStats.inputs += inputVars.length;\n allStats.unions += unionVars.length;\n }\n\n const injection: RuntimeTemplateInjection = options?.injection\n ? { mode: \"inject\", perSchema: options.injection }\n : { mode: \"inline\" };\n\n const code = multiRuntimeTemplate({\n schemas: schemaConfigs,\n injection,\n });\n\n return {\n code,\n stats: allStats,\n };\n};\n"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
const require_generator = require('./generator-
|
|
1
|
+
const require_generator = require('./generator-DlTMMIez.cjs');
|
|
2
2
|
|
|
3
3
|
exports.createSchemaIndex = require_generator.createSchemaIndex;
|
|
4
4
|
exports.generateMultiSchemaModule = require_generator.generateMultiSchemaModule;
|
|
@@ -319,47 +319,31 @@ const renderInputFields = (schema, fields) => {
|
|
|
319
319
|
indentSize: 6
|
|
320
320
|
});
|
|
321
321
|
};
|
|
322
|
-
const
|
|
322
|
+
const renderScalarVar = (schemaName, record) => {
|
|
323
323
|
const typeInfo = builtinScalarTypes.get(record.name) ?? {
|
|
324
324
|
input: "string",
|
|
325
325
|
output: "string"
|
|
326
326
|
};
|
|
327
|
-
return
|
|
327
|
+
return `const scalar_${schemaName}_${record.name} = { name: "${record.name}", $type: {} as { input: ${typeInfo.input}; output: ${typeInfo.output}; inputProfile: { kind: "scalar"; name: "${record.name}"; value: ${typeInfo.input} }; outputProfile: { kind: "scalar"; name: "${record.name}"; value: ${typeInfo.output} } } } as const;`;
|
|
328
328
|
};
|
|
329
|
-
const
|
|
330
|
-
const record = schema.objects.get(typeName);
|
|
331
|
-
if (!record) {
|
|
332
|
-
return "";
|
|
333
|
-
}
|
|
334
|
-
const fields = renderObjectFields(schema, record.fields);
|
|
335
|
-
return `${record.name}: { name: "${record.name}", fields: ${fields} }`;
|
|
336
|
-
};
|
|
337
|
-
const renderInputDefinition = (schema, typeName) => {
|
|
338
|
-
const record = schema.inputs.get(typeName);
|
|
339
|
-
if (!record) {
|
|
340
|
-
return "";
|
|
341
|
-
}
|
|
342
|
-
const fields = renderInputFields(schema, record.fields);
|
|
343
|
-
return `${record.name}: { name: "${record.name}", fields: ${fields} }`;
|
|
344
|
-
};
|
|
345
|
-
const renderEnumDefinition = (schema, typeName) => {
|
|
346
|
-
const record = schema.enums.get(typeName);
|
|
347
|
-
if (!record) {
|
|
348
|
-
return "";
|
|
349
|
-
}
|
|
329
|
+
const renderEnumVar = (schemaName, record) => {
|
|
350
330
|
const valueNames = Array.from(record.values.values()).sort((left, right) => left.name.value.localeCompare(right.name.value)).map((value) => value.name.value);
|
|
351
331
|
const valuesObj = valueNames.length === 0 ? "{}" : `{ ${valueNames.map((v) => `${v}: true`).join(", ")} }`;
|
|
352
332
|
const valueUnion = valueNames.length === 0 ? "never" : valueNames.map((v) => `"${v}"`).join(" | ");
|
|
353
|
-
return
|
|
333
|
+
return `const enum_${schemaName}_${record.name} = { name: "${record.name}", values: ${valuesObj}, $type: {} as { name: "${record.name}"; inputProfile: { kind: "enum"; name: "${record.name}"; value: ${valueUnion} }; outputProfile: { kind: "enum"; name: "${record.name}"; value: ${valueUnion} } } } as const;`;
|
|
354
334
|
};
|
|
355
|
-
const
|
|
356
|
-
const
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
335
|
+
const renderInputVar = (schemaName, schema, record) => {
|
|
336
|
+
const fields = renderInputFields(schema, record.fields);
|
|
337
|
+
return `const input_${schemaName}_${record.name} = { name: "${record.name}", fields: ${fields} } as const;`;
|
|
338
|
+
};
|
|
339
|
+
const renderObjectVar = (schemaName, schema, record) => {
|
|
340
|
+
const fields = renderObjectFields(schema, record.fields);
|
|
341
|
+
return `const object_${schemaName}_${record.name} = { name: "${record.name}", fields: ${fields} } as const;`;
|
|
342
|
+
};
|
|
343
|
+
const renderUnionVar = (schemaName, record) => {
|
|
360
344
|
const memberNames = Array.from(record.members.values()).sort((left, right) => left.name.value.localeCompare(right.name.value)).map((member) => member.name.value);
|
|
361
345
|
const typesObj = memberNames.length === 0 ? "{}" : `{ ${memberNames.map((m) => `${m}: true`).join(", ")} }`;
|
|
362
|
-
return
|
|
346
|
+
return `const union_${schemaName}_${record.name} = { name: "${record.name}", types: ${typesObj} } as const;`;
|
|
363
347
|
};
|
|
364
348
|
const collectObjectTypeNames = (schema) => Array.from(schema.objects.keys()).filter((name) => !name.startsWith("__")).sort((left, right) => left.localeCompare(right));
|
|
365
349
|
const renderFragmentBuildersType = (objectTypeNames, schemaName, adapterTypeName) => {
|
|
@@ -430,7 +414,6 @@ const multiRuntimeTemplate = ($$) => {
|
|
|
430
414
|
const gqlEntries = [];
|
|
431
415
|
for (const [name, config] of Object.entries($$.schemas)) {
|
|
432
416
|
const schemaVar = `${name}Schema`;
|
|
433
|
-
const scalarBlock = $$.injection.mode === "inject" ? scalarAliases.get(name) : config.scalarBlock;
|
|
434
417
|
const adapterVar = adapterAliases.get(name);
|
|
435
418
|
const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`];
|
|
436
419
|
if (adapterVar) {
|
|
@@ -441,19 +424,55 @@ const multiRuntimeTemplate = ($$) => {
|
|
|
441
424
|
const factoryVar = `createMethod_${name}`;
|
|
442
425
|
const defaultDepthBlock = config.defaultInputDepth !== undefined && config.defaultInputDepth !== 3 ? `\n __defaultInputDepth: ${config.defaultInputDepth},` : "";
|
|
443
426
|
const depthOverridesBlock = config.inputDepthOverrides && Object.keys(config.inputDepthOverrides).length > 0 ? `\n __inputDepthOverrides: ${JSON.stringify(config.inputDepthOverrides)},` : "";
|
|
427
|
+
const scalarVarsBlock = config.scalarVars.join("\n");
|
|
428
|
+
const enumVarsBlock = config.enumVars.length > 0 ? config.enumVars.join("\n") : "// (no enums)";
|
|
429
|
+
const inputVarsBlock = config.inputVars.length > 0 ? config.inputVars.join("\n") : "// (no inputs)";
|
|
430
|
+
const objectVarsBlock = config.objectVars.length > 0 ? config.objectVars.join("\n") : "// (no objects)";
|
|
431
|
+
const unionVarsBlock = config.unionVars.length > 0 ? config.unionVars.join("\n") : "// (no unions)";
|
|
432
|
+
const scalarAssembly = $$.injection.mode === "inject" ? scalarAliases.get(name) ?? "{}" : config.scalarNames.length > 0 ? `{ ${config.scalarNames.map((n) => `${n}: scalar_${name}_${n}`).join(", ")} }` : "{}";
|
|
433
|
+
const enumAssembly = config.enumNames.length > 0 ? `{ ${config.enumNames.map((n) => `${n}: enum_${name}_${n}`).join(", ")} }` : "{}";
|
|
434
|
+
const inputAssembly = config.inputNames.length > 0 ? `{ ${config.inputNames.map((n) => `${n}: input_${name}_${n}`).join(", ")} }` : "{}";
|
|
435
|
+
const objectAssembly = config.objectNames.length > 0 ? `{ ${config.objectNames.map((n) => `${n}: object_${name}_${n}`).join(", ")} }` : "{}";
|
|
436
|
+
const unionAssembly = config.unionNames.length > 0 ? `{ ${config.unionNames.map((n) => `${n}: union_${name}_${n}`).join(", ")} }` : "{}";
|
|
437
|
+
const scalarVarsSection = $$.injection.mode === "inject" ? "// (scalars imported)" : scalarVarsBlock;
|
|
438
|
+
const scalarAssemblyLine = $$.injection.mode === "inject" ? `// scalar_${name} is imported directly` : `const scalar_${name} = ${scalarAssembly} as const;`;
|
|
439
|
+
const scalarRef = $$.injection.mode === "inject" ? scalarAliases.get(name) ?? `scalar_${name}` : `scalar_${name}`;
|
|
444
440
|
schemaBlocks.push(`
|
|
441
|
+
// Individual scalar definitions
|
|
442
|
+
${scalarVarsSection}
|
|
443
|
+
|
|
444
|
+
// Individual enum definitions
|
|
445
|
+
${enumVarsBlock}
|
|
446
|
+
|
|
447
|
+
// Individual input definitions
|
|
448
|
+
${inputVarsBlock}
|
|
449
|
+
|
|
450
|
+
// Individual object definitions
|
|
451
|
+
${objectVarsBlock}
|
|
452
|
+
|
|
453
|
+
// Individual union definitions
|
|
454
|
+
${unionVarsBlock}
|
|
455
|
+
|
|
456
|
+
// Category assembly
|
|
457
|
+
${scalarAssemblyLine}
|
|
458
|
+
const enum_${name} = ${enumAssembly} as const;
|
|
459
|
+
const input_${name} = ${inputAssembly} as const;
|
|
460
|
+
const object_${name} = ${objectAssembly} as const;
|
|
461
|
+
const union_${name} = ${unionAssembly} as const;
|
|
462
|
+
|
|
463
|
+
// Schema assembly
|
|
445
464
|
const ${schemaVar} = {
|
|
446
|
-
label: "${name}",
|
|
447
|
-
operations: { query: "${config.queryType}", mutation: "${config.mutationType}", subscription: "${config.subscriptionType}" },
|
|
448
|
-
scalar: ${
|
|
449
|
-
enum: ${
|
|
450
|
-
input: ${
|
|
451
|
-
object: ${
|
|
452
|
-
union: ${
|
|
465
|
+
label: "${name}" as const,
|
|
466
|
+
operations: { query: "${config.queryType}", mutation: "${config.mutationType}", subscription: "${config.subscriptionType}" } as const,
|
|
467
|
+
scalar: ${scalarRef},
|
|
468
|
+
enum: enum_${name},
|
|
469
|
+
input: input_${name},
|
|
470
|
+
object: object_${name},
|
|
471
|
+
union: union_${name},${defaultDepthBlock}${depthOverridesBlock}
|
|
453
472
|
} as const;
|
|
454
473
|
|
|
455
474
|
const ${factoryVar} = createVarMethodFactory<typeof ${schemaVar}>();
|
|
456
|
-
const ${inputTypeMethodsVar} = ${config.inputTypeMethodsBlock}
|
|
475
|
+
const ${inputTypeMethodsVar} = ${config.inputTypeMethodsBlock};
|
|
457
476
|
|
|
458
477
|
${typeExports.join("\n")}`);
|
|
459
478
|
if (adapterVar) {
|
|
@@ -468,7 +487,6 @@ ${typeExports.join("\n")}`);
|
|
|
468
487
|
import {
|
|
469
488
|
type ExtractMetadataAdapter,
|
|
470
489
|
type FragmentBuilderFor,
|
|
471
|
-
type InputTypeMethods,
|
|
472
490
|
createGqlElementComposer,
|
|
473
491
|
createVarMethodFactory,
|
|
474
492
|
} from "@soda-gql/core";
|
|
@@ -490,43 +508,54 @@ const generateMultiSchemaModule = (schemas, options) => {
|
|
|
490
508
|
};
|
|
491
509
|
for (const [name, document] of schemas.entries()) {
|
|
492
510
|
const schema = createSchemaIndex(document);
|
|
493
|
-
const builtinScalarDefinitions = Array.from(builtinScalarTypes.keys()).map((name$1) => renderScalarDefinition(schema.scalars.get(name$1) ?? {
|
|
494
|
-
name: name$1,
|
|
495
|
-
directives: []
|
|
496
|
-
}));
|
|
497
|
-
const customScalarDefinitions = collectScalarNames(schema).filter((name$1) => !builtinScalarTypes.has(name$1)).map((name$1) => {
|
|
498
|
-
const record = schema.scalars.get(name$1);
|
|
499
|
-
return record ? renderScalarDefinition(record) : "";
|
|
500
|
-
}).filter((definition) => definition.length > 0);
|
|
501
|
-
const allScalarDefinitions = builtinScalarDefinitions.concat(customScalarDefinitions);
|
|
502
511
|
const objectTypeNames = collectObjectTypeNames(schema);
|
|
503
512
|
const enumTypeNames = collectEnumTypeNames(schema);
|
|
504
513
|
const inputTypeNames = collectInputTypeNames(schema);
|
|
505
514
|
const unionTypeNames = collectUnionTypeNames(schema);
|
|
506
|
-
const
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
const
|
|
511
|
-
const
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
}
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
515
|
+
const customScalarNames = collectScalarNames(schema).filter((n) => !builtinScalarTypes.has(n));
|
|
516
|
+
const scalarVars = [];
|
|
517
|
+
const enumVars = [];
|
|
518
|
+
const inputVars = [];
|
|
519
|
+
const objectVars = [];
|
|
520
|
+
const unionVars = [];
|
|
521
|
+
for (const scalarName of builtinScalarTypes.keys()) {
|
|
522
|
+
const record = schema.scalars.get(scalarName) ?? {
|
|
523
|
+
name: scalarName,
|
|
524
|
+
directives: []
|
|
525
|
+
};
|
|
526
|
+
scalarVars.push(renderScalarVar(name, record));
|
|
527
|
+
}
|
|
528
|
+
for (const scalarName of customScalarNames) {
|
|
529
|
+
const record = schema.scalars.get(scalarName);
|
|
530
|
+
if (record) {
|
|
531
|
+
scalarVars.push(renderScalarVar(name, record));
|
|
532
|
+
}
|
|
533
|
+
}
|
|
534
|
+
for (const enumName of enumTypeNames) {
|
|
535
|
+
const record = schema.enums.get(enumName);
|
|
536
|
+
if (record) {
|
|
537
|
+
enumVars.push(renderEnumVar(name, record));
|
|
538
|
+
}
|
|
539
|
+
}
|
|
540
|
+
for (const inputName of inputTypeNames) {
|
|
541
|
+
const record = schema.inputs.get(inputName);
|
|
542
|
+
if (record) {
|
|
543
|
+
inputVars.push(renderInputVar(name, schema, record));
|
|
544
|
+
}
|
|
545
|
+
}
|
|
546
|
+
for (const objectName of objectTypeNames) {
|
|
547
|
+
const record = schema.objects.get(objectName);
|
|
548
|
+
if (record) {
|
|
549
|
+
objectVars.push(renderObjectVar(name, schema, record));
|
|
550
|
+
}
|
|
551
|
+
}
|
|
552
|
+
for (const unionName of unionTypeNames) {
|
|
553
|
+
const record = schema.unions.get(unionName);
|
|
554
|
+
if (record) {
|
|
555
|
+
unionVars.push(renderUnionVar(name, record));
|
|
556
|
+
}
|
|
557
|
+
}
|
|
558
|
+
const allScalarNames = [...builtinScalarTypes.keys(), ...customScalarNames];
|
|
530
559
|
const factoryVar = `createMethod_${name}`;
|
|
531
560
|
const inputTypeMethodsBlock = renderInputTypeMethods(schema, factoryVar);
|
|
532
561
|
const adapterTypeName = options?.injection?.get(name)?.adapterImportPath ? `Adapter_${name}` : undefined;
|
|
@@ -538,20 +567,25 @@ const generateMultiSchemaModule = (schemas, options) => {
|
|
|
538
567
|
queryType,
|
|
539
568
|
mutationType,
|
|
540
569
|
subscriptionType,
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
570
|
+
scalarVars,
|
|
571
|
+
enumVars,
|
|
572
|
+
inputVars,
|
|
573
|
+
objectVars,
|
|
574
|
+
unionVars,
|
|
575
|
+
scalarNames: allScalarNames,
|
|
576
|
+
enumNames: enumTypeNames,
|
|
577
|
+
inputNames: inputTypeNames,
|
|
578
|
+
objectNames: objectTypeNames,
|
|
579
|
+
unionNames: unionTypeNames,
|
|
546
580
|
inputTypeMethodsBlock,
|
|
547
581
|
fragmentBuildersTypeBlock,
|
|
548
582
|
defaultInputDepth: options?.defaultInputDepth?.get(name),
|
|
549
583
|
inputDepthOverrides: options?.inputDepthOverrides?.get(name)
|
|
550
584
|
};
|
|
551
|
-
allStats.objects +=
|
|
552
|
-
allStats.enums +=
|
|
553
|
-
allStats.inputs +=
|
|
554
|
-
allStats.unions +=
|
|
585
|
+
allStats.objects += objectVars.length;
|
|
586
|
+
allStats.enums += enumVars.length;
|
|
587
|
+
allStats.inputs += inputVars.length;
|
|
588
|
+
allStats.unions += unionVars.length;
|
|
555
589
|
}
|
|
556
590
|
const injection = options?.injection ? {
|
|
557
591
|
mode: "inject",
|
|
@@ -569,4 +603,4 @@ const generateMultiSchemaModule = (schemas, options) => {
|
|
|
569
603
|
|
|
570
604
|
//#endregion
|
|
571
605
|
export { generateMultiSchemaModule as n, createSchemaIndex as t };
|
|
572
|
-
//# sourceMappingURL=generator-
|
|
606
|
+
//# sourceMappingURL=generator-swiNL05K.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generator-swiNL05K.mjs","names":["operationTypes: OperationTypeNames","kind: \"scalar\" | \"enum\" | \"input\"","kind: \"scalar\" | \"enum\" | \"union\" | \"object\"","imports: string[]","schemaBlocks: string[]","gqlEntries: string[]","schemaConfigs: Record<string, any>","scalarVars: string[]","enumVars: string[]","inputVars: string[]","objectVars: string[]","unionVars: string[]","injection: RuntimeTemplateInjection"],"sources":["../src/generator.ts"],"sourcesContent":["import {\n type ConstDirectiveNode,\n type ConstValueNode,\n type DocumentNode,\n type EnumValueDefinitionNode,\n type FieldDefinitionNode,\n type InputValueDefinitionNode,\n Kind,\n type NamedTypeNode,\n type SchemaDefinitionNode,\n type SchemaExtensionNode,\n type TypeNode,\n} from \"graphql\";\n\nconst builtinScalarTypes = new Map<string, { readonly input: string; readonly output: string }>([\n [\"ID\", { input: \"string\", output: \"string\" }],\n [\"String\", { input: \"string\", output: \"string\" }],\n [\"Int\", { input: \"number\", output: \"number\" }],\n [\"Float\", { input: \"number\", output: \"number\" }],\n [\"Boolean\", { input: \"boolean\", output: \"boolean\" }],\n]);\n\ntype OperationTypeNames = {\n query?: string;\n mutation?: string;\n subscription?: string;\n};\n\ntype ObjectRecord = {\n readonly name: string;\n readonly fields: Map<string, FieldDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype InputRecord = {\n readonly name: string;\n readonly fields: Map<string, InputValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype EnumRecord = {\n readonly name: string;\n readonly values: Map<string, EnumValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype UnionRecord = {\n readonly name: string;\n readonly members: Map<string, NamedTypeNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype ScalarRecord = {\n readonly name: string;\n directives: ConstDirectiveNode[];\n};\n\ntype SchemaIndex = {\n readonly objects: Map<string, ObjectRecord>;\n readonly inputs: Map<string, InputRecord>;\n readonly enums: Map<string, EnumRecord>;\n readonly unions: Map<string, UnionRecord>;\n readonly scalars: Map<string, ScalarRecord>;\n readonly operationTypes: OperationTypeNames;\n};\n\nconst ensureRecord = <T>(collection: Map<string, T>, key: string, factory: (name: string) => T): T => {\n const existing = collection.get(key);\n if (existing) {\n return existing;\n }\n\n const created = factory(key);\n collection.set(key, created);\n return created;\n};\n\nconst addObjectFields = (target: Map<string, FieldDefinitionNode>, fields: readonly FieldDefinitionNode[] | undefined): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addInputFields = (\n target: Map<string, InputValueDefinitionNode>,\n fields: readonly InputValueDefinitionNode[] | undefined,\n): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addEnumValues = (\n target: Map<string, EnumValueDefinitionNode>,\n values: readonly EnumValueDefinitionNode[] | undefined,\n): void => {\n if (!values) {\n return;\n }\n\n for (const value of values) {\n target.set(value.name.value, value);\n }\n};\n\nconst addUnionMembers = (target: Map<string, NamedTypeNode>, members: readonly NamedTypeNode[] | undefined): void => {\n if (!members) {\n return;\n }\n\n for (const member of members) {\n target.set(member.name.value, member);\n }\n};\n\nconst mergeDirectives = (\n existing: ConstDirectiveNode[] | undefined,\n incoming: readonly ConstDirectiveNode[] | undefined,\n precedence: \"definition\" | \"extension\",\n): ConstDirectiveNode[] => {\n const current = existing ?? [];\n const next = incoming ? Array.from(incoming) : [];\n return precedence === \"definition\" ? [...next, ...current] : [...current, ...next];\n};\n\nconst updateOperationTypes = (\n operationTypes: OperationTypeNames,\n definition: SchemaDefinitionNode | SchemaExtensionNode,\n): void => {\n for (const operation of definition.operationTypes ?? []) {\n const typeName = operation.type.name.value;\n switch (operation.operation) {\n case \"query\":\n operationTypes.query = typeName;\n break;\n case \"mutation\":\n operationTypes.mutation = typeName;\n break;\n case \"subscription\":\n operationTypes.subscription = typeName;\n break;\n default:\n break;\n }\n }\n};\n\nexport const createSchemaIndex = (document: DocumentNode): SchemaIndex => {\n const objects = new Map<string, ObjectRecord>();\n const inputs = new Map<string, InputRecord>();\n const enums = new Map<string, EnumRecord>();\n const unions = new Map<string, UnionRecord>();\n const scalars = new Map<string, ScalarRecord>();\n const operationTypes: OperationTypeNames = {};\n\n for (const definition of document.definitions) {\n switch (definition.kind) {\n case Kind.OBJECT_TYPE_DEFINITION:\n case Kind.OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(objects, definition.name.value, (name) => ({\n name,\n fields: new Map<string, FieldDefinitionNode>(),\n directives: [],\n }));\n addObjectFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.INPUT_OBJECT_TYPE_DEFINITION:\n case Kind.INPUT_OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.INPUT_OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(inputs, definition.name.value, (name) => ({\n name,\n fields: new Map<string, InputValueDefinitionNode>(),\n directives: [],\n }));\n addInputFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.ENUM_TYPE_DEFINITION:\n case Kind.ENUM_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.ENUM_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(enums, definition.name.value, (name) => ({\n name,\n values: new Map<string, EnumValueDefinitionNode>(),\n directives: [],\n }));\n addEnumValues(record.values, definition.values);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.UNION_TYPE_DEFINITION:\n case Kind.UNION_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.UNION_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(unions, definition.name.value, (name) => ({\n name,\n members: new Map<string, NamedTypeNode>(),\n directives: [],\n }));\n addUnionMembers(record.members, definition.types);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCALAR_TYPE_DEFINITION:\n case Kind.SCALAR_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.SCALAR_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(scalars, definition.name.value, (name) => ({\n name,\n directives: [],\n }));\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCHEMA_DEFINITION:\n case Kind.SCHEMA_EXTENSION:\n updateOperationTypes(operationTypes, definition);\n break;\n default:\n break;\n }\n }\n\n if (!operationTypes.query && objects.has(\"Query\")) {\n operationTypes.query = \"Query\";\n }\n if (!operationTypes.mutation && objects.has(\"Mutation\")) {\n operationTypes.mutation = \"Mutation\";\n }\n if (!operationTypes.subscription && objects.has(\"Subscription\")) {\n operationTypes.subscription = \"Subscription\";\n }\n\n return {\n objects,\n inputs,\n enums,\n unions,\n scalars,\n operationTypes,\n } satisfies SchemaIndex;\n};\n\ntype TypeLevel = {\n readonly kind: \"list\" | \"named\";\n readonly nonNull: boolean;\n};\n\nconst collectTypeLevels = (\n type: TypeNode,\n nonNull = false,\n levels: TypeLevel[] = [],\n): { readonly name: string; readonly levels: TypeLevel[] } => {\n if (type.kind === Kind.NON_NULL_TYPE) {\n return collectTypeLevels(type.type, true, levels);\n }\n\n if (type.kind === Kind.LIST_TYPE) {\n levels.push({ kind: \"list\", nonNull });\n return collectTypeLevels(type.type, false, levels);\n }\n\n levels.push({ kind: \"named\", nonNull });\n return { name: type.name.value, levels };\n};\n\nconst buildTypeModifier = (levels: TypeLevel[]): string => {\n let modifier = \"?\";\n\n for (const level of levels.slice().reverse()) {\n if (level.kind === \"named\") {\n // Inner type: always explicit nullable marker\n modifier = level.nonNull ? \"!\" : \"?\";\n continue;\n }\n\n // List type: append []? or []! based on list's nullability\n const listSuffix = level.nonNull ? \"[]!\" : \"[]?\";\n modifier = `${modifier}${listSuffix}`;\n }\n\n return modifier;\n};\n\nconst parseTypeReference = (type: TypeNode): { readonly name: string; readonly modifier: string } => {\n const { name, levels } = collectTypeLevels(type);\n return { name, modifier: buildTypeModifier(levels) };\n};\n\nconst isScalarName = (schema: SchemaIndex, name: string): boolean => builtinScalarTypes.has(name) || schema.scalars.has(name);\nconst isEnumName = (schema: SchemaIndex, name: string): boolean => schema.enums.has(name);\nconst _isInputName = (schema: SchemaIndex, name: string): boolean => schema.inputs.has(name);\nconst isUnionName = (schema: SchemaIndex, name: string): boolean => schema.unions.has(name);\nconst isObjectName = (schema: SchemaIndex, name: string): boolean => schema.objects.has(name);\n\nconst renderConstValue = (value: ConstValueNode): string => {\n switch (value.kind) {\n case Kind.NULL:\n return \"null\";\n case Kind.INT:\n case Kind.FLOAT:\n return value.value;\n case Kind.STRING:\n case Kind.ENUM:\n return JSON.stringify(value.value);\n case Kind.BOOLEAN:\n return value.value ? \"true\" : \"false\";\n case Kind.LIST:\n return `[${value.values.map((item) => renderConstValue(item)).join(\", \")}]`;\n case Kind.OBJECT: {\n if (value.fields.length === 0) {\n return \"{}\";\n }\n const entries = value.fields.map((field) => `${field.name.value}: ${renderConstValue(field.value)}`);\n return `{ ${entries.join(\", \")} }`;\n }\n }\n};\n\nconst renderConstArgumentMap = (\n args: readonly { readonly name: { readonly value: string }; readonly value: ConstValueNode }[] | undefined,\n): string => {\n const entries = (args ?? []).map((arg) => `${arg.name.value}: ${renderConstValue(arg.value)}`);\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDirectives = (directives: readonly ConstDirectiveNode[] | undefined): string => {\n const entries = (directives ?? []).map(\n (directive) => `${directive.name.value}: ${renderConstArgumentMap(directive.arguments)}`,\n );\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDefaultValue = (value: ConstValueNode | null | undefined): string =>\n value ? `() => (${renderConstValue(value)})` : \"null\";\n\nconst renderInputRef = (schema: SchemaIndex, definition: InputValueDefinitionNode): string => {\n const { name, modifier } = parseTypeReference(definition.type);\n const defaultValue = renderDefaultValue(definition.defaultValue ?? null);\n const directives = renderDirectives(definition.directives);\n\n let kind: \"scalar\" | \"enum\" | \"input\";\n if (isScalarName(schema, name)) {\n kind = \"scalar\";\n } else if (isEnumName(schema, name)) {\n kind = \"enum\";\n } else {\n kind = \"input\";\n }\n\n return `{ kind: \"${kind}\", name: \"${name}\", modifier: \"${modifier}\", defaultValue: ${defaultValue}, directives: ${directives} }`;\n};\n\nconst renderArgumentMap = (schema: SchemaIndex, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const entries = [...(args ?? [])]\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((arg) => `${arg.name.value}: ${renderInputRef(schema, arg)}`);\n\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderOutputRef = (schema: SchemaIndex, type: TypeNode, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const { name, modifier } = parseTypeReference(type);\n const argumentMap = renderArgumentMap(schema, args);\n\n let kind: \"scalar\" | \"enum\" | \"union\" | \"object\";\n if (isScalarName(schema, name)) {\n kind = \"scalar\";\n } else if (isEnumName(schema, name)) {\n kind = \"enum\";\n } else if (isUnionName(schema, name)) {\n kind = \"union\";\n } else if (isObjectName(schema, name)) {\n kind = \"object\";\n } else {\n kind = \"scalar\"; // fallback for unknown types\n }\n\n return `{ kind: \"${kind}\", name: \"${name}\", modifier: \"${modifier}\", arguments: ${argumentMap} }`;\n};\n\nconst renderPropertyLines = ({ entries, indentSize }: { entries: string[]; indentSize: number }) => {\n if (entries.length === 0) {\n return \"{}\";\n }\n\n const indent = \" \".repeat(indentSize);\n const lastIndent = \" \".repeat(indentSize - 2);\n return [\"{\", `${indent}${entries.join(`,\\n${indent}`)},`, `${lastIndent}}`].join(`\\n`);\n};\n\nconst renderObjectFields = (schema: SchemaIndex, fields: Map<string, FieldDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderOutputRef(schema, field.type, field.arguments)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\nconst renderInputFields = (schema: SchemaIndex, fields: Map<string, InputValueDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderInputRef(schema, field)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\n// Granular render functions - each type as its own const variable\nconst renderScalarVar = (schemaName: string, record: ScalarRecord): string => {\n const typeInfo = builtinScalarTypes.get(record.name) ?? { input: \"string\", output: \"string\" };\n return `const scalar_${schemaName}_${record.name} = { name: \"${record.name}\", $type: {} as { input: ${typeInfo.input}; output: ${typeInfo.output}; inputProfile: { kind: \"scalar\"; name: \"${record.name}\"; value: ${typeInfo.input} }; outputProfile: { kind: \"scalar\"; name: \"${record.name}\"; value: ${typeInfo.output} } } } as const;`;\n};\n\nconst renderEnumVar = (schemaName: string, record: EnumRecord): string => {\n const valueNames = Array.from(record.values.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((value) => value.name.value);\n const valuesObj = valueNames.length === 0 ? \"{}\" : `{ ${valueNames.map((v) => `${v}: true`).join(\", \")} }`;\n const valueUnion = valueNames.length === 0 ? \"never\" : valueNames.map((v) => `\"${v}\"`).join(\" | \");\n return `const enum_${schemaName}_${record.name} = { name: \"${record.name}\", values: ${valuesObj}, $type: {} as { name: \"${record.name}\"; inputProfile: { kind: \"enum\"; name: \"${record.name}\"; value: ${valueUnion} }; outputProfile: { kind: \"enum\"; name: \"${record.name}\"; value: ${valueUnion} } } } as const;`;\n};\n\nconst renderInputVar = (schemaName: string, schema: SchemaIndex, record: InputRecord): string => {\n const fields = renderInputFields(schema, record.fields);\n return `const input_${schemaName}_${record.name} = { name: \"${record.name}\", fields: ${fields} } as const;`;\n};\n\nconst renderObjectVar = (schemaName: string, schema: SchemaIndex, record: ObjectRecord): string => {\n const fields = renderObjectFields(schema, record.fields);\n return `const object_${schemaName}_${record.name} = { name: \"${record.name}\", fields: ${fields} } as const;`;\n};\n\nconst renderUnionVar = (schemaName: string, record: UnionRecord): string => {\n const memberNames = Array.from(record.members.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((member) => member.name.value);\n const typesObj = memberNames.length === 0 ? \"{}\" : `{ ${memberNames.map((m) => `${m}: true`).join(\", \")} }`;\n return `const union_${schemaName}_${record.name} = { name: \"${record.name}\", types: ${typesObj} } as const;`;\n};\n\nconst collectObjectTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.objects.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst renderFragmentBuildersType = (objectTypeNames: string[], schemaName: string, adapterTypeName?: string): string => {\n if (objectTypeNames.length === 0) {\n return `type FragmentBuilders_${schemaName} = Record<string, never>;`;\n }\n\n const adapterPart = adapterTypeName ? `, ExtractMetadataAdapter<${adapterTypeName}>` : \"\";\n const entries = objectTypeNames.map(\n (name) => ` readonly ${name}: FragmentBuilderFor<Schema_${schemaName}, \"${name}\"${adapterPart}>`,\n );\n return `type FragmentBuilders_${schemaName} = {\\n${entries.join(\";\\n\")};\\n};`;\n};\n\nconst collectInputTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.inputs.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectEnumTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.enums.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectUnionTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.unions.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectScalarNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.scalars.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst renderInputTypeMethod = (factoryVar: string, kind: \"scalar\" | \"enum\" | \"input\", typeName: string): string =>\n `${typeName}: ${factoryVar}(\"${kind}\", \"${typeName}\")`;\n\nconst renderInputTypeMethods = (schema: SchemaIndex, factoryVar: string): string => {\n const scalarMethods = Array.from(builtinScalarTypes.keys())\n .concat(collectScalarNames(schema).filter((name) => !builtinScalarTypes.has(name)))\n .map((name) => renderInputTypeMethod(factoryVar, \"scalar\", name));\n\n const enumMethods = collectEnumTypeNames(schema).map((name) => renderInputTypeMethod(factoryVar, \"enum\", name));\n\n const inputMethods = collectInputTypeNames(schema).map((name) => renderInputTypeMethod(factoryVar, \"input\", name));\n\n const allMethods = [...scalarMethods, ...enumMethods, ...inputMethods].sort((left, right) => {\n const leftName = left.split(\":\")[0] ?? \"\";\n const rightName = right.split(\":\")[0] ?? \"\";\n return leftName.localeCompare(rightName);\n });\n\n return renderPropertyLines({ entries: allMethods, indentSize: 2 });\n};\n\nexport type GeneratedModule = {\n readonly code: string;\n readonly stats: {\n readonly objects: number;\n readonly enums: number;\n readonly inputs: number;\n readonly unions: number;\n };\n};\n\ntype PerSchemaInjection = {\n readonly scalarImportPath: string;\n readonly adapterImportPath?: string;\n};\n\ntype RuntimeTemplateInjection =\n | { readonly mode: \"inline\" }\n | {\n readonly mode: \"inject\";\n readonly perSchema: Map<string, PerSchemaInjection>;\n };\n\nexport type RuntimeGenerationOptions = {\n readonly injection?: Map<string, PerSchemaInjection>;\n readonly defaultInputDepth?: Map<string, number>;\n readonly inputDepthOverrides?: Map<string, Readonly<Record<string, number>>>;\n};\n\ntype MultiRuntimeTemplateOptions = {\n readonly schemas: Record<\n string,\n {\n readonly queryType: string;\n readonly mutationType: string;\n readonly subscriptionType: string;\n // Granular: individual variable declarations\n readonly scalarVars: string[];\n readonly enumVars: string[];\n readonly inputVars: string[];\n readonly objectVars: string[];\n readonly unionVars: string[];\n // Granular: type name lists for assembly\n readonly scalarNames: string[];\n readonly enumNames: string[];\n readonly inputNames: string[];\n readonly objectNames: string[];\n readonly unionNames: string[];\n readonly inputTypeMethodsBlock: string;\n readonly fragmentBuildersTypeBlock: string;\n readonly defaultInputDepth?: number;\n readonly inputDepthOverrides?: Readonly<Record<string, number>>;\n }\n >;\n readonly injection: RuntimeTemplateInjection;\n};\n\nconst multiRuntimeTemplate = ($$: MultiRuntimeTemplateOptions) => {\n // Build imports based on injection mode\n const imports: string[] = [];\n const scalarAliases = new Map<string, string>();\n const adapterAliases = new Map<string, string>();\n\n if ($$.injection.mode === \"inject\") {\n // Group imports by file path\n const importsByPath = new Map<string, string[]>();\n\n for (const [schemaName, injection] of $$.injection.perSchema) {\n const scalarAlias = `scalar_${schemaName}`;\n scalarAliases.set(schemaName, scalarAlias);\n\n // Group scalar import\n const scalarSpecifiers = importsByPath.get(injection.scalarImportPath) ?? [];\n if (!importsByPath.has(injection.scalarImportPath)) {\n importsByPath.set(injection.scalarImportPath, scalarSpecifiers);\n }\n scalarSpecifiers.push(`scalar as ${scalarAlias}`);\n\n // Group adapter import (optional)\n if (injection.adapterImportPath) {\n const adapterAlias = `adapter_${schemaName}`;\n adapterAliases.set(schemaName, adapterAlias);\n const adapterSpecifiers = importsByPath.get(injection.adapterImportPath) ?? [];\n if (!importsByPath.has(injection.adapterImportPath)) {\n importsByPath.set(injection.adapterImportPath, adapterSpecifiers);\n }\n adapterSpecifiers.push(`adapter as ${adapterAlias}`);\n }\n }\n\n // Generate grouped imports\n for (const [path, specifiers] of importsByPath) {\n if (specifiers.length === 1) {\n imports.push(`import { ${specifiers[0]} } from \"${path}\";`);\n } else {\n imports.push(`import {\\n ${specifiers.join(\",\\n \")},\\n} from \"${path}\";`);\n }\n }\n }\n\n const extraImports = imports.length > 0 ? `${imports.join(\"\\n\")}\\n` : \"\";\n\n // Generate per-schema definitions (granular pattern)\n const schemaBlocks: string[] = [];\n const gqlEntries: string[] = [];\n\n for (const [name, config] of Object.entries($$.schemas)) {\n const schemaVar = `${name}Schema`;\n\n // Get optional adapter\n const adapterVar = adapterAliases.get(name);\n\n // Build type exports with fragment builders type\n const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`];\n if (adapterVar) {\n typeExports.push(`export type Adapter_${name} = typeof ${adapterVar} & { _?: never };`);\n }\n typeExports.push(config.fragmentBuildersTypeBlock);\n\n const inputTypeMethodsVar = `inputTypeMethods_${name}`;\n const factoryVar = `createMethod_${name}`;\n\n // Generate __defaultInputDepth block if non-default value\n const defaultDepthBlock =\n config.defaultInputDepth !== undefined && config.defaultInputDepth !== 3\n ? `\\n __defaultInputDepth: ${config.defaultInputDepth},`\n : \"\";\n\n // Generate __inputDepthOverrides block if there are overrides\n const depthOverridesBlock =\n config.inputDepthOverrides && Object.keys(config.inputDepthOverrides).length > 0\n ? `\\n __inputDepthOverrides: ${JSON.stringify(config.inputDepthOverrides)},`\n : \"\";\n\n // Granular: generate individual variable declarations\n const scalarVarsBlock = config.scalarVars.join(\"\\n\");\n const enumVarsBlock = config.enumVars.length > 0 ? config.enumVars.join(\"\\n\") : \"// (no enums)\";\n const inputVarsBlock = config.inputVars.length > 0 ? config.inputVars.join(\"\\n\") : \"// (no inputs)\";\n const objectVarsBlock = config.objectVars.length > 0 ? config.objectVars.join(\"\\n\") : \"// (no objects)\";\n const unionVarsBlock = config.unionVars.length > 0 ? config.unionVars.join(\"\\n\") : \"// (no unions)\";\n\n // Granular: generate assembly references\n // For injection mode, use imported scalar object; otherwise assemble from individual vars\n const scalarAssembly =\n $$.injection.mode === \"inject\"\n ? (scalarAliases.get(name) ?? \"{}\")\n : config.scalarNames.length > 0\n ? `{ ${config.scalarNames.map((n) => `${n}: scalar_${name}_${n}`).join(\", \")} }`\n : \"{}\";\n const enumAssembly =\n config.enumNames.length > 0 ? `{ ${config.enumNames.map((n) => `${n}: enum_${name}_${n}`).join(\", \")} }` : \"{}\";\n const inputAssembly =\n config.inputNames.length > 0 ? `{ ${config.inputNames.map((n) => `${n}: input_${name}_${n}`).join(\", \")} }` : \"{}\";\n const objectAssembly =\n config.objectNames.length > 0 ? `{ ${config.objectNames.map((n) => `${n}: object_${name}_${n}`).join(\", \")} }` : \"{}\";\n const unionAssembly =\n config.unionNames.length > 0 ? `{ ${config.unionNames.map((n) => `${n}: union_${name}_${n}`).join(\", \")} }` : \"{}\";\n\n // Granular: skip individual scalar vars when using injection (scalars come from import)\n const scalarVarsSection = $$.injection.mode === \"inject\" ? \"// (scalars imported)\" : scalarVarsBlock;\n\n // When injecting scalars, use the imported alias directly; otherwise use the assembled category object\n const scalarAssemblyLine =\n $$.injection.mode === \"inject\"\n ? `// scalar_${name} is imported directly`\n : `const scalar_${name} = ${scalarAssembly} as const;`;\n const scalarRef = $$.injection.mode === \"inject\" ? (scalarAliases.get(name) ?? `scalar_${name}`) : `scalar_${name}`;\n\n schemaBlocks.push(`\n// Individual scalar definitions\n${scalarVarsSection}\n\n// Individual enum definitions\n${enumVarsBlock}\n\n// Individual input definitions\n${inputVarsBlock}\n\n// Individual object definitions\n${objectVarsBlock}\n\n// Individual union definitions\n${unionVarsBlock}\n\n// Category assembly\n${scalarAssemblyLine}\nconst enum_${name} = ${enumAssembly} as const;\nconst input_${name} = ${inputAssembly} as const;\nconst object_${name} = ${objectAssembly} as const;\nconst union_${name} = ${unionAssembly} as const;\n\n// Schema assembly\nconst ${schemaVar} = {\n label: \"${name}\" as const,\n operations: { query: \"${config.queryType}\", mutation: \"${config.mutationType}\", subscription: \"${config.subscriptionType}\" } as const,\n scalar: ${scalarRef},\n enum: enum_${name},\n input: input_${name},\n object: object_${name},\n union: union_${name},${defaultDepthBlock}${depthOverridesBlock}\n} as const;\n\nconst ${factoryVar} = createVarMethodFactory<typeof ${schemaVar}>();\nconst ${inputTypeMethodsVar} = ${config.inputTypeMethodsBlock};\n\n${typeExports.join(\"\\n\")}`);\n\n // Build gql entry with options - inputTypeMethods is always required\n // Include FragmentBuilders type for codegen optimization\n if (adapterVar) {\n const typeParams = `<Schema_${name}, FragmentBuilders_${name}, Adapter_${name}>`;\n gqlEntries.push(\n ` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { adapter: ${adapterVar}, inputTypeMethods: ${inputTypeMethodsVar} })`,\n );\n } else {\n const typeParams = `<Schema_${name}, FragmentBuilders_${name}>`;\n gqlEntries.push(\n ` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { inputTypeMethods: ${inputTypeMethodsVar} })`,\n );\n }\n }\n\n return `\\\nimport {\n type ExtractMetadataAdapter,\n type FragmentBuilderFor,\n createGqlElementComposer,\n createVarMethodFactory,\n} from \"@soda-gql/core\";\n${extraImports}\n${schemaBlocks.join(\"\\n\")}\n\nexport const gql = {\n${gqlEntries.join(\",\\n\")}\n};\n`;\n};\n\nexport const generateMultiSchemaModule = (\n schemas: Map<string, DocumentNode>,\n options?: RuntimeGenerationOptions,\n): GeneratedModule => {\n // biome-ignore lint/suspicious/noExplicitAny: complex schema config type\n const schemaConfigs: Record<string, any> = {};\n const allStats = {\n objects: 0,\n enums: 0,\n inputs: 0,\n unions: 0,\n };\n\n for (const [name, document] of schemas.entries()) {\n const schema = createSchemaIndex(document);\n\n // Collect type names\n const objectTypeNames = collectObjectTypeNames(schema);\n const enumTypeNames = collectEnumTypeNames(schema);\n const inputTypeNames = collectInputTypeNames(schema);\n const unionTypeNames = collectUnionTypeNames(schema);\n const customScalarNames = collectScalarNames(schema).filter((n) => !builtinScalarTypes.has(n));\n\n // Generate individual variable declarations (granular pattern)\n const scalarVars: string[] = [];\n const enumVars: string[] = [];\n const inputVars: string[] = [];\n const objectVars: string[] = [];\n const unionVars: string[] = [];\n\n // Builtin scalars\n for (const scalarName of builtinScalarTypes.keys()) {\n const record = schema.scalars.get(scalarName) ?? { name: scalarName, directives: [] };\n scalarVars.push(renderScalarVar(name, record));\n }\n\n // Custom scalars\n for (const scalarName of customScalarNames) {\n const record = schema.scalars.get(scalarName);\n if (record) {\n scalarVars.push(renderScalarVar(name, record));\n }\n }\n\n // Enums\n for (const enumName of enumTypeNames) {\n const record = schema.enums.get(enumName);\n if (record) {\n enumVars.push(renderEnumVar(name, record));\n }\n }\n\n // Inputs\n for (const inputName of inputTypeNames) {\n const record = schema.inputs.get(inputName);\n if (record) {\n inputVars.push(renderInputVar(name, schema, record));\n }\n }\n\n // Objects\n for (const objectName of objectTypeNames) {\n const record = schema.objects.get(objectName);\n if (record) {\n objectVars.push(renderObjectVar(name, schema, record));\n }\n }\n\n // Unions\n for (const unionName of unionTypeNames) {\n const record = schema.unions.get(unionName);\n if (record) {\n unionVars.push(renderUnionVar(name, record));\n }\n }\n\n // Type name lists for assembly\n const allScalarNames = [...builtinScalarTypes.keys(), ...customScalarNames];\n\n const factoryVar = `createMethod_${name}`;\n const inputTypeMethodsBlock = renderInputTypeMethods(schema, factoryVar);\n // Pass adapter type name if injection has adapter for this schema\n const adapterTypeName = options?.injection?.get(name)?.adapterImportPath ? `Adapter_${name}` : undefined;\n const fragmentBuildersTypeBlock = renderFragmentBuildersType(objectTypeNames, name, adapterTypeName);\n\n const queryType = schema.operationTypes.query ?? \"Query\";\n const mutationType = schema.operationTypes.mutation ?? \"Mutation\";\n const subscriptionType = schema.operationTypes.subscription ?? \"Subscription\";\n\n schemaConfigs[name] = {\n queryType,\n mutationType,\n subscriptionType,\n // Granular: individual variable declarations\n scalarVars,\n enumVars,\n inputVars,\n objectVars,\n unionVars,\n // Granular: type name lists for assembly\n scalarNames: allScalarNames,\n enumNames: enumTypeNames,\n inputNames: inputTypeNames,\n objectNames: objectTypeNames,\n unionNames: unionTypeNames,\n inputTypeMethodsBlock,\n fragmentBuildersTypeBlock,\n defaultInputDepth: options?.defaultInputDepth?.get(name),\n inputDepthOverrides: options?.inputDepthOverrides?.get(name),\n };\n\n // Accumulate stats\n allStats.objects += objectVars.length;\n allStats.enums += enumVars.length;\n allStats.inputs += inputVars.length;\n allStats.unions += unionVars.length;\n }\n\n const injection: RuntimeTemplateInjection = options?.injection\n ? { mode: \"inject\", perSchema: options.injection }\n : { mode: \"inline\" };\n\n const code = multiRuntimeTemplate({\n schemas: schemaConfigs,\n injection,\n });\n\n return {\n code,\n stats: allStats,\n };\n};\n"],"mappings":"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"}
|
package/dist/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
const require_generator = require('./generator-
|
|
1
|
+
const require_generator = require('./generator-DlTMMIez.cjs');
|
|
2
2
|
let node_fs = require("node:fs");
|
|
3
3
|
let node_path = require("node:path");
|
|
4
4
|
let neverthrow = require("neverthrow");
|
|
@@ -198,7 +198,7 @@ const runCodegen = async (options) => {
|
|
|
198
198
|
}
|
|
199
199
|
const { code } = require_generator.generateMultiSchemaModule(schemas, { injection: injectionConfig });
|
|
200
200
|
for (const [name, document] of schemas.entries()) {
|
|
201
|
-
const schemaIndex = (await Promise.resolve().then(() => require("./generator-
|
|
201
|
+
const schemaIndex = (await Promise.resolve().then(() => require("./generator-Dr445O16.cjs"))).createSchemaIndex(document);
|
|
202
202
|
const objects = Array.from(schemaIndex.objects.keys()).filter((n) => !n.startsWith("__")).length;
|
|
203
203
|
const enums = Array.from(schemaIndex.enums.keys()).filter((n) => !n.startsWith("__")).length;
|
|
204
204
|
const inputs = Array.from(schemaIndex.inputs.keys()).filter((n) => !n.startsWith("__")).length;
|
package/dist/index.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { n as generateMultiSchemaModule } from "./generator-
|
|
1
|
+
import { n as generateMultiSchemaModule } from "./generator-swiNL05K.mjs";
|
|
2
2
|
import { existsSync, mkdirSync, readFileSync, writeFileSync } from "node:fs";
|
|
3
3
|
import { basename, dirname, extname, relative, resolve } from "node:path";
|
|
4
4
|
import { err, ok } from "neverthrow";
|
|
@@ -198,7 +198,7 @@ const runCodegen = async (options) => {
|
|
|
198
198
|
}
|
|
199
199
|
const { code } = generateMultiSchemaModule(schemas, { injection: injectionConfig });
|
|
200
200
|
for (const [name, document] of schemas.entries()) {
|
|
201
|
-
const schemaIndex = (await import("./generator-
|
|
201
|
+
const schemaIndex = (await import("./generator-LDU9eA31.mjs")).createSchemaIndex(document);
|
|
202
202
|
const objects = Array.from(schemaIndex.objects.keys()).filter((n) => !n.startsWith("__")).length;
|
|
203
203
|
const enums = Array.from(schemaIndex.enums.keys()).filter((n) => !n.startsWith("__")).length;
|
|
204
204
|
const inputs = Array.from(schemaIndex.inputs.keys()).filter((n) => !n.startsWith("__")).length;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@soda-gql/codegen",
|
|
3
|
-
"version": "0.5.
|
|
3
|
+
"version": "0.5.1",
|
|
4
4
|
"description": "GraphQL schema code generation for soda-gql",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"private": false,
|
|
@@ -46,8 +46,8 @@
|
|
|
46
46
|
"./package.json": "./package.json"
|
|
47
47
|
},
|
|
48
48
|
"dependencies": {
|
|
49
|
-
"@soda-gql/core": "0.5.
|
|
50
|
-
"@soda-gql/runtime": "0.5.
|
|
49
|
+
"@soda-gql/core": "0.5.1",
|
|
50
|
+
"@soda-gql/runtime": "0.5.1",
|
|
51
51
|
"esbuild": "^0.24.0",
|
|
52
52
|
"graphql": "^16.8.1",
|
|
53
53
|
"neverthrow": "^8.1.1"
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generator-4a-rsLCK.cjs","names":["operationTypes: OperationTypeNames","Kind","kind: \"scalar\" | \"enum\" | \"input\"","kind: \"scalar\" | \"enum\" | \"union\" | \"object\"","imports: string[]","schemaBlocks: string[]","gqlEntries: string[]","schemaConfigs: Record<string, any>","name","injection: RuntimeTemplateInjection"],"sources":["../src/generator.ts"],"sourcesContent":["import {\n type ConstDirectiveNode,\n type ConstValueNode,\n type DocumentNode,\n type EnumValueDefinitionNode,\n type FieldDefinitionNode,\n type InputValueDefinitionNode,\n Kind,\n type NamedTypeNode,\n type SchemaDefinitionNode,\n type SchemaExtensionNode,\n type TypeNode,\n} from \"graphql\";\n\nconst builtinScalarTypes = new Map<string, { readonly input: string; readonly output: string }>([\n [\"ID\", { input: \"string\", output: \"string\" }],\n [\"String\", { input: \"string\", output: \"string\" }],\n [\"Int\", { input: \"number\", output: \"number\" }],\n [\"Float\", { input: \"number\", output: \"number\" }],\n [\"Boolean\", { input: \"boolean\", output: \"boolean\" }],\n]);\n\ntype OperationTypeNames = {\n query?: string;\n mutation?: string;\n subscription?: string;\n};\n\ntype ObjectRecord = {\n readonly name: string;\n readonly fields: Map<string, FieldDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype InputRecord = {\n readonly name: string;\n readonly fields: Map<string, InputValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype EnumRecord = {\n readonly name: string;\n readonly values: Map<string, EnumValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype UnionRecord = {\n readonly name: string;\n readonly members: Map<string, NamedTypeNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype ScalarRecord = {\n readonly name: string;\n directives: ConstDirectiveNode[];\n};\n\ntype SchemaIndex = {\n readonly objects: Map<string, ObjectRecord>;\n readonly inputs: Map<string, InputRecord>;\n readonly enums: Map<string, EnumRecord>;\n readonly unions: Map<string, UnionRecord>;\n readonly scalars: Map<string, ScalarRecord>;\n readonly operationTypes: OperationTypeNames;\n};\n\nconst ensureRecord = <T>(collection: Map<string, T>, key: string, factory: (name: string) => T): T => {\n const existing = collection.get(key);\n if (existing) {\n return existing;\n }\n\n const created = factory(key);\n collection.set(key, created);\n return created;\n};\n\nconst addObjectFields = (target: Map<string, FieldDefinitionNode>, fields: readonly FieldDefinitionNode[] | undefined): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addInputFields = (\n target: Map<string, InputValueDefinitionNode>,\n fields: readonly InputValueDefinitionNode[] | undefined,\n): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addEnumValues = (\n target: Map<string, EnumValueDefinitionNode>,\n values: readonly EnumValueDefinitionNode[] | undefined,\n): void => {\n if (!values) {\n return;\n }\n\n for (const value of values) {\n target.set(value.name.value, value);\n }\n};\n\nconst addUnionMembers = (target: Map<string, NamedTypeNode>, members: readonly NamedTypeNode[] | undefined): void => {\n if (!members) {\n return;\n }\n\n for (const member of members) {\n target.set(member.name.value, member);\n }\n};\n\nconst mergeDirectives = (\n existing: ConstDirectiveNode[] | undefined,\n incoming: readonly ConstDirectiveNode[] | undefined,\n precedence: \"definition\" | \"extension\",\n): ConstDirectiveNode[] => {\n const current = existing ?? [];\n const next = incoming ? Array.from(incoming) : [];\n return precedence === \"definition\" ? [...next, ...current] : [...current, ...next];\n};\n\nconst updateOperationTypes = (\n operationTypes: OperationTypeNames,\n definition: SchemaDefinitionNode | SchemaExtensionNode,\n): void => {\n for (const operation of definition.operationTypes ?? []) {\n const typeName = operation.type.name.value;\n switch (operation.operation) {\n case \"query\":\n operationTypes.query = typeName;\n break;\n case \"mutation\":\n operationTypes.mutation = typeName;\n break;\n case \"subscription\":\n operationTypes.subscription = typeName;\n break;\n default:\n break;\n }\n }\n};\n\nexport const createSchemaIndex = (document: DocumentNode): SchemaIndex => {\n const objects = new Map<string, ObjectRecord>();\n const inputs = new Map<string, InputRecord>();\n const enums = new Map<string, EnumRecord>();\n const unions = new Map<string, UnionRecord>();\n const scalars = new Map<string, ScalarRecord>();\n const operationTypes: OperationTypeNames = {};\n\n for (const definition of document.definitions) {\n switch (definition.kind) {\n case Kind.OBJECT_TYPE_DEFINITION:\n case Kind.OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(objects, definition.name.value, (name) => ({\n name,\n fields: new Map<string, FieldDefinitionNode>(),\n directives: [],\n }));\n addObjectFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.INPUT_OBJECT_TYPE_DEFINITION:\n case Kind.INPUT_OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.INPUT_OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(inputs, definition.name.value, (name) => ({\n name,\n fields: new Map<string, InputValueDefinitionNode>(),\n directives: [],\n }));\n addInputFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.ENUM_TYPE_DEFINITION:\n case Kind.ENUM_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.ENUM_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(enums, definition.name.value, (name) => ({\n name,\n values: new Map<string, EnumValueDefinitionNode>(),\n directives: [],\n }));\n addEnumValues(record.values, definition.values);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.UNION_TYPE_DEFINITION:\n case Kind.UNION_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.UNION_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(unions, definition.name.value, (name) => ({\n name,\n members: new Map<string, NamedTypeNode>(),\n directives: [],\n }));\n addUnionMembers(record.members, definition.types);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCALAR_TYPE_DEFINITION:\n case Kind.SCALAR_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.SCALAR_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(scalars, definition.name.value, (name) => ({\n name,\n directives: [],\n }));\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCHEMA_DEFINITION:\n case Kind.SCHEMA_EXTENSION:\n updateOperationTypes(operationTypes, definition);\n break;\n default:\n break;\n }\n }\n\n if (!operationTypes.query && objects.has(\"Query\")) {\n operationTypes.query = \"Query\";\n }\n if (!operationTypes.mutation && objects.has(\"Mutation\")) {\n operationTypes.mutation = \"Mutation\";\n }\n if (!operationTypes.subscription && objects.has(\"Subscription\")) {\n operationTypes.subscription = \"Subscription\";\n }\n\n return {\n objects,\n inputs,\n enums,\n unions,\n scalars,\n operationTypes,\n } satisfies SchemaIndex;\n};\n\ntype TypeLevel = {\n readonly kind: \"list\" | \"named\";\n readonly nonNull: boolean;\n};\n\nconst collectTypeLevels = (\n type: TypeNode,\n nonNull = false,\n levels: TypeLevel[] = [],\n): { readonly name: string; readonly levels: TypeLevel[] } => {\n if (type.kind === Kind.NON_NULL_TYPE) {\n return collectTypeLevels(type.type, true, levels);\n }\n\n if (type.kind === Kind.LIST_TYPE) {\n levels.push({ kind: \"list\", nonNull });\n return collectTypeLevels(type.type, false, levels);\n }\n\n levels.push({ kind: \"named\", nonNull });\n return { name: type.name.value, levels };\n};\n\nconst buildTypeModifier = (levels: TypeLevel[]): string => {\n let modifier = \"?\";\n\n for (const level of levels.slice().reverse()) {\n if (level.kind === \"named\") {\n // Inner type: always explicit nullable marker\n modifier = level.nonNull ? \"!\" : \"?\";\n continue;\n }\n\n // List type: append []? or []! based on list's nullability\n const listSuffix = level.nonNull ? \"[]!\" : \"[]?\";\n modifier = `${modifier}${listSuffix}`;\n }\n\n return modifier;\n};\n\nconst parseTypeReference = (type: TypeNode): { readonly name: string; readonly modifier: string } => {\n const { name, levels } = collectTypeLevels(type);\n return { name, modifier: buildTypeModifier(levels) };\n};\n\nconst isScalarName = (schema: SchemaIndex, name: string): boolean => builtinScalarTypes.has(name) || schema.scalars.has(name);\nconst isEnumName = (schema: SchemaIndex, name: string): boolean => schema.enums.has(name);\nconst _isInputName = (schema: SchemaIndex, name: string): boolean => schema.inputs.has(name);\nconst isUnionName = (schema: SchemaIndex, name: string): boolean => schema.unions.has(name);\nconst isObjectName = (schema: SchemaIndex, name: string): boolean => schema.objects.has(name);\n\nconst renderConstValue = (value: ConstValueNode): string => {\n switch (value.kind) {\n case Kind.NULL:\n return \"null\";\n case Kind.INT:\n case Kind.FLOAT:\n return value.value;\n case Kind.STRING:\n case Kind.ENUM:\n return JSON.stringify(value.value);\n case Kind.BOOLEAN:\n return value.value ? \"true\" : \"false\";\n case Kind.LIST:\n return `[${value.values.map((item) => renderConstValue(item)).join(\", \")}]`;\n case Kind.OBJECT: {\n if (value.fields.length === 0) {\n return \"{}\";\n }\n const entries = value.fields.map((field) => `${field.name.value}: ${renderConstValue(field.value)}`);\n return `{ ${entries.join(\", \")} }`;\n }\n }\n};\n\nconst renderConstArgumentMap = (\n args: readonly { readonly name: { readonly value: string }; readonly value: ConstValueNode }[] | undefined,\n): string => {\n const entries = (args ?? []).map((arg) => `${arg.name.value}: ${renderConstValue(arg.value)}`);\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDirectives = (directives: readonly ConstDirectiveNode[] | undefined): string => {\n const entries = (directives ?? []).map(\n (directive) => `${directive.name.value}: ${renderConstArgumentMap(directive.arguments)}`,\n );\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDefaultValue = (value: ConstValueNode | null | undefined): string =>\n value ? `() => (${renderConstValue(value)})` : \"null\";\n\nconst renderInputRef = (schema: SchemaIndex, definition: InputValueDefinitionNode): string => {\n const { name, modifier } = parseTypeReference(definition.type);\n const defaultValue = renderDefaultValue(definition.defaultValue ?? null);\n const directives = renderDirectives(definition.directives);\n\n let kind: \"scalar\" | \"enum\" | \"input\";\n if (isScalarName(schema, name)) {\n kind = \"scalar\";\n } else if (isEnumName(schema, name)) {\n kind = \"enum\";\n } else {\n kind = \"input\";\n }\n\n return `{ kind: \"${kind}\", name: \"${name}\", modifier: \"${modifier}\", defaultValue: ${defaultValue}, directives: ${directives} }`;\n};\n\nconst renderArgumentMap = (schema: SchemaIndex, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const entries = [...(args ?? [])]\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((arg) => `${arg.name.value}: ${renderInputRef(schema, arg)}`);\n\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderOutputRef = (schema: SchemaIndex, type: TypeNode, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const { name, modifier } = parseTypeReference(type);\n const argumentMap = renderArgumentMap(schema, args);\n\n let kind: \"scalar\" | \"enum\" | \"union\" | \"object\";\n if (isScalarName(schema, name)) {\n kind = \"scalar\";\n } else if (isEnumName(schema, name)) {\n kind = \"enum\";\n } else if (isUnionName(schema, name)) {\n kind = \"union\";\n } else if (isObjectName(schema, name)) {\n kind = \"object\";\n } else {\n kind = \"scalar\"; // fallback for unknown types\n }\n\n return `{ kind: \"${kind}\", name: \"${name}\", modifier: \"${modifier}\", arguments: ${argumentMap} }`;\n};\n\nconst renderPropertyLines = ({ entries, indentSize }: { entries: string[]; indentSize: number }) => {\n if (entries.length === 0) {\n return \"{}\";\n }\n\n const indent = \" \".repeat(indentSize);\n const lastIndent = \" \".repeat(indentSize - 2);\n return [\"{\", `${indent}${entries.join(`,\\n${indent}`)},`, `${lastIndent}}`].join(`\\n`);\n};\n\nconst renderObjectFields = (schema: SchemaIndex, fields: Map<string, FieldDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderOutputRef(schema, field.type, field.arguments)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\nconst renderInputFields = (schema: SchemaIndex, fields: Map<string, InputValueDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderInputRef(schema, field)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\nconst renderScalarDefinition = (record: ScalarRecord): string => {\n const typeInfo = builtinScalarTypes.get(record.name) ?? { input: \"string\", output: \"string\" };\n return `${record.name}: { name: \"${record.name}\", $type: {} as { input: ${typeInfo.input}; output: ${typeInfo.output}; inputProfile: { kind: \"scalar\"; name: \"${record.name}\"; value: ${typeInfo.input} }; outputProfile: { kind: \"scalar\"; name: \"${record.name}\"; value: ${typeInfo.output} } } }`;\n};\n\nconst renderObjectDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.objects.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const fields = renderObjectFields(schema, record.fields);\n return `${record.name}: { name: \"${record.name}\", fields: ${fields} }`;\n};\n\nconst renderInputDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.inputs.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const fields = renderInputFields(schema, record.fields);\n return `${record.name}: { name: \"${record.name}\", fields: ${fields} }`;\n};\n\nconst renderEnumDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.enums.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const valueNames = Array.from(record.values.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((value) => value.name.value);\n const valuesObj = valueNames.length === 0 ? \"{}\" : `{ ${valueNames.map((v) => `${v}: true`).join(\", \")} }`;\n const valueUnion = valueNames.length === 0 ? \"never\" : valueNames.map((v) => `\"${v}\"`).join(\" | \");\n\n return `${record.name}: { name: \"${record.name}\", values: ${valuesObj}, $type: {} as { name: \"${record.name}\"; inputProfile: { kind: \"enum\"; name: \"${record.name}\"; value: ${valueUnion} }; outputProfile: { kind: \"enum\"; name: \"${record.name}\"; value: ${valueUnion} } } }`;\n};\n\nconst renderUnionDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.unions.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const memberNames = Array.from(record.members.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((member) => member.name.value);\n const typesObj = memberNames.length === 0 ? \"{}\" : `{ ${memberNames.map((m) => `${m}: true`).join(\", \")} }`;\n\n return `${record.name}: { name: \"${record.name}\", types: ${typesObj} }`;\n};\n\nconst collectObjectTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.objects.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst renderFragmentBuildersType = (objectTypeNames: string[], schemaName: string, adapterTypeName?: string): string => {\n if (objectTypeNames.length === 0) {\n return `type FragmentBuilders_${schemaName} = Record<string, never>;`;\n }\n\n const adapterPart = adapterTypeName ? `, ExtractMetadataAdapter<${adapterTypeName}>` : \"\";\n const entries = objectTypeNames.map(\n (name) => ` readonly ${name}: FragmentBuilderFor<Schema_${schemaName}, \"${name}\"${adapterPart}>`,\n );\n return `type FragmentBuilders_${schemaName} = {\\n${entries.join(\";\\n\")};\\n};`;\n};\n\nconst collectInputTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.inputs.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectEnumTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.enums.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectUnionTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.unions.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectScalarNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.scalars.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst renderInputTypeMethod = (factoryVar: string, kind: \"scalar\" | \"enum\" | \"input\", typeName: string): string =>\n `${typeName}: ${factoryVar}(\"${kind}\", \"${typeName}\")`;\n\nconst renderInputTypeMethods = (schema: SchemaIndex, factoryVar: string): string => {\n const scalarMethods = Array.from(builtinScalarTypes.keys())\n .concat(collectScalarNames(schema).filter((name) => !builtinScalarTypes.has(name)))\n .map((name) => renderInputTypeMethod(factoryVar, \"scalar\", name));\n\n const enumMethods = collectEnumTypeNames(schema).map((name) => renderInputTypeMethod(factoryVar, \"enum\", name));\n\n const inputMethods = collectInputTypeNames(schema).map((name) => renderInputTypeMethod(factoryVar, \"input\", name));\n\n const allMethods = [...scalarMethods, ...enumMethods, ...inputMethods].sort((left, right) => {\n const leftName = left.split(\":\")[0] ?? \"\";\n const rightName = right.split(\":\")[0] ?? \"\";\n return leftName.localeCompare(rightName);\n });\n\n return renderPropertyLines({ entries: allMethods, indentSize: 2 });\n};\n\nexport type GeneratedModule = {\n readonly code: string;\n readonly stats: {\n readonly objects: number;\n readonly enums: number;\n readonly inputs: number;\n readonly unions: number;\n };\n};\n\ntype PerSchemaInjection = {\n readonly scalarImportPath: string;\n readonly adapterImportPath?: string;\n};\n\ntype RuntimeTemplateInjection =\n | { readonly mode: \"inline\" }\n | {\n readonly mode: \"inject\";\n readonly perSchema: Map<string, PerSchemaInjection>;\n };\n\nexport type RuntimeGenerationOptions = {\n readonly injection?: Map<string, PerSchemaInjection>;\n readonly defaultInputDepth?: Map<string, number>;\n readonly inputDepthOverrides?: Map<string, Readonly<Record<string, number>>>;\n};\n\ntype MultiRuntimeTemplateOptions = {\n readonly schemas: Record<\n string,\n {\n readonly queryType: string;\n readonly mutationType: string;\n readonly subscriptionType: string;\n readonly scalarBlock: string;\n readonly enumBlock: string;\n readonly inputBlock: string;\n readonly objectBlock: string;\n readonly unionBlock: string;\n readonly inputTypeMethodsBlock: string;\n readonly fragmentBuildersTypeBlock: string;\n readonly defaultInputDepth?: number;\n readonly inputDepthOverrides?: Readonly<Record<string, number>>;\n }\n >;\n readonly injection: RuntimeTemplateInjection;\n};\n\nconst multiRuntimeTemplate = ($$: MultiRuntimeTemplateOptions) => {\n // Build imports based on injection mode\n const imports: string[] = [];\n const scalarAliases = new Map<string, string>();\n const adapterAliases = new Map<string, string>();\n\n if ($$.injection.mode === \"inject\") {\n // Group imports by file path\n const importsByPath = new Map<string, string[]>();\n\n for (const [schemaName, injection] of $$.injection.perSchema) {\n const scalarAlias = `scalar_${schemaName}`;\n scalarAliases.set(schemaName, scalarAlias);\n\n // Group scalar import\n const scalarSpecifiers = importsByPath.get(injection.scalarImportPath) ?? [];\n if (!importsByPath.has(injection.scalarImportPath)) {\n importsByPath.set(injection.scalarImportPath, scalarSpecifiers);\n }\n scalarSpecifiers.push(`scalar as ${scalarAlias}`);\n\n // Group adapter import (optional)\n if (injection.adapterImportPath) {\n const adapterAlias = `adapter_${schemaName}`;\n adapterAliases.set(schemaName, adapterAlias);\n const adapterSpecifiers = importsByPath.get(injection.adapterImportPath) ?? [];\n if (!importsByPath.has(injection.adapterImportPath)) {\n importsByPath.set(injection.adapterImportPath, adapterSpecifiers);\n }\n adapterSpecifiers.push(`adapter as ${adapterAlias}`);\n }\n }\n\n // Generate grouped imports\n for (const [path, specifiers] of importsByPath) {\n if (specifiers.length === 1) {\n imports.push(`import { ${specifiers[0]} } from \"${path}\";`);\n } else {\n imports.push(`import {\\n ${specifiers.join(\",\\n \")},\\n} from \"${path}\";`);\n }\n }\n }\n\n const extraImports = imports.length > 0 ? `${imports.join(\"\\n\")}\\n` : \"\";\n\n // Generate per-schema definitions\n const schemaBlocks: string[] = [];\n const gqlEntries: string[] = [];\n\n for (const [name, config] of Object.entries($$.schemas)) {\n const schemaVar = `${name}Schema`;\n const scalarBlock = $$.injection.mode === \"inject\" ? scalarAliases.get(name) : config.scalarBlock;\n\n // Get optional adapter\n const adapterVar = adapterAliases.get(name);\n\n // Build type exports with fragment builders type\n const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`];\n if (adapterVar) {\n typeExports.push(`export type Adapter_${name} = typeof ${adapterVar} & { _?: never };`);\n }\n typeExports.push(config.fragmentBuildersTypeBlock);\n\n const inputTypeMethodsVar = `inputTypeMethods_${name}`;\n const factoryVar = `createMethod_${name}`;\n\n // Generate __defaultInputDepth block if non-default value\n const defaultDepthBlock =\n config.defaultInputDepth !== undefined && config.defaultInputDepth !== 3\n ? `\\n __defaultInputDepth: ${config.defaultInputDepth},`\n : \"\";\n\n // Generate __inputDepthOverrides block if there are overrides\n const depthOverridesBlock =\n config.inputDepthOverrides && Object.keys(config.inputDepthOverrides).length > 0\n ? `\\n __inputDepthOverrides: ${JSON.stringify(config.inputDepthOverrides)},`\n : \"\";\n\n schemaBlocks.push(`\nconst ${schemaVar} = {\n label: \"${name}\",\n operations: { query: \"${config.queryType}\", mutation: \"${config.mutationType}\", subscription: \"${config.subscriptionType}\" },\n scalar: ${scalarBlock},\n enum: ${config.enumBlock},\n input: ${config.inputBlock},\n object: ${config.objectBlock},\n union: ${config.unionBlock},${defaultDepthBlock}${depthOverridesBlock}\n} as const;\n\nconst ${factoryVar} = createVarMethodFactory<typeof ${schemaVar}>();\nconst ${inputTypeMethodsVar} = ${config.inputTypeMethodsBlock} satisfies InputTypeMethods<typeof ${schemaVar}>;\n\n${typeExports.join(\"\\n\")}`);\n\n // Build gql entry with options - inputTypeMethods is always required\n // Include FragmentBuilders type for codegen optimization\n if (adapterVar) {\n const typeParams = `<Schema_${name}, FragmentBuilders_${name}, Adapter_${name}>`;\n gqlEntries.push(\n ` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { adapter: ${adapterVar}, inputTypeMethods: ${inputTypeMethodsVar} })`,\n );\n } else {\n const typeParams = `<Schema_${name}, FragmentBuilders_${name}>`;\n gqlEntries.push(\n ` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { inputTypeMethods: ${inputTypeMethodsVar} })`,\n );\n }\n }\n\n return `\\\nimport {\n type ExtractMetadataAdapter,\n type FragmentBuilderFor,\n type InputTypeMethods,\n createGqlElementComposer,\n createVarMethodFactory,\n} from \"@soda-gql/core\";\n${extraImports}\n${schemaBlocks.join(\"\\n\")}\n\nexport const gql = {\n${gqlEntries.join(\",\\n\")}\n};\n`;\n};\n\nexport const generateMultiSchemaModule = (\n schemas: Map<string, DocumentNode>,\n options?: RuntimeGenerationOptions,\n): GeneratedModule => {\n // biome-ignore lint/suspicious/noExplicitAny: complex schema config type\n const schemaConfigs: Record<string, any> = {};\n const allStats = {\n objects: 0,\n enums: 0,\n inputs: 0,\n unions: 0,\n };\n\n for (const [name, document] of schemas.entries()) {\n const schema = createSchemaIndex(document);\n\n const builtinScalarDefinitions = Array.from(builtinScalarTypes.keys()).map((name) =>\n renderScalarDefinition(schema.scalars.get(name) ?? { name, directives: [] }),\n );\n\n const customScalarDefinitions = collectScalarNames(schema)\n .filter((name) => !builtinScalarTypes.has(name))\n .map((name) => {\n const record = schema.scalars.get(name);\n return record ? renderScalarDefinition(record) : \"\";\n })\n .filter((definition) => definition.length > 0);\n\n const allScalarDefinitions = builtinScalarDefinitions.concat(customScalarDefinitions);\n\n const objectTypeNames = collectObjectTypeNames(schema);\n const enumTypeNames = collectEnumTypeNames(schema);\n const inputTypeNames = collectInputTypeNames(schema);\n const unionTypeNames = collectUnionTypeNames(schema);\n\n const scalarBlock = renderPropertyLines({ entries: allScalarDefinitions, indentSize: 4 });\n const enumDefinitions = enumTypeNames\n .map((name) => renderEnumDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const enumBlock = renderPropertyLines({ entries: enumDefinitions, indentSize: 4 });\n const inputDefinitions = inputTypeNames\n .map((name) => renderInputDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const inputBlock = renderPropertyLines({ entries: inputDefinitions, indentSize: 4 });\n const objectDefinitions = objectTypeNames\n .map((name) => renderObjectDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const objectBlock = renderPropertyLines({ entries: objectDefinitions, indentSize: 4 });\n const unionDefinitions = unionTypeNames\n .map((name) => renderUnionDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const unionBlock = renderPropertyLines({ entries: unionDefinitions, indentSize: 4 });\n\n const factoryVar = `createMethod_${name}`;\n const inputTypeMethodsBlock = renderInputTypeMethods(schema, factoryVar);\n // Pass adapter type name if injection has adapter for this schema\n const adapterTypeName = options?.injection?.get(name)?.adapterImportPath ? `Adapter_${name}` : undefined;\n const fragmentBuildersTypeBlock = renderFragmentBuildersType(objectTypeNames, name, adapterTypeName);\n\n const queryType = schema.operationTypes.query ?? \"Query\";\n const mutationType = schema.operationTypes.mutation ?? \"Mutation\";\n const subscriptionType = schema.operationTypes.subscription ?? \"Subscription\";\n\n schemaConfigs[name] = {\n queryType,\n mutationType,\n subscriptionType,\n scalarBlock,\n enumBlock,\n inputBlock,\n objectBlock,\n unionBlock,\n inputTypeMethodsBlock,\n fragmentBuildersTypeBlock,\n defaultInputDepth: options?.defaultInputDepth?.get(name),\n inputDepthOverrides: options?.inputDepthOverrides?.get(name),\n };\n\n // Accumulate stats\n allStats.objects += objectDefinitions.length;\n allStats.enums += enumDefinitions.length;\n allStats.inputs += inputDefinitions.length;\n allStats.unions += unionDefinitions.length;\n }\n\n const injection: RuntimeTemplateInjection = options?.injection\n ? { mode: \"inject\", perSchema: options.injection }\n : { mode: \"inline\" };\n\n const code = multiRuntimeTemplate({\n schemas: schemaConfigs,\n injection,\n });\n\n return {\n code,\n stats: allStats,\n };\n};\n"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generator-DEyKWZwB.mjs","names":["operationTypes: OperationTypeNames","kind: \"scalar\" | \"enum\" | \"input\"","kind: \"scalar\" | \"enum\" | \"union\" | \"object\"","imports: string[]","schemaBlocks: string[]","gqlEntries: string[]","schemaConfigs: Record<string, any>","name","injection: RuntimeTemplateInjection"],"sources":["../src/generator.ts"],"sourcesContent":["import {\n type ConstDirectiveNode,\n type ConstValueNode,\n type DocumentNode,\n type EnumValueDefinitionNode,\n type FieldDefinitionNode,\n type InputValueDefinitionNode,\n Kind,\n type NamedTypeNode,\n type SchemaDefinitionNode,\n type SchemaExtensionNode,\n type TypeNode,\n} from \"graphql\";\n\nconst builtinScalarTypes = new Map<string, { readonly input: string; readonly output: string }>([\n [\"ID\", { input: \"string\", output: \"string\" }],\n [\"String\", { input: \"string\", output: \"string\" }],\n [\"Int\", { input: \"number\", output: \"number\" }],\n [\"Float\", { input: \"number\", output: \"number\" }],\n [\"Boolean\", { input: \"boolean\", output: \"boolean\" }],\n]);\n\ntype OperationTypeNames = {\n query?: string;\n mutation?: string;\n subscription?: string;\n};\n\ntype ObjectRecord = {\n readonly name: string;\n readonly fields: Map<string, FieldDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype InputRecord = {\n readonly name: string;\n readonly fields: Map<string, InputValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype EnumRecord = {\n readonly name: string;\n readonly values: Map<string, EnumValueDefinitionNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype UnionRecord = {\n readonly name: string;\n readonly members: Map<string, NamedTypeNode>;\n directives: ConstDirectiveNode[];\n};\n\ntype ScalarRecord = {\n readonly name: string;\n directives: ConstDirectiveNode[];\n};\n\ntype SchemaIndex = {\n readonly objects: Map<string, ObjectRecord>;\n readonly inputs: Map<string, InputRecord>;\n readonly enums: Map<string, EnumRecord>;\n readonly unions: Map<string, UnionRecord>;\n readonly scalars: Map<string, ScalarRecord>;\n readonly operationTypes: OperationTypeNames;\n};\n\nconst ensureRecord = <T>(collection: Map<string, T>, key: string, factory: (name: string) => T): T => {\n const existing = collection.get(key);\n if (existing) {\n return existing;\n }\n\n const created = factory(key);\n collection.set(key, created);\n return created;\n};\n\nconst addObjectFields = (target: Map<string, FieldDefinitionNode>, fields: readonly FieldDefinitionNode[] | undefined): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addInputFields = (\n target: Map<string, InputValueDefinitionNode>,\n fields: readonly InputValueDefinitionNode[] | undefined,\n): void => {\n if (!fields) {\n return;\n }\n\n for (const field of fields) {\n target.set(field.name.value, field);\n }\n};\n\nconst addEnumValues = (\n target: Map<string, EnumValueDefinitionNode>,\n values: readonly EnumValueDefinitionNode[] | undefined,\n): void => {\n if (!values) {\n return;\n }\n\n for (const value of values) {\n target.set(value.name.value, value);\n }\n};\n\nconst addUnionMembers = (target: Map<string, NamedTypeNode>, members: readonly NamedTypeNode[] | undefined): void => {\n if (!members) {\n return;\n }\n\n for (const member of members) {\n target.set(member.name.value, member);\n }\n};\n\nconst mergeDirectives = (\n existing: ConstDirectiveNode[] | undefined,\n incoming: readonly ConstDirectiveNode[] | undefined,\n precedence: \"definition\" | \"extension\",\n): ConstDirectiveNode[] => {\n const current = existing ?? [];\n const next = incoming ? Array.from(incoming) : [];\n return precedence === \"definition\" ? [...next, ...current] : [...current, ...next];\n};\n\nconst updateOperationTypes = (\n operationTypes: OperationTypeNames,\n definition: SchemaDefinitionNode | SchemaExtensionNode,\n): void => {\n for (const operation of definition.operationTypes ?? []) {\n const typeName = operation.type.name.value;\n switch (operation.operation) {\n case \"query\":\n operationTypes.query = typeName;\n break;\n case \"mutation\":\n operationTypes.mutation = typeName;\n break;\n case \"subscription\":\n operationTypes.subscription = typeName;\n break;\n default:\n break;\n }\n }\n};\n\nexport const createSchemaIndex = (document: DocumentNode): SchemaIndex => {\n const objects = new Map<string, ObjectRecord>();\n const inputs = new Map<string, InputRecord>();\n const enums = new Map<string, EnumRecord>();\n const unions = new Map<string, UnionRecord>();\n const scalars = new Map<string, ScalarRecord>();\n const operationTypes: OperationTypeNames = {};\n\n for (const definition of document.definitions) {\n switch (definition.kind) {\n case Kind.OBJECT_TYPE_DEFINITION:\n case Kind.OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(objects, definition.name.value, (name) => ({\n name,\n fields: new Map<string, FieldDefinitionNode>(),\n directives: [],\n }));\n addObjectFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.INPUT_OBJECT_TYPE_DEFINITION:\n case Kind.INPUT_OBJECT_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.INPUT_OBJECT_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(inputs, definition.name.value, (name) => ({\n name,\n fields: new Map<string, InputValueDefinitionNode>(),\n directives: [],\n }));\n addInputFields(record.fields, definition.fields);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.ENUM_TYPE_DEFINITION:\n case Kind.ENUM_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.ENUM_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(enums, definition.name.value, (name) => ({\n name,\n values: new Map<string, EnumValueDefinitionNode>(),\n directives: [],\n }));\n addEnumValues(record.values, definition.values);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.UNION_TYPE_DEFINITION:\n case Kind.UNION_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.UNION_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(unions, definition.name.value, (name) => ({\n name,\n members: new Map<string, NamedTypeNode>(),\n directives: [],\n }));\n addUnionMembers(record.members, definition.types);\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCALAR_TYPE_DEFINITION:\n case Kind.SCALAR_TYPE_EXTENSION: {\n const precedence = definition.kind === Kind.SCALAR_TYPE_DEFINITION ? \"definition\" : \"extension\";\n const record = ensureRecord(scalars, definition.name.value, (name) => ({\n name,\n directives: [],\n }));\n record.directives = mergeDirectives(record.directives, definition.directives, precedence);\n break;\n }\n case Kind.SCHEMA_DEFINITION:\n case Kind.SCHEMA_EXTENSION:\n updateOperationTypes(operationTypes, definition);\n break;\n default:\n break;\n }\n }\n\n if (!operationTypes.query && objects.has(\"Query\")) {\n operationTypes.query = \"Query\";\n }\n if (!operationTypes.mutation && objects.has(\"Mutation\")) {\n operationTypes.mutation = \"Mutation\";\n }\n if (!operationTypes.subscription && objects.has(\"Subscription\")) {\n operationTypes.subscription = \"Subscription\";\n }\n\n return {\n objects,\n inputs,\n enums,\n unions,\n scalars,\n operationTypes,\n } satisfies SchemaIndex;\n};\n\ntype TypeLevel = {\n readonly kind: \"list\" | \"named\";\n readonly nonNull: boolean;\n};\n\nconst collectTypeLevels = (\n type: TypeNode,\n nonNull = false,\n levels: TypeLevel[] = [],\n): { readonly name: string; readonly levels: TypeLevel[] } => {\n if (type.kind === Kind.NON_NULL_TYPE) {\n return collectTypeLevels(type.type, true, levels);\n }\n\n if (type.kind === Kind.LIST_TYPE) {\n levels.push({ kind: \"list\", nonNull });\n return collectTypeLevels(type.type, false, levels);\n }\n\n levels.push({ kind: \"named\", nonNull });\n return { name: type.name.value, levels };\n};\n\nconst buildTypeModifier = (levels: TypeLevel[]): string => {\n let modifier = \"?\";\n\n for (const level of levels.slice().reverse()) {\n if (level.kind === \"named\") {\n // Inner type: always explicit nullable marker\n modifier = level.nonNull ? \"!\" : \"?\";\n continue;\n }\n\n // List type: append []? or []! based on list's nullability\n const listSuffix = level.nonNull ? \"[]!\" : \"[]?\";\n modifier = `${modifier}${listSuffix}`;\n }\n\n return modifier;\n};\n\nconst parseTypeReference = (type: TypeNode): { readonly name: string; readonly modifier: string } => {\n const { name, levels } = collectTypeLevels(type);\n return { name, modifier: buildTypeModifier(levels) };\n};\n\nconst isScalarName = (schema: SchemaIndex, name: string): boolean => builtinScalarTypes.has(name) || schema.scalars.has(name);\nconst isEnumName = (schema: SchemaIndex, name: string): boolean => schema.enums.has(name);\nconst _isInputName = (schema: SchemaIndex, name: string): boolean => schema.inputs.has(name);\nconst isUnionName = (schema: SchemaIndex, name: string): boolean => schema.unions.has(name);\nconst isObjectName = (schema: SchemaIndex, name: string): boolean => schema.objects.has(name);\n\nconst renderConstValue = (value: ConstValueNode): string => {\n switch (value.kind) {\n case Kind.NULL:\n return \"null\";\n case Kind.INT:\n case Kind.FLOAT:\n return value.value;\n case Kind.STRING:\n case Kind.ENUM:\n return JSON.stringify(value.value);\n case Kind.BOOLEAN:\n return value.value ? \"true\" : \"false\";\n case Kind.LIST:\n return `[${value.values.map((item) => renderConstValue(item)).join(\", \")}]`;\n case Kind.OBJECT: {\n if (value.fields.length === 0) {\n return \"{}\";\n }\n const entries = value.fields.map((field) => `${field.name.value}: ${renderConstValue(field.value)}`);\n return `{ ${entries.join(\", \")} }`;\n }\n }\n};\n\nconst renderConstArgumentMap = (\n args: readonly { readonly name: { readonly value: string }; readonly value: ConstValueNode }[] | undefined,\n): string => {\n const entries = (args ?? []).map((arg) => `${arg.name.value}: ${renderConstValue(arg.value)}`);\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDirectives = (directives: readonly ConstDirectiveNode[] | undefined): string => {\n const entries = (directives ?? []).map(\n (directive) => `${directive.name.value}: ${renderConstArgumentMap(directive.arguments)}`,\n );\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderDefaultValue = (value: ConstValueNode | null | undefined): string =>\n value ? `() => (${renderConstValue(value)})` : \"null\";\n\nconst renderInputRef = (schema: SchemaIndex, definition: InputValueDefinitionNode): string => {\n const { name, modifier } = parseTypeReference(definition.type);\n const defaultValue = renderDefaultValue(definition.defaultValue ?? null);\n const directives = renderDirectives(definition.directives);\n\n let kind: \"scalar\" | \"enum\" | \"input\";\n if (isScalarName(schema, name)) {\n kind = \"scalar\";\n } else if (isEnumName(schema, name)) {\n kind = \"enum\";\n } else {\n kind = \"input\";\n }\n\n return `{ kind: \"${kind}\", name: \"${name}\", modifier: \"${modifier}\", defaultValue: ${defaultValue}, directives: ${directives} }`;\n};\n\nconst renderArgumentMap = (schema: SchemaIndex, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const entries = [...(args ?? [])]\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((arg) => `${arg.name.value}: ${renderInputRef(schema, arg)}`);\n\n return renderPropertyLines({ entries, indentSize: 8 });\n};\n\nconst renderOutputRef = (schema: SchemaIndex, type: TypeNode, args: readonly InputValueDefinitionNode[] | undefined): string => {\n const { name, modifier } = parseTypeReference(type);\n const argumentMap = renderArgumentMap(schema, args);\n\n let kind: \"scalar\" | \"enum\" | \"union\" | \"object\";\n if (isScalarName(schema, name)) {\n kind = \"scalar\";\n } else if (isEnumName(schema, name)) {\n kind = \"enum\";\n } else if (isUnionName(schema, name)) {\n kind = \"union\";\n } else if (isObjectName(schema, name)) {\n kind = \"object\";\n } else {\n kind = \"scalar\"; // fallback for unknown types\n }\n\n return `{ kind: \"${kind}\", name: \"${name}\", modifier: \"${modifier}\", arguments: ${argumentMap} }`;\n};\n\nconst renderPropertyLines = ({ entries, indentSize }: { entries: string[]; indentSize: number }) => {\n if (entries.length === 0) {\n return \"{}\";\n }\n\n const indent = \" \".repeat(indentSize);\n const lastIndent = \" \".repeat(indentSize - 2);\n return [\"{\", `${indent}${entries.join(`,\\n${indent}`)},`, `${lastIndent}}`].join(`\\n`);\n};\n\nconst renderObjectFields = (schema: SchemaIndex, fields: Map<string, FieldDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderOutputRef(schema, field.type, field.arguments)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\nconst renderInputFields = (schema: SchemaIndex, fields: Map<string, InputValueDefinitionNode>): string => {\n const entries = Array.from(fields.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((field) => `${field.name.value}: ${renderInputRef(schema, field)}`);\n\n return renderPropertyLines({ entries, indentSize: 6 });\n};\n\nconst renderScalarDefinition = (record: ScalarRecord): string => {\n const typeInfo = builtinScalarTypes.get(record.name) ?? { input: \"string\", output: \"string\" };\n return `${record.name}: { name: \"${record.name}\", $type: {} as { input: ${typeInfo.input}; output: ${typeInfo.output}; inputProfile: { kind: \"scalar\"; name: \"${record.name}\"; value: ${typeInfo.input} }; outputProfile: { kind: \"scalar\"; name: \"${record.name}\"; value: ${typeInfo.output} } } }`;\n};\n\nconst renderObjectDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.objects.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const fields = renderObjectFields(schema, record.fields);\n return `${record.name}: { name: \"${record.name}\", fields: ${fields} }`;\n};\n\nconst renderInputDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.inputs.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const fields = renderInputFields(schema, record.fields);\n return `${record.name}: { name: \"${record.name}\", fields: ${fields} }`;\n};\n\nconst renderEnumDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.enums.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const valueNames = Array.from(record.values.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((value) => value.name.value);\n const valuesObj = valueNames.length === 0 ? \"{}\" : `{ ${valueNames.map((v) => `${v}: true`).join(\", \")} }`;\n const valueUnion = valueNames.length === 0 ? \"never\" : valueNames.map((v) => `\"${v}\"`).join(\" | \");\n\n return `${record.name}: { name: \"${record.name}\", values: ${valuesObj}, $type: {} as { name: \"${record.name}\"; inputProfile: { kind: \"enum\"; name: \"${record.name}\"; value: ${valueUnion} }; outputProfile: { kind: \"enum\"; name: \"${record.name}\"; value: ${valueUnion} } } }`;\n};\n\nconst renderUnionDefinition = (schema: SchemaIndex, typeName: string): string => {\n const record = schema.unions.get(typeName);\n if (!record) {\n return \"\";\n }\n\n const memberNames = Array.from(record.members.values())\n .sort((left, right) => left.name.value.localeCompare(right.name.value))\n .map((member) => member.name.value);\n const typesObj = memberNames.length === 0 ? \"{}\" : `{ ${memberNames.map((m) => `${m}: true`).join(\", \")} }`;\n\n return `${record.name}: { name: \"${record.name}\", types: ${typesObj} }`;\n};\n\nconst collectObjectTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.objects.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst renderFragmentBuildersType = (objectTypeNames: string[], schemaName: string, adapterTypeName?: string): string => {\n if (objectTypeNames.length === 0) {\n return `type FragmentBuilders_${schemaName} = Record<string, never>;`;\n }\n\n const adapterPart = adapterTypeName ? `, ExtractMetadataAdapter<${adapterTypeName}>` : \"\";\n const entries = objectTypeNames.map(\n (name) => ` readonly ${name}: FragmentBuilderFor<Schema_${schemaName}, \"${name}\"${adapterPart}>`,\n );\n return `type FragmentBuilders_${schemaName} = {\\n${entries.join(\";\\n\")};\\n};`;\n};\n\nconst collectInputTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.inputs.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectEnumTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.enums.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectUnionTypeNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.unions.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst collectScalarNames = (schema: SchemaIndex): string[] =>\n Array.from(schema.scalars.keys())\n .filter((name) => !name.startsWith(\"__\"))\n .sort((left, right) => left.localeCompare(right));\n\nconst renderInputTypeMethod = (factoryVar: string, kind: \"scalar\" | \"enum\" | \"input\", typeName: string): string =>\n `${typeName}: ${factoryVar}(\"${kind}\", \"${typeName}\")`;\n\nconst renderInputTypeMethods = (schema: SchemaIndex, factoryVar: string): string => {\n const scalarMethods = Array.from(builtinScalarTypes.keys())\n .concat(collectScalarNames(schema).filter((name) => !builtinScalarTypes.has(name)))\n .map((name) => renderInputTypeMethod(factoryVar, \"scalar\", name));\n\n const enumMethods = collectEnumTypeNames(schema).map((name) => renderInputTypeMethod(factoryVar, \"enum\", name));\n\n const inputMethods = collectInputTypeNames(schema).map((name) => renderInputTypeMethod(factoryVar, \"input\", name));\n\n const allMethods = [...scalarMethods, ...enumMethods, ...inputMethods].sort((left, right) => {\n const leftName = left.split(\":\")[0] ?? \"\";\n const rightName = right.split(\":\")[0] ?? \"\";\n return leftName.localeCompare(rightName);\n });\n\n return renderPropertyLines({ entries: allMethods, indentSize: 2 });\n};\n\nexport type GeneratedModule = {\n readonly code: string;\n readonly stats: {\n readonly objects: number;\n readonly enums: number;\n readonly inputs: number;\n readonly unions: number;\n };\n};\n\ntype PerSchemaInjection = {\n readonly scalarImportPath: string;\n readonly adapterImportPath?: string;\n};\n\ntype RuntimeTemplateInjection =\n | { readonly mode: \"inline\" }\n | {\n readonly mode: \"inject\";\n readonly perSchema: Map<string, PerSchemaInjection>;\n };\n\nexport type RuntimeGenerationOptions = {\n readonly injection?: Map<string, PerSchemaInjection>;\n readonly defaultInputDepth?: Map<string, number>;\n readonly inputDepthOverrides?: Map<string, Readonly<Record<string, number>>>;\n};\n\ntype MultiRuntimeTemplateOptions = {\n readonly schemas: Record<\n string,\n {\n readonly queryType: string;\n readonly mutationType: string;\n readonly subscriptionType: string;\n readonly scalarBlock: string;\n readonly enumBlock: string;\n readonly inputBlock: string;\n readonly objectBlock: string;\n readonly unionBlock: string;\n readonly inputTypeMethodsBlock: string;\n readonly fragmentBuildersTypeBlock: string;\n readonly defaultInputDepth?: number;\n readonly inputDepthOverrides?: Readonly<Record<string, number>>;\n }\n >;\n readonly injection: RuntimeTemplateInjection;\n};\n\nconst multiRuntimeTemplate = ($$: MultiRuntimeTemplateOptions) => {\n // Build imports based on injection mode\n const imports: string[] = [];\n const scalarAliases = new Map<string, string>();\n const adapterAliases = new Map<string, string>();\n\n if ($$.injection.mode === \"inject\") {\n // Group imports by file path\n const importsByPath = new Map<string, string[]>();\n\n for (const [schemaName, injection] of $$.injection.perSchema) {\n const scalarAlias = `scalar_${schemaName}`;\n scalarAliases.set(schemaName, scalarAlias);\n\n // Group scalar import\n const scalarSpecifiers = importsByPath.get(injection.scalarImportPath) ?? [];\n if (!importsByPath.has(injection.scalarImportPath)) {\n importsByPath.set(injection.scalarImportPath, scalarSpecifiers);\n }\n scalarSpecifiers.push(`scalar as ${scalarAlias}`);\n\n // Group adapter import (optional)\n if (injection.adapterImportPath) {\n const adapterAlias = `adapter_${schemaName}`;\n adapterAliases.set(schemaName, adapterAlias);\n const adapterSpecifiers = importsByPath.get(injection.adapterImportPath) ?? [];\n if (!importsByPath.has(injection.adapterImportPath)) {\n importsByPath.set(injection.adapterImportPath, adapterSpecifiers);\n }\n adapterSpecifiers.push(`adapter as ${adapterAlias}`);\n }\n }\n\n // Generate grouped imports\n for (const [path, specifiers] of importsByPath) {\n if (specifiers.length === 1) {\n imports.push(`import { ${specifiers[0]} } from \"${path}\";`);\n } else {\n imports.push(`import {\\n ${specifiers.join(\",\\n \")},\\n} from \"${path}\";`);\n }\n }\n }\n\n const extraImports = imports.length > 0 ? `${imports.join(\"\\n\")}\\n` : \"\";\n\n // Generate per-schema definitions\n const schemaBlocks: string[] = [];\n const gqlEntries: string[] = [];\n\n for (const [name, config] of Object.entries($$.schemas)) {\n const schemaVar = `${name}Schema`;\n const scalarBlock = $$.injection.mode === \"inject\" ? scalarAliases.get(name) : config.scalarBlock;\n\n // Get optional adapter\n const adapterVar = adapterAliases.get(name);\n\n // Build type exports with fragment builders type\n const typeExports = [`export type Schema_${name} = typeof ${schemaVar} & { _?: never };`];\n if (adapterVar) {\n typeExports.push(`export type Adapter_${name} = typeof ${adapterVar} & { _?: never };`);\n }\n typeExports.push(config.fragmentBuildersTypeBlock);\n\n const inputTypeMethodsVar = `inputTypeMethods_${name}`;\n const factoryVar = `createMethod_${name}`;\n\n // Generate __defaultInputDepth block if non-default value\n const defaultDepthBlock =\n config.defaultInputDepth !== undefined && config.defaultInputDepth !== 3\n ? `\\n __defaultInputDepth: ${config.defaultInputDepth},`\n : \"\";\n\n // Generate __inputDepthOverrides block if there are overrides\n const depthOverridesBlock =\n config.inputDepthOverrides && Object.keys(config.inputDepthOverrides).length > 0\n ? `\\n __inputDepthOverrides: ${JSON.stringify(config.inputDepthOverrides)},`\n : \"\";\n\n schemaBlocks.push(`\nconst ${schemaVar} = {\n label: \"${name}\",\n operations: { query: \"${config.queryType}\", mutation: \"${config.mutationType}\", subscription: \"${config.subscriptionType}\" },\n scalar: ${scalarBlock},\n enum: ${config.enumBlock},\n input: ${config.inputBlock},\n object: ${config.objectBlock},\n union: ${config.unionBlock},${defaultDepthBlock}${depthOverridesBlock}\n} as const;\n\nconst ${factoryVar} = createVarMethodFactory<typeof ${schemaVar}>();\nconst ${inputTypeMethodsVar} = ${config.inputTypeMethodsBlock} satisfies InputTypeMethods<typeof ${schemaVar}>;\n\n${typeExports.join(\"\\n\")}`);\n\n // Build gql entry with options - inputTypeMethods is always required\n // Include FragmentBuilders type for codegen optimization\n if (adapterVar) {\n const typeParams = `<Schema_${name}, FragmentBuilders_${name}, Adapter_${name}>`;\n gqlEntries.push(\n ` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { adapter: ${adapterVar}, inputTypeMethods: ${inputTypeMethodsVar} })`,\n );\n } else {\n const typeParams = `<Schema_${name}, FragmentBuilders_${name}>`;\n gqlEntries.push(\n ` ${name}: createGqlElementComposer${typeParams}(${schemaVar}, { inputTypeMethods: ${inputTypeMethodsVar} })`,\n );\n }\n }\n\n return `\\\nimport {\n type ExtractMetadataAdapter,\n type FragmentBuilderFor,\n type InputTypeMethods,\n createGqlElementComposer,\n createVarMethodFactory,\n} from \"@soda-gql/core\";\n${extraImports}\n${schemaBlocks.join(\"\\n\")}\n\nexport const gql = {\n${gqlEntries.join(\",\\n\")}\n};\n`;\n};\n\nexport const generateMultiSchemaModule = (\n schemas: Map<string, DocumentNode>,\n options?: RuntimeGenerationOptions,\n): GeneratedModule => {\n // biome-ignore lint/suspicious/noExplicitAny: complex schema config type\n const schemaConfigs: Record<string, any> = {};\n const allStats = {\n objects: 0,\n enums: 0,\n inputs: 0,\n unions: 0,\n };\n\n for (const [name, document] of schemas.entries()) {\n const schema = createSchemaIndex(document);\n\n const builtinScalarDefinitions = Array.from(builtinScalarTypes.keys()).map((name) =>\n renderScalarDefinition(schema.scalars.get(name) ?? { name, directives: [] }),\n );\n\n const customScalarDefinitions = collectScalarNames(schema)\n .filter((name) => !builtinScalarTypes.has(name))\n .map((name) => {\n const record = schema.scalars.get(name);\n return record ? renderScalarDefinition(record) : \"\";\n })\n .filter((definition) => definition.length > 0);\n\n const allScalarDefinitions = builtinScalarDefinitions.concat(customScalarDefinitions);\n\n const objectTypeNames = collectObjectTypeNames(schema);\n const enumTypeNames = collectEnumTypeNames(schema);\n const inputTypeNames = collectInputTypeNames(schema);\n const unionTypeNames = collectUnionTypeNames(schema);\n\n const scalarBlock = renderPropertyLines({ entries: allScalarDefinitions, indentSize: 4 });\n const enumDefinitions = enumTypeNames\n .map((name) => renderEnumDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const enumBlock = renderPropertyLines({ entries: enumDefinitions, indentSize: 4 });\n const inputDefinitions = inputTypeNames\n .map((name) => renderInputDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const inputBlock = renderPropertyLines({ entries: inputDefinitions, indentSize: 4 });\n const objectDefinitions = objectTypeNames\n .map((name) => renderObjectDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const objectBlock = renderPropertyLines({ entries: objectDefinitions, indentSize: 4 });\n const unionDefinitions = unionTypeNames\n .map((name) => renderUnionDefinition(schema, name))\n .filter((definition) => definition.length > 0);\n const unionBlock = renderPropertyLines({ entries: unionDefinitions, indentSize: 4 });\n\n const factoryVar = `createMethod_${name}`;\n const inputTypeMethodsBlock = renderInputTypeMethods(schema, factoryVar);\n // Pass adapter type name if injection has adapter for this schema\n const adapterTypeName = options?.injection?.get(name)?.adapterImportPath ? `Adapter_${name}` : undefined;\n const fragmentBuildersTypeBlock = renderFragmentBuildersType(objectTypeNames, name, adapterTypeName);\n\n const queryType = schema.operationTypes.query ?? \"Query\";\n const mutationType = schema.operationTypes.mutation ?? \"Mutation\";\n const subscriptionType = schema.operationTypes.subscription ?? \"Subscription\";\n\n schemaConfigs[name] = {\n queryType,\n mutationType,\n subscriptionType,\n scalarBlock,\n enumBlock,\n inputBlock,\n objectBlock,\n unionBlock,\n inputTypeMethodsBlock,\n fragmentBuildersTypeBlock,\n defaultInputDepth: options?.defaultInputDepth?.get(name),\n inputDepthOverrides: options?.inputDepthOverrides?.get(name),\n };\n\n // Accumulate stats\n allStats.objects += objectDefinitions.length;\n allStats.enums += enumDefinitions.length;\n allStats.inputs += inputDefinitions.length;\n allStats.unions += unionDefinitions.length;\n }\n\n const injection: RuntimeTemplateInjection = options?.injection\n ? { mode: \"inject\", perSchema: options.injection }\n : { mode: \"inline\" };\n\n const code = multiRuntimeTemplate({\n schemas: schemaConfigs,\n injection,\n });\n\n return {\n code,\n stats: allStats,\n };\n};\n"],"mappings":"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"}
|