Endo API documentation
    Preparing search index...

    Module @endo/patterns - v1.7.0

    @endo/patterns

    The main export from the package is an M namespace object, for making a variety of Matchers (hence "M"). For example:

    import '@endo/init/debug.js';
    import { M, mustMatch } from '@endo/patterns';

    const specimen = harden({ foo: 3, bar: 4 });

    const pattern = M.splitRecord(
    { foo: M.number() }, // required properties
    { bar: M.string(), baz: M.number() }, // optional
    );

    mustMatch(specimen, pattern); // throws: 'bar?: number 4 - Must be a string'

    See PatternMatchers for more on M.splitRecord(), M.number(), and other methods.

    M also has GuardMakers methods to make InterfaceGuards that use Patterns to characterize dynamic behavior such as method argument/response signatures and promise awaiting. The @endo/exo! package uses InterfaceGuards as the first level of defense for Exo objects against malformed input.

    For best rendering, use the Endo reference docs site.

    Builds on @endo/pass-style! as described in kindOf and passStyleOf levels of abstraction to define higher level data types as individual refinements of Passable CopyTagged records (PassStyle "tagged"):

    • CopySet -- a collection of unique distinguishable Keys
    • CopyBag -- a collection of entries associating a unique distinguishable Key with a positive integer count (see Multiset).
    • CopyMap -- a collection of entries associating a unique distinguishable Key with a Passable
    • Matcher -- a predicate characterizing a subset of Passables, such as "strings" or "8-bit unsigned integer numbers" or "CopyArrays of Remotables"

    In support of the above, there is also compareKeys and keyEQ exposing pass-invariant Key comparison, and two concepts with corresponding TypeScript types:

    • Key -- a Passable arbitrarily deep acyclic data structure in which each non-leaf node is a CopyArray, CopyRecord, CopySet, CopyBag, or CopyMap that is the child of at most one other internal node (forming a possibly-empty tree of containers), and each leaf is either an empty such container or a Passable primitive value or a Remotable (but the same Remotable r may be a child of multiple parents, e.g. { foo: r, bar: [r] }). A Key is stable and stably comparable with other Keys via keyEQ. Key is the most general data type covering valid contents for CopySets and CopyBags and keys for CopyMaps (the last of which explains the "Key" name).
    • Pattern -- a Passable value that can be used to match some subset of Passables. Each Pattern is either a Key that matches itself (and any copy of itself --- keyEQ considers identity only for Remotables, where it is shared across all local Presences of the same Remotable), or a Key-like structure in which one or more leaves is a Matcher rather than a primitive or Remotable.

    Interfaces

    AllLimits
    GuardMakers
    MethodGuardOptional
    MethodGuardRest
    MethodGuardReturns
    PatternMatchers

    Type Aliases

    ArgGuard
    AwaitArgGuard
    AwaitArgGuardPayload
    CheckPattern
    CopyBag
    CopyMap
    CopySet
    DefaultGuardType
    FullCompare
    GetRankCover
    InterfaceGuard
    InterfaceGuardPayload
    Key
    KeyCollection
    KeyCompare
    KeyComparison
    KeyToDBKey
    Kind
    Limits
    MakeInterfaceGuard
    MakeInterfaceGuardGeneral
    MakeInterfaceGuardSloppy
    MakeInterfaceGuardStrict
    Matcher
    MatcherNamespace
    Method
    MethodGuard
    MethodGuardMaker
    MethodGuardPayload
    MethodGuardRestReturns
    Pattern
    RawGuard
    RawGuardPayload
    ScalarKey
    SyncValueGuard

    Variables

    assertPattern
    bagCompare
    bagDisjointSubtract
    bagIntersection
    bagIsSuperbag
    bagUnion
    containerHasSplit
    elementsCompare
    elementsDisjointSubtract
    elementsDisjointUnion
    elementsIntersection
    elementsIsDisjoint
    elementsIsSuperset
    elementsUnion
    getRankCover
    isPattern
    kindOf
    M
    matches
    mustMatch
    setCompare
    setDisjointSubtract
    setDisjointUnion
    setIntersection
    setIsDisjoint
    setIsSuperset
    setUnion

    Functions

    assertAwaitArgGuard
    assertCopyBag
    assertCopyMap
    assertCopySet
    assertInterfaceGuard
    assertKey
    assertMethodGuard
    assertRawGuard
    assertScalarKey
    coerceToBagEntries
    coerceToElements
    compareKeys
    getAwaitArgGuardPayload
    getCopyBagEntries
    getCopyMapEntries
    getCopySetKeys
    getInterfaceGuardPayload
    getInterfaceMethodKeys
    getMethodGuardPayload
    isAwaitArgGuard
    isCopyBag
    isCopyMap
    isCopySet
    isKey
    isRawGuard
    keyEQ
    keyGT
    keyGTE
    keyLT
    keyLTE
    listDifference
    makeCopyBag
    makeCopyBagFromElements
    makeCopyMap
    makeCopySet
    objectMap