varchar.ts — drizzle-orm Source File
Architecture documentation for varchar.ts, a typescript file in the drizzle-orm codebase. 7 imports, 1 dependents.
Entity Profile
Dependency Diagram
graph LR 10fa851b_a5c2_87ef_18e8_115bcbf2d9d4["varchar.ts"] f4f42b4c_8610_03dd_fe01_232098668127["common.ts"] 10fa851b_a5c2_87ef_18e8_115bcbf2d9d4 --> f4f42b4c_8610_03dd_fe01_232098668127 099d7c6d_2fc4_7b20_40e3_1b8af4138fe6["PgColumn"] 10fa851b_a5c2_87ef_18e8_115bcbf2d9d4 --> 099d7c6d_2fc4_7b20_40e3_1b8af4138fe6 2dc784c6_95e9_4e28_ec81_7caf4acbd426["column-builder.ts"] 10fa851b_a5c2_87ef_18e8_115bcbf2d9d4 --> 2dc784c6_95e9_4e28_ec81_7caf4acbd426 05f0a280_d0c9_693a_a4bf_83cc671012d2["column.ts"] 10fa851b_a5c2_87ef_18e8_115bcbf2d9d4 --> 05f0a280_d0c9_693a_a4bf_83cc671012d2 27705a9d_afe9_57dd_8c97_e52d8a67d426["entity.ts"] 10fa851b_a5c2_87ef_18e8_115bcbf2d9d4 --> 27705a9d_afe9_57dd_8c97_e52d8a67d426 17418917_ff81_c4e5_90f4_f37d557e5d51["table.ts"] 10fa851b_a5c2_87ef_18e8_115bcbf2d9d4 --> 17418917_ff81_c4e5_90f4_f37d557e5d51 ecce3253_1e75_a87f_27b3_ca87e81a3024["utils.ts"] 10fa851b_a5c2_87ef_18e8_115bcbf2d9d4 --> ecce3253_1e75_a87f_27b3_ca87e81a3024 b38cf654_48d6_41dc_6c0f_203697984d98["all.ts"] b38cf654_48d6_41dc_6c0f_203697984d98 --> 10fa851b_a5c2_87ef_18e8_115bcbf2d9d4 style 10fa851b_a5c2_87ef_18e8_115bcbf2d9d4 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';
import type { ColumnBaseConfig } from '~/column.ts';
import { entityKind } from '~/entity.ts';
import type { AnyPgTable } from '~/pg-core/table.ts';
import { getColumnNameAndConfig, type Writable } from '~/utils.ts';
import { PgColumn, PgColumnBuilder } from './common.ts';
export type PgVarcharBuilderInitial<
TName extends string,
TEnum extends [string, ...string[]],
TLength extends number | undefined,
> = PgVarcharBuilder<{
name: TName;
dataType: 'string';
columnType: 'PgVarchar';
data: TEnum[number];
driverParam: string;
enumValues: TEnum;
length: TLength;
}>;
export class PgVarcharBuilder<
T extends ColumnBuilderBaseConfig<'string', 'PgVarchar'> & { length?: number | undefined },
> extends PgColumnBuilder<
T,
{ length: T['length']; enumValues: T['enumValues'] },
{ length: T['length'] }
> {
static override readonly [entityKind]: string = 'PgVarcharBuilder';
constructor(name: T['name'], config: PgVarcharConfig<T['enumValues'], T['length']>) {
super(name, 'string', 'PgVarchar');
this.config.length = config.length;
this.config.enumValues = config.enum;
}
/** @internal */
override build<TTableName extends string>(
table: AnyPgTable<{ name: TTableName }>,
): PgVarchar<MakeColumnConfig<T, TTableName> & { length: T['length'] }> {
return new PgVarchar<MakeColumnConfig<T, TTableName> & { length: T['length'] }>(
table,
this.config as ColumnBuilderRuntimeConfig<any, any>,
);
}
}
export class PgVarchar<T extends ColumnBaseConfig<'string', 'PgVarchar'> & { length?: number | undefined }>
extends PgColumn<T, { length: T['length']; enumValues: T['enumValues'] }, { length: T['length'] }>
{
static override readonly [entityKind]: string = 'PgVarchar';
readonly length = this.config.length;
override readonly enumValues = this.config.enumValues;
getSQLType(): string {
return this.length === undefined ? `varchar` : `varchar(${this.length})`;
}
}
export interface PgVarcharConfig<
TEnum extends readonly string[] | string[] | undefined = readonly string[] | string[] | undefined,
TLength extends number | undefined = number | undefined,
> {
enum?: TEnum;
length?: TLength;
}
export function varchar(): PgVarcharBuilderInitial<'', [string, ...string[]], undefined>;
export function varchar<
U extends string,
T extends Readonly<[U, ...U[]]>,
L extends number | undefined,
>(
config?: PgVarcharConfig<T | Writable<T>, L>,
): PgVarcharBuilderInitial<'', Writable<T>, L>;
export function varchar<
TName extends string,
U extends string,
T extends Readonly<[U, ...U[]]>,
L extends number | undefined,
>(
name: TName,
config?: PgVarcharConfig<T | Writable<T>, L>,
): PgVarcharBuilderInitial<TName, Writable<T>, L>;
export function varchar(a?: string | PgVarcharConfig, b: PgVarcharConfig = {}): any {
const { name, config } = getColumnNameAndConfig<PgVarcharConfig>(a, b);
return new PgVarcharBuilder(name, config as any);
}
Domain
Subdomains
Functions
Classes
Imported By
Source
Frequently Asked Questions
What does varchar.ts do?
varchar.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the DrizzleORM domain, DatabaseDrivers subdomain.
What functions are defined in varchar.ts?
varchar.ts defines 1 function(s): varchar.
What does varchar.ts depend on?
varchar.ts imports 7 module(s): PgColumn, column-builder.ts, column.ts, common.ts, entity.ts, table.ts, utils.ts.
What files import varchar.ts?
varchar.ts is imported by 1 file(s): all.ts.
Where is varchar.ts in the architecture?
varchar.ts is located at drizzle-orm/src/pg-core/columns/varchar.ts (domain: DrizzleORM, subdomain: DatabaseDrivers, directory: drizzle-orm/src/pg-core/columns).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free