the-forest/client/node_modules/internal-slot
2024-09-17 20:35:18 -04:00
..
.github client raw doggin the db 2024-09-17 20:35:18 -04:00
test client raw doggin the db 2024-09-17 20:35:18 -04:00
.editorconfig client raw doggin the db 2024-09-17 20:35:18 -04:00
.eslintrc client raw doggin the db 2024-09-17 20:35:18 -04:00
.nycrc client raw doggin the db 2024-09-17 20:35:18 -04:00
CHANGELOG.md client raw doggin the db 2024-09-17 20:35:18 -04:00
index.js client raw doggin the db 2024-09-17 20:35:18 -04:00
LICENSE client raw doggin the db 2024-09-17 20:35:18 -04:00
package.json client raw doggin the db 2024-09-17 20:35:18 -04:00
README.md client raw doggin the db 2024-09-17 20:35:18 -04:00

internal-slot Version Badge

github actions coverage dependency status dev dependency status License Downloads

npm badge

Truly private storage, akin to the JS specs concept of internal slots.

Uses a WeakMap when available; a Map when not; and a regular object in even older engines. Performance and garbage collection behavior will reflect the environments capabilities accordingly.

Example

var SLOT = require('internal-slot');
var assert = require('assert');

var o = {};

assert.throws(function () { SLOT.assert(o, 'foo'); });

assert.equal(SLOT.has(o, 'foo'), false);
assert.equal(SLOT.get(o, 'foo'), undefined);

SLOT.set(o, 'foo', 42);

assert.equal(SLOT.has(o, 'foo'), true);
assert.equal(SLOT.get(o, 'foo'), 42);

assert.doesNotThrow(function () { SLOT.assert(o, 'foo'); });

Tests

Simply clone the repo, npm install, and run npm test

Security

Please email @ljharb or see https://tidelift.com/security if you have a potential security vulnerability to report.