From d89bf0f7bdfd6b3712bbf95a885271f9fe8ae277 Mon Sep 17 00:00:00 2001 From: "Mark S. Miller" Date: Mon, 29 Apr 2024 12:05:22 -0700 Subject: [PATCH 1/3] refactor(patterns): improve pattern types. Flatten @imports --- packages/patterns/src/keys/checkKey.js | 8 +++-- packages/patterns/src/keys/compareKeys.js | 4 +-- packages/patterns/src/keys/copyBag.js | 9 +++--- packages/patterns/src/keys/copySet.js | 4 +-- .../src/keys/keycollection-operators.js | 21 ++++++------ .../patterns/src/keys/merge-bag-operators.js | 7 ++-- .../patterns/src/keys/merge-set-operators.js | 7 ++-- .../patterns/src/patterns/getGuardPayloads.js | 4 ++- .../patterns/src/patterns/patternMatchers.js | 32 +++++++++---------- packages/patterns/src/patterns/types.js | 22 ++----------- packages/patterns/src/types.js | 19 +++++++++-- packages/patterns/test/test-pattern-limits.js | 8 +++-- packages/ses/src/error/assert.js | 9 +----- 13 files changed, 75 insertions(+), 79 deletions(-) diff --git a/packages/patterns/src/keys/checkKey.js b/packages/patterns/src/keys/checkKey.js index 04383756b2..93e49f3b01 100644 --- a/packages/patterns/src/keys/checkKey.js +++ b/packages/patterns/src/keys/checkKey.js @@ -20,9 +20,11 @@ import { checkBagEntries, makeBagOfEntries } from './copyBag.js'; const { ownKeys } = Reflect; -/** @import {Checker} from '@endo/marshal' */ -/** @import {Passable} from '@endo/pass-style' */ -/** @import {CopyBag, CopyMap, CopySet, Key} from '../types' */ +/** + * @import {Passable} from '@endo/pass-style' + * @import {Checker} from '@endo/marshal' + * @import {CopyBag, CopyMap, CopySet, Key} from '../types' + */ // ////////////////// Primitive and Scalar keys //////////////////////////////// diff --git a/packages/patterns/src/keys/compareKeys.js b/packages/patterns/src/keys/compareKeys.js index 9743f6d834..63820aa008 100644 --- a/packages/patterns/src/keys/compareKeys.js +++ b/packages/patterns/src/keys/compareKeys.js @@ -17,7 +17,7 @@ import { } from './checkKey.js'; import { makeCompareCollection } from './keycollection-operators.js'; -/** @import {CopySet} from '../types' */ +/** @import {CopySet, KeyCompare} from '../types.js' */ /** * CopySet X is smaller than CopySet Y iff all of these conditions hold: @@ -86,7 +86,7 @@ const _mapCompare = makeCompareCollection( ); harden(_mapCompare); -/** @type {import('../types').KeyCompare} */ +/** @type {KeyCompare} */ export const compareKeys = (left, right) => { assertKey(left); assertKey(right); diff --git a/packages/patterns/src/keys/copyBag.js b/packages/patterns/src/keys/copyBag.js index 2d0baff4f1..5cfb53ac50 100644 --- a/packages/patterns/src/keys/copyBag.js +++ b/packages/patterns/src/keys/copyBag.js @@ -12,10 +12,11 @@ import { import { X } from '@endo/errors'; -/** @import {CopyBag} from '../types' */ -/** @import {FullCompare} from '../types' */ -/** @import {Checker} from '@endo/marshal' */ -/** @import {Passable} from '@endo/pass-style' */ +/** + * @import {Passable} from '@endo/pass-style' + * @import {Checker} from '@endo/marshal' + * @import {CopyBag, FullCompare} from '../types' + */ /** * @template T diff --git a/packages/patterns/src/keys/copySet.js b/packages/patterns/src/keys/copySet.js index c902efc54c..f6dc4e4855 100644 --- a/packages/patterns/src/keys/copySet.js +++ b/packages/patterns/src/keys/copySet.js @@ -13,9 +13,9 @@ import { import { X } from '@endo/errors'; /** - * @import {CopySet, FullCompare} from '../types' - * @import {Checker} from '@endo/marshal' * @import {Passable} from '@endo/pass-style' + * @import {Checker} from '@endo/marshal' + * @import {CopySet, FullCompare} from '../types' */ /** diff --git a/packages/patterns/src/keys/keycollection-operators.js b/packages/patterns/src/keys/keycollection-operators.js index ca261da50e..2647a63872 100644 --- a/packages/patterns/src/keys/keycollection-operators.js +++ b/packages/patterns/src/keys/keycollection-operators.js @@ -8,11 +8,10 @@ import { import { makeIterator } from '@endo/common/make-iterator.js'; import { makeArrayIterator } from '@endo/common/make-array-iterator.js'; -/** @import {RankCompare} from '@endo/marshal' */ -/** @import {KeyComparison} from '../types' */ -/** @import {KeyCompare} from '../types' */ -/** @import {FullCompare} from '../types' */ -/** @import {KeyCollection} from '../types' */ +/** + * @import {RankCompare} from '@endo/marshal' + * @import {Key, KeyCompare, FullCompare, KeyComparison, KeyCollection} from '../types' + */ import { q, Fail } from '@endo/errors'; @@ -22,10 +21,10 @@ import { q, Fail } from '@endo/errors'; * rank, into an iterable that resolves those ties using `fullCompare`. * * @template [V=unknown] - * @param {Array<[import('../types.js').Key, V]>} entries + * @param {Array<[Key, V]>} entries * @param {RankCompare} rankCompare * @param {FullCompare} fullCompare - * @returns {IterableIterator<[import('../types.js').Key, V]>} + * @returns {IterableIterator<[Key, V]>} */ const generateFullSortedEntries = (entries, rankCompare, fullCompare) => { assertRankSorted(entries, rankCompare); @@ -82,9 +81,9 @@ harden(generateFullSortedEntries); * @template [V=unknown] * @param {C} c1 * @param {C} c2 - * @param {(collection: C) => Array<[import('../types.js').Key, V]>} getEntries + * @param {(collection: C) => Array<[Key, V]>} getEntries * @param {any} absentValue - * @returns {IterableIterator<[import('../types.js').Key, V | absentValue, V | absentValue]>} + * @returns {IterableIterator<[Key, V | absentValue, V | absentValue]>} */ export const generateCollectionPairEntries = ( c1, @@ -127,7 +126,7 @@ export const generateCollectionPairEntries = ( nextY(); return makeIterator(() => { let done = false; - /** @type {[import('../types.js').Key, V | absentValue, V | absentValue]} */ + /** @type {[Key, V | absentValue, V | absentValue]} */ let value; if (xDone && yDone) { done = true; @@ -178,7 +177,7 @@ harden(generateCollectionPairEntries); * * @template [C=KeyCollection] * @template [V=unknown] - * @param {(collection: C) => Array<[import('../types.js').Key, V]>} getEntries + * @param {(collection: C) => Array<[Key, V]>} getEntries * @param {any} absentValue * @param {KeyCompare} compareValues * @returns {(left: C, right: C) => KeyComparison} diff --git a/packages/patterns/src/keys/merge-bag-operators.js b/packages/patterns/src/keys/merge-bag-operators.js index 2e4f122665..262c3a9a73 100644 --- a/packages/patterns/src/keys/merge-bag-operators.js +++ b/packages/patterns/src/keys/merge-bag-operators.js @@ -7,9 +7,10 @@ import { import { q, Fail } from '@endo/errors'; import { assertNoDuplicateKeys, makeBagOfEntries } from './copyBag.js'; -/** @import {KeyComparison} from '../types' */ -/** @import {FullCompare} from '../types' */ -/** @import {RankCompare} from '@endo/marshal' */ +/** + * @import {RankCompare} from '@endo/marshal' + * @import {FullCompare} from '../types' + */ // Based on merge-set-operators.js, but altered for the bag representation. // TODO share more code with that file and keycollection-operators.js. diff --git a/packages/patterns/src/keys/merge-set-operators.js b/packages/patterns/src/keys/merge-set-operators.js index 97d5cb22e9..54468126fa 100644 --- a/packages/patterns/src/keys/merge-set-operators.js +++ b/packages/patterns/src/keys/merge-set-operators.js @@ -7,9 +7,10 @@ import { import { q, Fail } from '@endo/errors'; import { assertNoDuplicates, makeSetOfElements } from './copySet.js'; -/** @import {KeyComparison} from '../types' */ -/** @import {FullCompare} from '../types' */ -/** @import {RankCompare} from '@endo/marshal' */ +/** + * @import {RankCompare} from '@endo/marshal' + * @import {FullCompare, KeyComparison} from '../types' + */ // TODO share more code with keycollection-operators.js. diff --git a/packages/patterns/src/patterns/getGuardPayloads.js b/packages/patterns/src/patterns/getGuardPayloads.js index 02e1842465..3aef72ba79 100644 --- a/packages/patterns/src/patterns/getGuardPayloads.js +++ b/packages/patterns/src/patterns/getGuardPayloads.js @@ -16,7 +16,9 @@ import { } from './patternMatchers.js'; import { getCopyMapKeys, makeCopyMap } from '../keys/checkKey.js'; -/** @import {AwaitArgGuard, AwaitArgGuardPayload, InterfaceGuard, InterfaceGuardPayload, MethodGuard, MethodGuardPayload} from '../types.js' */ +/** + * @import {AwaitArgGuard, AwaitArgGuardPayload, InterfaceGuard, InterfaceGuardPayload, MethodGuard, MethodGuardPayload} from '../types.js' + */ // The get*GuardPayload functions exist to adapt to the worlds both // before and after https://github.com/endojs/endo/pull/1712 . When diff --git a/packages/patterns/src/patterns/patternMatchers.js b/packages/patterns/src/patterns/patternMatchers.js index 6a043fa800..ddbcd05d6b 100644 --- a/packages/patterns/src/patterns/patternMatchers.js +++ b/packages/patterns/src/patterns/patternMatchers.js @@ -34,16 +34,16 @@ import { } from '../keys/checkKey.js'; import { generateCollectionPairEntries } from '../keys/keycollection-operators.js'; -/// - -/** @import {Checker, CopyRecord, CopyTagged, Passable} from '@endo/pass-style' */ -/** @import {ArgGuard, AwaitArgGuard, CheckPattern, GetRankCover, InterfaceGuard, MatcherNamespace, MethodGuard, MethodGuardMaker, Pattern, RawGuard, SyncValueGuard} from '../types.js' */ -/** @import {Kind, MatchHelper} from './types.js' */ +/** + * @import {Checker, CopyRecord, CopyTagged, Passable} from '@endo/pass-style' + * @import {ArgGuard, AwaitArgGuard, CheckPattern, GetRankCover, InterfaceGuard, MatcherNamespace, MethodGuard, MethodGuardMaker, Pattern, RawGuard, SyncValueGuard, Kind, Limits, AllLimits, Key, DefaultGuardType} from '../types.js' + * @import {MatchHelper, PatternKit} from './types.js' + */ const { entries, values } = Object; const { ownKeys } = Reflect; -/** @type {WeakSet} */ +/** @type {WeakSet} */ const patternMemo = new WeakSet(); // /////////////////////// Match Helpers Helpers ///////////////////////////// @@ -78,13 +78,11 @@ export const defaultLimits = harden({ * Thus, the result only needs to support destructuring. The current * implementation uses inheritance as a cheap hack. * - * @param {import('../types.js').Limits} [limits] - * @returns {import('../types.js').AllLimits} + * @param {Limits} [limits] + * @returns {AllLimits} */ const limit = (limits = {}) => - /** @type {import('../types.js').AllLimits} */ ( - harden({ __proto__: defaultLimits, ...limits }) - ); + /** @type {AllLimits} */(harden({ __proto__: defaultLimits, ...limits })); const checkIsWellFormedWithLimit = ( payload, @@ -149,7 +147,7 @@ const checkDecimalDigitsLimit = (specimen, decimalDigitsLimit, check) => { }; /** - * @returns {import('./types.js').PatternKit} + * @returns {PatternKit} */ const makePatternKit = () => { /** @@ -157,7 +155,7 @@ const makePatternKit = () => { * Otherwise result undefined. * * @param {string} tag - * @returns {import('./types.js').MatchHelper | undefined} + * @returns {MatchHelper | undefined} */ const maybeMatchHelper = tag => // eslint-disable-next-line no-use-before-define @@ -301,7 +299,7 @@ const makePatternKit = () => { /** * @param {Passable} specimen - * @param {import('../types.js').Key} keyAsPattern + * @param {Key} keyAsPattern * @param {Checker} check * @returns {boolean} */ @@ -1697,7 +1695,7 @@ const makePatternKit = () => { split: (base, rest = undefined) => { if (passStyleOf(harden(base)) === 'copyArray') { // TODO at-ts-expect-error works locally but not from @endo/exo - // @ts-ignore We know it should be an array + // @ts-expect-error We know it should be an array return M.splitArray(base, rest && [], rest); } else { return M.splitRecord(base, rest && {}, rest); @@ -1706,7 +1704,7 @@ const makePatternKit = () => { partial: (base, rest = undefined) => { if (passStyleOf(harden(base)) === 'copyArray') { // TODO at-ts-expect-error works locally but not from @endo/exo - // @ts-ignore We know it should be an array + // @ts-expect-error We know it should be an array return M.splitArray([], base, rest); } else { return M.splitRecord({}, base, rest); @@ -1933,7 +1931,7 @@ harden(assertInterfaceGuard); * @template {Record} [M = Record] * @param {string} interfaceName * @param {M} methodGuards - * @param {{ sloppy?: boolean, defaultGuards?: import('../types.js').DefaultGuardType }} [options] + * @param {{ sloppy?: boolean, defaultGuards?: DefaultGuardType }} [options] * @returns {InterfaceGuard} */ const makeInterfaceGuard = (interfaceName, methodGuards, options = {}) => { diff --git a/packages/patterns/src/patterns/types.js b/packages/patterns/src/patterns/types.js index bf828a47a6..93239dae9a 100644 --- a/packages/patterns/src/patterns/types.js +++ b/packages/patterns/src/patterns/types.js @@ -2,25 +2,9 @@ export {}; -/** @import {Passable} from '@endo/pass-style' */ -/** @import {PassStyle} from '@endo/pass-style' */ -/** @import {Checker} from '@endo/pass-style' */ -/** @import {MethodGuard} from '../types.js' */ - -/** @import {MatcherNamespace} from '../types' */ -/** @import {Pattern} from '../types' */ -/** @import {GetRankCover} from '../types' */ - /** - * @typedef {Exclude | - * 'copySet' | 'copyBag' | 'copyMap' | - * `match:${any}` | `guard:${any}` - * } Kind - * It is either a PassStyle other than 'tagged', or, if the underlying - * PassStyle is 'tagged', then the `getTag` value for tags that are - * recognized at the @endo/patterns level of abstraction. For each of those - * tags, a tagged record only has that kind if it satisfies the invariants - * that the @endo/patterns level associates with that kind. + * @import {Passable, Checker} from '@endo/pass-style' + * @import {MatcherNamespace, Pattern, GetRankCover, Kind} from '../types' */ /** @@ -42,7 +26,7 @@ export {}; * Assuming validity of `matcherPayload` as the payload of a Matcher corresponding * with this MatchHelper, reports whether `specimen` is matched by that Matcher. * - * @property {import('../types').GetRankCover} getRankCover + * @property {GetRankCover} getRankCover * Assumes this is the payload of a CopyTagged with the corresponding * matchTag. Return a RankCover to bound from below and above, * in rank order, all possible Passables that would match this Matcher. diff --git a/packages/patterns/src/types.js b/packages/patterns/src/types.js index 671a75b286..7b86c88c54 100644 --- a/packages/patterns/src/types.js +++ b/packages/patterns/src/types.js @@ -2,9 +2,10 @@ export {}; -/** @import {Checker, CopyArray, CopyRecord, CopyTagged, Passable} from '@endo/pass-style' */ -/** @import {PassStyle} from '@endo/pass-style' */ -/** @import {RankCompare, RankCover} from '@endo/marshal' */ +/** + * @import {CopyArray, CopyRecord, CopyTagged, Passable, PassStyle, Checker} from '@endo/pass-style' + * @import {RankCompare, RankCover} from '@endo/marshal' + */ /** * @typedef {Passable} Key @@ -218,6 +219,18 @@ export {}; * @typedef {Partial} Limits */ +/** + * @typedef {Exclude | + * 'copySet' | 'copyBag' | 'copyMap' | + * `match:${any}` | `guard:${any}` + * } Kind + * It is either a PassStyle other than 'tagged', or, if the underlying + * PassStyle is 'tagged', then the `getTag` value for tags that are + * recognized at the @endo/patterns level of abstraction. For each of those + * tags, a tagged record only has that kind if it satisfies the invariants + * that the @endo/patterns level associates with that kind. + */ + /** * @typedef {object} PatternMatchers * diff --git a/packages/patterns/test/test-pattern-limits.js b/packages/patterns/test/test-pattern-limits.js index 3deda75991..04c882ac94 100644 --- a/packages/patterns/test/test-pattern-limits.js +++ b/packages/patterns/test/test-pattern-limits.js @@ -8,11 +8,13 @@ import { defaultLimits, } from '../src/patterns/patternMatchers.js'; -/** @import {Passable} from '@endo/marshal' */ -/** @import {Pattern} from '../src/types.js' */ +/** + * @import {Passable} from '@endo/marshal' + * @import {Pattern} from '../src/types.js' + */ /** - * @typedef MatchTest + * @typedef {object} MatchTest * @property {Passable} specimen * @property {Pattern[]} yesPatterns * @property {[Pattern, RegExp|string][]} noPatterns diff --git a/packages/ses/src/error/assert.js b/packages/ses/src/error/assert.js index b3cb5d3735..dc20634e0b 100644 --- a/packages/ses/src/error/assert.js +++ b/packages/ses/src/error/assert.js @@ -47,14 +47,7 @@ import './internal-types.js'; import { makeNoteLogArgsArrayKit } from './note-log-args.js'; /** - * @import {BaseAssert, - * Assert, - * AssertionFunctions, - * AssertionUtilities, - * StringablePayload, - * DetailsToken, - * MakeAssert, - * } from '../../types.js' + * @import {BaseAssert, Assert, AssertionFunctions, AssertionUtilities, StringablePayload, DetailsToken, MakeAssert} from '../../types.js' */ // For our internal debugging purposes, uncomment From f78bf3ffe12e68aab31d69e64a4b286f67e77ccb Mon Sep 17 00:00:00 2001 From: "Mark S. Miller" Date: Mon, 29 Apr 2024 12:07:52 -0700 Subject: [PATCH 2/3] fixup! format --- packages/patterns/src/patterns/patternMatchers.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/patterns/src/patterns/patternMatchers.js b/packages/patterns/src/patterns/patternMatchers.js index ddbcd05d6b..b46c3bffb7 100644 --- a/packages/patterns/src/patterns/patternMatchers.js +++ b/packages/patterns/src/patterns/patternMatchers.js @@ -82,7 +82,7 @@ export const defaultLimits = harden({ * @returns {AllLimits} */ const limit = (limits = {}) => - /** @type {AllLimits} */(harden({ __proto__: defaultLimits, ...limits })); + /** @type {AllLimits} */ (harden({ __proto__: defaultLimits, ...limits })); const checkIsWellFormedWithLimit = ( payload, From 51f2ed37aab36c6229c8829803abc082b4744cb8 Mon Sep 17 00:00:00 2001 From: "Mark S. Miller" Date: Mon, 29 Apr 2024 13:10:43 -0700 Subject: [PATCH 3/3] fixup: review suggestions --- packages/patterns/src/keys/checkKey.js | 2 +- packages/patterns/src/keys/copyBag.js | 2 +- packages/patterns/src/keys/copySet.js | 2 +- packages/patterns/src/keys/keycollection-operators.js | 2 +- packages/patterns/src/keys/merge-bag-operators.js | 2 +- packages/patterns/src/keys/merge-set-operators.js | 2 +- packages/patterns/src/patterns/types.js | 2 +- 7 files changed, 7 insertions(+), 7 deletions(-) diff --git a/packages/patterns/src/keys/checkKey.js b/packages/patterns/src/keys/checkKey.js index 93e49f3b01..54b8e717b1 100644 --- a/packages/patterns/src/keys/checkKey.js +++ b/packages/patterns/src/keys/checkKey.js @@ -23,7 +23,7 @@ const { ownKeys } = Reflect; /** * @import {Passable} from '@endo/pass-style' * @import {Checker} from '@endo/marshal' - * @import {CopyBag, CopyMap, CopySet, Key} from '../types' + * @import {CopyBag, CopyMap, CopySet, Key} from '../types.js' */ // ////////////////// Primitive and Scalar keys //////////////////////////////// diff --git a/packages/patterns/src/keys/copyBag.js b/packages/patterns/src/keys/copyBag.js index 5cfb53ac50..52d6dbcc7e 100644 --- a/packages/patterns/src/keys/copyBag.js +++ b/packages/patterns/src/keys/copyBag.js @@ -15,7 +15,7 @@ import { X } from '@endo/errors'; /** * @import {Passable} from '@endo/pass-style' * @import {Checker} from '@endo/marshal' - * @import {CopyBag, FullCompare} from '../types' + * @import {CopyBag, FullCompare} from '../types.js' */ /** diff --git a/packages/patterns/src/keys/copySet.js b/packages/patterns/src/keys/copySet.js index f6dc4e4855..9741b7b2d3 100644 --- a/packages/patterns/src/keys/copySet.js +++ b/packages/patterns/src/keys/copySet.js @@ -15,7 +15,7 @@ import { X } from '@endo/errors'; /** * @import {Passable} from '@endo/pass-style' * @import {Checker} from '@endo/marshal' - * @import {CopySet, FullCompare} from '../types' + * @import {CopySet, FullCompare} from '../types.js' */ /** diff --git a/packages/patterns/src/keys/keycollection-operators.js b/packages/patterns/src/keys/keycollection-operators.js index 2647a63872..7d51bdb42c 100644 --- a/packages/patterns/src/keys/keycollection-operators.js +++ b/packages/patterns/src/keys/keycollection-operators.js @@ -10,7 +10,7 @@ import { makeArrayIterator } from '@endo/common/make-array-iterator.js'; /** * @import {RankCompare} from '@endo/marshal' - * @import {Key, KeyCompare, FullCompare, KeyComparison, KeyCollection} from '../types' + * @import {Key, KeyCompare, FullCompare, KeyComparison, KeyCollection} from '../types.js' */ import { q, Fail } from '@endo/errors'; diff --git a/packages/patterns/src/keys/merge-bag-operators.js b/packages/patterns/src/keys/merge-bag-operators.js index 262c3a9a73..79a95f2630 100644 --- a/packages/patterns/src/keys/merge-bag-operators.js +++ b/packages/patterns/src/keys/merge-bag-operators.js @@ -9,7 +9,7 @@ import { assertNoDuplicateKeys, makeBagOfEntries } from './copyBag.js'; /** * @import {RankCompare} from '@endo/marshal' - * @import {FullCompare} from '../types' + * @import {FullCompare} from '../types.js' */ // Based on merge-set-operators.js, but altered for the bag representation. diff --git a/packages/patterns/src/keys/merge-set-operators.js b/packages/patterns/src/keys/merge-set-operators.js index 54468126fa..c345b0e646 100644 --- a/packages/patterns/src/keys/merge-set-operators.js +++ b/packages/patterns/src/keys/merge-set-operators.js @@ -9,7 +9,7 @@ import { assertNoDuplicates, makeSetOfElements } from './copySet.js'; /** * @import {RankCompare} from '@endo/marshal' - * @import {FullCompare, KeyComparison} from '../types' + * @import {FullCompare, KeyComparison} from '../types.js' */ // TODO share more code with keycollection-operators.js. diff --git a/packages/patterns/src/patterns/types.js b/packages/patterns/src/patterns/types.js index 93239dae9a..7c15fe3f99 100644 --- a/packages/patterns/src/patterns/types.js +++ b/packages/patterns/src/patterns/types.js @@ -4,7 +4,7 @@ export {}; /** * @import {Passable, Checker} from '@endo/pass-style' - * @import {MatcherNamespace, Pattern, GetRankCover, Kind} from '../types' + * @import {MatcherNamespace, Pattern, GetRankCover, Kind} from '../types.js' */ /**