Skip to content

Commit

Permalink
fix: review suggestions
Browse files Browse the repository at this point in the history
  • Loading branch information
erights committed Jul 15, 2023
1 parent bfb5641 commit 0c9fcef
Showing 1 changed file with 23 additions and 11 deletions.
34 changes: 23 additions & 11 deletions packages/pass-style/src/passStyleOf.js
Original file line number Diff line number Diff line change
Expand Up @@ -67,10 +67,6 @@ const makeHelperTable = passStyleHelpers => {
* @returns {PassStyleOf}
*/
const makePassStyleOf = passStyleHelpers => {
if (typeof globalThis?.VatData?.passStyleOf === 'function') {
return globalThis.VatData.passStyleOf;
}

const HelperTable = makeHelperTable(passStyleHelpers);
const remotableHelper = HelperTable.remotable;

Expand Down Expand Up @@ -194,13 +190,29 @@ const makePassStyleOf = passStyleHelpers => {
return harden(passStyleOf);
};

export const passStyleOf = makePassStyleOf([
CopyArrayHelper,
CopyRecordHelper,
TaggedHelper,
ErrorHelper,
RemotableHelper,
]);
/**
* If there is already a `VataData` global containing a `passStyleOf`,
* then presumably it was endowed for us by liveslots, so we should use
* and export that one instead. Other software may have left it for us here,
* but it would require write access to our global, or the ability to
* provide endowments to our global, both of which seems adequate as a test of
* whether it is authorized to serve the same role as liveslots.
*
* NOTE HAZARD: This use by liveslots does rely on `passStyleOf` being
* deterministic. If it is not, then in a liveslot-like virtualized
* environment, it can be used to detect GC.
*
* @type {PassStyleOf}
*/
export const passStyleOf =
globalThis?.VatData?.passStyleOf ||
makePassStyleOf([
CopyArrayHelper,
CopyRecordHelper,
TaggedHelper,
ErrorHelper,
RemotableHelper,
]);

export const assertPassable = val => {
passStyleOf(val); // throws if val is not a passable
Expand Down

0 comments on commit 0c9fcef

Please sign in to comment.