summaryrefslogtreecommitdiff
path: root/src/lang/ts-lang/builtin
diff options
context:
space:
mode:
authorKai Stevenson <kai@kaistevenson.com>2025-11-03 23:41:31 -0800
committerKai Stevenson <kai@kaistevenson.com>2025-11-03 23:41:31 -0800
commit8b610f2bcfc223333254ce9679730c42dce6d26e (patch)
treeac1eab726395523f8725bda3d040e22214cba409 /src/lang/ts-lang/builtin
parent56040f3ff85e77311f0c864a89afd63fcf1bdb50 (diff)
add createFn
Diffstat (limited to 'src/lang/ts-lang/builtin')
-rw-r--r--src/lang/ts-lang/builtin/builtin.ts33
-rw-r--r--src/lang/ts-lang/builtin/index.ts3
-rw-r--r--src/lang/ts-lang/builtin/sbuiltin.ts27
3 files changed, 63 insertions, 0 deletions
diff --git a/src/lang/ts-lang/builtin/builtin.ts b/src/lang/ts-lang/builtin/builtin.ts
new file mode 100644
index 0000000..a289867
--- /dev/null
+++ b/src/lang/ts-lang/builtin/builtin.ts
@@ -0,0 +1,33 @@
+import { FnError } from ".";
+import {
+ AddNumbers,
+ AddStrings,
+ Multiply,
+ ToString,
+ UnarrayIfOnlyHead,
+} from "../util";
+
+export type BUILTIN_Arr<Args extends readonly any[]> = Args;
+
+export type BUILTIN_ToString<Args extends readonly any[]> = ToString<
+ UnarrayIfOnlyHead<{
+ [Idx in keyof Args]: ToString<Args[Idx]>;
+ }>
+>;
+
+export type BUILTIN_Add<Args extends readonly any[]> =
+ Args extends readonly string[]
+ ? AddStrings<Args>
+ : Args extends readonly number[]
+ ? AddNumbers<Args>
+ : FnError<`Cannot add operands ${ToString<Args>}`>;
+
+export type BUILTIN_Mul<Args extends readonly any[]> = Args extends [
+ infer A,
+ infer B,
+ infer C
+]
+ ? FnError<`Can only multiply [number, number], but got ${ToString<Args>}`>
+ : Args extends [infer M extends number, infer N extends number]
+ ? Multiply<M, N>
+ : FnError<`Can only multiply [number, number], but got ${ToString<Args>}`>;
diff --git a/src/lang/ts-lang/builtin/index.ts b/src/lang/ts-lang/builtin/index.ts
new file mode 100644
index 0000000..de2bee3
--- /dev/null
+++ b/src/lang/ts-lang/builtin/index.ts
@@ -0,0 +1,3 @@
+export type FnError<T extends string> = `Function execution error: ${T}`;
+export * from "./builtin";
+export * from "./sbuiltin";
diff --git a/src/lang/ts-lang/builtin/sbuiltin.ts b/src/lang/ts-lang/builtin/sbuiltin.ts
new file mode 100644
index 0000000..01f197e
--- /dev/null
+++ b/src/lang/ts-lang/builtin/sbuiltin.ts
@@ -0,0 +1,27 @@
+import { ASTNode, StackFrame } from "../core/common";
+import { CallFn, FnPrim, GetEvaluatedChildren, EvalError } from "../core/eval";
+import { ExtractNumber, ToString } from "../util";
+
+export type SBUILTIN_Call<
+ Node extends ASTNode,
+ Frame extends StackFrame
+> = GetEvaluatedChildren<Node, Frame> extends [
+ infer Fn extends FnPrim,
+ ...infer Values extends readonly any[]
+]
+ ? CallFn<Fn, Values, Frame>
+ : EvalError<`Invalid params for function call: ${ToString<
+ GetEvaluatedChildren<Node, Frame>
+ >}`>;
+
+export type SBUILTIN_Map<
+ Node extends ASTNode,
+ Frame extends StackFrame
+> = GetEvaluatedChildren<Node, Frame> extends [
+ infer Arr extends readonly any[],
+ infer Fn extends FnPrim
+]
+ ? { [Idx in keyof Arr]: CallFn<Fn, [Arr[Idx], ExtractNumber<Idx>], Frame> }
+ : EvalError<`Invalid params for map: ${ToString<
+ GetEvaluatedChildren<Node, Frame>
+ >}`>;