add second argument to writable - fixes #2072

pull/2091/head
Richard Harris 6 years ago
parent fa1322b00b
commit 9e8e99caf6

@ -34,7 +34,8 @@ export function readable(start, value) {
}; };
} }
export function writable(value) { export function writable(value, start = noop) {
let stop;
const subscribers = []; const subscribers = [];
function set(newValue) { function set(newValue) {
@ -51,11 +52,13 @@ export function writable(value) {
function subscribe(run, invalidate = noop) { function subscribe(run, invalidate = noop) {
const subscriber = [run, invalidate]; const subscriber = [run, invalidate];
subscribers.push(subscriber); subscribers.push(subscriber);
if (subscribers.length === 1) stop = start() || noop;
run(value); run(value);
return () => { return () => {
const index = subscribers.indexOf(subscriber); const index = subscribers.indexOf(subscriber);
if (index !== -1) subscribers.splice(index, 1); if (index !== -1) subscribers.splice(index, 1);
if (subscribers.length === 0) stop();
}; };
} }

@ -21,6 +21,27 @@ describe('store', () => {
assert.deepEqual(values, [0, 1, 2]); assert.deepEqual(values, [0, 1, 2]);
}); });
it('calls provided subscribe handler', () => {
let called = 0;
const store = writable(0, () => {
called += 1;
return () => called -= 1;
});
const unsubscribe1 = store.subscribe(() => {});
assert.equal(called, 1);
const unsubscribe2 = store.subscribe(() => {});
assert.equal(called, 1);
unsubscribe1();
assert.equal(called, 1);
unsubscribe2();
assert.equal(called, 0);
});
}); });
describe('readable', () => { describe('readable', () => {

Loading…
Cancel
Save