interface GuardMakers {
    await: ((argPattern: Pattern) => AwaitArgGuard);
    call: ((...argPatterns: SyncValueGuard[]) => MethodGuardMaker);
    callWhen: ((...argGuards: ArgGuard[]) => MethodGuardMaker);
    interface: MakeInterfaceGuard;
    raw: (() => RawGuard);
}

Properties

await: ((argPattern: Pattern) => AwaitArgGuard)

Guard a positional parameter in M.callWhen, awaiting it and matching its fulfillment against the provided pattern. For example, M.callWhen(M.await(M.nat())).returns() will await the first argument, check that its fulfillment satisfies M.nat(), and only then call the guarded method with that fulfillment. If the argument is a non-promise value that already satisfies M.nat(), then the result of awaiting it will still pass, and M.callWhen will still delay the guarded method call to a future turn. If the argument is a promise that rejects rather than fulfills, or if its fulfillment does not satisfy the nested pattern, then the call is rejected without ever invoking the guarded method.

Any AwaitArgGuard may not appear as a rest pattern or a result pattern, only a top-level single parameter pattern.

call: ((...argPatterns: SyncValueGuard[]) => MethodGuardMaker)

Guard a synchronous call. Arguments not guarded by M.raw() are automatically hardened and must be at least Passable.

callWhen: ((...argGuards: ArgGuard[]) => MethodGuardMaker)

Guard an async call. Arguments not guarded by M.raw() are automatically hardened and must be at least Passable.

Guard the interface of an exo object

raw: (() => RawGuard)

In parameter position, pass this argument through without any hardening or checking. In rest position, pass the rest of the arguments through without any hardening or checking. In return position, return the result without any hardening or checking.