diff --git a/packages/captp/package.json b/packages/captp/package.json
index 535b55ac2c..2ca2a07740 100644
--- a/packages/captp/package.json
+++ b/packages/captp/package.json
@@ -52,6 +52,7 @@
"c8": "^7.14.0"
},
"dependencies": {
+ "@endo/errors": "^1.0.2",
"@endo/eventual-send": "^1.1.0",
"@endo/marshal": "^1.1.0",
"@endo/nat": "^5.0.2",
diff --git a/packages/captp/src/atomics.js b/packages/captp/src/atomics.js
index db03de5c88..318862fae6 100644
--- a/packages/captp/src/atomics.js
+++ b/packages/captp/src/atomics.js
@@ -1,6 +1,6 @@
///
-const { details: X, Fail } = assert;
+import { X, Fail } from '@endo/errors';
// This is a pathological minimum, but exercised by the unit test.
export const MIN_DATA_BUFFER_LENGTH = 1;
@@ -154,7 +154,7 @@ export const makeAtomicsTrapGuest = transferBuffer => {
//
// TODO: It would be nice to use an error type, but captp is just too
// noisy with spurious "Temporary logging of sent error" messages.
- // it.throw(assert.error(X`Trap host has not finished`));
+ // it.throw(makeError(X`Trap host has not finished`));
it.throw(null);
// eslint-disable-next-line no-bitwise
diff --git a/packages/captp/src/captp.js b/packages/captp/src/captp.js
index 3171aa72ce..db6033b0f8 100644
--- a/packages/captp/src/captp.js
+++ b/packages/captp/src/captp.js
@@ -12,14 +12,13 @@ import { Remotable, Far, makeMarshal, QCLASS } from '@endo/marshal';
import { E, HandledPromise } from '@endo/eventual-send';
import { isPromise, makePromiseKit } from '@endo/promise-kit';
+import { X, Fail, annotateError } from '@endo/errors';
import { makeTrap } from './trap.js';
import { makeFinalizingMap } from './finalize.js';
export { E };
-const { details: X, Fail } = assert;
-
const WELL_KNOWN_SLOT_PROPERTIES = harden(['answerID', 'questionID', 'target']);
/**
@@ -670,7 +669,7 @@ export const makeCapTP = (
if (!e) {
Fail`trapGuest expected trapHost AsyncIterator(${questionID}) to be done, but it wasn't`;
}
- assert.note(e, X`trapHost AsyncIterator(${questionID}) threw`);
+ annotateError(e, X`trapHost AsyncIterator(${questionID}) threw`);
throw e;
}
};
diff --git a/packages/captp/test/traplib.js b/packages/captp/test/traplib.js
index 0c796531f6..41fdf09029 100644
--- a/packages/captp/test/traplib.js
+++ b/packages/captp/test/traplib.js
@@ -2,12 +2,11 @@
///
import { Far } from '@endo/marshal';
+import { X, Fail } from '@endo/errors';
import { E, makeCapTP } from '../src/captp.js';
import { makeAtomicsTrapGuest, makeAtomicsTrapHost } from '../src/atomics.js';
-const { details: X, Fail } = assert;
-
export const createHostBootstrap = makeTrapHandler => {
// Create a remotable that has a syncable return value.
return Far('test traps', {
diff --git a/packages/captp/test/worker.js b/packages/captp/test/worker.js
index 2dfd477bcc..0def2ef38d 100644
--- a/packages/captp/test/worker.js
+++ b/packages/captp/test/worker.js
@@ -4,10 +4,9 @@ import '@endo/init/pre-remoting.js';
import '@endo/init/debug.js';
import { parentPort } from 'worker_threads';
+import { Fail } from '@endo/errors';
import { makeGuest, makeHost } from './traplib.js';
-const { Fail } = assert;
-
let dispatch;
parentPort.addListener('message', obj => {
switch (obj.type) {
diff --git a/packages/check-bundle/lite.js b/packages/check-bundle/lite.js
index c81f191ba9..b8c54f2e60 100644
--- a/packages/check-bundle/lite.js
+++ b/packages/check-bundle/lite.js
@@ -4,7 +4,7 @@
import { decodeBase64 } from '@endo/base64/decode.js';
import { parseArchive } from '@endo/compartment-mapper/import-archive.js';
-const { Fail, details: d, quote: q } = assert;
+import { Fail, X, q } from '@endo/errors';
/**
* Verifies that a bundle passes its own integrity checks or rejects the
@@ -25,7 +25,7 @@ export const checkBundle = async (
assert.typeof(
bundle,
'object',
- d`checkBundle cannot hash non-bundle, must be of type object, got ${q(
+ X`checkBundle cannot hash non-bundle, must be of type object, got ${q(
bundle,
)}`,
);
@@ -56,7 +56,7 @@ export const checkBundle = async (
assert.typeof(
moduleFormat,
'string',
- d`checkBundle cannot hash non-bundle, moduleFormat must be a string, got ${typeof moduleFormat}`,
+ X`checkBundle cannot hash non-bundle, moduleFormat must be a string, got ${typeof moduleFormat}`,
);
if (moduleFormat === 'endoZipBase64') {
@@ -64,12 +64,12 @@ export const checkBundle = async (
assert.typeof(
endoZipBase64,
'string',
- d`checkBundle cannot hash non-bundle, property 'endoZipBase64' must be a string, got ${typeof endoZipBase64}`,
+ X`checkBundle cannot hash non-bundle, property 'endoZipBase64' must be a string, got ${typeof endoZipBase64}`,
);
assert.typeof(
endoZipBase64Sha512,
'string',
- d`checkBundle cannot bundle without the property 'endoZipBase64Sha512', which must be a string, got ${typeof endoZipBase64Sha512}`,
+ X`checkBundle cannot bundle without the property 'endoZipBase64Sha512', which must be a string, got ${typeof endoZipBase64Sha512}`,
);
const bytes = decodeBase64(endoZipBase64);
const { sha512: parsedSha512 } = await parseArchive(bytes, bundleName, {
diff --git a/packages/check-bundle/package.json b/packages/check-bundle/package.json
index 955b9d6a12..84be999f5c 100644
--- a/packages/check-bundle/package.json
+++ b/packages/check-bundle/package.json
@@ -40,7 +40,8 @@
},
"dependencies": {
"@endo/base64": "^1.0.1",
- "@endo/compartment-mapper": "^1.1.0"
+ "@endo/compartment-mapper": "^1.1.0",
+ "@endo/errors": "^1.0.2"
},
"devDependencies": {
"@endo/bundle-source": "^3.0.2",
diff --git a/packages/common/from-unique-entries.js b/packages/common/from-unique-entries.js
index a2daad065f..252f0bdd1a 100644
--- a/packages/common/from-unique-entries.js
+++ b/packages/common/from-unique-entries.js
@@ -1,8 +1,8 @@
+import { q, Fail } from '@endo/errors';
+
const { fromEntries } = Object;
const { ownKeys } = Reflect;
-const { quote: q, Fail } = assert;
-
/**
* Throws if multiple entries use the same property name. Otherwise acts
* like `Object.fromEntries` but hardens the result.
diff --git a/packages/common/package.json b/packages/common/package.json
index 593327bd65..eb3a13a992 100644
--- a/packages/common/package.json
+++ b/packages/common/package.json
@@ -41,6 +41,7 @@
"test:xs": "exit 0"
},
"dependencies": {
+ "@endo/errors": "^1.0.2",
"@endo/eventual-send": "^1.1.0",
"@endo/promise-kit": "^1.0.2"
},
diff --git a/packages/common/test/test-apply-labeling-error.js b/packages/common/test/test-apply-labeling-error.js
index e042e29831..e43603f17f 100644
--- a/packages/common/test/test-apply-labeling-error.js
+++ b/packages/common/test/test-apply-labeling-error.js
@@ -1,7 +1,8 @@
import { test } from './prepare-test-env-ava.js';
-import { applyLabelingError } from '../apply-labeling-error.js';
-const { Fail } = assert;
+// eslint-disable-next-line import/order
+import { Fail } from '@endo/errors';
+import { applyLabelingError } from '../apply-labeling-error.js';
test('test applyLabelingError', async t => {
t.is(
diff --git a/packages/common/throw-labeled.js b/packages/common/throw-labeled.js
index 38f90de1ab..b7457ecf4f 100644
--- a/packages/common/throw-labeled.js
+++ b/packages/common/throw-labeled.js
@@ -1,4 +1,4 @@
-const { details: X } = assert;
+import { X, makeError, annotateError } from '@endo/errors';
/**
* Given an error `innerErr` and a `label`, throws a similar
@@ -14,11 +14,8 @@ export const throwLabeled = (innerErr, label, ErrorConstructor = undefined) => {
if (typeof label === 'number') {
label = `[${label}]`;
}
- const outerErr = assert.error(
- `${label}: ${innerErr.message}`,
- ErrorConstructor,
- );
- assert.note(outerErr, X`Caused by ${innerErr}`);
+ const outerErr = makeError(`${label}: ${innerErr.message}`, ErrorConstructor);
+ annotateError(outerErr, X`Caused by ${innerErr}`);
throw outerErr;
};
harden(throwLabeled);
diff --git a/packages/daemon/package.json b/packages/daemon/package.json
index e1e7c502a6..a6d3b0d568 100644
--- a/packages/daemon/package.json
+++ b/packages/daemon/package.json
@@ -40,6 +40,7 @@
},
"dependencies": {
"@endo/captp": "^4.0.2",
+ "@endo/errors": "^1.0.2",
"@endo/eventual-send": "^1.1.0",
"@endo/far": "^1.0.2",
"@endo/lockdown": "^1.0.2",
diff --git a/packages/daemon/src/daemon.js b/packages/daemon/src/daemon.js
index 3e1f2fae76..d229a6bd87 100644
--- a/packages/daemon/src/daemon.js
+++ b/packages/daemon/src/daemon.js
@@ -17,10 +17,9 @@ import url from 'url';
import { E, Far } from '@endo/far';
import { makePromiseKit } from '@endo/promise-kit';
+import { q } from '@endo/errors';
import { makeNodeNetstringCapTP } from './connection.js';
-const { quote: q } = assert;
-
const { promise: cancelled, reject: cancel } = makePromiseKit();
// TODO thread through command arguments.
diff --git a/packages/errors/index.js b/packages/errors/index.js
index 9812aec3be..15320cbe1e 100644
--- a/packages/errors/index.js
+++ b/packages/errors/index.js
@@ -71,4 +71,10 @@ export {
quote,
redacted,
throwRedacted,
+ // conventional abbreviations and aliases
+ bare as b,
+ quote as q,
+ redacted as X,
+ throwRedacted as Fail,
+ note as annotateError,
};
diff --git a/packages/eventual-send/src/E.js b/packages/eventual-send/src/E.js
index 29ff9e7ad1..f04c0423f6 100644
--- a/packages/eventual-send/src/E.js
+++ b/packages/eventual-send/src/E.js
@@ -53,7 +53,7 @@ const makeEProxyHandler = (recipient, HandledPromise) =>
// Reject the async function call
return HandledPromise.reject(
assert.error(
- X`Unexpected receiver for "${propertyKey}" method of E(${q(
+ X`Unexpected receiver for "${q(propertyKey)}" method of E(${q(
recipient,
)})`,
),
diff --git a/packages/exo/package.json b/packages/exo/package.json
index e9b673f32b..5f0412b54e 100644
--- a/packages/exo/package.json
+++ b/packages/exo/package.json
@@ -33,6 +33,7 @@
},
"dependencies": {
"@endo/common": "^1.0.2",
+ "@endo/errors": "^1.0.2",
"@endo/env-options": "^1.1.0",
"@endo/eventual-send": "^1.1.0",
"@endo/far": "^1.0.2",
diff --git a/packages/exo/src/exo-makers.js b/packages/exo/src/exo-makers.js
index 54b1904376..82500fcc3a 100644
--- a/packages/exo/src/exo-makers.js
+++ b/packages/exo/src/exo-makers.js
@@ -2,9 +2,9 @@
import { environmentOptionsListHas } from '@endo/env-options';
import { objectMap } from '@endo/common/object-map.js';
+import { Fail, q } from '@endo/errors';
import { defendPrototype, defendPrototypeKit } from './exo-tools.js';
-const { Fail, quote: q } = assert;
const { create, seal, freeze, defineProperty, values } = Object;
// Turn on to give each exo instance its own toStringTag value.
diff --git a/packages/exo/src/exo-tools.js b/packages/exo/src/exo-tools.js
index 99685f1498..478f80a19b 100644
--- a/packages/exo/src/exo-tools.js
+++ b/packages/exo/src/exo-tools.js
@@ -13,6 +13,7 @@ import {
} from '@endo/patterns';
import { listDifference } from '@endo/common/list-difference.js';
import { objectMap } from '@endo/common/object-map.js';
+import { q, Fail } from '@endo/errors';
import { GET_INTERFACE_GUARD } from './get-interface.js';
/** @typedef {import('@endo/patterns').Method} Method */
@@ -23,7 +24,6 @@ import { GET_INTERFACE_GUARD } from './get-interface.js';
* @typedef {import('@endo/patterns').InterfaceGuard} InterfaceGuard
*/
-const { quote: q, Fail } = assert;
const { apply, ownKeys } = Reflect;
const { defineProperties, fromEntries } = Object;
diff --git a/packages/exo/test/test-exo-wobbly-point.js b/packages/exo/test/test-exo-wobbly-point.js
index 1ec065e125..4850ad5b2f 100644
--- a/packages/exo/test/test-exo-wobbly-point.js
+++ b/packages/exo/test/test-exo-wobbly-point.js
@@ -14,10 +14,11 @@ import { test } from './prepare-test-env-ava.js';
import { getMethodNames } from '@endo/eventual-send/utils.js';
import { passStyleOf, Far, GET_METHOD_NAMES } from '@endo/pass-style';
import { M } from '@endo/patterns';
-import { defineExoClass } from '../src/exo-makers.js';
+
+import { Fail, q } from '@endo/errors';
import { GET_INTERFACE_GUARD } from '../src/get-interface.js';
+import { defineExoClass } from '../src/exo-makers.js';
-const { Fail, quote: q } = assert;
const { apply } = Reflect;
const ExoEmptyI = M.interface('ExoEmpty', {});
diff --git a/packages/exo/test/test-label-instances.js b/packages/exo/test/test-label-instances.js
index 6ffafe0723..8fff031504 100644
--- a/packages/exo/test/test-label-instances.js
+++ b/packages/exo/test/test-label-instances.js
@@ -4,14 +4,14 @@ import { test } from './prepare-test-env-ava-label-instances.js';
// eslint-disable-next-line import/order
import { passStyleOf } from '@endo/far';
import { M } from '@endo/patterns';
+
+import { q } from '@endo/errors';
import {
defineExoClass,
defineExoClassKit,
makeExo,
} from '../src/exo-makers.js';
-const { quote: q } = assert;
-
const UpCounterI = M.interface('UpCounter', {
incr: M.call().returns(M.number()),
});
diff --git a/packages/far/package.json b/packages/far/package.json
index 609b471d2e..920ce96711 100644
--- a/packages/far/package.json
+++ b/packages/far/package.json
@@ -32,6 +32,7 @@
},
"homepage": "https://github.com/endojs/endo#readme",
"dependencies": {
+ "@endo/errors": "^1.0.2",
"@endo/eventual-send": "^1.1.0",
"@endo/pass-style": "^1.1.0"
},
diff --git a/packages/far/test/test-marshal-far-obj.js b/packages/far/test/test-marshal-far-obj.js
index f4ecd7091f..404e3d64c4 100644
--- a/packages/far/test/test-marshal-far-obj.js
+++ b/packages/far/test/test-marshal-far-obj.js
@@ -1,10 +1,11 @@
// @ts-check
-
import { test } from './prepare-test-env-ava.js';
+// eslint-disable-next-line import/order
+import { q } from '@endo/errors';
+
import { Far, passStyleOf, getInterfaceOf } from '../src/index.js';
-const { quote: q } = assert;
const { create, getPrototypeOf } = Object;
// this only includes the tests that do not use liveSlots
diff --git a/packages/import-bundle/package.json b/packages/import-bundle/package.json
index cf0469af29..ef94ca706a 100644
--- a/packages/import-bundle/package.json
+++ b/packages/import-bundle/package.json
@@ -29,6 +29,7 @@
"dependencies": {
"@endo/base64": "^1.0.1",
"@endo/compartment-mapper": "^1.1.0",
+ "@endo/errors": "^1.0.2",
"@endo/where": "^1.0.1",
"ses": "^1.1.0"
},
diff --git a/packages/import-bundle/src/index.js b/packages/import-bundle/src/index.js
index 739e70989d..487f18a8af 100644
--- a/packages/import-bundle/src/index.js
+++ b/packages/import-bundle/src/index.js
@@ -7,10 +7,9 @@
import { parseArchive } from '@endo/compartment-mapper/import-archive.js';
import { decodeBase64 } from '@endo/base64';
+import { Fail } from '@endo/errors';
import { wrapInescapableCompartment } from './compartment-wrapper.js';
-const { Fail } = assert;
-
// importBundle takes the output of bundle-source, and returns a namespace
// object (with .default, and maybe other properties for named exports)
diff --git a/packages/lp32/package.json b/packages/lp32/package.json
index 184152cc94..d6720b9249 100644
--- a/packages/lp32/package.json
+++ b/packages/lp32/package.json
@@ -49,6 +49,7 @@
"test": "ava"
},
"dependencies": {
+ "@endo/errors": "^1.0.2",
"@endo/init": "^1.0.2",
"@endo/stream": "^1.0.2",
"ses": "^1.1.0"
diff --git a/packages/lp32/reader.js b/packages/lp32/reader.js
index 13d441e760..9b0fd462ae 100644
--- a/packages/lp32/reader.js
+++ b/packages/lp32/reader.js
@@ -4,10 +4,9 @@
// We use a DataView to give users choice over endianness.
// But DataView does not default to host-byte-order like other typed arrays.
+import { Fail, q } from '@endo/errors';
import { hostIsLittleEndian } from './src/host-endian.js';
-const { Fail, quote: q } = assert;
-
/**
* @param {Iterable | AsyncIterable} reader
* @param {object} opts
diff --git a/packages/lp32/writer.js b/packages/lp32/writer.js
index c186c0e097..e8416cba56 100644
--- a/packages/lp32/writer.js
+++ b/packages/lp32/writer.js
@@ -1,10 +1,9 @@
// @ts-check
///
+import { Fail, q } from '@endo/errors';
import { hostIsLittleEndian } from './src/host-endian.js';
-const { Fail, quote: q } = assert;
-
/**
* @param {import('@endo/stream').Writer} output
* @param {object} opts
diff --git a/packages/marshal/package.json b/packages/marshal/package.json
index d003e16105..41c1da8461 100644
--- a/packages/marshal/package.json
+++ b/packages/marshal/package.json
@@ -40,6 +40,7 @@
},
"homepage": "https://github.com/endojs/endo#readme",
"dependencies": {
+ "@endo/errors": "^1.0.2",
"@endo/eventual-send": "^1.1.0",
"@endo/nat": "^5.0.2",
"@endo/pass-style": "^1.1.0",
diff --git a/packages/marshal/src/deeplyFulfilled.js b/packages/marshal/src/deeplyFulfilled.js
index ebedc93a6d..e7ec72ec68 100644
--- a/packages/marshal/src/deeplyFulfilled.js
+++ b/packages/marshal/src/deeplyFulfilled.js
@@ -7,7 +7,8 @@ import { getTag, isObject, makeTagged, passStyleOf } from '@endo/pass-style';
/** @typedef {import('@endo/pass-style').Passable} Passable */
/** @template T @typedef {import('@endo/eventual-send').ERef} ERef */
-const { details: X, quote: q } = assert;
+import { X, q } from '@endo/errors';
+
const { ownKeys } = Reflect;
const { fromEntries } = Object;
diff --git a/packages/marshal/src/dot-membrane.js b/packages/marshal/src/dot-membrane.js
index d1ad11831b..b8144d0a9f 100644
--- a/packages/marshal/src/dot-membrane.js
+++ b/packages/marshal/src/dot-membrane.js
@@ -3,11 +3,11 @@
import { E } from '@endo/eventual-send';
import { isObject, getInterfaceOf, Far, passStyleOf } from '@endo/pass-style';
+import { Fail } from '@endo/errors';
import { makeMarshal } from './marshal.js';
const { fromEntries } = Object;
const { ownKeys } = Reflect;
-const { Fail } = assert;
// TODO(erights): Add Converter type
/** @param {any} [mirrorConverter] */
diff --git a/packages/marshal/src/encodePassable.js b/packages/marshal/src/encodePassable.js
index 877c20d297..fe24a2b0c2 100644
--- a/packages/marshal/src/encodePassable.js
+++ b/packages/marshal/src/encodePassable.js
@@ -18,7 +18,8 @@ import {
*/
/** @typedef {import('./types.js').RankCover} RankCover */
-const { quote: q, Fail } = assert;
+import { q, Fail } from '@endo/errors';
+
const { fromEntries, is } = Object;
const { ownKeys } = Reflect;
diff --git a/packages/marshal/src/encodeToCapData.js b/packages/marshal/src/encodeToCapData.js
index 5546072a71..c4655d58f7 100644
--- a/packages/marshal/src/encodeToCapData.js
+++ b/packages/marshal/src/encodeToCapData.js
@@ -17,6 +17,7 @@ import {
nameForPassableSymbol,
passableSymbolForName,
} from '@endo/pass-style';
+import { X, Fail, q } from '@endo/errors';
/** @typedef {import('@endo/pass-style').Passable} Passable */
/** @typedef {import('./types.js').Encoding} Encoding */
@@ -33,7 +34,6 @@ const {
fromEntries,
freeze,
} = Object;
-const { details: X, Fail, quote: q } = assert;
/**
* Special property name that indicates an encoding that needs special
diff --git a/packages/marshal/src/encodeToSmallcaps.js b/packages/marshal/src/encodeToSmallcaps.js
index 0313f6c942..ccf6f3088e 100644
--- a/packages/marshal/src/encodeToSmallcaps.js
+++ b/packages/marshal/src/encodeToSmallcaps.js
@@ -16,6 +16,7 @@ import {
nameForPassableSymbol,
passableSymbolForName,
} from '@endo/pass-style';
+import { X, Fail, q } from '@endo/errors';
/** @typedef {import('@endo/pass-style').Passable} Passable */
/** @typedef {import('@endo/pass-style').Remotable} Remotable */
@@ -27,7 +28,6 @@ import {
const { ownKeys } = Reflect;
const { isArray } = Array;
const { is, entries, fromEntries } = Object;
-const { details: X, Fail, quote: q } = assert;
const BANG = '!'.charCodeAt(0);
const DASH = '-'.charCodeAt(0);
diff --git a/packages/marshal/src/marshal-justin.js b/packages/marshal/src/marshal-justin.js
index 054e689d90..240328774f 100644
--- a/packages/marshal/src/marshal-justin.js
+++ b/packages/marshal/src/marshal-justin.js
@@ -6,6 +6,7 @@ import {
isObject,
passableSymbolForName,
} from '@endo/pass-style';
+import { q, X, Fail } from '@endo/errors';
import { QCLASS } from './encodeToCapData.js';
/** @typedef {import('./types.js').Encoding} Encoding */
@@ -14,7 +15,6 @@ import { QCLASS } from './encodeToCapData.js';
const { ownKeys } = Reflect;
const { isArray } = Array;
const { stringify: quote } = JSON;
-const { quote: q, details: X, Fail } = assert;
/**
* @typedef {object} Indenter
diff --git a/packages/marshal/src/marshal-stringify.js b/packages/marshal/src/marshal-stringify.js
index 1052c90bfc..989100cda8 100644
--- a/packages/marshal/src/marshal-stringify.js
+++ b/packages/marshal/src/marshal-stringify.js
@@ -1,11 +1,10 @@
///
+import { Fail } from '@endo/errors';
import { makeMarshal } from './marshal.js';
/** @typedef {import('@endo/pass-style').Passable} Passable */
-const { Fail } = assert;
-
/** @type {import('./types.js').ConvertValToSlot} */
const doNotConvertValToSlot = val =>
Fail`Marshal's stringify rejects presences and promises ${val}`;
diff --git a/packages/marshal/src/marshal.js b/packages/marshal/src/marshal.js
index f317325ea5..fe2b419e3b 100644
--- a/packages/marshal/src/marshal.js
+++ b/packages/marshal/src/marshal.js
@@ -8,6 +8,7 @@ import {
hasOwnPropertyOf,
} from '@endo/pass-style';
+import { X, Fail, q, makeError, annotateError } from '@endo/errors';
import {
QCLASS,
makeEncodeToCapData,
@@ -29,7 +30,6 @@ import {
/** @typedef {import('@endo/pass-style').RemotableObject} Remotable */
const { isArray } = Array;
-const { details: X, Fail, quote: q } = assert;
const { ownKeys } = Reflect;
/** @type {ConvertValToSlot} */
@@ -124,7 +124,7 @@ export const makeMarshal = (
// with the correlation.
const errorId = encodeRecur(nextErrorId());
assert.typeof(errorId, 'string');
- assert.note(err, X`Sent as ${errorId}`);
+ annotateError(err, X`Sent as ${errorId}`);
marshalSaveError(err);
return harden({ errorId, message, name });
} else {
@@ -278,7 +278,7 @@ export const makeMarshal = (
dErrorId === undefined
? `Remote${EC.name}`
: `Remote${EC.name}(${dErrorId})`;
- const error = assert.error(dMessage, EC, { errorName });
+ const error = makeError(dMessage, EC, { errorName });
return harden(error);
};
diff --git a/packages/marshal/src/rankOrder.js b/packages/marshal/src/rankOrder.js
index f8d8d9d95c..e11c9200f4 100644
--- a/packages/marshal/src/rankOrder.js
+++ b/packages/marshal/src/rankOrder.js
@@ -1,4 +1,5 @@
import { getTag, passStyleOf, nameForPassableSymbol } from '@endo/pass-style';
+import { Fail, q } from '@endo/errors';
import {
passStylePrefixes,
recordNames,
@@ -12,7 +13,6 @@ import {
/** @typedef {import('./types.js').RankCompare} RankCompare */
/** @typedef {import('./types.js').FullCompare} FullCompare */
-const { Fail, quote: q } = assert;
const { entries, fromEntries, setPrototypeOf, is } = Object;
/**
diff --git a/packages/marshal/src/types.js b/packages/marshal/src/types.js
index 47ea1fc8be..bc4899e1f5 100644
--- a/packages/marshal/src/types.js
+++ b/packages/marshal/src/types.js
@@ -116,7 +116,7 @@ export {};
* identify the sending of errors relative to this marshal instance.
* @property {(err: Error) => void=} marshalSaveError If `errorTagging` is
* `'on'`, then errors serialized by this marshal instance are also
- * logged by calling `marshalSaveError` *after* `assert.note` associated
+ * logged by calling `marshalSaveError` *after* `annotateError` associated
* that error with its errorId. Thus, if `marshalSaveError` in turn logs
* to the normal console, which is the default, then the console will
* show that note showing the associated errorId.
diff --git a/packages/marshal/test/test-encodePassable.js b/packages/marshal/test/test-encodePassable.js
index 29133cc973..72495b701f 100644
--- a/packages/marshal/test/test-encodePassable.js
+++ b/packages/marshal/test/test-encodePassable.js
@@ -1,13 +1,15 @@
// @ts-nocheck
/* eslint-disable no-bitwise, @endo/restrict-comparison-operands */
-
// eslint-disable-next-line import/order
import { test } from './prepare-test-env-ava.js';
-// eslint-disable-next-line import/no-extraneous-dependencies
+// eslint-disable-next-line import/order
import { fc } from '@fast-check/ava';
-
import { arbPassable } from '@endo/pass-style/tools.js';
+import { Fail, q } from '@endo/errors';
+
+// eslint-disable-next-line import/no-extraneous-dependencies
+
import {
makeEncodePassable,
makeDecodePassable,
@@ -15,8 +17,6 @@ import {
import { compareRank, makeComparatorKit } from '../src/rankOrder.js';
import { sample } from './test-rankOrder.js';
-const { Fail, quote: q } = assert;
-
const buffers = {
__proto__: null,
r: [],
diff --git a/packages/marshal/test/test-marshal-far-obj.js b/packages/marshal/test/test-marshal-far-obj.js
index a194160730..9ff4e053f1 100644
--- a/packages/marshal/test/test-marshal-far-obj.js
+++ b/packages/marshal/test/test-marshal-far-obj.js
@@ -1,11 +1,11 @@
+// eslint-disable-next-line import/order
import { test } from './prepare-test-env-ava.js';
-// eslint-disable-next-line import/order
+import { q } from '@endo/errors';
import { passStyleOf, Remotable, Far, getInterfaceOf } from '@endo/pass-style';
import { makeMarshal } from '../src/marshal.js';
-const { quote: q } = assert;
const { create, getPrototypeOf, prototype: objectPrototype } = Object;
// this only includes the tests that do not use liveSlots
diff --git a/packages/marshal/test/test-rankOrder.js b/packages/marshal/test/test-rankOrder.js
index 07392d6a16..048734b2c5 100644
--- a/packages/marshal/test/test-rankOrder.js
+++ b/packages/marshal/test/test-rankOrder.js
@@ -12,6 +12,7 @@ import {
arbPassable,
} from '@endo/pass-style/tools.js';
+import { q } from '@endo/errors';
import {
FullRankCover,
compareRank,
@@ -22,8 +23,6 @@ import {
assertRankSorted,
} from '../src/rankOrder.js';
-const { quote: q } = assert;
-
test('compareRank is reflexive', async t => {
await fc.assert(
fc.property(arbPassable, x => {
diff --git a/packages/pass-style/package.json b/packages/pass-style/package.json
index 3c45bb38e1..88fa405c7f 100644
--- a/packages/pass-style/package.json
+++ b/packages/pass-style/package.json
@@ -33,6 +33,7 @@
"test": "ava"
},
"dependencies": {
+ "@endo/errors": "^1.0.2",
"@endo/eventual-send": "^1.1.0",
"@endo/promise-kit": "^1.0.2",
"@fast-check/ava": "^1.1.5"
diff --git a/packages/pass-style/src/copyArray.js b/packages/pass-style/src/copyArray.js
index 28568f8815..1a7c6d236f 100644
--- a/packages/pass-style/src/copyArray.js
+++ b/packages/pass-style/src/copyArray.js
@@ -1,8 +1,8 @@
///
+import { X } from '@endo/errors';
import { assertChecker, checkNormalProperty } from './passStyle-helpers.js';
-const { details: X } = assert;
const { getPrototypeOf } = Object;
const { ownKeys } = Reflect;
const { isArray, prototype: arrayPrototype } = Array;
diff --git a/packages/pass-style/src/copyRecord.js b/packages/pass-style/src/copyRecord.js
index 67adc38fcf..38ee0d4ff9 100644
--- a/packages/pass-style/src/copyRecord.js
+++ b/packages/pass-style/src/copyRecord.js
@@ -1,12 +1,12 @@
///
+import { X } from '@endo/errors';
import {
assertChecker,
canBeMethod,
checkNormalProperty,
} from './passStyle-helpers.js';
-const { details: X } = assert;
const { ownKeys } = Reflect;
const { getPrototypeOf, values, prototype: objectPrototype } = Object;
diff --git a/packages/pass-style/src/error.js b/packages/pass-style/src/error.js
index c41e1871e6..d015aaac9b 100644
--- a/packages/pass-style/src/error.js
+++ b/packages/pass-style/src/error.js
@@ -1,11 +1,11 @@
///
+import { X, Fail, annotateError } from '@endo/errors';
import { assertChecker } from './passStyle-helpers.js';
/** @typedef {import('./internal-types.js').PassStyleHelper} PassStyleHelper */
/** @typedef {import('./types.js').Checker} Checker */
-const { details: X, Fail } = assert;
const { getPrototypeOf, getOwnPropertyDescriptors } = Object;
const { ownKeys } = Reflect;
@@ -116,7 +116,7 @@ export const toPassableError = err => {
// Even the cleaned up error copy, if sent to the console, should
// cause hidden diagnostic information of the original error
// to be logged.
- assert.note(newError, X`copied from error ${err}`);
+ annotateError(newError, X`copied from error ${err}`);
return newError;
};
harden(toPassableError);
diff --git a/packages/pass-style/src/make-far.js b/packages/pass-style/src/make-far.js
index 1e92acbbc3..2937ceba56 100644
--- a/packages/pass-style/src/make-far.js
+++ b/packages/pass-style/src/make-far.js
@@ -1,14 +1,13 @@
///
import { getMethodNames } from '@endo/eventual-send/utils.js';
+import { q, Fail } from '@endo/errors';
import { assertChecker, PASS_STYLE } from './passStyle-helpers.js';
import { assertIface, getInterfaceOf, RemotableHelper } from './remotable.js';
/** @typedef {import('./types.js').InterfaceSpec} InterfaceSpec */
/** @template L,R @typedef {import('@endo/eventual-send').RemotableBrand} RemotableBrand */
-const { quote: q, Fail } = assert;
-
const { prototype: functionPrototype } = Function;
const {
getPrototypeOf,
diff --git a/packages/pass-style/src/makeTagged.js b/packages/pass-style/src/makeTagged.js
index b20ee544b8..0a80c69106 100644
--- a/packages/pass-style/src/makeTagged.js
+++ b/packages/pass-style/src/makeTagged.js
@@ -1,10 +1,10 @@
///
+import { Fail } from '@endo/errors';
import { PASS_STYLE } from './passStyle-helpers.js';
import { assertPassable } from './passStyleOf.js';
const { create, prototype: objectPrototype } = Object;
-const { Fail } = assert;
export const makeTagged = (tag, payload) => {
typeof tag === 'string' ||
diff --git a/packages/pass-style/src/passStyle-helpers.js b/packages/pass-style/src/passStyle-helpers.js
index 840156641c..65823d35cc 100644
--- a/packages/pass-style/src/passStyle-helpers.js
+++ b/packages/pass-style/src/passStyle-helpers.js
@@ -3,7 +3,8 @@
/** @typedef {import('./types.js').Checker} Checker */
/** @typedef {import('./types.js').PassStyle} PassStyle */
-const { details: X, quote: q } = assert;
+import { X, q } from '@endo/errors';
+
const { isArray } = Array;
const { prototype: functionPrototype } = Function;
const {
diff --git a/packages/pass-style/src/passStyleOf.js b/packages/pass-style/src/passStyleOf.js
index 0a49fe71a1..a335b2bca2 100644
--- a/packages/pass-style/src/passStyleOf.js
+++ b/packages/pass-style/src/passStyleOf.js
@@ -3,6 +3,7 @@
///
import { isPromise } from '@endo/promise-kit';
+import { X, Fail, q } from '@endo/errors';
import { isObject, isTypedArray, PASS_STYLE } from './passStyle-helpers.js';
import { CopyArrayHelper } from './copyArray.js';
@@ -22,7 +23,6 @@ import { assertSafePromise } from './safe-promise.js';
/** @typedef {Exclude} HelperPassStyle */
-const { details: X, Fail, quote: q } = assert;
const { ownKeys } = Reflect;
const { isFrozen } = Object;
diff --git a/packages/pass-style/src/remotable.js b/packages/pass-style/src/remotable.js
index 476dff5387..0a2b32dd18 100644
--- a/packages/pass-style/src/remotable.js
+++ b/packages/pass-style/src/remotable.js
@@ -1,5 +1,6 @@
///
+import { X, Fail, q } from '@endo/errors';
import {
assertChecker,
canBeMethod,
@@ -17,7 +18,6 @@ import {
/** @typedef {import('./internal-types.js').PassStyleHelper} PassStyleHelper */
/** @typedef {import('./types.js').RemotableObject} Remotable */
-const { details: X, Fail, quote: q } = assert;
const { ownKeys } = Reflect;
const { isArray } = Array;
const {
diff --git a/packages/pass-style/src/safe-promise.js b/packages/pass-style/src/safe-promise.js
index 30de135151..80c425d843 100644
--- a/packages/pass-style/src/safe-promise.js
+++ b/packages/pass-style/src/safe-promise.js
@@ -1,11 +1,11 @@
///
import { isPromise } from '@endo/promise-kit';
+import { X, q } from '@endo/errors';
import { assertChecker, hasOwnPropertyOf } from './passStyle-helpers.js';
/** @typedef {import('./types.js').Checker} Checker */
-const { details: X, quote: q } = assert;
const { isFrozen, getPrototypeOf, getOwnPropertyDescriptor } = Object;
const { ownKeys } = Reflect;
const { toStringTag } = Symbol;
diff --git a/packages/pass-style/src/symbol.js b/packages/pass-style/src/symbol.js
index f67853a3bb..ca01808206 100644
--- a/packages/pass-style/src/symbol.js
+++ b/packages/pass-style/src/symbol.js
@@ -1,4 +1,5 @@
-const { Fail, quote: q } = assert;
+import { Fail, q } from '@endo/errors';
+
const { ownKeys } = Reflect;
/**
diff --git a/packages/pass-style/src/tagged.js b/packages/pass-style/src/tagged.js
index 86cf17857b..e7d4f5bce1 100644
--- a/packages/pass-style/src/tagged.js
+++ b/packages/pass-style/src/tagged.js
@@ -1,5 +1,6 @@
///
+import { Fail } from '@endo/errors';
import {
assertChecker,
checkTagRecord,
@@ -8,7 +9,6 @@ import {
checkPassStyle,
} from './passStyle-helpers.js';
-const { Fail } = assert;
const { ownKeys } = Reflect;
const { getOwnPropertyDescriptors } = Object;
diff --git a/packages/pass-style/src/typeGuards.js b/packages/pass-style/src/typeGuards.js
index 2d2f13e267..300c6c9486 100644
--- a/packages/pass-style/src/typeGuards.js
+++ b/packages/pass-style/src/typeGuards.js
@@ -1,3 +1,4 @@
+import { Fail, q } from '@endo/errors';
import { passStyleOf } from './passStyleOf.js';
/** @typedef {import('./types.js').Passable} Passable */
@@ -11,8 +12,6 @@ import { passStyleOf } from './passStyleOf.js';
*/
/** @typedef {import('./types.js').RemotableObject} Remotable */
-const { Fail, quote: q } = assert;
-
/**
* Check whether the argument is a pass-by-copy array, AKA a "copyArray"
* in @endo/marshal terms
diff --git a/packages/pass-style/test/test-passStyleOf.js b/packages/pass-style/test/test-passStyleOf.js
index 77dd715be1..33c71a1bd9 100644
--- a/packages/pass-style/test/test-passStyleOf.js
+++ b/packages/pass-style/test/test-passStyleOf.js
@@ -1,12 +1,14 @@
/* eslint-disable max-classes-per-file */
import { test } from './prepare-test-env-ava.js';
+// eslint-disable-next-line import/order
+import { q } from '@endo/errors';
+
import { passStyleOf } from '../src/passStyleOf.js';
import { Far } from '../src/make-far.js';
import { makeTagged } from '../src/makeTagged.js';
import { PASS_STYLE } from '../src/passStyle-helpers.js';
-const { quote: q } = assert;
const { getPrototypeOf, defineProperty } = Object;
const { ownKeys } = Reflect;
diff --git a/packages/patterns/package.json b/packages/patterns/package.json
index a2bc01a610..5324eb2577 100644
--- a/packages/patterns/package.json
+++ b/packages/patterns/package.json
@@ -32,6 +32,7 @@
},
"dependencies": {
"@endo/common": "^1.0.2",
+ "@endo/errors": "^1.0.2",
"@endo/eventual-send": "^1.1.0",
"@endo/marshal": "^1.1.0",
"@endo/promise-kit": "^1.0.2"
diff --git a/packages/patterns/src/keys/checkKey.js b/packages/patterns/src/keys/checkKey.js
index 3fddf7022a..dc0d3f95e3 100644
--- a/packages/patterns/src/keys/checkKey.js
+++ b/packages/patterns/src/keys/checkKey.js
@@ -14,10 +14,10 @@ import {
} from '@endo/marshal';
import { identChecker } from '@endo/common/ident-checker.js';
+import { X, q, Fail } from '@endo/errors';
import { checkElements, makeSetOfElements } from './copySet.js';
import { checkBagEntries, makeBagOfEntries } from './copyBag.js';
-const { details: X, quote: q, Fail } = assert;
const { ownKeys } = Reflect;
/** @typedef {import('@endo/marshal').Checker} Checker */
diff --git a/packages/patterns/src/keys/compareKeys.js b/packages/patterns/src/keys/compareKeys.js
index 7beee3a65a..19a679c3cb 100644
--- a/packages/patterns/src/keys/compareKeys.js
+++ b/packages/patterns/src/keys/compareKeys.js
@@ -8,6 +8,7 @@ import {
recordValues,
trivialComparator,
} from '@endo/marshal';
+import { q, Fail } from '@endo/errors';
import {
assertKey,
getCopyBagEntries,
@@ -18,8 +19,6 @@ import { makeCompareCollection } from './keycollection-operators.js';
/** @template {import('../types.js').Key} [K=import('../types.js').Key] @typedef {import('../types').CopySet} CopySet */
-const { quote: q, Fail } = assert;
-
/**
* CopySet X is smaller than CopySet Y iff all of these conditions hold:
* 1. For every x in X, x is also in Y.
diff --git a/packages/patterns/src/keys/copyBag.js b/packages/patterns/src/keys/copyBag.js
index 71c897ac21..d93af49260 100644
--- a/packages/patterns/src/keys/copyBag.js
+++ b/packages/patterns/src/keys/copyBag.js
@@ -10,7 +10,7 @@ import {
///
-const { details: X } = assert;
+import { X } from '@endo/errors';
/** @template {Key} [K=Key] @typedef {import('../types').CopyBag} CopyBag */
/** @typedef {import('../types').Key} Key */
diff --git a/packages/patterns/src/keys/copySet.js b/packages/patterns/src/keys/copySet.js
index e72dd65516..01137c2710 100644
--- a/packages/patterns/src/keys/copySet.js
+++ b/packages/patterns/src/keys/copySet.js
@@ -10,7 +10,7 @@ import {
///
-const { details: X } = assert;
+import { X } from '@endo/errors';
/** @template {Key} [K=Key] @typedef {import('../types').CopySet} CopySet */
/** @typedef {import('../types').Key} Key */
diff --git a/packages/patterns/src/keys/keycollection-operators.js b/packages/patterns/src/keys/keycollection-operators.js
index e738188986..e55b3a31a9 100644
--- a/packages/patterns/src/keys/keycollection-operators.js
+++ b/packages/patterns/src/keys/keycollection-operators.js
@@ -14,7 +14,7 @@ import { makeArrayIterator } from '@endo/common/make-array-iterator.js';
/** @typedef {import('../types').FullCompare} FullCompare */
/** @typedef {import('../types').KeyCollection} KeyCollection */
-const { quote: q, Fail } = assert;
+import { q, Fail } from '@endo/errors';
/**
* Refines a sequence of entries that is already sorted over its keys by the
diff --git a/packages/patterns/src/keys/merge-bag-operators.js b/packages/patterns/src/keys/merge-bag-operators.js
index 88a1ce1e50..04dcfa2039 100644
--- a/packages/patterns/src/keys/merge-bag-operators.js
+++ b/packages/patterns/src/keys/merge-bag-operators.js
@@ -4,10 +4,9 @@ import {
makeFullOrderComparatorKit,
sortByRank,
} from '@endo/marshal';
+import { q, Fail } from '@endo/errors';
import { assertNoDuplicateKeys, makeBagOfEntries } from './copyBag.js';
-const { quote: q, Fail } = assert;
-
/** @typedef {import('../types').KeyComparison} KeyComparison */
/** @typedef {import('../types').FullCompare} FullCompare */
/** @typedef {import('@endo/marshal').RankCompare} RankCompare */
diff --git a/packages/patterns/src/keys/merge-set-operators.js b/packages/patterns/src/keys/merge-set-operators.js
index c18e18d070..42351b180d 100644
--- a/packages/patterns/src/keys/merge-set-operators.js
+++ b/packages/patterns/src/keys/merge-set-operators.js
@@ -4,10 +4,9 @@ import {
makeFullOrderComparatorKit,
sortByRank,
} from '@endo/marshal';
+import { q, Fail } from '@endo/errors';
import { assertNoDuplicates, makeSetOfElements } from './copySet.js';
-const { quote: q, Fail } = assert;
-
/** @typedef {import('../types').KeyComparison} KeyComparison */
/** @typedef {import('../types').FullCompare} FullCompare */
/** @typedef {import('@endo/marshal').RankCompare} RankCompare */
diff --git a/packages/patterns/src/patterns/patternMatchers.js b/packages/patterns/src/patterns/patternMatchers.js
index 55bb8de11b..aafeb33413 100644
--- a/packages/patterns/src/patterns/patternMatchers.js
+++ b/packages/patterns/src/patterns/patternMatchers.js
@@ -18,6 +18,7 @@ import { applyLabelingError } from '@endo/common/apply-labeling-error.js';
import { fromUniqueEntries } from '@endo/common/from-unique-entries.js';
import { listDifference } from '@endo/common/list-difference.js';
+import { q, b, X, Fail, makeError, annotateError } from '@endo/errors';
import { keyEQ, keyGT, keyGTE, keyLT, keyLTE } from '../keys/compareKeys.js';
import {
assertKey,
@@ -36,7 +37,6 @@ import { generateCollectionPairEntries } from '../keys/keycollection-operators.j
///
-const { quote: q, bare: b, details: X, Fail } = assert;
const { entries, values } = Object;
const { ownKeys } = Reflect;
@@ -586,11 +586,11 @@ const makePatternKit = () => {
}
// should only throw
checkMatches(specimen, patt, assertChecker, label);
- const outerError = assert.error(
+ const outerError = makeError(
X`internal: ${label}: inconsistent pattern match: ${q(patt)}`,
);
if (innerError !== undefined) {
- assert.note(outerError, X`caused by ${innerError}`);
+ annotateError(outerError, X`caused by ${innerError}`);
}
throw outerError;
};
diff --git a/packages/patterns/test/test-copyMap.js b/packages/patterns/test/test-copyMap.js
index 151ed195b1..feb27aa540 100644
--- a/packages/patterns/test/test-copyMap.js
+++ b/packages/patterns/test/test-copyMap.js
@@ -1,5 +1,7 @@
-import { test } from './prepare-test-env-ava.js';
// eslint-disable-next-line import/order
+import { test } from './prepare-test-env-ava.js';
+
+import { Fail } from '@endo/errors';
import { makeTagged, getTag, passStyleOf } from '@endo/marshal';
import {
isCopyMap,
@@ -12,8 +14,6 @@ import { matches } from '../src/patterns/patternMatchers.js';
import '../src/types.js';
-const { Fail } = assert;
-
const assertIsCopyMap = (t, m) => {
t.is(passStyleOf(m), 'tagged');
t.is(getTag(m), 'copyMap');
diff --git a/packages/patterns/test/test-patterns.js b/packages/patterns/test/test-patterns.js
index 60a9891da1..65f21dd7d7 100644
--- a/packages/patterns/test/test-patterns.js
+++ b/packages/patterns/test/test-patterns.js
@@ -1,6 +1,8 @@
/* eslint-disable no-continue */
-import { test } from './prepare-test-env-ava.js';
// eslint-disable-next-line import/order
+import { test } from './prepare-test-env-ava.js';
+
+import { Fail } from '@endo/errors';
import { makeTagged, Far } from '@endo/marshal';
import {
makeCopyBag,
@@ -13,8 +15,6 @@ import '../src/types.js';
/** @typedef {import('ava').ExecutionContext} TestContext */
-const { Fail } = assert;
-
// TODO The desired semantics for CopyMap comparison have not yet been decided.
// See https://github.com/endojs/endo/pull/1737#pullrequestreview-1596595411
const copyMapComparison = (() => {
diff --git a/packages/stream-node/package.json b/packages/stream-node/package.json
index b0483271cc..b14de7695c 100644
--- a/packages/stream-node/package.json
+++ b/packages/stream-node/package.json
@@ -40,6 +40,7 @@
"test": "ava"
},
"dependencies": {
+ "@endo/errors": "^1.0.2",
"@endo/init": "^1.0.2",
"@endo/stream": "^1.0.2",
"ses": "^1.1.0"
diff --git a/packages/stream-node/reader.js b/packages/stream-node/reader.js
index c4c2947fec..0b232ef1e5 100644
--- a/packages/stream-node/reader.js
+++ b/packages/stream-node/reader.js
@@ -8,7 +8,7 @@
import { mapReader } from '@endo/stream';
-const { Fail, quote: q } = assert;
+import { Fail, q } from '@endo/errors';
/**
* @param {import('stream').Readable} input the source Node.js reader
diff --git a/packages/stream-node/writer.js b/packages/stream-node/writer.js
index 2c9d27d069..59f8038e45 100644
--- a/packages/stream-node/writer.js
+++ b/packages/stream-node/writer.js
@@ -5,7 +5,7 @@
// @ts-check
///
-const { Fail } = assert;
+import { Fail } from '@endo/errors';
const sink = harden(() => {});