From 1dc201144daceab0b12193ada0f13dbb25e917f6 Mon Sep 17 00:00:00 2001 From: Nicolas Morel Date: Mon, 29 Jan 2024 11:49:34 +0100 Subject: [PATCH] fix(types): support encoding for string type cast (#2407) --- test/tsc-build/strict-checks/typeCast.ts | 12 ++++++++---- typings/mysql/lib/parsers/typeCast.d.ts | 2 +- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/test/tsc-build/strict-checks/typeCast.ts b/test/tsc-build/strict-checks/typeCast.ts index a4ffee3396..0d04844100 100644 --- a/test/tsc-build/strict-checks/typeCast.ts +++ b/test/tsc-build/strict-checks/typeCast.ts @@ -27,13 +27,14 @@ import { access, sql } from '../promise/baseConnection.js'; const type: string = field.type; const buffer: Buffer | null = field.buffer(); const string: string | null = field.string(); + const stringWithEncoding: string | null = field.string('utf-8'); const geometry: | { x: number; y: number } | { x: number; y: number }[] | null = field.geometry(); console.log(db, length, name, table, type); - console.log(buffer, string, geometry); + console.log(buffer, string, stringWithEncoding, geometry); return next(); }, @@ -64,13 +65,14 @@ import { access, sql } from '../promise/baseConnection.js'; const type: string = field.type; const buffer: Buffer | null = field.buffer(); const string: string | null = field.string(); + const stringWithEncoding: string | null = field.string('utf-8'); const geometry: | { x: number; y: number } | { x: number; y: number }[] | null = field.geometry(); console.log(db, length, name, table, type); - console.log(buffer, string, geometry); + console.log(buffer, string, stringWithEncoding, geometry); return next(); }, @@ -101,13 +103,14 @@ import { access, sql } from '../promise/baseConnection.js'; const type: string = field.type; const buffer: Buffer | null = field.buffer(); const string: string | null = field.string(); + const stringWithEncoding: string | null = field.string('utf-8'); const geometry: | { x: number; y: number } | { x: number; y: number }[] | null = field.geometry(); console.log(db, length, name, table, type); - console.log(buffer, string, geometry); + console.log(buffer, string, stringWithEncoding, geometry); return next(); }, @@ -138,13 +141,14 @@ import { access, sql } from '../promise/baseConnection.js'; const type: string = field.type; const buffer: Buffer | null = field.buffer(); const string: string | null = field.string(); + const stringWithEncoding: string | null = field.string('utf-8'); const geometry: | { x: number; y: number } | { x: number; y: number }[] | null = field.geometry(); console.log(db, length, name, table, type); - console.log(buffer, string, geometry); + console.log(buffer, string, stringWithEncoding, geometry); return next(); }, diff --git a/typings/mysql/lib/parsers/typeCast.d.ts b/typings/mysql/lib/parsers/typeCast.d.ts index 67aad03f2a..0311bdb089 100644 --- a/typings/mysql/lib/parsers/typeCast.d.ts +++ b/typings/mysql/lib/parsers/typeCast.d.ts @@ -43,7 +43,7 @@ type Field = Type & { db: string; table: string; name: string; - string: () => string | null; + string: (encoding?: BufferEncoding | string | undefined) => string | null; buffer: () => Buffer | null; geometry: () => Geometry | Geometry[] | null; };