From ba2e9d7cd7b7da6c6e832deba1d1ea4bce0c3de9 Mon Sep 17 00:00:00 2001 From: "Mark S. Miller" Date: Thu, 8 Aug 2024 16:11:08 -0700 Subject: [PATCH] feat(exo): defineExoClassKitFromJSClassKit --- packages/exo/test/exo-wobbly-point.test.js | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/packages/exo/test/exo-wobbly-point.test.js b/packages/exo/test/exo-wobbly-point.test.js index 1553ded80a..6a12dda14b 100644 --- a/packages/exo/test/exo-wobbly-point.test.js +++ b/packages/exo/test/exo-wobbly-point.test.js @@ -9,13 +9,14 @@ /* eslint-disable max-classes-per-file */ import test from '@endo/ses-ava/prepare-endo.js'; +import { Fail, q } from '@endo/errors'; +import { objectMap } from '@endo/common/object-map.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 { Fail, q } from '@endo/errors'; import { GET_INTERFACE_GUARD } from '../src/get-interface.js'; -import { defineExoClass } from '../src/exo-makers.js'; +import { defineExoClass, defineExoClassKit } from '../src/exo-makers.js'; const { apply } = Reflect; @@ -40,6 +41,16 @@ const defineExoClassFromJSClass = klass => defineExoClass(klass.name, klass.implements, klass.init, klass.prototype); harden(defineExoClassFromJSClass); +// Need an example use. +// eslint-disable-next-line no-unused-vars +const defineExoClassKitFromJSClassKit = (name, init, klassKit) => + defineExoClassKit( + name, + objectMap(klassKit, klass => klass.implements), + init, + objectMap(klassKit, klass => klass.prototype), + ); + const ExoPointI = M.interface('ExoPoint', { toString: M.call().returns(M.string()), getX: M.call().returns(M.gte(0)),