diff options
| author | Kai Stevenson <kai@kaistevenson.com> | 2025-11-04 20:53:37 -0800 |
|---|---|---|
| committer | Kai Stevenson <kai@kaistevenson.com> | 2025-11-04 21:01:45 -0800 |
| commit | e86c68dffaffee6ba44d98ba06761245f6d5b670 (patch) | |
| tree | 507922cde204c414d3a6072aef704859639aebb8 /src/lang/ts-lang/builtin/builtin.ts | |
| parent | b8fd8f0672c289ff43e501f430b76de1c7b0440a (diff) | |
add branching
Diffstat (limited to 'src/lang/ts-lang/builtin/builtin.ts')
| -rw-r--r-- | src/lang/ts-lang/builtin/builtin.ts | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/src/lang/ts-lang/builtin/builtin.ts b/src/lang/ts-lang/builtin/builtin.ts index a289867..ed6b0a3 100644 --- a/src/lang/ts-lang/builtin/builtin.ts +++ b/src/lang/ts-lang/builtin/builtin.ts @@ -31,3 +31,18 @@ export type BUILTIN_Mul<Args extends readonly any[]> = Args extends [ : Args extends [infer M extends number, infer N extends number] ? Multiply<M, N> : FnError<`Can only multiply [number, number], but got ${ToString<Args>}`>; + +export type BUILTIN_IfElse<Args extends readonly any[]> = Args extends [ + infer A, + infer B, + infer C, + infer D +] + ? FnError<`Invalid args for "if": ${ToString<Args>}`> + : Args extends [infer Cond, infer TrueVal, infer FalseVal] + ? Cond extends true + ? TrueVal + : Cond extends false + ? FalseVal + : FnError<`Condition value ${ToString<Cond>} is not a boolean`> + : FnError<`Invalid args for "if": ${ToString<Args>}`>; |
