diff options
| author | Kai Stevenson <kai@kaistevenson.com> | 2025-11-03 23:41:31 -0800 |
|---|---|---|
| committer | Kai Stevenson <kai@kaistevenson.com> | 2025-11-03 23:41:31 -0800 |
| commit | 8b610f2bcfc223333254ce9679730c42dce6d26e (patch) | |
| tree | ac1eab726395523f8725bda3d040e22214cba409 /src/lang/ks-lang | |
| parent | 56040f3ff85e77311f0c864a89afd63fcf1bdb50 (diff) | |
add createFn
Diffstat (limited to 'src/lang/ks-lang')
| -rw-r--r-- | src/lang/ks-lang/index.ts | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/src/lang/ks-lang/index.ts b/src/lang/ks-lang/index.ts new file mode 100644 index 0000000..c60203f --- /dev/null +++ b/src/lang/ks-lang/index.ts @@ -0,0 +1,27 @@ +import { callFn, emptyStackFrame, evaluate, lex, parse } from "../js-lang"; +import { + Evaluate, + FnPrim, + Lex, + Parse, + EvalError, + CallFn, + EmptyStackFrame, +} from "../ts-lang"; + +export const createFn = <Program extends string>( + program: Program +): Evaluate<Parse<Lex<Program>>> extends [infer ProgramFn extends FnPrim] + ? <const Args extends any[]>( + ...args: Args + ) => CallFn<ProgramFn, Args, EmptyStackFrame> + : EvalError<"Cannot create a function from a program that does not eval to a function"> => { + const [programFn] = evaluate(parse(lex(program))) as Array<FnPrim>; + if (!programFn.fn) { + throw new Error( + "Cannot create a function from a program that does not eval to a function" + ); + } + + return ((...args: any[]) => callFn(programFn, args, emptyStackFrame)) as any; +}; |
