Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@agoric/store

Package Overview
Dependencies
Maintainers
5
Versions
2637
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@agoric/store - npm Package Compare versions

Comparing version 0.6.8-dev-e0f7ee8.0 to 0.6.8-dev-ecb8097.0

src/keys/checkKey.js

14

exported.js
import './src/types.js';
// TODO The following line should be deleted. It exports the type
// `MatchHelper` which is not used outside this store package. Without this
// line, this store package lints fine. But linting the governance
// package complains that it cannot find the type `MatchHelper`.
// I don't know why. I even tried adding
// import '@agoric/store/exported.js';
// to the modules in governance that import from '@agoric/store',
// but it did not help.
//
// Even with this line, the solo package still has the same complaint.
// So instead I moved the MatchHelper type, which should be internal,
// to types.js. See the comment there.
import './src/patterns/internal-types.js';

12

package.json
{
"name": "@agoric/store",
"version": "0.6.8-dev-e0f7ee8.0+e0f7ee8",
"version": "0.6.8-dev-ecb8097.0+ecb8097",
"description": "Wrapper for JavaScript map",

@@ -34,7 +34,9 @@ "type": "module",

"dependencies": {
"@agoric/assert": "0.3.16-dev-e0f7ee8.0+e0f7ee8",
"@agoric/marshal": "0.5.1-dev-e0f7ee8.0+e0f7ee8"
"@agoric/assert": "0.3.16-dev-ecb8097.0+ecb8097",
"@agoric/eventual-send": "0.14.1-dev-ecb8097.0+ecb8097",
"@agoric/marshal": "0.5.1-dev-ecb8097.0+ecb8097",
"@agoric/promise-kit": "0.2.30-dev-ecb8097.0+ecb8097"
},
"devDependencies": {
"@agoric/swingset-vat": "0.24.1-dev-e0f7ee8.0+e0f7ee8",
"@agoric/swingset-vat": "0.24.1-dev-ecb8097.0+ecb8097",
"ava": "^3.12.1"

@@ -68,3 +70,3 @@ },

},
"gitHead": "e0f7ee8884648973c63bbcae587ea36e51f58a64"
"gitHead": "ecb80976a8fbc2e6fee4210be5d0347740e705e3"
}

@@ -1,9 +0,27 @@

export { makeScalarMap, makeScalarMap as makeStore } from './scalarMap.js';
// @ts-check
export { isKey, assertKey } from './keys/checkKey.js';
export { keyLT, keyLTE, keyEQ, keyGTE, keyGT } from './keys/compareKeys.js';
export { makePatternKit } from './patterns/patternMatchers.js';
export { compareRank } from './patterns/rankOrder.js';
export { makeScalarWeakSetStore } from './stores/scalarWeakSetStore.js';
export { makeScalarSetStore } from './stores/scalarSetStore.js';
export {
makeScalarWeakMap,
makeScalarWeakMap as makeWeakStore,
} from './scalarWeakMap.js';
makeScalarWeakMapStore,
makeScalarWeakMapStore as makeScalarWeakMap, // Deprecated legacy
makeScalarWeakMapStore as makeWeakStore, // Deprecated legacy
} from './stores/scalarWeakMapStore.js';
export {
makeScalarMapStore,
makeScalarMapStore as makeScalarMap, // Deprecated legacy
makeScalarMapStore as makeStore, // Deprecated legacy
} from './stores/scalarMapStore.js';
// /////////////////////// Deprecated Legacy ///////////////////////////////////
// export default as well as makeLegacy* only for compatibility
// during the transition.
export { makeLegacyMap, makeLegacyMap as default } from './legacyMap.js';
export { makeLegacyWeakMap } from './legacyWeakMap.js';
export { makeLegacyMap, makeLegacyMap as default } from './legacy/legacyMap.js';
export { makeLegacyWeakMap } from './legacy/legacyWeakMap.js';

@@ -7,25 +7,91 @@ // @ts-check

