Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions rust/src/generated/api_types.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
//! Auto-generated from api.schema.json — do not edit manually.

#![allow(clippy::large_enum_variant)]
#![allow(dead_code)]

use std::collections::HashMap;

Expand Down
1 change: 1 addition & 0 deletions rust/src/generated/rpc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
#![allow(missing_docs)]
#![allow(clippy::too_many_arguments)]
#![allow(dead_code)]

use super::api_types::{rpc_methods, *};
use super::session_events::SessionMode;
Expand Down
23 changes: 22 additions & 1 deletion scripts/codegen/go.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1731,6 +1731,27 @@ function goVariantMatchFunctionLines(
return lines;
}

function goDiscriminatorMethodName(
typeName: string,
discriminatorProp: string,
discGoName: string,
variants: GoDiscriminatedUnionVariant[],
ctx: GoCodegenCtx
): string {
const collidesWithVariantField = variants.some((variant) => {
const resolved = resolveSchema(variant.schema, ctx.definitions) ?? variant.schema;
const objectSchema = resolveObjectSchema(resolved, ctx.definitions) ?? resolved;
return Object.keys(objectSchema.properties ?? {}).some((propName) => {
if (propName === discriminatorProp) {
return variant.discriminatorValues.length > 1 && discGoName === "Discriminator";
}
return toGoFieldName(propName) === discGoName;
});
});

return collidesWithVariantField ? `${toGoUnexportedIdentifier(typeName)}${discGoName}` : discGoName;
}

/**
* Emit a Go interface for a discriminated union (anyOf with const discriminator).
*/
Expand All @@ -1748,7 +1769,7 @@ function emitGoFlatDiscriminatedUnion(
const mapping = discriminator.mapping;
const unionVariants = [...discriminator.variants].sort((left, right) => compareGoTypeNames(left.typeName, right.typeName));
const discGoName = toGoFieldName(discriminatorProp);
const discriminatorMethodName = discGoName;
const discriminatorMethodName = goDiscriminatorMethodName(typeName, discriminatorProp, discGoName, unionVariants, ctx);
let discEnumName: string | undefined;
let discGoType = "bool";
if (discriminator.valueKind === "string") {
Expand Down
20 changes: 19 additions & 1 deletion scripts/codegen/rust.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1545,6 +1545,7 @@ function generateApiTypesCode(
out.push("//! Auto-generated from api.schema.json — do not edit manually.");
out.push("");
out.push("#![allow(clippy::large_enum_variant)]");
out.push("#![allow(dead_code)]");
out.push("");
out.push("use std::collections::HashMap;");
out.push("");
Expand Down Expand Up @@ -1776,6 +1777,17 @@ function getResultTypeName(
return `${toPascalCase(method.rpcMethod)}Result`;
}

function methodUsesInternalSchema(
schema: JSONSchema7 | null | undefined,
defCollections: DefinitionCollections,
): boolean {
if (!schema) return false;

const nonNullable = getNullableInner(schema) ?? schema;
const resolved = resolveSchema(nonNullable, defCollections) ?? nonNullable;
return isSchemaInternal(resolved);
}

function pushNamespaceMethodBody(
out: string[],
constName: string,
Expand Down Expand Up @@ -1884,7 +1896,12 @@ function emitNamespaceMethod(
};

const paramArg = hasParams ? `, params: ${paramsTypeName}` : "";
const fnVis = method.visibility === "internal" ? "pub(crate)" : "pub";
const fnVis =
method.visibility === "internal" ||
methodUsesInternalSchema(method.params, defCollections) ||
methodUsesInternalSchema(method.result, defCollections)
? "pub(crate)"
: "pub";

if (hasParams && paramsInfo.optional) {
out.push(...buildDocs(false));
Expand Down Expand Up @@ -1949,6 +1966,7 @@ function generateRpcCode(apiSchema: ApiSchema): string {
out.push("");
out.push("#![allow(missing_docs)]");
out.push("#![allow(clippy::too_many_arguments)]");
out.push("#![allow(dead_code)]");
out.push("");
out.push("use super::api_types::{rpc_methods, *};");
const externalTypeRefs = new Map<string, Set<string>>();
Expand Down
Loading