Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
refs: Agoric/agoric-sdk#8459 , #1794 , Agoric/agoric-sdk#8051
Description
At the @endo/patterns level of abstraction, the
kindOf
function has the same role thatpassStyleOf
has at the lower @endo/pass-style level of abstraction. However, the @endo/patterns package omittedkindOf
from its exports, preventing some natural uses, such as those found in Agoric/agoric-sdk#8459This PR simply repairs that omission, by exporting
kindOf
so that dependent packages can use it.Security Considerations
Without
kindOf
, client code like Agoric/agoric-sdk#8051 might be tempted to just checkpassStyleOf(x) === 'tagged' && getTag(x) === 'someTagOfInterest'
. But this does not verify thatx
obeys the invariants expected of an object with kind'someTagOfInterest'
.kindOf
bundles in this invariant check, protecting client code from assuming invariants that were actually violated.Scaling Considerations
Like
passStyleOf
, thekindOf
function has an internal memoizing cache, apparently built on a JSWeakMap
. However, liveslots replaces the globalWeakMap
with a virtual one, in order to maintain the virtual object illusion without making gc observable. When used with virtual/durable keys, this replacementWeakMap
leaks heap memory. This necessitates mechanism like #1794 and Agoric/agoric-sdk#8051 , so liveSlots can construct its ownpassStyleOf
using the original JSWeakMap
and then endow it to compartments running under liveSlots.Fortunately, the
kindOf
memo does not have this problem. BecausekindOf(x) !== passStyleOf(x)
only whenpassStyleOf(x) === 'tagged'
, thekindOf
memo delegates all other cases topassStyleOf
and memoizes only its decision for these tagged objects as keys. These tagged objects are pass-by-copy, and therefore are never virtual or durable objects.Documentation Considerations
The taxonomy represented by the
kindOf
function must anyway be documented in any full explanation of the @endo/patterns package. It should be natural to extend such documentation to explainkindOf
as producing that taxonomy, just aspassStyleOf
produces the taxonomy of Passables.The best explanations of these two levels of abstraction, and how they relate to each other, are
none of which are modified by this PR.
Testing Considerations
We typically do not test that something is exported. Rather, the exporting module typically tests things it exports and assumes that it exports what the programmer thinks it exports. We should follow that practice here. So there should not be any test for the substantive change caused by this PR. But
kindOf
itself must be adequately tested to be deserving of export. For purposes of this PR, I propose that test-patterns.js already adequate testskindOf
.Upgrade Considerations
If we change the invariants associated with a tag name, we must ensure that any durably-stored old objects that were already recognized to be of that kind are still recognized to be of that kind. But, for upgrade, it should be harmless for the kind to expand to include objects it previously would have excluded.
However, even this expansion could be problematic for communicating such data, given version skew between vats. If a vat post that does recognize
X
as a valid'foo'
kind passesX
to a vat that does not yet recognize that it is a valid'foo'
kind, they could get confused. But this hazard already exists and is not actually affected by this PR. Further, such recognition mismatches in tagged recognition is already fundamental to the notion of'tagged'
as an extension point in the Passable system.