Skip to content

Commit

Permalink
feat(compartment-mapper): Thread native flag to opt-in for native XS …
Browse files Browse the repository at this point in the history
…runtime modules
  • Loading branch information
kriskowal committed Dec 6, 2024
1 parent e4b6d14 commit e99126a
Show file tree
Hide file tree
Showing 7 changed files with 35 additions and 0 deletions.
9 changes: 9 additions & 0 deletions packages/compartment-mapper/NEWS.md
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,15 @@ Experimental:
enabled by default. See the signature of `loadFromMap()` in `import-lite.js`
for details.

Experimental:

- Adds a `__native__: true` option to all paths to import, that indicates that
the application will fall through to the native implementation of
Compartment, currently only available on XS, which lacks support for
precompiled module sources (as exist in many archived applications,
particularly Agoric smart contract bundles) and instead supports loading
modules from original sources (which is not possible at runtime on XS).

# v1.2.0 (2024-07-30)

- Fixes incompatible behavior with Node.js package conditional exports #2276.
Expand Down
14 changes: 14 additions & 0 deletions packages/compartment-mapper/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -328,6 +328,20 @@ These will be appended to each module from the archive, for debugging purposes.
The `@endo/bundle-source` and `@endo/import-bundle` tools integrate source maps
for an end-to-end debugging experience.
# XS (experimental)
The Compartment Mapper can use native XS `Compartment` and `ModuleSource` under
certain conditions:
1. The application must be an XS script that was compiled with the `xs`
package condition.
This causes `ses`, `@endo/module-source`, and `@endo/import-bundle` to
provide slightly different implementations that can fall through to native
behavior.
2. The application must opt-in with the `__native__: true` option on any
of the compartment mapper methods that import modules like `importLocation`
and `importArchive`.
# Design
Each of the workflows the compartment mapper executes a portion of one sequence
Expand Down
4 changes: 4 additions & 0 deletions packages/compartment-mapper/src/import-archive-lite.js
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,7 @@ export const parseArchive = async (
modules = undefined,
importHook: exitModuleImportHook = undefined,
parserForLanguage: parserForLanguageOption = {},
__native__ = false,
} = options;

const parserForLanguage = freeze(
Expand Down Expand Up @@ -343,6 +344,7 @@ export const parseArchive = async (
}),
),
Compartment: CompartmentParseOption,
__native__,
});

await pendingJobsPromise;
Expand All @@ -362,6 +364,7 @@ export const parseArchive = async (
transforms,
__shimTransforms__,
Compartment: CompartmentOption = CompartmentParseOption,
__native__,
importHook: exitModuleImportHook,
} = options || {};

Expand All @@ -388,6 +391,7 @@ export const parseArchive = async (
transforms,
__shimTransforms__,
Compartment: CompartmentOption,
__native__,
});

await pendingJobsPromise;
Expand Down
3 changes: 3 additions & 0 deletions packages/compartment-mapper/src/import-lite.js
Original file line number Diff line number Diff line change
Expand Up @@ -152,6 +152,7 @@ export const loadFromMap = async (readPowers, compartmentMap, options = {}) => {
transforms,
__shimTransforms__,
Compartment: CompartmentOption = LoadCompartmentOption,
__native__,
importHook: exitModuleImportHook,
} = options;
const compartmentExitModuleImportHook = exitModuleImportHookMaker({
Expand Down Expand Up @@ -201,6 +202,7 @@ export const loadFromMap = async (readPowers, compartmentMap, options = {}) => {
syncModuleTransforms,
__shimTransforms__,
Compartment: CompartmentOption,
__native__,
}));
} else {
// sync module transforms are allowed, because they are "compatible"
Expand All @@ -215,6 +217,7 @@ export const loadFromMap = async (readPowers, compartmentMap, options = {}) => {
syncModuleTransforms,
__shimTransforms__,
Compartment: CompartmentOption,
__native__,
}));
}

Expand Down
2 changes: 2 additions & 0 deletions packages/compartment-mapper/src/link.js
Original file line number Diff line number Diff line change
Expand Up @@ -258,6 +258,7 @@ export const link = (
moduleTransforms,
syncModuleTransforms,
__shimTransforms__ = [],
__native__ = false,
archiveOnly = false,
Compartment = defaultCompartment,
} = options;
Expand Down Expand Up @@ -362,6 +363,7 @@ export const link = (
transforms,
__shimTransforms__,
__options__: true,
__native__,
});

if (!archiveOnly) {
Expand Down
2 changes: 2 additions & 0 deletions packages/compartment-mapper/src/types/external.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ export type ExecuteOptions = Partial<{
__shimTransforms__: Array<Transform>;
attenuations: Record<string, object>;
Compartment: typeof Compartment;
__native__: boolean;
}> &
ModulesOption &
ExitModuleImportHookOption;
Expand All @@ -38,6 +39,7 @@ export type ParseArchiveOptions = Partial<{
computeSha512: HashFn;
computeSourceLocation: ComputeSourceLocationHook;
computeSourceMapLocation: ComputeSourceMapLocationHook;
__native__: boolean;
}> &
ModulesOption &
CompartmentOption &
Expand Down
1 change: 1 addition & 0 deletions packages/compartment-mapper/src/types/internal.ts
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ export type LinkOptions = {
moduleTransforms?: ModuleTransforms;
syncModuleTransforms?: SyncModuleTransforms;
archiveOnly?: boolean;
__native__?: boolean;
} & ExecuteOptions;

export type LinkResult = {
Expand Down

0 comments on commit e99126a

Please sign in to comment.