summaryrefslogtreecommitdiff
path: root/src/lang
diff options
context:
space:
mode:
authorKai Stevenson <kai@kaistevenson.com>2025-11-09 12:34:02 -0800
committerKai Stevenson <kai@kaistevenson.com>2025-11-09 12:34:02 -0800
commit93992029bd349185d15de02e0f633e95c62695a9 (patch)
tree3fef46b489750d622d9e803aad16cc90e8a95210 /src/lang
parent8442ed67628e5d51e02b876d0f27479f9215bf0a (diff)
tostring test, fixes
Diffstat (limited to 'src/lang')
-rw-r--r--src/lang/js-lang/builtin/builtin.ts14
-rw-r--r--src/lang/ts-lang/util/string.ts5
2 files changed, 15 insertions, 4 deletions
diff --git a/src/lang/js-lang/builtin/builtin.ts b/src/lang/js-lang/builtin/builtin.ts
index bc40794..a984ca8 100644
--- a/src/lang/js-lang/builtin/builtin.ts
+++ b/src/lang/js-lang/builtin/builtin.ts
@@ -2,9 +2,17 @@ type BUILTIN = (args: any[]) => any;
export const V_BUILTIN_Arr: BUILTIN = (args) => args;
-// FIXME actually implement this properly
-export const V_BUILTIN_ToString: BUILTIN = (args) =>
- args.length === 1 ? JSON.stringify(args[0]) : JSON.stringify(args);
+const toStringInner = (o: any): string => {
+ if (Array.isArray(o)) {
+ return `[${o.map(toStringInner).join(", ")}]`;
+ }
+
+ return o.toString();
+};
+
+export const V_BUILTIN_ToString: BUILTIN = (args) => {
+ return args.length === 1 ? toStringInner(args[0]) : toStringInner(args);
+};
export const V_BUILTIN_Add: BUILTIN = (args) => {
if (args.every((arg) => ["string", "number"].includes(typeof arg))) {
diff --git a/src/lang/ts-lang/util/string.ts b/src/lang/ts-lang/util/string.ts
index 5772f40..ae17c2c 100644
--- a/src/lang/ts-lang/util/string.ts
+++ b/src/lang/ts-lang/util/string.ts
@@ -5,7 +5,10 @@ export type AddStrings<
? AddStrings<Tail, `${Carry}${Head}`>
: Carry;
-export type ToString<T, Carry extends string = ""> = T extends string | number
+export type ToString<T, Carry extends string = ""> = T extends
+ | string
+ | number
+ | boolean
? `${T}`
: T extends readonly any[]
? T extends readonly [infer Head, ...infer Tail]