Internet-programming_PIbd-2.../Library/node_modules/internal-slot
2023-11-30 18:35:42 +04:00
..
.github i just have broken all of it 2023-11-30 18:35:42 +04:00
test i just have broken all of it 2023-11-30 18:35:42 +04:00
.editorconfig i just have broken all of it 2023-11-30 18:35:42 +04:00
.eslintrc i just have broken all of it 2023-11-30 18:35:42 +04:00
.nycrc i just have broken all of it 2023-11-30 18:35:42 +04:00
CHANGELOG.md i just have broken all of it 2023-11-30 18:35:42 +04:00
index.js i just have broken all of it 2023-11-30 18:35:42 +04:00
LICENSE i just have broken all of it 2023-11-30 18:35:42 +04:00
package.json i just have broken all of it 2023-11-30 18:35:42 +04:00
README.md i just have broken all of it 2023-11-30 18:35:42 +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.