fix(core): update
This commit is contained in:
parent
84d3a6310d
commit
124400df69
@ -3,6 +3,6 @@
|
||||
*/
|
||||
export const commitinfo = {
|
||||
name: '@push.rocks/smartrx',
|
||||
version: '3.0.7',
|
||||
version: '3.0.8',
|
||||
description: 'smart wrapper for rxjs'
|
||||
}
|
||||
|
@ -1,5 +1,6 @@
|
||||
import * as plugins from './smartrx.plugins.js';
|
||||
export * from './smartrx.classes.observablemap.js';
|
||||
export * from './smartrx.classes.observableintake.js';
|
||||
export * from './smartrx.functions.js';
|
||||
import * as rxjs from './smartrx.plugins.rxjs.js';
|
||||
export { rxjs };
|
||||
|
32
ts/smartrx.functions.ts
Normal file
32
ts/smartrx.functions.ts
Normal file
@ -0,0 +1,32 @@
|
||||
import { Observable } from 'rxjs';
|
||||
import { Readable } from 'stream';
|
||||
|
||||
export function fromStreamWithBackpressure<T>(stream: Readable): Observable<T> {
|
||||
return new Observable<T>((subscriber) => {
|
||||
const pauseStream = () => stream.pause();
|
||||
const resumeStream = () => process.nextTick(() => stream.resume());
|
||||
|
||||
// Handler for each piece of data
|
||||
const onData = (data: T) => {
|
||||
// Pause the stream to apply backpressure
|
||||
pauseStream();
|
||||
// Emit data and resume the stream if the subscriber is ready
|
||||
subscriber.next(data);
|
||||
resumeStream();
|
||||
};
|
||||
|
||||
// Subscribe to stream events
|
||||
stream.on('data', onData);
|
||||
stream.on('error', (error) => subscriber.error(error));
|
||||
stream.on('end', () => subscriber.complete());
|
||||
stream.on('close', () => subscriber.complete());
|
||||
|
||||
// If the subscriber unsubscribes, clean up the stream listeners
|
||||
return () => {
|
||||
stream.removeListener('data', onData);
|
||||
stream.removeListener('error', subscriber.error);
|
||||
stream.removeListener('end', subscriber.complete);
|
||||
stream.removeListener('close', subscriber.complete);
|
||||
};
|
||||
});
|
||||
}
|
Loading…
Reference in New Issue
Block a user