@farming-labs/orm 0.0.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.
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts","../src/client.ts","../src/fields.ts","../src/manifest.ts","../src/generators.ts","../src/memory.ts","../src/relations.ts","../src/schema.ts"],"sourcesContent":["export * from \"./client\";\nexport * from \"./fields\";\nexport * from \"./generators\";\nexport * from \"./manifest\";\nexport * from \"./memory\";\nexport * from \"./relations\";\nexport * from \"./schema\";\n","import type { SchemaDefinition } from \"./schema\";\nimport type {\n ModelName,\n RelationForName,\n RelationName,\n RelationTarget,\n ScalarRecord,\n} from \"./schema\";\n\ntype Direction = \"asc\" | \"desc\";\n\ntype Primitive = string | number | boolean | Date | null;\n\ntype Comparable = string | number | Date;\n\ntype ValueFilter<T> = T extends string\n ? T | { eq?: T; contains?: string; in?: T[]; not?: T }\n : T extends Comparable\n ? T | { eq?: T; gt?: T; gte?: T; lt?: T; lte?: T; in?: T[]; not?: T }\n : T | { eq?: T; in?: T[]; not?: T };\n\nexport type Where<TRecord extends Record<string, Primitive>> = {\n [K in keyof TRecord]?: ValueFilter<TRecord[K]>;\n} & {\n AND?: Array<Where<TRecord>>;\n OR?: Array<Where<TRecord>>;\n NOT?: Where<TRecord>;\n};\n\ntype RelationQuery<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>> = {\n where?: Where<ScalarRecord<TSchema, TModelName>>;\n select?: SelectShape<TSchema, TModelName>;\n orderBy?: Partial<Record<keyof ScalarRecord<TSchema, TModelName> & string, Direction>>;\n take?: number;\n skip?: number;\n};\n\ntype RelationSelectionValue<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n TRelationName extends RelationName<TSchema, TModelName>,\n> = true | RelationQuery<TSchema, RelationTarget<TSchema, TModelName, TRelationName>>;\n\nexport type SelectShape<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n> = {\n [K in\n | (keyof ScalarRecord<TSchema, TModelName> & string)\n | RelationName<TSchema, TModelName>]?: K extends RelationName<TSchema, TModelName>\n ? true | RelationQuery<TSchema, any>\n : true;\n};\n\ntype IsManyRelation<TRelation> = TRelation extends { kind: \"hasMany\" | \"manyToMany\" }\n ? true\n : false;\n\ntype DefaultSelectedRecord<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n> = ScalarRecord<TSchema, TModelName>;\n\ntype SelectedScalars<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName>,\n> = {\n [K in keyof TSelect & keyof ScalarRecord<TSchema, TModelName> as TSelect[K] extends true\n ? K\n : never]: ScalarRecord<TSchema, TModelName>[K];\n};\n\ntype RelationResult<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n TRelationName extends RelationName<TSchema, TModelName>,\n TValue extends RelationSelectionValue<TSchema, TModelName, TRelationName>,\n> = TValue extends true\n ? IsManyRelation<RelationForName<TSchema, TModelName, TRelationName>> extends true\n ? Array<DefaultSelectedRecord<TSchema, RelationTarget<TSchema, TModelName, TRelationName>>>\n : DefaultSelectedRecord<TSchema, RelationTarget<TSchema, TModelName, TRelationName>> | null\n : TValue extends RelationQuery<TSchema, infer Target>\n ? Target extends ModelName<TSchema>\n ? IsManyRelation<RelationForName<TSchema, TModelName, TRelationName>> extends true\n ? Array<\n SelectedRecord<\n TSchema,\n Target,\n TValue[\"select\"] extends SelectShape<TSchema, Target> ? TValue[\"select\"] : undefined\n >\n >\n : SelectedRecord<\n TSchema,\n Target,\n TValue[\"select\"] extends SelectShape<TSchema, Target> ? TValue[\"select\"] : undefined\n > | null\n : never\n : never;\n\ntype SelectedRelations<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName>,\n> = {\n [K in keyof TSelect & RelationName<TSchema, TModelName>]: RelationResult<\n TSchema,\n TModelName,\n K,\n Extract<TSelect[K], RelationSelectionValue<TSchema, TModelName, K>>\n >;\n};\n\nexport type SelectedRecord<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName> | undefined,\n> =\n TSelect extends SelectShape<TSchema, TModelName>\n ? SelectedScalars<TSchema, TModelName, TSelect> &\n SelectedRelations<TSchema, TModelName, TSelect>\n : DefaultSelectedRecord<TSchema, TModelName>;\n\nexport type FindManyArgs<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined,\n> = {\n where?: Where<ScalarRecord<TSchema, TModelName>>;\n select?: TSelect;\n orderBy?: Partial<Record<keyof ScalarRecord<TSchema, TModelName> & string, Direction>>;\n take?: number;\n skip?: number;\n};\n\nexport type FindFirstArgs<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined,\n> = FindManyArgs<TSchema, TModelName, TSelect>;\n\nexport type CreateArgs<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined,\n> = {\n data: Partial<ScalarRecord<TSchema, TModelName>>;\n select?: TSelect;\n};\n\nexport type UpdateArgs<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined,\n> = {\n where: Where<ScalarRecord<TSchema, TModelName>>;\n data: Partial<ScalarRecord<TSchema, TModelName>>;\n select?: TSelect;\n};\n\nexport type DeleteArgs<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n> = {\n where: Where<ScalarRecord<TSchema, TModelName>>;\n};\n\nexport interface OrmDriver<TSchema extends SchemaDefinition<any>> {\n findMany<\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined,\n >(\n schema: TSchema,\n model: TModelName,\n args: FindManyArgs<TSchema, TModelName, TSelect>,\n ): Promise<Array<SelectedRecord<TSchema, TModelName, TSelect>>>;\n findFirst<\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined,\n >(\n schema: TSchema,\n model: TModelName,\n args: FindFirstArgs<TSchema, TModelName, TSelect>,\n ): Promise<SelectedRecord<TSchema, TModelName, TSelect> | null>;\n create<\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined,\n >(\n schema: TSchema,\n model: TModelName,\n args: CreateArgs<TSchema, TModelName, TSelect>,\n ): Promise<SelectedRecord<TSchema, TModelName, TSelect>>;\n update<\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined,\n >(\n schema: TSchema,\n model: TModelName,\n args: UpdateArgs<TSchema, TModelName, TSelect>,\n ): Promise<SelectedRecord<TSchema, TModelName, TSelect> | null>;\n delete<TModelName extends ModelName<TSchema>>(\n schema: TSchema,\n model: TModelName,\n args: DeleteArgs<TSchema, TModelName>,\n ): Promise<number>;\n transaction<TResult>(\n schema: TSchema,\n run: (driver: OrmDriver<TSchema>) => Promise<TResult>,\n ): Promise<TResult>;\n}\n\nexport type ModelClient<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n> = {\n findMany<TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(\n args?: FindManyArgs<TSchema, TModelName, TSelect>,\n ): Promise<Array<SelectedRecord<TSchema, TModelName, TSelect>>>;\n findFirst<TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(\n args?: FindFirstArgs<TSchema, TModelName, TSelect>,\n ): Promise<SelectedRecord<TSchema, TModelName, TSelect> | null>;\n create<TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(\n args: CreateArgs<TSchema, TModelName, TSelect>,\n ): Promise<SelectedRecord<TSchema, TModelName, TSelect>>;\n update<TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(\n args: UpdateArgs<TSchema, TModelName, TSelect>,\n ): Promise<SelectedRecord<TSchema, TModelName, TSelect> | null>;\n delete(args: DeleteArgs<TSchema, TModelName>): Promise<number>;\n};\n\nexport type OrmClient<TSchema extends SchemaDefinition<any>> = {\n [K in ModelName<TSchema>]: ModelClient<TSchema, K>;\n} & {\n transaction<TResult>(run: (tx: OrmClient<TSchema>) => Promise<TResult>): Promise<TResult>;\n};\n\nfunction createModelClient<\n TSchema extends SchemaDefinition<any>,\n TModelName extends ModelName<TSchema>,\n>(\n schema: TSchema,\n driver: OrmDriver<TSchema>,\n model: TModelName,\n): ModelClient<TSchema, TModelName> {\n return {\n findMany(args) {\n return driver.findMany(schema, model, (args ?? {}) as any) as any;\n },\n findFirst(args) {\n return driver.findFirst(schema, model, (args ?? {}) as any) as any;\n },\n create(args) {\n return driver.create(schema, model, args as any) as any;\n },\n update(args) {\n return driver.update(schema, model, args as any) as any;\n },\n delete(args) {\n return driver.delete(schema, model, args as any) as any;\n },\n };\n}\n\nexport function createOrm<TSchema extends SchemaDefinition<any>>(options: {\n schema: TSchema;\n driver: OrmDriver<TSchema>;\n}): OrmClient<TSchema> {\n const { schema, driver } = options;\n const models: Record<string, unknown> = {};\n\n for (const model of Object.keys(schema.models)) {\n models[model] = createModelClient(schema, driver, model as ModelName<TSchema>);\n }\n\n const orm = models as OrmClient<TSchema>;\n orm.transaction = (run) =>\n driver.transaction(schema, async (txDriver) => {\n const tx = createOrm({\n schema,\n driver: txDriver,\n });\n return run(tx);\n });\n return orm;\n}\n","export type ScalarKind = \"id\" | \"string\" | \"boolean\" | \"datetime\";\n\nexport type FieldReference = `${string}.${string}`;\n\nexport type FieldConfig<\n Kind extends ScalarKind = ScalarKind,\n Nullable extends boolean = boolean,\n> = {\n kind: Kind;\n nullable: Nullable;\n unique: boolean;\n defaultValue?: unknown;\n generated?: \"id\" | \"now\";\n mappedName?: string;\n references?: FieldReference;\n description?: string;\n};\n\nexport type AnyFieldBuilder = FieldBuilder<ScalarKind, boolean>;\n\nconst cloneField = <Kind extends ScalarKind, Nullable extends boolean = false>(\n config: FieldConfig<Kind, Nullable>,\n) => new FieldBuilder(config);\n\nexport class FieldBuilder<Kind extends ScalarKind, Nullable extends boolean = false> {\n readonly _tag = \"field\";\n\n constructor(readonly config: FieldConfig<Kind, Nullable>) {}\n\n unique() {\n return cloneField({\n ...this.config,\n unique: true,\n });\n }\n\n nullable() {\n return cloneField<Kind, true>({\n ...this.config,\n nullable: true,\n });\n }\n\n default(value: unknown) {\n return cloneField({\n ...this.config,\n defaultValue: value,\n });\n }\n\n defaultNow() {\n return cloneField({\n ...this.config,\n generated: \"now\",\n });\n }\n\n references(reference: FieldReference) {\n return cloneField({\n ...this.config,\n references: reference,\n });\n }\n\n map(name: string) {\n return cloneField({\n ...this.config,\n mappedName: name,\n });\n }\n\n describe(description: string) {\n return cloneField({\n ...this.config,\n description,\n });\n }\n}\n\nexport type ScalarValue<Kind extends ScalarKind> = Kind extends \"id\"\n ? string\n : Kind extends \"string\"\n ? string\n : Kind extends \"boolean\"\n ? boolean\n : Date;\n\nexport type FieldOutput<TField> =\n TField extends FieldBuilder<infer Kind, infer Nullable>\n ? Nullable extends true\n ? ScalarValue<Kind> | null\n : ScalarValue<Kind>\n : never;\n\nexport function id() {\n return new FieldBuilder({\n kind: \"id\",\n nullable: false,\n unique: true,\n generated: \"id\",\n });\n}\n\nexport function string() {\n return new FieldBuilder({\n kind: \"string\",\n nullable: false,\n unique: false,\n });\n}\n\nexport function boolean() {\n return new FieldBuilder({\n kind: \"boolean\",\n nullable: false,\n unique: false,\n });\n}\n\nexport function datetime() {\n return new FieldBuilder({\n kind: \"datetime\",\n nullable: false,\n unique: false,\n });\n}\n","import type { ScalarKind } from \"./fields\";\nimport type { AnyRelation } from \"./relations\";\nimport type { AnyModelDefinition, SchemaDefinition } from \"./schema\";\n\nexport type ManifestField = {\n name: string;\n column: string;\n kind: ScalarKind;\n nullable: boolean;\n unique: boolean;\n generated?: \"id\" | \"now\";\n defaultValue?: unknown;\n references?: string;\n description?: string;\n};\n\nexport type ManifestModel = {\n name: string;\n table: string;\n description?: string;\n fields: Record<string, ManifestField>;\n relations: Record<string, AnyRelation>;\n};\n\nexport type SchemaManifest = {\n models: Record<string, ManifestModel>;\n};\n\nexport function createManifest<\n TSchema extends SchemaDefinition<Record<string, AnyModelDefinition>>,\n>(schema: TSchema): SchemaManifest {\n const models = Object.fromEntries(\n (Object.entries(schema.models) as Array<[string, AnyModelDefinition]>).map(\n ([name, definition]) => {\n const fields = Object.fromEntries(\n (\n Object.entries(definition.fields) as Array<\n [string, AnyModelDefinition[\"fields\"][string]]\n >\n ).map(([fieldName, field]) => [\n fieldName,\n {\n name: fieldName,\n column: field.config.mappedName ?? fieldName,\n kind: field.config.kind,\n nullable: field.config.nullable,\n unique: field.config.unique,\n generated: field.config.generated,\n defaultValue: field.config.defaultValue,\n references: field.config.references,\n description: field.config.description,\n } satisfies ManifestField,\n ]),\n );\n\n return [\n name,\n {\n name,\n table: definition.table,\n description: definition.description,\n fields,\n relations: definition.relations,\n } satisfies ManifestModel,\n ];\n },\n ),\n );\n\n return { models };\n}\n","import {\n createManifest,\n type ManifestField,\n type ManifestModel,\n type SchemaManifest,\n} from \"./manifest\";\nimport type { SchemaDefinition } from \"./schema\";\n\nexport type PrismaGenerationOptions = {\n provider?: \"postgresql\" | \"mysql\" | \"sqlite\";\n datasourceName?: string;\n generatorName?: string;\n};\n\nexport type DrizzleGenerationOptions = {\n dialect: \"pg\" | \"mysql\" | \"sqlite\";\n};\n\nexport type SqlGenerationOptions = {\n dialect: \"postgres\" | \"mysql\" | \"sqlite\";\n};\n\nconst capitalize = (value: string) => value.charAt(0).toUpperCase() + value.slice(1);\nconst pluralize = (value: string) => (value.endsWith(\"s\") ? value : `${value}s`);\n\nfunction prismaType(field: ManifestField) {\n switch (field.kind) {\n case \"id\":\n case \"string\":\n return \"String\";\n case \"boolean\":\n return \"Boolean\";\n case \"datetime\":\n return \"DateTime\";\n }\n}\n\nfunction drizzleImports(dialect: DrizzleGenerationOptions[\"dialect\"], manifest: SchemaManifest) {\n const models = Object.values(manifest.models) as ManifestModel[];\n const needsBoolean = models.some((model) =>\n Object.values(model.fields).some((field) => field.kind === \"boolean\"),\n );\n const needsDate = models.some((model) =>\n Object.values(model.fields).some((field) => field.kind === \"datetime\"),\n );\n\n if (dialect === \"pg\") {\n return [\n \"pgTable\",\n \"text\",\n needsBoolean ? \"boolean\" : null,\n needsDate ? \"timestamp\" : null,\n ].filter(Boolean);\n }\n\n if (dialect === \"mysql\") {\n return [\n \"mysqlTable\",\n \"varchar\",\n \"text\",\n needsBoolean ? \"boolean\" : null,\n needsDate ? \"datetime\" : null,\n ].filter(Boolean);\n }\n\n return [\"sqliteTable\", \"text\", \"integer\"];\n}\n\nfunction drizzleColumn(field: ManifestField, dialect: DrizzleGenerationOptions[\"dialect\"]) {\n if (field.kind === \"id\") {\n if (dialect === \"mysql\") {\n return `varchar(\"${field.column}\", { length: 191 }).primaryKey()`;\n }\n return `text(\"${field.column}\").primaryKey()`;\n }\n\n if (field.kind === \"string\") {\n if (dialect === \"mysql\") {\n const base =\n field.unique || field.references\n ? `varchar(\"${field.column}\", { length: 191 })`\n : `text(\"${field.column}\")`;\n return `${base}${field.nullable ? \"\" : \".notNull()\"}${field.unique ? \".unique()\" : \"\"}${\n field.defaultValue !== undefined ? `.default(${JSON.stringify(field.defaultValue)})` : \"\"\n }`;\n }\n return `text(\"${field.column}\")${field.nullable ? \"\" : \".notNull()\"}${field.unique ? \".unique()\" : \"\"}${\n field.defaultValue !== undefined ? `.default(${JSON.stringify(field.defaultValue)})` : \"\"\n }`;\n }\n\n if (field.kind === \"boolean\") {\n if (dialect === \"sqlite\") {\n return `integer(\"${field.column}\", { mode: \"boolean\" })${field.nullable ? \"\" : \".notNull()\"}${\n field.defaultValue !== undefined ? `.default(${String(field.defaultValue)})` : \"\"\n }`;\n }\n return `boolean(\"${field.column}\")${field.nullable ? \"\" : \".notNull()\"}${\n field.defaultValue !== undefined ? `.default(${String(field.defaultValue)})` : \"\"\n }`;\n }\n\n if (dialect === \"mysql\") {\n return `datetime(\"${field.column}\", { mode: \"date\" })${field.nullable ? \"\" : \".notNull()\"}`;\n }\n if (dialect === \"sqlite\") {\n return `integer(\"${field.column}\", { mode: \"timestamp\" })${field.nullable ? \"\" : \".notNull()\"}`;\n }\n return `timestamp(\"${field.column}\")${field.nullable ? \"\" : \".notNull()\"}`;\n}\n\nfunction sqlType(field: ManifestField, dialect: SqlGenerationOptions[\"dialect\"]) {\n if (field.kind === \"id\") {\n return dialect === \"mysql\" ? \"varchar(191)\" : \"text\";\n }\n if (field.kind === \"string\") {\n return dialect === \"mysql\" && field.unique ? \"varchar(191)\" : \"text\";\n }\n if (field.kind === \"boolean\") {\n return dialect === \"sqlite\" ? \"integer\" : \"boolean\";\n }\n if (dialect === \"mysql\") {\n return \"datetime\";\n }\n if (dialect === \"sqlite\") {\n return \"text\";\n }\n return \"timestamp\";\n}\n\nexport function renderPrismaSchema(\n schema: SchemaDefinition<any>,\n options: PrismaGenerationOptions = {},\n) {\n const manifest = createManifest(schema);\n const provider = options.provider ?? \"postgresql\";\n const generatorName = options.generatorName ?? \"client\";\n const datasourceName = options.datasourceName ?? \"db\";\n const reverseRelations = new Map<string, Array<{ sourceModel: string; many: boolean }>>();\n\n for (const model of Object.values(manifest.models) as ManifestModel[]) {\n for (const field of Object.values(model.fields)) {\n if (!field.references) continue;\n const [targetModel] = field.references.split(\".\");\n reverseRelations.set(targetModel, [\n ...(reverseRelations.get(targetModel) ?? []),\n {\n sourceModel: model.name,\n many: !field.unique,\n },\n ]);\n }\n }\n\n const blocks = (Object.values(manifest.models) as ManifestModel[]).map((model) => {\n const lines: string[] = [];\n const modelName = capitalize(model.name);\n\n for (const field of Object.values(model.fields)) {\n const fieldType = prismaType(field);\n const modifiers: string[] = [];\n if (field.kind === \"id\") modifiers.push(\"@id\");\n if (field.generated === \"id\") modifiers.push(\"@default(cuid())\");\n if (field.generated === \"now\") modifiers.push(\"@default(now())\");\n if (field.defaultValue !== undefined && field.generated === undefined) {\n modifiers.push(\n typeof field.defaultValue === \"string\"\n ? `@default(\"${field.defaultValue}\")`\n : `@default(${String(field.defaultValue)})`,\n );\n }\n if (field.unique && field.kind !== \"id\") modifiers.push(\"@unique\");\n if (field.column !== field.name) modifiers.push(`@map(\"${field.column}\")`);\n\n lines.push(\n ` ${field.name} ${fieldType}${field.nullable ? \"?\" : \"\"}${modifiers.length ? ` ${modifiers.join(\" \")}` : \"\"}`,\n );\n\n if (field.references) {\n const [targetModel, targetField] = field.references.split(\".\");\n lines.push(\n ` ${targetModel} ${capitalize(targetModel)} @relation(fields: [${field.name}], references: [${targetField}])`,\n );\n }\n }\n\n for (const relation of reverseRelations.get(model.name) ?? []) {\n lines.push(\n relation.many\n ? ` ${pluralize(relation.sourceModel)} ${capitalize(relation.sourceModel)}[]`\n : ` ${relation.sourceModel} ${capitalize(relation.sourceModel)}?`,\n );\n }\n\n const mapLine = model.table !== modelName ? `\\n @@map(\"${model.table}\")` : \"\";\n return `model ${modelName} {\\n${lines.join(\"\\n\")}${mapLine}\\n}`;\n });\n\n return (\n `generator ${generatorName} {\\n provider = \"prisma-client-js\"\\n}\\n\\n` +\n `datasource ${datasourceName} {\\n provider = \"${provider}\"\\n url = ${\n provider === \"sqlite\" ? '\"file:./dev.db\"' : 'env(\"DATABASE_URL\")'\n }\\n}\\n\\n${blocks.join(\"\\n\\n\")}\\n`\n );\n}\n\nexport function renderDrizzleSchema(\n schema: SchemaDefinition<any>,\n options: DrizzleGenerationOptions,\n) {\n const manifest = createManifest(schema);\n const imports = drizzleImports(options.dialect, manifest).join(\", \");\n const tableFactory =\n options.dialect === \"pg\"\n ? \"pgTable\"\n : options.dialect === \"mysql\"\n ? \"mysqlTable\"\n : \"sqliteTable\";\n\n const modelBlocks = (Object.values(manifest.models) as ManifestModel[]).map((model) => {\n const lines = Object.values(model.fields).map((field) => {\n let value = drizzleColumn(field, options.dialect);\n if (field.references) {\n const [targetModel, targetField] = field.references.split(\".\");\n value += `.references(() => ${targetModel}.${targetField})`;\n }\n return ` ${field.name}: ${value}`;\n });\n\n return `export const ${model.name} = ${tableFactory}(\"${model.table}\", {\\n${lines.join(\",\\n\")}\\n});`;\n });\n\n return `import { ${imports} } from \"drizzle-orm/${\n options.dialect === \"pg\"\n ? \"pg-core\"\n : options.dialect === \"mysql\"\n ? \"mysql-core\"\n : \"sqlite-core\"\n }\";\\n\\n${modelBlocks.join(\"\\n\\n\")}\\n`;\n}\n\nexport function renderSafeSql(schema: SchemaDefinition<any>, options: SqlGenerationOptions) {\n const manifest = createManifest(schema);\n const statements = (Object.values(manifest.models) as ManifestModel[]).map((model) => {\n const columns = Object.values(model.fields).map((field) => {\n const parts = [`${field.column} ${sqlType(field, options.dialect)}`];\n if (field.kind === \"id\") parts.push(\"primary key\");\n if (!field.nullable) parts.push(\"not null\");\n if (field.unique && field.kind !== \"id\") parts.push(\"unique\");\n if (field.defaultValue !== undefined) {\n parts.push(\n `default ${\n typeof field.defaultValue === \"string\"\n ? `'${field.defaultValue}'`\n : String(field.defaultValue)\n }`,\n );\n }\n if (field.references) {\n const [targetModel, targetField] = field.references.split(\".\");\n const targetTable = manifest.models[targetModel]?.table ?? targetModel;\n parts.push(`references ${targetTable}(${targetField})`);\n }\n return ` ${parts.join(\" \")}`;\n });\n\n return `create table if not exists ${model.table} (\\n${columns.join(\",\\n\")}\\n);`;\n });\n\n return `${statements.join(\"\\n\\n\")}\\n`;\n}\n\nexport function replaceGeneratedBlock(input: { current: string; label: string; content: string }) {\n const start = `// @farming-labs/orm:start:${input.label}`;\n const end = `// @farming-labs/orm:end:${input.label}`;\n const block = `${start}\\n${input.content.trim()}\\n${end}`;\n\n if (input.current.includes(start) && input.current.includes(end)) {\n const pattern = new RegExp(`${start}[\\\\s\\\\S]*?${end}`, \"m\");\n return input.current.replace(pattern, block);\n }\n\n return `${input.current.trim()}\\n\\n${block}\\n`;\n}\n","import { randomUUID } from \"node:crypto\";\nimport type {\n CreateArgs,\n DeleteArgs,\n FindFirstArgs,\n FindManyArgs,\n OrmDriver,\n SelectShape,\n SelectedRecord,\n UpdateArgs,\n Where,\n} from \"./client\";\nimport type { SchemaDefinition } from \"./schema\";\nimport type { ModelName, RelationName } from \"./schema\";\n\ntype MemoryStore<TSchema extends SchemaDefinition<any>> = Partial<\n Record<ModelName<TSchema>, Array<Record<string, unknown>>>\n>;\n\nconst isDate = (value: unknown): value is Date => value instanceof Date;\n\nfunction evaluateFilter(value: unknown, filter: unknown) {\n if (\n filter === undefined ||\n filter === null ||\n typeof filter !== \"object\" ||\n isDate(filter) ||\n Array.isArray(filter)\n ) {\n return value === filter;\n }\n\n const record = filter as Record<string, unknown>;\n\n if (\"eq\" in record && value !== record.eq) return false;\n if (\"not\" in record && value === record.not) return false;\n if (\"in\" in record) {\n const values = Array.isArray(record.in) ? record.in : [];\n if (!values.includes(value)) return false;\n }\n if (\"contains\" in record) {\n if (typeof value !== \"string\" || typeof record.contains !== \"string\") return false;\n if (!value.includes(record.contains)) return false;\n }\n if (\"gt\" in record && value !== undefined) {\n if (!(value instanceof Date || typeof value === \"number\" || typeof value === \"string\")) {\n return false;\n }\n if (!(value > record.gt!)) return false;\n }\n if (\"gte\" in record && value !== undefined) {\n if (!(value instanceof Date || typeof value === \"number\" || typeof value === \"string\")) {\n return false;\n }\n if (!(value >= record.gte!)) return false;\n }\n if (\"lt\" in record && value !== undefined) {\n if (!(value instanceof Date || typeof value === \"number\" || typeof value === \"string\")) {\n return false;\n }\n if (!(value < record.lt!)) return false;\n }\n if (\"lte\" in record && value !== undefined) {\n if (!(value instanceof Date || typeof value === \"number\" || typeof value === \"string\")) {\n return false;\n }\n if (!(value <= record.lte!)) return false;\n }\n\n return true;\n}\n\nfunction matchesWhere<TRecord extends Record<string, unknown>>(\n record: TRecord,\n where?: Where<any>,\n) {\n if (!where) return true;\n\n if (where.AND && !where.AND.every((clause: Where<any>) => matchesWhere(record, clause))) {\n return false;\n }\n\n if (where.OR && !where.OR.some((clause: Where<any>) => matchesWhere(record, clause))) {\n return false;\n }\n\n if (where.NOT && matchesWhere(record, where.NOT)) {\n return false;\n }\n\n for (const [key, filter] of Object.entries(where)) {\n if (key === \"AND\" || key === \"OR\" || key === \"NOT\") continue;\n if (!evaluateFilter(record[key], filter)) return false;\n }\n\n return true;\n}\n\nfunction applyDefault(value: unknown, field: { generated?: string; defaultValue?: unknown }) {\n if (value !== undefined) return value;\n\n if (field.generated === \"id\") return randomUUID();\n if (field.generated === \"now\") return new Date();\n\n if (typeof field.defaultValue === \"function\") {\n return (field.defaultValue as () => unknown)();\n }\n\n return field.defaultValue;\n}\n\nfunction sortRows(\n rows: Array<Record<string, unknown>>,\n orderBy?: Partial<Record<string, \"asc\" | \"desc\">>,\n) {\n if (!orderBy) return rows;\n const entries = Object.entries(orderBy);\n if (!entries.length) return rows;\n\n return [...rows].sort((left, right) => {\n for (const [field, direction] of entries) {\n const a = left[field];\n const b = right[field];\n if (a === b) continue;\n if (a === undefined) return direction === \"asc\" ? -1 : 1;\n if (b === undefined) return direction === \"asc\" ? 1 : -1;\n if (a == null) return direction === \"asc\" ? -1 : 1;\n if (b == null) return direction === \"asc\" ? 1 : -1;\n if (a < b) return direction === \"asc\" ? -1 : 1;\n if (a > b) return direction === \"asc\" ? 1 : -1;\n }\n return 0;\n });\n}\n\nfunction pageRows(rows: Array<Record<string, unknown>>, skip?: number, take?: number) {\n const start = skip ?? 0;\n const end = take === undefined ? undefined : start + take;\n return rows.slice(start, end);\n}\n\nexport function createMemoryDriver<TSchema extends SchemaDefinition<any>>(\n seed?: MemoryStore<TSchema>,\n): OrmDriver<TSchema> {\n const state: MemoryStore<TSchema> = structuredClone(seed ?? {});\n\n function getRows<TModelName extends ModelName<TSchema>>(model: TModelName) {\n const rows = state[model] ?? [];\n state[model] = rows;\n return rows;\n }\n\n function applyQuery<TModelName extends ModelName<TSchema>>(\n model: TModelName,\n args: FindManyArgs<TSchema, TModelName, any> | FindFirstArgs<TSchema, TModelName, any>,\n ) {\n const rows = getRows(model);\n const filtered = rows.filter((row) => matchesWhere(row, args.where));\n const sorted = sortRows(\n filtered,\n args.orderBy as Partial<Record<string, \"asc\" | \"desc\">> | undefined,\n );\n return pageRows(sorted, args.skip, args.take);\n }\n\n async function projectRow<\n TModelName extends ModelName<TSchema>,\n TSelect extends SelectShape<TSchema, TModelName> | undefined,\n >(\n schema: TSchema,\n model: TModelName,\n row: Record<string, unknown>,\n select?: TSelect,\n ): Promise<SelectedRecord<TSchema, TModelName, TSelect>> {\n const modelDefinition = schema.models[model];\n const output: Record<string, unknown> = {};\n\n if (!select) {\n for (const fieldName of Object.keys(modelDefinition.fields)) {\n output[fieldName] = row[fieldName];\n }\n return output as SelectedRecord<TSchema, TModelName, TSelect>;\n }\n\n for (const [key, value] of Object.entries(select)) {\n if (value !== true && value === undefined) continue;\n\n if (key in modelDefinition.fields && value === true) {\n output[key] = row[key];\n continue;\n }\n\n if (key in modelDefinition.relations) {\n output[key] = await resolveRelation(\n schema,\n model,\n key as RelationName<TSchema, TModelName>,\n row,\n value as true | FindManyArgs<TSchema, any, any>,\n );\n }\n }\n\n return output as SelectedRecord<TSchema, TModelName, TSelect>;\n }\n\n async function resolveRelation<\n TModelName extends ModelName<TSchema>,\n TRelationName extends RelationName<TSchema, TModelName>,\n >(\n schema: TSchema,\n model: TModelName,\n relationName: TRelationName,\n row: Record<string, unknown>,\n value: true | FindManyArgs<TSchema, any, any>,\n ) {\n const relation = schema.models[model].relations[relationName];\n const relationArgs = value === true ? {} : value;\n\n if (relation.kind === \"belongsTo\") {\n const targetRows = getRows(relation.target as ModelName<TSchema>);\n const foreignValue = row[relation.foreignKey];\n const target = targetRows.find((item) => item.id === foreignValue);\n return target\n ? projectRow(schema, relation.target as ModelName<TSchema>, target, relationArgs.select)\n : null;\n }\n\n if (relation.kind === \"hasOne\") {\n const targetRows = getRows(relation.target as ModelName<TSchema>);\n const target = targetRows.find((item) => item[relation.foreignKey] === row.id);\n return target\n ? projectRow(schema, relation.target as ModelName<TSchema>, target, relationArgs.select)\n : null;\n }\n\n if (relation.kind === \"hasMany\") {\n const targetRows = getRows(relation.target as ModelName<TSchema>).filter(\n (item) => item[relation.foreignKey] === row.id,\n );\n const sorted = sortRows(\n targetRows,\n relationArgs.orderBy as Partial<Record<string, \"asc\" | \"desc\">> | undefined,\n );\n const paged = pageRows(sorted, relationArgs.skip, relationArgs.take);\n const filtered = paged.filter((item) => matchesWhere(item, relationArgs.where));\n return Promise.all(\n filtered.map((item) =>\n projectRow(schema, relation.target as ModelName<TSchema>, item, relationArgs.select),\n ),\n );\n }\n\n const throughRows = getRows(relation.through as ModelName<TSchema>).filter(\n (item) => item[relation.from] === row.id,\n );\n const targetIds = throughRows.map((item) => item[relation.to]);\n const targetRows = getRows(relation.target as ModelName<TSchema>).filter((item) =>\n targetIds.includes(item.id),\n );\n const sorted = sortRows(\n targetRows,\n relationArgs.orderBy as Partial<Record<string, \"asc\" | \"desc\">> | undefined,\n );\n const paged = pageRows(sorted, relationArgs.skip, relationArgs.take);\n const filtered = paged.filter((item) => matchesWhere(item, relationArgs.where));\n\n return Promise.all(\n filtered.map((item) =>\n projectRow(schema, relation.target as ModelName<TSchema>, item, relationArgs.select),\n ),\n );\n }\n\n const driver = {\n async findMany(\n schema: TSchema,\n model: ModelName<TSchema>,\n args: FindManyArgs<TSchema, ModelName<TSchema>, any>,\n ) {\n const rows = applyQuery(model, args);\n return Promise.all(rows.map((row) => projectRow(schema, model, row, args.select)));\n },\n async findFirst(\n schema: TSchema,\n model: ModelName<TSchema>,\n args: FindFirstArgs<TSchema, ModelName<TSchema>, any>,\n ) {\n const row = applyQuery(model, args)[0];\n if (!row) return null;\n return projectRow(schema, model, row, args.select);\n },\n async create(\n schema: TSchema,\n model: ModelName<TSchema>,\n args: CreateArgs<TSchema, ModelName<TSchema>, any>,\n ) {\n const modelDefinition = schema.models[model];\n const nextRow: Record<string, unknown> = {};\n for (const [fieldName, field] of Object.entries(modelDefinition.fields) as Array<\n [string, (typeof modelDefinition.fields)[string]]\n >) {\n nextRow[fieldName] = applyDefault(args.data[fieldName], field.config);\n }\n\n getRows(model).push(nextRow);\n return projectRow(schema, model, nextRow, args.select);\n },\n async update(\n schema: TSchema,\n model: ModelName<TSchema>,\n args: UpdateArgs<TSchema, ModelName<TSchema>, any>,\n ) {\n const rows = getRows(model);\n const row = rows.find((item) => matchesWhere(item, args.where));\n if (!row) return null;\n Object.assign(row, args.data);\n return projectRow(schema, model, row, args.select);\n },\n async delete(\n _schema: TSchema,\n model: ModelName<TSchema>,\n args: DeleteArgs<TSchema, ModelName<TSchema>>,\n ) {\n const rows = getRows(model);\n const before = rows.length;\n state[model] = rows.filter((item) => !matchesWhere(item, args.where));\n return before - (state[model]?.length ?? 0);\n },\n async transaction<TResult>(\n _schema: TSchema,\n run: (driver: OrmDriver<TSchema>) => Promise<TResult>,\n ) {\n const snapshot = structuredClone(state);\n try {\n return await run(driver);\n } catch (error) {\n Object.keys(state).forEach((key) => {\n delete state[key as ModelName<TSchema>];\n });\n Object.assign(state, snapshot);\n throw error;\n }\n },\n } as OrmDriver<TSchema>;\n\n return driver;\n}\n","export type RelationKind = \"belongsTo\" | \"hasOne\" | \"hasMany\" | \"manyToMany\";\n\nexport type RelationDefinition<\n Target extends string = string,\n Kind extends RelationKind = RelationKind,\n> = Kind extends \"manyToMany\"\n ? {\n kind: Kind;\n target: Target;\n through: string;\n from: string;\n to: string;\n }\n : {\n kind: Kind;\n target: Target;\n foreignKey: string;\n };\n\nexport type AnyRelation = RelationDefinition<string, RelationKind>;\n\nexport function belongsTo<Target extends string>(target: Target, config: { foreignKey: string }) {\n return {\n kind: \"belongsTo\",\n target,\n foreignKey: config.foreignKey,\n } satisfies RelationDefinition<Target, \"belongsTo\">;\n}\n\nexport function hasOne<Target extends string>(target: Target, config: { foreignKey: string }) {\n return {\n kind: \"hasOne\",\n target,\n foreignKey: config.foreignKey,\n } satisfies RelationDefinition<Target, \"hasOne\">;\n}\n\nexport function hasMany<Target extends string>(target: Target, config: { foreignKey: string }) {\n return {\n kind: \"hasMany\",\n target,\n foreignKey: config.foreignKey,\n } satisfies RelationDefinition<Target, \"hasMany\">;\n}\n\nexport function manyToMany<Target extends string>(\n target: Target,\n config: {\n through: string;\n from: string;\n to: string;\n },\n) {\n return {\n kind: \"manyToMany\",\n target,\n through: config.through,\n from: config.from,\n to: config.to,\n } satisfies RelationDefinition<Target, \"manyToMany\">;\n}\n","import type { AnyFieldBuilder, FieldOutput } from \"./fields\";\nimport type { AnyRelation, RelationDefinition } from \"./relations\";\n\nexport type FieldMap = Record<string, AnyFieldBuilder>;\nexport type RelationMap = Record<string, AnyRelation>;\n\nexport type ModelDefinition<\n Fields extends FieldMap = FieldMap,\n Relations extends RelationMap = RelationMap,\n> = {\n readonly _tag: \"model\";\n readonly table: string;\n readonly fields: Fields;\n readonly relations: Relations;\n readonly description?: string;\n};\n\nexport type AnyModelDefinition = ModelDefinition<FieldMap, RelationMap>;\n\nexport type SchemaDefinition<\n Models extends Record<string, AnyModelDefinition> = Record<string, AnyModelDefinition>,\n> = {\n readonly _tag: \"schema\";\n readonly models: Models;\n};\n\nexport function model<Fields extends FieldMap, Relations extends RelationMap = {}>(config: {\n table: string;\n fields: Fields;\n relations?: Relations;\n description?: string;\n}): ModelDefinition<Fields, Relations> {\n return {\n _tag: \"model\",\n table: config.table,\n fields: config.fields,\n relations: (config.relations ?? {}) as Relations,\n description: config.description,\n };\n}\n\nexport function defineSchema<Models extends Record<string, AnyModelDefinition>>(\n models: Models,\n): SchemaDefinition<Models> {\n return {\n _tag: \"schema\",\n models,\n };\n}\n\nexport type SchemaModels<TSchema> = TSchema extends SchemaDefinition<infer Models> ? Models : never;\n\nexport type ModelName<TSchema> = keyof SchemaModels<TSchema> & string;\n\nexport type ModelForName<TSchema, TName extends ModelName<TSchema>> = SchemaModels<TSchema>[TName];\n\nexport type ModelFields<TSchema, TName extends ModelName<TSchema>> = ModelForName<\n TSchema,\n TName\n>[\"fields\"];\n\nexport type ModelRelations<TSchema, TName extends ModelName<TSchema>> = ModelForName<\n TSchema,\n TName\n>[\"relations\"];\n\nexport type ScalarRecord<TSchema, TName extends ModelName<TSchema>> = {\n [K in keyof ModelFields<TSchema, TName> & string]: FieldOutput<ModelFields<TSchema, TName>[K]>;\n};\n\nexport type RelationName<TSchema, TName extends ModelName<TSchema>> = keyof ModelRelations<\n TSchema,\n TName\n> &\n string;\n\nexport type RelationForName<\n TSchema,\n TName extends ModelName<TSchema>,\n TRelationName extends RelationName<TSchema, TName>,\n> = ModelRelations<TSchema, TName>[TRelationName];\n\nexport type RelationTarget<\n TSchema,\n TName extends ModelName<TSchema>,\n TRelationName extends RelationName<TSchema, TName>,\n> =\n RelationForName<TSchema, TName, TRelationName> extends RelationDefinition<infer Target, any>\n ? Extract<Target, ModelName<TSchema>>\n : never;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;AC4OA,SAAS,kBAIP,QACA,QACAA,QACkC;AAClC,SAAO;AAAA,IACL,SAAS,MAAM;AACb,aAAO,OAAO,SAAS,QAAQA,QAAQ,QAAQ,CAAC,CAAS;AAAA,IAC3D;AAAA,IACA,UAAU,MAAM;AACd,aAAO,OAAO,UAAU,QAAQA,QAAQ,QAAQ,CAAC,CAAS;AAAA,IAC5D;AAAA,IACA,OAAO,MAAM;AACX,aAAO,OAAO,OAAO,QAAQA,QAAO,IAAW;AAAA,IACjD;AAAA,IACA,OAAO,MAAM;AACX,aAAO,OAAO,OAAO,QAAQA,QAAO,IAAW;AAAA,IACjD;AAAA,IACA,OAAO,MAAM;AACX,aAAO,OAAO,OAAO,QAAQA,QAAO,IAAW;AAAA,IACjD;AAAA,EACF;AACF;AAEO,SAAS,UAAiD,SAG1C;AACrB,QAAM,EAAE,QAAQ,OAAO,IAAI;AAC3B,QAAM,SAAkC,CAAC;AAEzC,aAAWA,UAAS,OAAO,KAAK,OAAO,MAAM,GAAG;AAC9C,WAAOA,MAAK,IAAI,kBAAkB,QAAQ,QAAQA,MAA2B;AAAA,EAC/E;AAEA,QAAM,MAAM;AACZ,MAAI,cAAc,CAAC,QACjB,OAAO,YAAY,QAAQ,OAAO,aAAa;AAC7C,UAAM,KAAK,UAAU;AAAA,MACnB;AAAA,MACA,QAAQ;AAAA,IACV,CAAC;AACD,WAAO,IAAI,EAAE;AAAA,EACf,CAAC;AACH,SAAO;AACT;;;ACxQA,IAAM,aAAa,CACjB,WACG,IAAI,aAAa,MAAM;AAErB,IAAM,eAAN,MAA8E;AAAA,EAGnF,YAAqB,QAAqC;AAArC;AAAA,EAAsC;AAAA,EAFlD,OAAO;AAAA,EAIhB,SAAS;AACP,WAAO,WAAW;AAAA,MAChB,GAAG,KAAK;AAAA,MACR,QAAQ;AAAA,IACV,CAAC;AAAA,EACH;AAAA,EAEA,WAAW;AACT,WAAO,WAAuB;AAAA,MAC5B,GAAG,KAAK;AAAA,MACR,UAAU;AAAA,IACZ,CAAC;AAAA,EACH;AAAA,EAEA,QAAQ,OAAgB;AACtB,WAAO,WAAW;AAAA,MAChB,GAAG,KAAK;AAAA,MACR,cAAc;AAAA,IAChB,CAAC;AAAA,EACH;AAAA,EAEA,aAAa;AACX,WAAO,WAAW;AAAA,MAChB,GAAG,KAAK;AAAA,MACR,WAAW;AAAA,IACb,CAAC;AAAA,EACH;AAAA,EAEA,WAAW,WAA2B;AACpC,WAAO,WAAW;AAAA,MAChB,GAAG,KAAK;AAAA,MACR,YAAY;AAAA,IACd,CAAC;AAAA,EACH;AAAA,EAEA,IAAI,MAAc;AAChB,WAAO,WAAW;AAAA,MAChB,GAAG,KAAK;AAAA,MACR,YAAY;AAAA,IACd,CAAC;AAAA,EACH;AAAA,EAEA,SAAS,aAAqB;AAC5B,WAAO,WAAW;AAAA,MAChB,GAAG,KAAK;AAAA,MACR;AAAA,IACF,CAAC;AAAA,EACH;AACF;AAiBO,SAAS,KAAK;AACnB,SAAO,IAAI,aAAa;AAAA,IACtB,MAAM;AAAA,IACN,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,WAAW;AAAA,EACb,CAAC;AACH;AAEO,SAAS,SAAS;AACvB,SAAO,IAAI,aAAa;AAAA,IACtB,MAAM;AAAA,IACN,UAAU;AAAA,IACV,QAAQ;AAAA,EACV,CAAC;AACH;AAEO,SAAS,UAAU;AACxB,SAAO,IAAI,aAAa;AAAA,IACtB,MAAM;AAAA,IACN,UAAU;AAAA,IACV,QAAQ;AAAA,EACV,CAAC;AACH;AAEO,SAAS,WAAW;AACzB,SAAO,IAAI,aAAa;AAAA,IACtB,MAAM;AAAA,IACN,UAAU;AAAA,IACV,QAAQ;AAAA,EACV,CAAC;AACH;;;ACjGO,SAAS,eAEd,QAAiC;AACjC,QAAM,SAAS,OAAO;AAAA,IACnB,OAAO,QAAQ,OAAO,MAAM,EAA0C;AAAA,MACrE,CAAC,CAAC,MAAM,UAAU,MAAM;AACtB,cAAM,SAAS,OAAO;AAAA,UAElB,OAAO,QAAQ,WAAW,MAAM,EAGhC,IAAI,CAAC,CAAC,WAAW,KAAK,MAAM;AAAA,YAC5B;AAAA,YACA;AAAA,cACE,MAAM;AAAA,cACN,QAAQ,MAAM,OAAO,cAAc;AAAA,cACnC,MAAM,MAAM,OAAO;AAAA,cACnB,UAAU,MAAM,OAAO;AAAA,cACvB,QAAQ,MAAM,OAAO;AAAA,cACrB,WAAW,MAAM,OAAO;AAAA,cACxB,cAAc,MAAM,OAAO;AAAA,cAC3B,YAAY,MAAM,OAAO;AAAA,cACzB,aAAa,MAAM,OAAO;AAAA,YAC5B;AAAA,UACF,CAAC;AAAA,QACH;AAEA,eAAO;AAAA,UACL;AAAA,UACA;AAAA,YACE;AAAA,YACA,OAAO,WAAW;AAAA,YAClB,aAAa,WAAW;AAAA,YACxB;AAAA,YACA,WAAW,WAAW;AAAA,UACxB;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAEA,SAAO,EAAE,OAAO;AAClB;;;AChDA,IAAM,aAAa,CAAC,UAAkB,MAAM,OAAO,CAAC,EAAE,YAAY,IAAI,MAAM,MAAM,CAAC;AACnF,IAAM,YAAY,CAAC,UAAmB,MAAM,SAAS,GAAG,IAAI,QAAQ,GAAG,KAAK;AAE5E,SAAS,WAAW,OAAsB;AACxC,UAAQ,MAAM,MAAM;AAAA,IAClB,KAAK;AAAA,IACL,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AACH,aAAO;AAAA,EACX;AACF;AAEA,SAAS,eAAe,SAA8C,UAA0B;AAC9F,QAAM,SAAS,OAAO,OAAO,SAAS,MAAM;AAC5C,QAAM,eAAe,OAAO;AAAA,IAAK,CAACC,WAChC,OAAO,OAAOA,OAAM,MAAM,EAAE,KAAK,CAAC,UAAU,MAAM,SAAS,SAAS;AAAA,EACtE;AACA,QAAM,YAAY,OAAO;AAAA,IAAK,CAACA,WAC7B,OAAO,OAAOA,OAAM,MAAM,EAAE,KAAK,CAAC,UAAU,MAAM,SAAS,UAAU;AAAA,EACvE;AAEA,MAAI,YAAY,MAAM;AACpB,WAAO;AAAA,MACL;AAAA,MACA;AAAA,MACA,eAAe,YAAY;AAAA,MAC3B,YAAY,cAAc;AAAA,IAC5B,EAAE,OAAO,OAAO;AAAA,EAClB;AAEA,MAAI,YAAY,SAAS;AACvB,WAAO;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,MACA,eAAe,YAAY;AAAA,MAC3B,YAAY,aAAa;AAAA,IAC3B,EAAE,OAAO,OAAO;AAAA,EAClB;AAEA,SAAO,CAAC,eAAe,QAAQ,SAAS;AAC1C;AAEA,SAAS,cAAc,OAAsB,SAA8C;AACzF,MAAI,MAAM,SAAS,MAAM;AACvB,QAAI,YAAY,SAAS;AACvB,aAAO,YAAY,MAAM,MAAM;AAAA,IACjC;AACA,WAAO,SAAS,MAAM,MAAM;AAAA,EAC9B;AAEA,MAAI,MAAM,SAAS,UAAU;AAC3B,QAAI,YAAY,SAAS;AACvB,YAAM,OACJ,MAAM,UAAU,MAAM,aAClB,YAAY,MAAM,MAAM,wBACxB,SAAS,MAAM,MAAM;AAC3B,aAAO,GAAG,IAAI,GAAG,MAAM,WAAW,KAAK,YAAY,GAAG,MAAM,SAAS,cAAc,EAAE,GACnF,MAAM,iBAAiB,SAAY,YAAY,KAAK,UAAU,MAAM,YAAY,CAAC,MAAM,EACzF;AAAA,IACF;AACA,WAAO,SAAS,MAAM,MAAM,KAAK,MAAM,WAAW,KAAK,YAAY,GAAG,MAAM,SAAS,cAAc,EAAE,GACnG,MAAM,iBAAiB,SAAY,YAAY,KAAK,UAAU,MAAM,YAAY,CAAC,MAAM,EACzF;AAAA,EACF;AAEA,MAAI,MAAM,SAAS,WAAW;AAC5B,QAAI,YAAY,UAAU;AACxB,aAAO,YAAY,MAAM,MAAM,0BAA0B,MAAM,WAAW,KAAK,YAAY,GACzF,MAAM,iBAAiB,SAAY,YAAY,OAAO,MAAM,YAAY,CAAC,MAAM,EACjF;AAAA,IACF;AACA,WAAO,YAAY,MAAM,MAAM,KAAK,MAAM,WAAW,KAAK,YAAY,GACpE,MAAM,iBAAiB,SAAY,YAAY,OAAO,MAAM,YAAY,CAAC,MAAM,EACjF;AAAA,EACF;AAEA,MAAI,YAAY,SAAS;AACvB,WAAO,aAAa,MAAM,MAAM,uBAAuB,MAAM,WAAW,KAAK,YAAY;AAAA,EAC3F;AACA,MAAI,YAAY,UAAU;AACxB,WAAO,YAAY,MAAM,MAAM,4BAA4B,MAAM,WAAW,KAAK,YAAY;AAAA,EAC/F;AACA,SAAO,cAAc,MAAM,MAAM,KAAK,MAAM,WAAW,KAAK,YAAY;AAC1E;AAEA,SAAS,QAAQ,OAAsB,SAA0C;AAC/E,MAAI,MAAM,SAAS,MAAM;AACvB,WAAO,YAAY,UAAU,iBAAiB;AAAA,EAChD;AACA,MAAI,MAAM,SAAS,UAAU;AAC3B,WAAO,YAAY,WAAW,MAAM,SAAS,iBAAiB;AAAA,EAChE;AACA,MAAI,MAAM,SAAS,WAAW;AAC5B,WAAO,YAAY,WAAW,YAAY;AAAA,EAC5C;AACA,MAAI,YAAY,SAAS;AACvB,WAAO;AAAA,EACT;AACA,MAAI,YAAY,UAAU;AACxB,WAAO;AAAA,EACT;AACA,SAAO;AACT;AAEO,SAAS,mBACd,QACA,UAAmC,CAAC,GACpC;AACA,QAAM,WAAW,eAAe,MAAM;AACtC,QAAM,WAAW,QAAQ,YAAY;AACrC,QAAM,gBAAgB,QAAQ,iBAAiB;AAC/C,QAAM,iBAAiB,QAAQ,kBAAkB;AACjD,QAAM,mBAAmB,oBAAI,IAA2D;AAExF,aAAWA,UAAS,OAAO,OAAO,SAAS,MAAM,GAAsB;AACrE,eAAW,SAAS,OAAO,OAAOA,OAAM,MAAM,GAAG;AAC/C,UAAI,CAAC,MAAM,WAAY;AACvB,YAAM,CAAC,WAAW,IAAI,MAAM,WAAW,MAAM,GAAG;AAChD,uBAAiB,IAAI,aAAa;AAAA,QAChC,GAAI,iBAAiB,IAAI,WAAW,KAAK,CAAC;AAAA,QAC1C;AAAA,UACE,aAAaA,OAAM;AAAA,UACnB,MAAM,CAAC,MAAM;AAAA,QACf;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AAEA,QAAM,SAAU,OAAO,OAAO,SAAS,MAAM,EAAsB,IAAI,CAACA,WAAU;AAChF,UAAM,QAAkB,CAAC;AACzB,UAAM,YAAY,WAAWA,OAAM,IAAI;AAEvC,eAAW,SAAS,OAAO,OAAOA,OAAM,MAAM,GAAG;AAC/C,YAAM,YAAY,WAAW,KAAK;AAClC,YAAM,YAAsB,CAAC;AAC7B,UAAI,MAAM,SAAS,KAAM,WAAU,KAAK,KAAK;AAC7C,UAAI,MAAM,cAAc,KAAM,WAAU,KAAK,kBAAkB;AAC/D,UAAI,MAAM,cAAc,MAAO,WAAU,KAAK,iBAAiB;AAC/D,UAAI,MAAM,iBAAiB,UAAa,MAAM,cAAc,QAAW;AACrE,kBAAU;AAAA,UACR,OAAO,MAAM,iBAAiB,WAC1B,aAAa,MAAM,YAAY,OAC/B,YAAY,OAAO,MAAM,YAAY,CAAC;AAAA,QAC5C;AAAA,MACF;AACA,UAAI,MAAM,UAAU,MAAM,SAAS,KAAM,WAAU,KAAK,SAAS;AACjE,UAAI,MAAM,WAAW,MAAM,KAAM,WAAU,KAAK,SAAS,MAAM,MAAM,IAAI;AAEzE,YAAM;AAAA,QACJ,KAAK,MAAM,IAAI,IAAI,SAAS,GAAG,MAAM,WAAW,MAAM,EAAE,GAAG,UAAU,SAAS,IAAI,UAAU,KAAK,GAAG,CAAC,KAAK,EAAE;AAAA,MAC9G;AAEA,UAAI,MAAM,YAAY;AACpB,cAAM,CAAC,aAAa,WAAW,IAAI,MAAM,WAAW,MAAM,GAAG;AAC7D,cAAM;AAAA,UACJ,KAAK,WAAW,IAAI,WAAW,WAAW,CAAC,uBAAuB,MAAM,IAAI,mBAAmB,WAAW;AAAA,QAC5G;AAAA,MACF;AAAA,IACF;AAEA,eAAW,YAAY,iBAAiB,IAAIA,OAAM,IAAI,KAAK,CAAC,GAAG;AAC7D,YAAM;AAAA,QACJ,SAAS,OACL,KAAK,UAAU,SAAS,WAAW,CAAC,IAAI,WAAW,SAAS,WAAW,CAAC,OACxE,KAAK,SAAS,WAAW,IAAI,WAAW,SAAS,WAAW,CAAC;AAAA,MACnE;AAAA,IACF;AAEA,UAAM,UAAUA,OAAM,UAAU,YAAY;AAAA,WAAcA,OAAM,KAAK,OAAO;AAC5E,WAAO,SAAS,SAAS;AAAA,EAAO,MAAM,KAAK,IAAI,CAAC,GAAG,OAAO;AAAA;AAAA,EAC5D,CAAC;AAED,SACE,aAAa,aAAa;AAAA;AAAA;AAAA;AAAA,aACZ,cAAc;AAAA,gBAAqB,QAAQ;AAAA,eACvD,aAAa,WAAW,oBAAoB,qBAC9C;AAAA;AAAA;AAAA,EAAU,OAAO,KAAK,MAAM,CAAC;AAAA;AAEjC;AAEO,SAAS,oBACd,QACA,SACA;AACA,QAAM,WAAW,eAAe,MAAM;AACtC,QAAM,UAAU,eAAe,QAAQ,SAAS,QAAQ,EAAE,KAAK,IAAI;AACnE,QAAM,eACJ,QAAQ,YAAY,OAChB,YACA,QAAQ,YAAY,UAClB,eACA;AAER,QAAM,cAAe,OAAO,OAAO,SAAS,MAAM,EAAsB,IAAI,CAACA,WAAU;AACrF,UAAM,QAAQ,OAAO,OAAOA,OAAM,MAAM,EAAE,IAAI,CAAC,UAAU;AACvD,UAAI,QAAQ,cAAc,OAAO,QAAQ,OAAO;AAChD,UAAI,MAAM,YAAY;AACpB,cAAM,CAAC,aAAa,WAAW,IAAI,MAAM,WAAW,MAAM,GAAG;AAC7D,iBAAS,qBAAqB,WAAW,IAAI,WAAW;AAAA,MAC1D;AACA,aAAO,KAAK,MAAM,IAAI,KAAK,KAAK;AAAA,IAClC,CAAC;AAED,WAAO,gBAAgBA,OAAM,IAAI,MAAM,YAAY,KAAKA,OAAM,KAAK;AAAA,EAAS,MAAM,KAAK,KAAK,CAAC;AAAA;AAAA,EAC/F,CAAC;AAED,SAAO,YAAY,OAAO,wBACxB,QAAQ,YAAY,OAChB,YACA,QAAQ,YAAY,UAClB,eACA,aACR;AAAA;AAAA,EAAS,YAAY,KAAK,MAAM,CAAC;AAAA;AACnC;AAEO,SAAS,cAAc,QAA+B,SAA+B;AAC1F,QAAM,WAAW,eAAe,MAAM;AACtC,QAAM,aAAc,OAAO,OAAO,SAAS,MAAM,EAAsB,IAAI,CAACA,WAAU;AACpF,UAAM,UAAU,OAAO,OAAOA,OAAM,MAAM,EAAE,IAAI,CAAC,UAAU;AACzD,YAAM,QAAQ,CAAC,GAAG,MAAM,MAAM,IAAI,QAAQ,OAAO,QAAQ,OAAO,CAAC,EAAE;AACnE,UAAI,MAAM,SAAS,KAAM,OAAM,KAAK,aAAa;AACjD,UAAI,CAAC,MAAM,SAAU,OAAM,KAAK,UAAU;AAC1C,UAAI,MAAM,UAAU,MAAM,SAAS,KAAM,OAAM,KAAK,QAAQ;AAC5D,UAAI,MAAM,iBAAiB,QAAW;AACpC,cAAM;AAAA,UACJ,WACE,OAAO,MAAM,iBAAiB,WAC1B,IAAI,MAAM,YAAY,MACtB,OAAO,MAAM,YAAY,CAC/B;AAAA,QACF;AAAA,MACF;AACA,UAAI,MAAM,YAAY;AACpB,cAAM,CAAC,aAAa,WAAW,IAAI,MAAM,WAAW,MAAM,GAAG;AAC7D,cAAM,cAAc,SAAS,OAAO,WAAW,GAAG,SAAS;AAC3D,cAAM,KAAK,cAAc,WAAW,IAAI,WAAW,GAAG;AAAA,MACxD;AACA,aAAO,KAAK,MAAM,KAAK,GAAG,CAAC;AAAA,IAC7B,CAAC;AAED,WAAO,8BAA8BA,OAAM,KAAK;AAAA,EAAO,QAAQ,KAAK,KAAK,CAAC;AAAA;AAAA,EAC5E,CAAC;AAED,SAAO,GAAG,WAAW,KAAK,MAAM,CAAC;AAAA;AACnC;AAEO,SAAS,sBAAsB,OAA4D;AAChG,QAAM,QAAQ,8BAA8B,MAAM,KAAK;AACvD,QAAM,MAAM,4BAA4B,MAAM,KAAK;AACnD,QAAM,QAAQ,GAAG,KAAK;AAAA,EAAK,MAAM,QAAQ,KAAK,CAAC;AAAA,EAAK,GAAG;AAEvD,MAAI,MAAM,QAAQ,SAAS,KAAK,KAAK,MAAM,QAAQ,SAAS,GAAG,GAAG;AAChE,UAAM,UAAU,IAAI,OAAO,GAAG,KAAK,aAAa,GAAG,IAAI,GAAG;AAC1D,WAAO,MAAM,QAAQ,QAAQ,SAAS,KAAK;AAAA,EAC7C;AAEA,SAAO,GAAG,MAAM,QAAQ,KAAK,CAAC;AAAA;AAAA,EAAO,KAAK;AAAA;AAC5C;;;AC3RA,yBAA2B;AAmB3B,IAAM,SAAS,CAAC,UAAkC,iBAAiB;AAEnE,SAAS,eAAe,OAAgB,QAAiB;AACvD,MACE,WAAW,UACX,WAAW,QACX,OAAO,WAAW,YAClB,OAAO,MAAM,KACb,MAAM,QAAQ,MAAM,GACpB;AACA,WAAO,UAAU;AAAA,EACnB;AAEA,QAAM,SAAS;AAEf,MAAI,QAAQ,UAAU,UAAU,OAAO,GAAI,QAAO;AAClD,MAAI,SAAS,UAAU,UAAU,OAAO,IAAK,QAAO;AACpD,MAAI,QAAQ,QAAQ;AAClB,UAAM,SAAS,MAAM,QAAQ,OAAO,EAAE,IAAI,OAAO,KAAK,CAAC;AACvD,QAAI,CAAC,OAAO,SAAS,KAAK,EAAG,QAAO;AAAA,EACtC;AACA,MAAI,cAAc,QAAQ;AACxB,QAAI,OAAO,UAAU,YAAY,OAAO,OAAO,aAAa,SAAU,QAAO;AAC7E,QAAI,CAAC,MAAM,SAAS,OAAO,QAAQ,EAAG,QAAO;AAAA,EAC/C;AACA,MAAI,QAAQ,UAAU,UAAU,QAAW;AACzC,QAAI,EAAE,iBAAiB,QAAQ,OAAO,UAAU,YAAY,OAAO,UAAU,WAAW;AACtF,aAAO;AAAA,IACT;AACA,QAAI,EAAE,QAAQ,OAAO,IAAM,QAAO;AAAA,EACpC;AACA,MAAI,SAAS,UAAU,UAAU,QAAW;AAC1C,QAAI,EAAE,iBAAiB,QAAQ,OAAO,UAAU,YAAY,OAAO,UAAU,WAAW;AACtF,aAAO;AAAA,IACT;AACA,QAAI,EAAE,SAAS,OAAO,KAAO,QAAO;AAAA,EACtC;AACA,MAAI,QAAQ,UAAU,UAAU,QAAW;AACzC,QAAI,EAAE,iBAAiB,QAAQ,OAAO,UAAU,YAAY,OAAO,UAAU,WAAW;AACtF,aAAO;AAAA,IACT;AACA,QAAI,EAAE,QAAQ,OAAO,IAAM,QAAO;AAAA,EACpC;AACA,MAAI,SAAS,UAAU,UAAU,QAAW;AAC1C,QAAI,EAAE,iBAAiB,QAAQ,OAAO,UAAU,YAAY,OAAO,UAAU,WAAW;AACtF,aAAO;AAAA,IACT;AACA,QAAI,EAAE,SAAS,OAAO,KAAO,QAAO;AAAA,EACtC;AAEA,SAAO;AACT;AAEA,SAAS,aACP,QACA,OACA;AACA,MAAI,CAAC,MAAO,QAAO;AAEnB,MAAI,MAAM,OAAO,CAAC,MAAM,IAAI,MAAM,CAAC,WAAuB,aAAa,QAAQ,MAAM,CAAC,GAAG;AACvF,WAAO;AAAA,EACT;AAEA,MAAI,MAAM,MAAM,CAAC,MAAM,GAAG,KAAK,CAAC,WAAuB,aAAa,QAAQ,MAAM,CAAC,GAAG;AACpF,WAAO;AAAA,EACT;AAEA,MAAI,MAAM,OAAO,aAAa,QAAQ,MAAM,GAAG,GAAG;AAChD,WAAO;AAAA,EACT;AAEA,aAAW,CAAC,KAAK,MAAM,KAAK,OAAO,QAAQ,KAAK,GAAG;AACjD,QAAI,QAAQ,SAAS,QAAQ,QAAQ,QAAQ,MAAO;AACpD,QAAI,CAAC,eAAe,OAAO,GAAG,GAAG,MAAM,EAAG,QAAO;AAAA,EACnD;AAEA,SAAO;AACT;AAEA,SAAS,aAAa,OAAgB,OAAuD;AAC3F,MAAI,UAAU,OAAW,QAAO;AAEhC,MAAI,MAAM,cAAc,KAAM,YAAO,+BAAW;AAChD,MAAI,MAAM,cAAc,MAAO,QAAO,oBAAI,KAAK;AAE/C,MAAI,OAAO,MAAM,iBAAiB,YAAY;AAC5C,WAAQ,MAAM,aAA+B;AAAA,EAC/C;AAEA,SAAO,MAAM;AACf;AAEA,SAAS,SACP,MACA,SACA;AACA,MAAI,CAAC,QAAS,QAAO;AACrB,QAAM,UAAU,OAAO,QAAQ,OAAO;AACtC,MAAI,CAAC,QAAQ,OAAQ,QAAO;AAE5B,SAAO,CAAC,GAAG,IAAI,EAAE,KAAK,CAAC,MAAM,UAAU;AACrC,eAAW,CAAC,OAAO,SAAS,KAAK,SAAS;AACxC,YAAM,IAAI,KAAK,KAAK;AACpB,YAAM,IAAI,MAAM,KAAK;AACrB,UAAI,MAAM,EAAG;AACb,UAAI,MAAM,OAAW,QAAO,cAAc,QAAQ,KAAK;AACvD,UAAI,MAAM,OAAW,QAAO,cAAc,QAAQ,IAAI;AACtD,UAAI,KAAK,KAAM,QAAO,cAAc,QAAQ,KAAK;AACjD,UAAI,KAAK,KAAM,QAAO,cAAc,QAAQ,IAAI;AAChD,UAAI,IAAI,EAAG,QAAO,cAAc,QAAQ,KAAK;AAC7C,UAAI,IAAI,EAAG,QAAO,cAAc,QAAQ,IAAI;AAAA,IAC9C;AACA,WAAO;AAAA,EACT,CAAC;AACH;AAEA,SAAS,SAAS,MAAsC,MAAe,MAAe;AACpF,QAAM,QAAQ,QAAQ;AACtB,QAAM,MAAM,SAAS,SAAY,SAAY,QAAQ;AACrD,SAAO,KAAK,MAAM,OAAO,GAAG;AAC9B;AAEO,SAAS,mBACd,MACoB;AACpB,QAAM,QAA8B,gBAAgB,QAAQ,CAAC,CAAC;AAE9D,WAAS,QAA+CC,QAAmB;AACzE,UAAM,OAAO,MAAMA,MAAK,KAAK,CAAC;AAC9B,UAAMA,MAAK,IAAI;AACf,WAAO;AAAA,EACT;AAEA,WAAS,WACPA,QACA,MACA;AACA,UAAM,OAAO,QAAQA,MAAK;AAC1B,UAAM,WAAW,KAAK,OAAO,CAAC,QAAQ,aAAa,KAAK,KAAK,KAAK,CAAC;AACnE,UAAM,SAAS;AAAA,MACb;AAAA,MACA,KAAK;AAAA,IACP;AACA,WAAO,SAAS,QAAQ,KAAK,MAAM,KAAK,IAAI;AAAA,EAC9C;AAEA,iBAAe,WAIb,QACAA,QACA,KACA,QACuD;AACvD,UAAM,kBAAkB,OAAO,OAAOA,MAAK;AAC3C,UAAM,SAAkC,CAAC;AAEzC,QAAI,CAAC,QAAQ;AACX,iBAAW,aAAa,OAAO,KAAK,gBAAgB,MAAM,GAAG;AAC3D,eAAO,SAAS,IAAI,IAAI,SAAS;AAAA,MACnC;AACA,aAAO;AAAA,IACT;AAEA,eAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,MAAM,GAAG;AACjD,UAAI,UAAU,QAAQ,UAAU,OAAW;AAE3C,UAAI,OAAO,gBAAgB,UAAU,UAAU,MAAM;AACnD,eAAO,GAAG,IAAI,IAAI,GAAG;AACrB;AAAA,MACF;AAEA,UAAI,OAAO,gBAAgB,WAAW;AACpC,eAAO,GAAG,IAAI,MAAM;AAAA,UAClB;AAAA,UACAA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AAEA,iBAAe,gBAIb,QACAA,QACA,cACA,KACA,OACA;AACA,UAAM,WAAW,OAAO,OAAOA,MAAK,EAAE,UAAU,YAAY;AAC5D,UAAM,eAAe,UAAU,OAAO,CAAC,IAAI;AAE3C,QAAI,SAAS,SAAS,aAAa;AACjC,YAAMC,cAAa,QAAQ,SAAS,MAA4B;AAChE,YAAM,eAAe,IAAI,SAAS,UAAU;AAC5C,YAAM,SAASA,YAAW,KAAK,CAAC,SAAS,KAAK,OAAO,YAAY;AACjE,aAAO,SACH,WAAW,QAAQ,SAAS,QAA8B,QAAQ,aAAa,MAAM,IACrF;AAAA,IACN;AAEA,QAAI,SAAS,SAAS,UAAU;AAC9B,YAAMA,cAAa,QAAQ,SAAS,MAA4B;AAChE,YAAM,SAASA,YAAW,KAAK,CAAC,SAAS,KAAK,SAAS,UAAU,MAAM,IAAI,EAAE;AAC7E,aAAO,SACH,WAAW,QAAQ,SAAS,QAA8B,QAAQ,aAAa,MAAM,IACrF;AAAA,IACN;AAEA,QAAI,SAAS,SAAS,WAAW;AAC/B,YAAMA,cAAa,QAAQ,SAAS,MAA4B,EAAE;AAAA,QAChE,CAAC,SAAS,KAAK,SAAS,UAAU,MAAM,IAAI;AAAA,MAC9C;AACA,YAAMC,UAAS;AAAA,QACbD;AAAA,QACA,aAAa;AAAA,MACf;AACA,YAAME,SAAQ,SAASD,SAAQ,aAAa,MAAM,aAAa,IAAI;AACnE,YAAME,YAAWD,OAAM,OAAO,CAAC,SAAS,aAAa,MAAM,aAAa,KAAK,CAAC;AAC9E,aAAO,QAAQ;AAAA,QACbC,UAAS;AAAA,UAAI,CAAC,SACZ,WAAW,QAAQ,SAAS,QAA8B,MAAM,aAAa,MAAM;AAAA,QACrF;AAAA,MACF;AAAA,IACF;AAEA,UAAM,cAAc,QAAQ,SAAS,OAA6B,EAAE;AAAA,MAClE,CAAC,SAAS,KAAK,SAAS,IAAI,MAAM,IAAI;AAAA,IACxC;AACA,UAAM,YAAY,YAAY,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;AAC7D,UAAM,aAAa,QAAQ,SAAS,MAA4B,EAAE;AAAA,MAAO,CAAC,SACxE,UAAU,SAAS,KAAK,EAAE;AAAA,IAC5B;AACA,UAAM,SAAS;AAAA,MACb;AAAA,MACA,aAAa;AAAA,IACf;AACA,UAAM,QAAQ,SAAS,QAAQ,aAAa,MAAM,aAAa,IAAI;AACnE,UAAM,WAAW,MAAM,OAAO,CAAC,SAAS,aAAa,MAAM,aAAa,KAAK,CAAC;AAE9E,WAAO,QAAQ;AAAA,MACb,SAAS;AAAA,QAAI,CAAC,SACZ,WAAW,QAAQ,SAAS,QAA8B,MAAM,aAAa,MAAM;AAAA,MACrF;AAAA,IACF;AAAA,EACF;AAEA,QAAM,SAAS;AAAA,IACb,MAAM,SACJ,QACAJ,QACA,MACA;AACA,YAAM,OAAO,WAAWA,QAAO,IAAI;AACnC,aAAO,QAAQ,IAAI,KAAK,IAAI,CAAC,QAAQ,WAAW,QAAQA,QAAO,KAAK,KAAK,MAAM,CAAC,CAAC;AAAA,IACnF;AAAA,IACA,MAAM,UACJ,QACAA,QACA,MACA;AACA,YAAM,MAAM,WAAWA,QAAO,IAAI,EAAE,CAAC;AACrC,UAAI,CAAC,IAAK,QAAO;AACjB,aAAO,WAAW,QAAQA,QAAO,KAAK,KAAK,MAAM;AAAA,IACnD;AAAA,IACA,MAAM,OACJ,QACAA,QACA,MACA;AACA,YAAM,kBAAkB,OAAO,OAAOA,MAAK;AAC3C,YAAM,UAAmC,CAAC;AAC1C,iBAAW,CAAC,WAAW,KAAK,KAAK,OAAO,QAAQ,gBAAgB,MAAM,GAEnE;AACD,gBAAQ,SAAS,IAAI,aAAa,KAAK,KAAK,SAAS,GAAG,MAAM,MAAM;AAAA,MACtE;AAEA,cAAQA,MAAK,EAAE,KAAK,OAAO;AAC3B,aAAO,WAAW,QAAQA,QAAO,SAAS,KAAK,MAAM;AAAA,IACvD;AAAA,IACA,MAAM,OACJ,QACAA,QACA,MACA;AACA,YAAM,OAAO,QAAQA,MAAK;AAC1B,YAAM,MAAM,KAAK,KAAK,CAAC,SAAS,aAAa,MAAM,KAAK,KAAK,CAAC;AAC9D,UAAI,CAAC,IAAK,QAAO;AACjB,aAAO,OAAO,KAAK,KAAK,IAAI;AAC5B,aAAO,WAAW,QAAQA,QAAO,KAAK,KAAK,MAAM;AAAA,IACnD;AAAA,IACA,MAAM,OACJ,SACAA,QACA,MACA;AACA,YAAM,OAAO,QAAQA,MAAK;AAC1B,YAAM,SAAS,KAAK;AACpB,YAAMA,MAAK,IAAI,KAAK,OAAO,CAAC,SAAS,CAAC,aAAa,MAAM,KAAK,KAAK,CAAC;AACpE,aAAO,UAAU,MAAMA,MAAK,GAAG,UAAU;AAAA,IAC3C;AAAA,IACA,MAAM,YACJ,SACA,KACA;AACA,YAAM,WAAW,gBAAgB,KAAK;AACtC,UAAI;AACF,eAAO,MAAM,IAAI,MAAM;AAAA,MACzB,SAAS,OAAO;AACd,eAAO,KAAK,KAAK,EAAE,QAAQ,CAAC,QAAQ;AAClC,iBAAO,MAAM,GAAyB;AAAA,QACxC,CAAC;AACD,eAAO,OAAO,OAAO,QAAQ;AAC7B,cAAM;AAAA,MACR;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AACT;;;ACtUO,SAAS,UAAiC,QAAgB,QAAgC;AAC/F,SAAO;AAAA,IACL,MAAM;AAAA,IACN;AAAA,IACA,YAAY,OAAO;AAAA,EACrB;AACF;AAEO,SAAS,OAA8B,QAAgB,QAAgC;AAC5F,SAAO;AAAA,IACL,MAAM;AAAA,IACN;AAAA,IACA,YAAY,OAAO;AAAA,EACrB;AACF;AAEO,SAAS,QAA+B,QAAgB,QAAgC;AAC7F,SAAO;AAAA,IACL,MAAM;AAAA,IACN;AAAA,IACA,YAAY,OAAO;AAAA,EACrB;AACF;AAEO,SAAS,WACd,QACA,QAKA;AACA,SAAO;AAAA,IACL,MAAM;AAAA,IACN;AAAA,IACA,SAAS,OAAO;AAAA,IAChB,MAAM,OAAO;AAAA,IACb,IAAI,OAAO;AAAA,EACb;AACF;;;AClCO,SAAS,MAAmE,QAK5C;AACrC,SAAO;AAAA,IACL,MAAM;AAAA,IACN,OAAO,OAAO;AAAA,IACd,QAAQ,OAAO;AAAA,IACf,WAAY,OAAO,aAAa,CAAC;AAAA,IACjC,aAAa,OAAO;AAAA,EACtB;AACF;AAEO,SAAS,aACd,QAC0B;AAC1B,SAAO;AAAA,IACL,MAAM;AAAA,IACN;AAAA,EACF;AACF;","names":["model","model","model","targetRows","sorted","paged","filtered"]}
@@ -0,0 +1,254 @@
1
+ type ScalarKind = "id" | "string" | "boolean" | "datetime";
2
+ type FieldReference = `${string}.${string}`;
3
+ type FieldConfig<Kind extends ScalarKind = ScalarKind, Nullable extends boolean = boolean> = {
4
+ kind: Kind;
5
+ nullable: Nullable;
6
+ unique: boolean;
7
+ defaultValue?: unknown;
8
+ generated?: "id" | "now";
9
+ mappedName?: string;
10
+ references?: FieldReference;
11
+ description?: string;
12
+ };
13
+ type AnyFieldBuilder = FieldBuilder<ScalarKind, boolean>;
14
+ declare class FieldBuilder<Kind extends ScalarKind, Nullable extends boolean = false> {
15
+ readonly config: FieldConfig<Kind, Nullable>;
16
+ readonly _tag = "field";
17
+ constructor(config: FieldConfig<Kind, Nullable>);
18
+ unique(): FieldBuilder<Kind, Nullable>;
19
+ nullable(): FieldBuilder<Kind, true>;
20
+ default(value: unknown): FieldBuilder<Kind, Nullable>;
21
+ defaultNow(): FieldBuilder<Kind, Nullable>;
22
+ references(reference: FieldReference): FieldBuilder<Kind, Nullable>;
23
+ map(name: string): FieldBuilder<Kind, Nullable>;
24
+ describe(description: string): FieldBuilder<Kind, Nullable>;
25
+ }
26
+ type ScalarValue<Kind extends ScalarKind> = Kind extends "id" ? string : Kind extends "string" ? string : Kind extends "boolean" ? boolean : Date;
27
+ type FieldOutput<TField> = TField extends FieldBuilder<infer Kind, infer Nullable> ? Nullable extends true ? ScalarValue<Kind> | null : ScalarValue<Kind> : never;
28
+ declare function id(): FieldBuilder<"id", false>;
29
+ declare function string(): FieldBuilder<"string", false>;
30
+ declare function boolean(): FieldBuilder<"boolean", false>;
31
+ declare function datetime(): FieldBuilder<"datetime", false>;
32
+
33
+ type RelationKind = "belongsTo" | "hasOne" | "hasMany" | "manyToMany";
34
+ type RelationDefinition<Target extends string = string, Kind extends RelationKind = RelationKind> = Kind extends "manyToMany" ? {
35
+ kind: Kind;
36
+ target: Target;
37
+ through: string;
38
+ from: string;
39
+ to: string;
40
+ } : {
41
+ kind: Kind;
42
+ target: Target;
43
+ foreignKey: string;
44
+ };
45
+ type AnyRelation = RelationDefinition<string, RelationKind>;
46
+ declare function belongsTo<Target extends string>(target: Target, config: {
47
+ foreignKey: string;
48
+ }): {
49
+ kind: "belongsTo";
50
+ target: Target;
51
+ foreignKey: string;
52
+ };
53
+ declare function hasOne<Target extends string>(target: Target, config: {
54
+ foreignKey: string;
55
+ }): {
56
+ kind: "hasOne";
57
+ target: Target;
58
+ foreignKey: string;
59
+ };
60
+ declare function hasMany<Target extends string>(target: Target, config: {
61
+ foreignKey: string;
62
+ }): {
63
+ kind: "hasMany";
64
+ target: Target;
65
+ foreignKey: string;
66
+ };
67
+ declare function manyToMany<Target extends string>(target: Target, config: {
68
+ through: string;
69
+ from: string;
70
+ to: string;
71
+ }): {
72
+ kind: "manyToMany";
73
+ target: Target;
74
+ through: string;
75
+ from: string;
76
+ to: string;
77
+ };
78
+
79
+ type FieldMap = Record<string, AnyFieldBuilder>;
80
+ type RelationMap = Record<string, AnyRelation>;
81
+ type ModelDefinition<Fields extends FieldMap = FieldMap, Relations extends RelationMap = RelationMap> = {
82
+ readonly _tag: "model";
83
+ readonly table: string;
84
+ readonly fields: Fields;
85
+ readonly relations: Relations;
86
+ readonly description?: string;
87
+ };
88
+ type AnyModelDefinition = ModelDefinition<FieldMap, RelationMap>;
89
+ type SchemaDefinition<Models extends Record<string, AnyModelDefinition> = Record<string, AnyModelDefinition>> = {
90
+ readonly _tag: "schema";
91
+ readonly models: Models;
92
+ };
93
+ declare function model<Fields extends FieldMap, Relations extends RelationMap = {}>(config: {
94
+ table: string;
95
+ fields: Fields;
96
+ relations?: Relations;
97
+ description?: string;
98
+ }): ModelDefinition<Fields, Relations>;
99
+ declare function defineSchema<Models extends Record<string, AnyModelDefinition>>(models: Models): SchemaDefinition<Models>;
100
+ type SchemaModels<TSchema> = TSchema extends SchemaDefinition<infer Models> ? Models : never;
101
+ type ModelName<TSchema> = keyof SchemaModels<TSchema> & string;
102
+ type ModelForName<TSchema, TName extends ModelName<TSchema>> = SchemaModels<TSchema>[TName];
103
+ type ModelFields<TSchema, TName extends ModelName<TSchema>> = ModelForName<TSchema, TName>["fields"];
104
+ type ModelRelations<TSchema, TName extends ModelName<TSchema>> = ModelForName<TSchema, TName>["relations"];
105
+ type ScalarRecord<TSchema, TName extends ModelName<TSchema>> = {
106
+ [K in keyof ModelFields<TSchema, TName> & string]: FieldOutput<ModelFields<TSchema, TName>[K]>;
107
+ };
108
+ type RelationName<TSchema, TName extends ModelName<TSchema>> = keyof ModelRelations<TSchema, TName> & string;
109
+ type RelationForName<TSchema, TName extends ModelName<TSchema>, TRelationName extends RelationName<TSchema, TName>> = ModelRelations<TSchema, TName>[TRelationName];
110
+ type RelationTarget<TSchema, TName extends ModelName<TSchema>, TRelationName extends RelationName<TSchema, TName>> = RelationForName<TSchema, TName, TRelationName> extends RelationDefinition<infer Target, any> ? Extract<Target, ModelName<TSchema>> : never;
111
+
112
+ type Direction = "asc" | "desc";
113
+ type Primitive = string | number | boolean | Date | null;
114
+ type Comparable = string | number | Date;
115
+ type ValueFilter<T> = T extends string ? T | {
116
+ eq?: T;
117
+ contains?: string;
118
+ in?: T[];
119
+ not?: T;
120
+ } : T extends Comparable ? T | {
121
+ eq?: T;
122
+ gt?: T;
123
+ gte?: T;
124
+ lt?: T;
125
+ lte?: T;
126
+ in?: T[];
127
+ not?: T;
128
+ } : T | {
129
+ eq?: T;
130
+ in?: T[];
131
+ not?: T;
132
+ };
133
+ type Where<TRecord extends Record<string, Primitive>> = {
134
+ [K in keyof TRecord]?: ValueFilter<TRecord[K]>;
135
+ } & {
136
+ AND?: Array<Where<TRecord>>;
137
+ OR?: Array<Where<TRecord>>;
138
+ NOT?: Where<TRecord>;
139
+ };
140
+ type RelationQuery<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>> = {
141
+ where?: Where<ScalarRecord<TSchema, TModelName>>;
142
+ select?: SelectShape<TSchema, TModelName>;
143
+ orderBy?: Partial<Record<keyof ScalarRecord<TSchema, TModelName> & string, Direction>>;
144
+ take?: number;
145
+ skip?: number;
146
+ };
147
+ type RelationSelectionValue<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>, TRelationName extends RelationName<TSchema, TModelName>> = true | RelationQuery<TSchema, RelationTarget<TSchema, TModelName, TRelationName>>;
148
+ type SelectShape<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>> = {
149
+ [K in (keyof ScalarRecord<TSchema, TModelName> & string) | RelationName<TSchema, TModelName>]?: K extends RelationName<TSchema, TModelName> ? true | RelationQuery<TSchema, any> : true;
150
+ };
151
+ type IsManyRelation<TRelation> = TRelation extends {
152
+ kind: "hasMany" | "manyToMany";
153
+ } ? true : false;
154
+ type DefaultSelectedRecord<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>> = ScalarRecord<TSchema, TModelName>;
155
+ type SelectedScalars<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>, TSelect extends SelectShape<TSchema, TModelName>> = {
156
+ [K in keyof TSelect & keyof ScalarRecord<TSchema, TModelName> as TSelect[K] extends true ? K : never]: ScalarRecord<TSchema, TModelName>[K];
157
+ };
158
+ type RelationResult<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>, TRelationName extends RelationName<TSchema, TModelName>, TValue extends RelationSelectionValue<TSchema, TModelName, TRelationName>> = TValue extends true ? IsManyRelation<RelationForName<TSchema, TModelName, TRelationName>> extends true ? Array<DefaultSelectedRecord<TSchema, RelationTarget<TSchema, TModelName, TRelationName>>> : DefaultSelectedRecord<TSchema, RelationTarget<TSchema, TModelName, TRelationName>> | null : TValue extends RelationQuery<TSchema, infer Target> ? Target extends ModelName<TSchema> ? IsManyRelation<RelationForName<TSchema, TModelName, TRelationName>> extends true ? Array<SelectedRecord<TSchema, Target, TValue["select"] extends SelectShape<TSchema, Target> ? TValue["select"] : undefined>> : SelectedRecord<TSchema, Target, TValue["select"] extends SelectShape<TSchema, Target> ? TValue["select"] : undefined> | null : never : never;
159
+ type SelectedRelations<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>, TSelect extends SelectShape<TSchema, TModelName>> = {
160
+ [K in keyof TSelect & RelationName<TSchema, TModelName>]: RelationResult<TSchema, TModelName, K, Extract<TSelect[K], RelationSelectionValue<TSchema, TModelName, K>>>;
161
+ };
162
+ type SelectedRecord<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>, TSelect extends SelectShape<TSchema, TModelName> | undefined> = TSelect extends SelectShape<TSchema, TModelName> ? SelectedScalars<TSchema, TModelName, TSelect> & SelectedRelations<TSchema, TModelName, TSelect> : DefaultSelectedRecord<TSchema, TModelName>;
163
+ type FindManyArgs<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>, TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined> = {
164
+ where?: Where<ScalarRecord<TSchema, TModelName>>;
165
+ select?: TSelect;
166
+ orderBy?: Partial<Record<keyof ScalarRecord<TSchema, TModelName> & string, Direction>>;
167
+ take?: number;
168
+ skip?: number;
169
+ };
170
+ type FindFirstArgs<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>, TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined> = FindManyArgs<TSchema, TModelName, TSelect>;
171
+ type CreateArgs<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>, TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined> = {
172
+ data: Partial<ScalarRecord<TSchema, TModelName>>;
173
+ select?: TSelect;
174
+ };
175
+ type UpdateArgs<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>, TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined> = {
176
+ where: Where<ScalarRecord<TSchema, TModelName>>;
177
+ data: Partial<ScalarRecord<TSchema, TModelName>>;
178
+ select?: TSelect;
179
+ };
180
+ type DeleteArgs<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>> = {
181
+ where: Where<ScalarRecord<TSchema, TModelName>>;
182
+ };
183
+ interface OrmDriver<TSchema extends SchemaDefinition<any>> {
184
+ findMany<TModelName extends ModelName<TSchema>, TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(schema: TSchema, model: TModelName, args: FindManyArgs<TSchema, TModelName, TSelect>): Promise<Array<SelectedRecord<TSchema, TModelName, TSelect>>>;
185
+ findFirst<TModelName extends ModelName<TSchema>, TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(schema: TSchema, model: TModelName, args: FindFirstArgs<TSchema, TModelName, TSelect>): Promise<SelectedRecord<TSchema, TModelName, TSelect> | null>;
186
+ create<TModelName extends ModelName<TSchema>, TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(schema: TSchema, model: TModelName, args: CreateArgs<TSchema, TModelName, TSelect>): Promise<SelectedRecord<TSchema, TModelName, TSelect>>;
187
+ update<TModelName extends ModelName<TSchema>, TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(schema: TSchema, model: TModelName, args: UpdateArgs<TSchema, TModelName, TSelect>): Promise<SelectedRecord<TSchema, TModelName, TSelect> | null>;
188
+ delete<TModelName extends ModelName<TSchema>>(schema: TSchema, model: TModelName, args: DeleteArgs<TSchema, TModelName>): Promise<number>;
189
+ transaction<TResult>(schema: TSchema, run: (driver: OrmDriver<TSchema>) => Promise<TResult>): Promise<TResult>;
190
+ }
191
+ type ModelClient<TSchema extends SchemaDefinition<any>, TModelName extends ModelName<TSchema>> = {
192
+ findMany<TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(args?: FindManyArgs<TSchema, TModelName, TSelect>): Promise<Array<SelectedRecord<TSchema, TModelName, TSelect>>>;
193
+ findFirst<TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(args?: FindFirstArgs<TSchema, TModelName, TSelect>): Promise<SelectedRecord<TSchema, TModelName, TSelect> | null>;
194
+ create<TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(args: CreateArgs<TSchema, TModelName, TSelect>): Promise<SelectedRecord<TSchema, TModelName, TSelect>>;
195
+ update<TSelect extends SelectShape<TSchema, TModelName> | undefined = undefined>(args: UpdateArgs<TSchema, TModelName, TSelect>): Promise<SelectedRecord<TSchema, TModelName, TSelect> | null>;
196
+ delete(args: DeleteArgs<TSchema, TModelName>): Promise<number>;
197
+ };
198
+ type OrmClient<TSchema extends SchemaDefinition<any>> = {
199
+ [K in ModelName<TSchema>]: ModelClient<TSchema, K>;
200
+ } & {
201
+ transaction<TResult>(run: (tx: OrmClient<TSchema>) => Promise<TResult>): Promise<TResult>;
202
+ };
203
+ declare function createOrm<TSchema extends SchemaDefinition<any>>(options: {
204
+ schema: TSchema;
205
+ driver: OrmDriver<TSchema>;
206
+ }): OrmClient<TSchema>;
207
+
208
+ type PrismaGenerationOptions = {
209
+ provider?: "postgresql" | "mysql" | "sqlite";
210
+ datasourceName?: string;
211
+ generatorName?: string;
212
+ };
213
+ type DrizzleGenerationOptions = {
214
+ dialect: "pg" | "mysql" | "sqlite";
215
+ };
216
+ type SqlGenerationOptions = {
217
+ dialect: "postgres" | "mysql" | "sqlite";
218
+ };
219
+ declare function renderPrismaSchema(schema: SchemaDefinition<any>, options?: PrismaGenerationOptions): string;
220
+ declare function renderDrizzleSchema(schema: SchemaDefinition<any>, options: DrizzleGenerationOptions): string;
221
+ declare function renderSafeSql(schema: SchemaDefinition<any>, options: SqlGenerationOptions): string;
222
+ declare function replaceGeneratedBlock(input: {
223
+ current: string;
224
+ label: string;
225
+ content: string;
226
+ }): string;
227
+
228
+ type ManifestField = {
229
+ name: string;
230
+ column: string;
231
+ kind: ScalarKind;
232
+ nullable: boolean;
233
+ unique: boolean;
234
+ generated?: "id" | "now";
235
+ defaultValue?: unknown;
236
+ references?: string;
237
+ description?: string;
238
+ };
239
+ type ManifestModel = {
240
+ name: string;
241
+ table: string;
242
+ description?: string;
243
+ fields: Record<string, ManifestField>;
244
+ relations: Record<string, AnyRelation>;
245
+ };
246
+ type SchemaManifest = {
247
+ models: Record<string, ManifestModel>;
248
+ };
249
+ declare function createManifest<TSchema extends SchemaDefinition<Record<string, AnyModelDefinition>>>(schema: TSchema): SchemaManifest;
250
+
251
+ type MemoryStore<TSchema extends SchemaDefinition<any>> = Partial<Record<ModelName<TSchema>, Array<Record<string, unknown>>>>;
252
+ declare function createMemoryDriver<TSchema extends SchemaDefinition<any>>(seed?: MemoryStore<TSchema>): OrmDriver<TSchema>;
253
+
254
+ export { type AnyFieldBuilder, type AnyModelDefinition, type AnyRelation, type CreateArgs, type DeleteArgs, type DrizzleGenerationOptions, FieldBuilder, type FieldConfig, type FieldMap, type FieldOutput, type FieldReference, type FindFirstArgs, type FindManyArgs, type ManifestField, type ManifestModel, type ModelClient, type ModelDefinition, type ModelFields, type ModelForName, type ModelName, type ModelRelations, type OrmClient, type OrmDriver, type PrismaGenerationOptions, type RelationDefinition, type RelationForName, type RelationKind, type RelationMap, type RelationName, type RelationTarget, type ScalarKind, type ScalarRecord, type ScalarValue, type SchemaDefinition, type SchemaManifest, type SchemaModels, type SelectShape, type SelectedRecord, type SqlGenerationOptions, type UpdateArgs, type Where, belongsTo, boolean, createManifest, createMemoryDriver, createOrm, datetime, defineSchema, hasMany, hasOne, id, manyToMany, model, renderDrizzleSchema, renderPrismaSchema, renderSafeSql, replaceGeneratedBlock, string };