Skip to content

Commit

Permalink
fix: review comments
Browse files Browse the repository at this point in the history
  • Loading branch information
erights committed Nov 12, 2022
1 parent 451ff5a commit 33b17a4
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 4 deletions.
4 changes: 2 additions & 2 deletions packages/store/src/patterns/encodePassable.js
Original file line number Diff line number Diff line change
Expand Up @@ -313,7 +313,7 @@ export const makeEncodePassable = ({
encodeError = (err, _) => assert.fail(X`error unexpected: ${err}`),
} = {}) => {
const encodePassable = passable => {
if (ErrorHelper.canBeValid(passable, x => x)) {
if (ErrorHelper.canBeValid(passable)) {
return encodeError(passable, encodePassable);
}
const passStyle = passStyleOf(passable);
Expand Down Expand Up @@ -478,7 +478,7 @@ harden(isEncodedRemotable);
* individually is a valid bigint prefix. `n` for "negative" and `p` for
* "positive". The ordering of these prefixes is the same as the
* rankOrdering of their respective PassStyles. This table is imported by
* randOrder.js for this purpose.
* rankOrder.js for this purpose.
*
* In addition, `|` is the remotable->ordinal mapping prefix:
* This is not used in covers but it is
Expand Down
5 changes: 5 additions & 0 deletions packages/store/src/patterns/patternMatchers.js
Original file line number Diff line number Diff line change
Expand Up @@ -509,6 +509,11 @@ const makePatternKit = () => {
X`${specimen} - Must be a copyRecord to match a copyRecord pattern: ${patt}`,
);
}
// TODO Detect and accumulate difference in one pass.
// Rather than using two calls to `listDifference` to detect and
// report if and how these lists differ, since they are already
// in sorted order, we should instead use an algorithm like
// `iterDisjointUnion` from merge-sort-operators.js
const specimenNames = recordNames(specimen);
const pattNames = recordNames(patt);
const missing = listDifference(pattNames, specimenNames);
Expand Down
8 changes: 6 additions & 2 deletions packages/store/src/patterns/rankOrder.js
Original file line number Diff line number Diff line change
Expand Up @@ -43,9 +43,13 @@ const passStyleRanks = /** @type {PassStyleRanksRecord} */ (
return trivialComparator(leftPrefixes, rightPrefixes);
})
.map(([passStyle, prefixes], index) => {
// Cover all strings that start with any character in `prefixes`.
// `prefixes` is already sorted, so that's
// Cover all strings that start with any character in `prefixes`,
// verifying that it is sorted so that is
// all s such that prefixes.at(0) ≤ s < successor(prefixes.at(-1)).
prefixes === [...prefixes].sort().join('') ||
assert.fail(
X`unsorted prefixes for passStyle ${q(passStyle)}: ${q(prefixes)}`,
);
const cover = [
prefixes.charAt(0),
String.fromCharCode(prefixes.charCodeAt(prefixes.length - 1) + 1),
Expand Down

0 comments on commit 33b17a4

Please sign in to comment.