/**
* @typedef {Passable} Key
*/
/**
* @typedef {Passable} Pattern
* Patterns can be either Keys or Matchers
*/
/**
* @typedef {CopyTagged} CopySet
*/
/**
* @typedef {CopyTagged} CopyMap
*/
/**
* @typedef {CopyTagged} Matcher
*/
/**
* @typedef {Object} StoreOptions
*
* @property {boolean=} longLived Which way to optimize. True means that we
* expect this store to outlive most of its keys, in which
* case we internally may use a `WeakMap`. Otherwise we internally may
* use a `Map`.
* Defaults to true, so please mark short lived stores explicitly
* Of the dimensions on which KeyedStores can differ, we only represent a few
* of them as standard options. A given store maker should document which
* options it supports, as well as its positions on dimensions for which it
* does not support options.
* @property {boolean=} longLived Which way to optimize a weak store. True means
* that we expect this weak store to outlive most of its keys, in which
* case we internally may use a JavaScript `WeakMap`. Otherwise we internally
* may use a JavaScript `Map`.
* Defaults to true, so please mark short lived stores explicitly.
* @property {Pattern=} schema The store will reject
* the insertion of any content that does not match the schema pattern.
* For a SetStore, this is a key pattern.
* For a MapStore, this is an entry pattern,
* i.e., a pattern over `[key,value]` pairs.
* Defaults to `M.any()`.
*/
/** @typedef {"forward" | "reverse"} Direction */
/**
* @template {Structure} K
* @template {Passable} V
* @typedef {Object} Store
*
* @property {(key: any) => boolean} has
* @template K
* @typedef {Object} WeakSetStore
* @property {(key: K) => boolean} has
* Check if a key exists. The key can be any JavaScript value, though the
* answer will always be false for keys that cannot be found in this map
* @property {(key: K, value: V) => void} init
* Initialize the key only if it doesn't already exist. The key must
* be one allowed by this map. For example a scalarMap only allows
* primitives and remotables.
* answer will always be false for keys that cannot be found in this store.
* @property {(key: K) => void} add
* Add the key to the set if it is not already there. Do nothing silently if
* already there.
* The key must be one allowed by this store. For example a scalar store only
* allows primitives and remotables.
* @property {(key: K) => void} delete
* Remove the key. Throws if not found.
*/
/**
* @template K
* @typedef {Object} SetStore
* @property {(key: K) => boolean} has
* Check if a key exists. The key can be any JavaScript value, though the
* answer will always be false for keys that cannot be found in this store.
* @property {(key: K) => void} add
* Add the key to the set if it is not already there. Do nothing silently if
* already there.
* The key must be one allowed by this store. For example a scalar store only
* allows primitives and remotables.
* @property {(key: K) => void} delete
* Remove the key. Throws if not found.
* @property {(keyPattern?: Pattern) => K[]} keys
* @property {(keyPattern?: Pattern) => CopySet} snapshot
* @property {(copySet: CopySet) => void} addAll
* @property {(keyPattern?: Pattern,
* direction?: Direction
* ) => Iterable<K>} cursor
*/
/**
* @template K,V
* @typedef {Object} WeakMapStore
* @property {(key: K) => boolean} has
* Check if a key exists. The key can be any JavaScript value, though the
* answer will always be false for keys that cannot be found in this store.
* @property {(key: K) => V} get
* Return a value for the key. Throws if not found.
* @property {(key: K, value: V) => void} init
* Initialize the key only if it doesn't already exist.
* The key must be one allowed by this store. For example a scalar store only
* allows primitives and remotables.
* @property {(key: K, value: V) => void} set

@@ -35,21 +101,16 @@ * Set the key. Throws if not found.

* Remove the key. Throws if not found.
* @property {() => K[]} keys - Return an array of keys
* @property {() => V[]} values - Return an array of values
* @property {() => [K, V][]} entries - Return an array of entries
*/
/**
* @template {Structure} K
* @template {Passable} V
* @typedef {Object} WeakStore
*
* @template K,V
* @typedef {Object} MapStore
* @property {(key: K) => boolean} has
* Check if a key exists. The key can be any JavaScript value, though the
* answer will always be false for keys that cannot be found in this map
* @property {(key: K, value: V) => void} init
* Initialize the key only if it doesn't already exist. The key must
* be one allowed by this map. For example a scalarMap only allows
* primitives and remotables. For now, a scalarWeakMap allows remotables.
* @property {(key: K) => V} get
* Return a value for the key. Throws if not found.
* @property {(key: K, value: V) => void} init
* Initialize the key only if it doesn't already exist.
* The key must be one allowed by this store. For example a scalar store only
* allows primitives and remotables.
* @property {(key: K, value: V) => void} set

@@ -59,17 +120,53 @@ * Set the key. Throws if not found.

* Remove the key. Throws if not found.
* @property {(keyPattern?: Pattern) => K[]} keys
* @property {(valuePattern?: Pattern) => V[]} values
* @property {(entryPattern?: Pattern) => [K,V][]} entries
* @property {(entryPattern?: Pattern) => CopyMap} snapshot
* @property {(copyMap: CopyMap) => void} addAll
* @property {(entryPattern?: Pattern,
* direction?: Direction
* ) => Iterable<[K,V]>} cursor
*/
// ////////////////////////////////////////////////////////////////////
// ///////////////////////// Deprecated Legacy /////////////////////////////////
/**
* @template K,V
* @typedef {WeakMapStore<K,V>} WeakStore
* Deprecated type name `WeakStore`. Use `WeakMapStore` instead.
*/
/**
* @template K,V
* @typedef {Object} Store
* Deprecated type name `Store`. Use `MapStore` instead.
* @property {(key: K) => boolean} has
* Check if a key exists. The key can be any JavaScript value, though the
* answer will always be false for keys that cannot be found in this map
* @property {(key: K) => V} get
* Return a value for the key. Throws if not found.
* @property {(key: K, value: V) => void} init
* Initialize the key only if it doesn't already exist.
* The key must be one allowed by this store. For example a scalar store only
* allows primitives and remotables.
* @property {(key: K, value: V) => void} set
* Set the key. Throws if not found.
* @property {(key: K) => void} delete
* Remove the key. Throws if not found.
* @property {(keyPattern?: Pattern) => K[]} keys
* @property {(valuePattern?: Pattern) => V[]} values
* @property {(entryPattern?: Pattern) => [K,V][]} entries
*/
/**
* @template K,V
* @typedef {Object} LegacyWeakMap
*
* LegacyWeakMap is deprecated. Use WeakMapStore instead.
* @property {(key: K) => boolean} has
* Check if a key exists
* @property {(key: K) => V} get
* Return a value for the key. Throws if not found.
* @property {(key: K, value: V) => void} init
* Initialize the key only if it
* doesn't already exist
* @property {(key: K) => V} get
* Return a value for the key. Throws if not found.
* @property {(key: K, value: V) => void} set

@@ -84,5 +181,160 @@ * Set the key. Throws if not found.

* @callback MakeLegacyWeakMap
*
* @param {string} [keyName='key'] - the column name for the key
* @returns {LegacyWeakMap}
*/
// /////////////////////////////////////////////////////////////////////////////
/**
* @callback CompareRank
* Returns `-1`, `0`, or `1` depending on whether the rank of `left`
* is before, tied-with, or after the rank of `right`.
*
* This comparison function is valid as argument to
* `Array.prototype.sort`. This is often described as a "total order"
* but, depending on your definitions, this is technically incorrect
* because it may return `0` to indicate that two distinguishable elements,
* like `-0` and `0`, are tied, i.e., are in the same equivalence class
* as far as this ordering is concerned. If each such equivalence class is
* a *rank* and ranks are disjoint, then this "rank order" is a
* total order among these ranks. In mathematics this goes by several
* other names such as "total preorder".
*
* This function establishes a total rank order over all passables.
* To do so it makes arbitrary choices, such as that all strings
* are after all numbers. Thus, this order is not intended to be
* used directly as a comparison with useful semantics. However, it must be
* closely enough related to such comparisons to aid in implementing
* lookups based on those comparisons. For example, in order to get a total
* order among ranks, we put `NaN` after all other JavaScript "number" values.
* But otherwise, we order JavaScript numbers by magnitude,
* with `-0` tied with `0`. A semantically useful ordering of JavaScript number
* values, i.e., IEEE floating point values, would compare magnitudes, and
* so agree with the rank ordering everywhere except `NaN`. An array sorted by
* rank would enable range queries by magnitude.
* @param {Passable} left
* @param {Passable} right
* @returns {-1 | 0 | 1}
*/
// ///////////////////// Should be internal only types /////////////////////////
/**
* @typedef {[string, string]} RankCover
*/
/**
* @typedef {[number, number]} IndexCover
*/
/**
* @callback GetPassStyleCover
* Associate with each passStyle a RankCover that may be an overestimate,
* and whose results therefore need to be filtered down. For example, because
* there is not a smallest or biggest bigint, bound it by `NaN` (the last place
* number) and `''` (the empty string, which is the first place string). Thus,
* a range query using this range may include these values, which would then
* need to be filtered out.
* @param {PassStyle} passStyle
* @returns {RankCover}
*/
/**
* @callback GetIndexCover
* @param {Passable[]} sorted
* @param {CompareRank} compare
* @param {RankCover} rankCover
* @returns {IndexCover}
*/
/**
* @callback CoveredEntries
* @param {Passable[]} sorted
* @param {IndexCover} indexCover
* @returns {Iterable<[number, Passable]>}
*/
/**
* @callback CheckMatches
* @param {Passable} specimen
* @param {Pattern} pattern
* @param {Checker=} check
*/
/**
* @callback CheckPattern
* @param {Passable} allegedPattern
* @param {Checker=} check
* @returns {boolean}
*/
/**
* @callback CheckKeyPattern
* @param {Passable} allegedPattern
* @param {Checker=} check
* @returns {boolean}
*/
/**
* @callback KeyToDBKey
* @param {Passable} key
* @returns {string}
*/
/**
* @callback GetRankCover
* @param {Pattern} pattern
* @param {KeyToDBKey} encodeKey
* @returns {RankCover}
*/
/**
* @typedef {Object} PatternMatcher
* @property {GetRankCover} getRankCover
*/
// /////////////////////////////////////////////////////////////////////////////
// TODO
// The following commented out type should be in internal-types.js, since the
// `MatchHelper` type is purely internal to this package. However,
// in order to get the governance and solo packages both to pass lint,
// I moved the type declaration itself to types.js. See the comments in
// in internal-types.js and exports.js
/**
* @typedef {Object} MatchHelper
* This factors out only the parts specific to each kind of Matcher. It is
* encapsulated, and its methods can make the stated unchecker assumptions
* enforced by the common calling logic.
*
* @property {(allegedPayload: Passable,
* check?: Checker
* ) => boolean} checkIsMatcherPayload
* Assumes this is the payload of a CopyTagged with the corresponding
* matchTag. Is this a valid payload for a Matcher with that tag?
*
* @property {(specimen: Passable,
* matcherPayload: Passable,
* check?: Checker
* ) => boolean} checkMatches
* Assuming a valid Matcher of this type with `matcherPayload` as its
* payload, does this specimen match that Matcher?
*
* @property {(
* payload: Passable,
* encodeKey: KeyToDBKey
* ) => RankCover} getRankCover
* Assumes this is the payload of a CopyTagged with the corresponding
* matchTag. Return a RankCover to bound from below and above,
* in rank order, all possible Passables that would match this Matcher.
* The left element must be before or the same rank as any possible
* matching specimen. The right element must be after or the same
* rank as any possible matching specimen.
*
* @property {(allegedPattern: Passable,
* check?: Checker
* ) => boolean} checkKeyPattern
* Assumes this is the payload of a CopyTagged with the corresponding
* matchTag. Is this a valid pattern for use as a query key or key schema?
*/
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc