kefir-bus
v2.3.1
Published
Kefir.bus for people who still want it
Downloads
31,400
Readme
kefirBus
Kefir 3.0 removed Kefir.bus
from the core project, so now it's up to 3rd
party modules to implement it. This module is an implementation of Kefir.Bus
that passes all of Kefir's older tests for Kefir.Bus.
Older code:
var Kefir = require('kefir');
var bus = Kefir.bus();
Now with this module:
var Kefir = require('kefir');
var kefirBus = require('kefir-bus');
var bus = kefirBus();
See Kefir's deprecated API docs for information about Kefir buses.
Most code that uses Buses can be done in a better and more idiomatic way with Kefir. Try to investigate alternatives before you use a bus! Consider the following code:
// BAD CODE EXAMPLE!
var bus = kefirBus();
setInterval(function() {
bus.emit(null);
}, 1000);
bus.take(5).onValue(function() {
console.log('beep'); // runs 5 times
});
This code never stops the interval timer! It will continue to emit nulls into the bus for eternity, even though no one is receiving the values. Unsubscribing from a bus can't send any unsubscription notification to to the producer calling the emit method.
Kefir itself has functions that provide streams which automatically stop producing values as soon they are unsubscribed from. The following code does not suffer from the problem of the previous example:
Kefir.interval(1000).take(5).onValue(function() {
console.log('beep'); // runs 5 times
});
Types
Both TypeScript and Flow type definitions for this module are included! The type definitions won't require any configuration to use.