@push.rocks/smartstream 2.0.3 → 2.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist_ts/00_commitinfo_data.js +3 -3
- package/dist_ts/index.d.ts +1 -0
- package/dist_ts/index.js +2 -1
- package/dist_ts/smartstream.classes.smartstream.d.ts +12 -0
- package/dist_ts/smartstream.classes.smartstream.js +48 -0
- package/dist_ts/smartstream.classes.streamintake.d.ts +2 -2
- package/dist_ts/smartstream.classes.streamwrapper.js +2 -2
- package/dist_ts/smartstream.plugins.d.ts +2 -2
- package/dist_ts/smartstream.plugins.js +3 -3
- package/npmextra.json +2 -2
- package/package.json +11 -12
- package/ts/00_commitinfo_data.ts +2 -2
- package/ts/index.ts +1 -0
- package/ts/smartstream.classes.smartstream.ts +55 -0
- package/ts/smartstream.plugins.ts +2 -2
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
* autocreated commitinfo by @pushrocks/commitinfo
|
|
3
3
|
*/
|
|
4
4
|
export const commitinfo = {
|
|
5
|
-
name: '@
|
|
6
|
-
version: '2.0.
|
|
5
|
+
name: '@push.rocks/smartstream',
|
|
6
|
+
version: '2.0.4',
|
|
7
7
|
description: 'simplifies access to node streams'
|
|
8
8
|
};
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMDBfY29tbWl0aW5mb19kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvMDBfY29tbWl0aW5mb19kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3hCLElBQUksRUFBRSx5QkFBeUI7SUFDL0IsT0FBTyxFQUFFLE9BQU87SUFDaEIsV0FBVyxFQUFFLG1DQUFtQztDQUNqRCxDQUFBIn0=
|
package/dist_ts/index.d.ts
CHANGED
package/dist_ts/index.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
+
export * from './smartstream.classes.smartstream.js';
|
|
1
2
|
export * from './smartstream.classes.streamwrapper.js';
|
|
2
3
|
export * from './smartstream.classes.streamintake.js';
|
|
3
4
|
export * from './smartstream.duplex.js';
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHlCQUF5QixDQUFDIn0=
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
+
/// <reference types="node" resolution-mode="require"/>
|
|
3
|
+
import * as plugins from './smartstream.plugins.js';
|
|
4
|
+
import { Duplex, type DuplexOptions } from 'stream';
|
|
5
|
+
export declare class SmartStream extends Duplex {
|
|
6
|
+
private observableSubscription?;
|
|
7
|
+
constructor(options?: DuplexOptions);
|
|
8
|
+
_read(size: number): void;
|
|
9
|
+
_write(chunk: any, encoding: string, callback: (error?: Error | null) => void): void;
|
|
10
|
+
static fromBuffer(buffer: Buffer, options?: DuplexOptions): SmartStream;
|
|
11
|
+
static fromObservable(observable: plugins.smartrx.rxjs.Observable<any>, options?: DuplexOptions): SmartStream;
|
|
12
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import * as plugins from './smartstream.plugins.js';
|
|
2
|
+
import { Duplex } from 'stream';
|
|
3
|
+
export class SmartStream extends Duplex {
|
|
4
|
+
constructor(options) {
|
|
5
|
+
super(options);
|
|
6
|
+
}
|
|
7
|
+
_read(size) {
|
|
8
|
+
// Implement if you need custom behavior, otherwise leave it empty
|
|
9
|
+
}
|
|
10
|
+
_write(chunk, encoding, callback) {
|
|
11
|
+
// Implement if you need custom behavior
|
|
12
|
+
callback();
|
|
13
|
+
}
|
|
14
|
+
static fromBuffer(buffer, options) {
|
|
15
|
+
const smartStream = new SmartStream(options);
|
|
16
|
+
process.nextTick(() => {
|
|
17
|
+
smartStream.push(buffer);
|
|
18
|
+
smartStream.push(null); // Signal the end of the data
|
|
19
|
+
});
|
|
20
|
+
return smartStream;
|
|
21
|
+
}
|
|
22
|
+
static fromObservable(observable, options) {
|
|
23
|
+
const smartStream = new SmartStream(options);
|
|
24
|
+
smartStream.observableSubscription = observable.subscribe({
|
|
25
|
+
next: (data) => {
|
|
26
|
+
if (!smartStream.push(data)) {
|
|
27
|
+
// Pause the observable if the stream buffer is full
|
|
28
|
+
smartStream.observableSubscription?.unsubscribe();
|
|
29
|
+
smartStream.once('drain', () => {
|
|
30
|
+
// Resume the observable when the stream buffer is drained
|
|
31
|
+
smartStream.observableSubscription?.unsubscribe();
|
|
32
|
+
smartStream.observableSubscription = observable.subscribe(data => {
|
|
33
|
+
smartStream.push(data);
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
},
|
|
38
|
+
error: (err) => {
|
|
39
|
+
smartStream.emit('error', err);
|
|
40
|
+
},
|
|
41
|
+
complete: () => {
|
|
42
|
+
smartStream.push(null); // Signal the end of the data
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
return smartStream;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzdHJlYW0uY2xhc3Nlcy5zbWFydHN0cmVhbS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0c3RyZWFtLmNsYXNzZXMuc21hcnRzdHJlYW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSwwQkFBMEIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsTUFBTSxFQUFzQixNQUFNLFFBQVEsQ0FBQztBQUVwRCxNQUFNLE9BQU8sV0FBWSxTQUFRLE1BQU07SUFHckMsWUFBWSxPQUF1QjtRQUNqQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztJQUVELEtBQUssQ0FBQyxJQUFZO1FBQ2hCLGtFQUFrRTtJQUNwRSxDQUFDO0lBRUQsTUFBTSxDQUFDLEtBQVUsRUFBRSxRQUFnQixFQUFFLFFBQXdDO1FBQzNFLHdDQUF3QztRQUN4QyxRQUFRLEVBQUUsQ0FBQztJQUNiLENBQUM7SUFFRCxNQUFNLENBQUMsVUFBVSxDQUFDLE1BQWMsRUFBRSxPQUF1QjtRQUN2RCxNQUFNLFdBQVcsR0FBRyxJQUFJLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUM3QyxPQUFPLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUNwQixXQUFXLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3pCLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyw2QkFBNkI7UUFDdkQsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLFdBQVcsQ0FBQztJQUNyQixDQUFDO0lBRUQsTUFBTSxDQUFDLGNBQWMsQ0FBQyxVQUFnRCxFQUFFLE9BQXVCO1FBQzdGLE1BQU0sV0FBVyxHQUFHLElBQUksV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzdDLFdBQVcsQ0FBQyxzQkFBc0IsR0FBRyxVQUFVLENBQUMsU0FBUyxDQUFDO1lBQ3hELElBQUksRUFBRSxDQUFDLElBQUksRUFBRSxFQUFFO2dCQUNiLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFO29CQUMzQixvREFBb0Q7b0JBQ3BELFdBQVcsQ0FBQyxzQkFBc0IsRUFBRSxXQUFXLEVBQUUsQ0FBQztvQkFDbEQsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsR0FBRyxFQUFFO3dCQUM3QiwwREFBMEQ7d0JBQzFELFdBQVcsQ0FBQyxzQkFBc0IsRUFBRSxXQUFXLEVBQUUsQ0FBQzt3QkFDbEQsV0FBVyxDQUFDLHNCQUFzQixHQUFHLFVBQVUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7NEJBQy9ELFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7d0JBQ3pCLENBQUMsQ0FBQyxDQUFDO29CQUNMLENBQUMsQ0FBQyxDQUFDO2lCQUNKO1lBQ0gsQ0FBQztZQUNELEtBQUssRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFO2dCQUNiLFdBQVcsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1lBQ2pDLENBQUM7WUFDRCxRQUFRLEVBQUUsR0FBRyxFQUFFO2dCQUNiLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyw2QkFBNkI7WUFDdkQsQ0FBQztTQUNGLENBQUMsQ0FBQztRQUVILE9BQU8sV0FBVyxDQUFDO0lBQ3JCLENBQUM7Q0FDRiJ9
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
-
/// <reference types="
|
|
2
|
+
/// <reference types="from2" />
|
|
3
3
|
import * as plugins from './smartstream.plugins.js';
|
|
4
4
|
export declare class StreamIntake<T> {
|
|
5
5
|
private signalEndBoolean;
|
|
@@ -15,7 +15,7 @@ export declare class StreamIntake<T> {
|
|
|
15
15
|
/**
|
|
16
16
|
* returns an oldstyle readble stream
|
|
17
17
|
*/
|
|
18
|
-
getReadableStream():
|
|
18
|
+
getReadableStream(): plugins.from2.Stream;
|
|
19
19
|
pushData(chunkData: T): void;
|
|
20
20
|
signalEnd(): void;
|
|
21
21
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import * as plugins from './smartstream.plugins.js';
|
|
2
2
|
// interfaces
|
|
3
|
-
import 'stream';
|
|
3
|
+
import { Transform } from 'stream';
|
|
4
4
|
/**
|
|
5
5
|
* class Smartstream handles
|
|
6
6
|
*/
|
|
@@ -78,4 +78,4 @@ export let cleanPipe = () => {
|
|
|
78
78
|
cb();
|
|
79
79
|
});
|
|
80
80
|
};
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzdHJlYW0uY2xhc3Nlcy5zdHJlYW13cmFwcGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRzdHJlYW0uY2xhc3Nlcy5zdHJlYW13cmFwcGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sMEJBQTBCLENBQUM7QUFFcEQsYUFBYTtBQUNiLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFlbkM7O0dBRUc7QUFDSCxNQUFNLE9BQU8sYUFBYTtJQUt4Qjs7T0FFRztJQUNILFlBQVksY0FBcUI7UUFQekIsZ0JBQVcsR0FBaUMsRUFBRSxDQUFDO1FBQy9DLDJCQUFzQixHQUF5QixFQUFFLENBQUM7UUFDbEQsMEJBQXFCLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQU0zRCxJQUFJLENBQUMsV0FBVyxHQUFHLGNBQWMsQ0FBQztJQUNwQyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxhQUFhO1FBQ1gsT0FBTyxJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDO0lBQzVDLENBQUM7SUFFRDs7T0FFRztJQUNILGFBQWEsQ0FBQyxZQUFvQixFQUFFLGdCQUFzQztRQUN4RSxJQUFJLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDO1lBQy9CLFNBQVMsRUFBRSxZQUFZO1lBQ3ZCLGFBQWEsRUFBRSxnQkFBZ0I7U0FDaEMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVEOzs7T0FHRztJQUNILEdBQUc7UUFDRCxNQUFNLElBQUksR0FBRyxPQUFPLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBUSxDQUFDO1FBRWhELGNBQWM7UUFDZCxNQUFNLG9CQUFvQixHQUFpQyxFQUFFLENBQUM7UUFDOUQsS0FBSyxNQUFNLFVBQVUsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3pDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztTQUN2QztRQUVELHFCQUFxQjtRQUNyQixJQUFJLFdBQVcsR0FBRyxJQUFJLENBQUM7UUFDdkIsSUFBSSxjQUFjLEdBQVksSUFBSSxDQUFDO1FBQ25DLEtBQUssTUFBTSxNQUFNLElBQUksb0JBQW9CLEVBQUU7WUFDekMsSUFBSSxjQUFjLEtBQUssSUFBSSxFQUFFO2dCQUMzQixXQUFXLEdBQUcsTUFBTSxDQUFDO2FBQ3RCO1lBQ0QsTUFBTSxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRTtnQkFDekIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNuQixDQUFDLENBQUMsQ0FBQztZQUNILEtBQUssTUFBTSxpQkFBaUIsSUFBSSxJQUFJLENBQUMsc0JBQXNCLEVBQUU7Z0JBQzNELE1BQU0sQ0FBQyxFQUFFLENBQUMsaUJBQWlCLENBQUMsU0FBUyxFQUFFLGlCQUFpQixDQUFDLGFBQWEsQ0FBQyxDQUFDO2FBQ3pFO1lBQ0QsSUFBSSxDQUFDLGNBQWMsRUFBRTtnQkFDbkIsV0FBVyxHQUFHLFdBQVcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7YUFDeEM7WUFDRCxjQUFjLEdBQUcsS0FBSyxDQUFDO1NBQ3hCO1FBRUQsSUFBSSxDQUFDLHFCQUFxQixDQUFDLE9BQU8sRUFBRSxDQUFDO1FBRXJDLFdBQVcsQ0FBQyxFQUFFLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRTtZQUN6QixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDakIsQ0FBQyxDQUFDLENBQUM7UUFDSCxXQUFXLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUU7WUFDM0IsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2pCLENBQUMsQ0FBQyxDQUFDO1FBQ0gsV0FBVyxDQUFDLEVBQUUsQ0FBQyxRQUFRLEVBQUUsR0FBRyxFQUFFO1lBQzVCLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNqQixDQUFDLENBQUMsQ0FBQztRQUNILE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0NBQ0Y7QUFFRCxNQUFNLENBQUMsSUFBSSxTQUFTLEdBQUcsR0FBRyxFQUFFO0lBQzFCLE9BQU8sT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQ3pCLENBQUMsSUFBSSxFQUFFLEdBQUcsRUFBRSxFQUFFLEVBQUUsRUFBRTtRQUNoQixFQUFFLEVBQUUsQ0FBQztJQUNQLENBQUMsRUFDRCxDQUFDLEVBQUUsRUFBRSxFQUFFO1FBQ0wsRUFBRSxFQUFFLENBQUM7SUFDUCxDQUFDLENBQ0YsQ0FBQztBQUNKLENBQUMsQ0FBQyJ9
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as stream from 'stream';
|
|
2
2
|
export { stream };
|
|
3
|
-
import * as smartpromise from '@
|
|
4
|
-
import * as smartrx from '@
|
|
3
|
+
import * as smartpromise from '@push.rocks/smartpromise';
|
|
4
|
+
import * as smartrx from '@push.rocks/smartrx';
|
|
5
5
|
export { smartpromise, smartrx };
|
|
6
6
|
import from2 from 'from2';
|
|
7
7
|
import through2 from 'through2';
|
|
@@ -2,11 +2,11 @@
|
|
|
2
2
|
import * as stream from 'stream';
|
|
3
3
|
export { stream };
|
|
4
4
|
// pushrocks scope
|
|
5
|
-
import * as smartpromise from '@
|
|
6
|
-
import * as smartrx from '@
|
|
5
|
+
import * as smartpromise from '@push.rocks/smartpromise';
|
|
6
|
+
import * as smartrx from '@push.rocks/smartrx';
|
|
7
7
|
export { smartpromise, smartrx };
|
|
8
8
|
// thirdparty
|
|
9
9
|
import from2 from 'from2';
|
|
10
10
|
import through2 from 'through2';
|
|
11
11
|
export { from2, through2 };
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzdHJlYW0ucGx1Z2lucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0c3RyZWFtLnBsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYztBQUNkLE9BQU8sS0FBSyxNQUFNLE1BQU0sUUFBUSxDQUFDO0FBRWpDLE9BQU8sRUFBRSxNQUFNLEVBQUUsQ0FBQztBQUVsQixrQkFBa0I7QUFDbEIsT0FBTyxLQUFLLFlBQVksTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEtBQUssT0FBTyxNQUFNLHFCQUFxQixDQUFDO0FBRS9DLE9BQU8sRUFBRSxZQUFZLEVBQUUsT0FBTyxFQUFFLENBQUM7QUFFakMsYUFBYTtBQUNiLE9BQU8sS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUMxQixPQUFPLFFBQVEsTUFBTSxVQUFVLENBQUM7QUFFaEMsT0FBTyxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUUsQ0FBQyJ9
|
package/npmextra.json
CHANGED
|
@@ -7,10 +7,10 @@
|
|
|
7
7
|
"projectType": "npm",
|
|
8
8
|
"module": {
|
|
9
9
|
"githost": "gitlab.com",
|
|
10
|
-
"gitscope": "
|
|
10
|
+
"gitscope": "push.rocks",
|
|
11
11
|
"gitrepo": "smartstream",
|
|
12
12
|
"description": "simplifies access to node streams",
|
|
13
|
-
"npmPackagename": "@
|
|
13
|
+
"npmPackagename": "@push.rocks/smartstream",
|
|
14
14
|
"license": "MIT"
|
|
15
15
|
}
|
|
16
16
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@push.rocks/smartstream",
|
|
3
|
-
"version": "2.0.
|
|
3
|
+
"version": "2.0.5",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "simplifies access to node streams",
|
|
6
6
|
"main": "dist_ts/index.js",
|
|
@@ -21,18 +21,17 @@
|
|
|
21
21
|
},
|
|
22
22
|
"homepage": "https://gitlab.com/pushrocks/smartstream#README",
|
|
23
23
|
"devDependencies": {
|
|
24
|
-
"@
|
|
25
|
-
"@
|
|
26
|
-
"@
|
|
27
|
-
"@
|
|
28
|
-
"
|
|
29
|
-
"tslint-config-prettier": "^1.18.0"
|
|
24
|
+
"@git.zone/tsbuild": "^2.1.66",
|
|
25
|
+
"@git.zone/tsrun": "^1.2.44",
|
|
26
|
+
"@git.zone/tstest": "^1.0.77",
|
|
27
|
+
"@push.rocks/smartfile": "^10.0.33",
|
|
28
|
+
"@push.rocks/tapbundle": "^5.0.15"
|
|
30
29
|
},
|
|
31
30
|
"dependencies": {
|
|
32
|
-
"@
|
|
33
|
-
"@
|
|
34
|
-
"@types/from2": "^2.3.
|
|
35
|
-
"@types/through2": "^2.0.
|
|
31
|
+
"@push.rocks/smartpromise": "^4.0.3",
|
|
32
|
+
"@push.rocks/smartrx": "^3.0.7",
|
|
33
|
+
"@types/from2": "^2.3.4",
|
|
34
|
+
"@types/through2": "^2.0.40",
|
|
36
35
|
"from2": "^2.3.0",
|
|
37
36
|
"through2": "^4.0.2"
|
|
38
37
|
},
|
|
@@ -51,4 +50,4 @@
|
|
|
51
50
|
"npmextra.json",
|
|
52
51
|
"readme.md"
|
|
53
52
|
]
|
|
54
|
-
}
|
|
53
|
+
}
|
package/ts/00_commitinfo_data.ts
CHANGED
package/ts/index.ts
CHANGED
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import * as plugins from './smartstream.plugins.js';
|
|
2
|
+
import { Duplex, type DuplexOptions } from 'stream';
|
|
3
|
+
|
|
4
|
+
export class SmartStream extends Duplex {
|
|
5
|
+
private observableSubscription?: plugins.smartrx.rxjs.Subscription;
|
|
6
|
+
|
|
7
|
+
constructor(options?: DuplexOptions) {
|
|
8
|
+
super(options);
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
_read(size: number) {
|
|
12
|
+
// Implement if you need custom behavior, otherwise leave it empty
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
_write(chunk: any, encoding: string, callback: (error?: Error | null) => void) {
|
|
16
|
+
// Implement if you need custom behavior
|
|
17
|
+
callback();
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
static fromBuffer(buffer: Buffer, options?: DuplexOptions): SmartStream {
|
|
21
|
+
const smartStream = new SmartStream(options);
|
|
22
|
+
process.nextTick(() => {
|
|
23
|
+
smartStream.push(buffer);
|
|
24
|
+
smartStream.push(null); // Signal the end of the data
|
|
25
|
+
});
|
|
26
|
+
return smartStream;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
static fromObservable(observable: plugins.smartrx.rxjs.Observable<any>, options?: DuplexOptions): SmartStream {
|
|
30
|
+
const smartStream = new SmartStream(options);
|
|
31
|
+
smartStream.observableSubscription = observable.subscribe({
|
|
32
|
+
next: (data) => {
|
|
33
|
+
if (!smartStream.push(data)) {
|
|
34
|
+
// Pause the observable if the stream buffer is full
|
|
35
|
+
smartStream.observableSubscription?.unsubscribe();
|
|
36
|
+
smartStream.once('drain', () => {
|
|
37
|
+
// Resume the observable when the stream buffer is drained
|
|
38
|
+
smartStream.observableSubscription?.unsubscribe();
|
|
39
|
+
smartStream.observableSubscription = observable.subscribe(data => {
|
|
40
|
+
smartStream.push(data);
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
},
|
|
45
|
+
error: (err) => {
|
|
46
|
+
smartStream.emit('error', err);
|
|
47
|
+
},
|
|
48
|
+
complete: () => {
|
|
49
|
+
smartStream.push(null); // Signal the end of the data
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
return smartStream;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
@@ -4,8 +4,8 @@ import * as stream from 'stream';
|
|
|
4
4
|
export { stream };
|
|
5
5
|
|
|
6
6
|
// pushrocks scope
|
|
7
|
-
import * as smartpromise from '@
|
|
8
|
-
import * as smartrx from '@
|
|
7
|
+
import * as smartpromise from '@push.rocks/smartpromise';
|
|
8
|
+
import * as smartrx from '@push.rocks/smartrx';
|
|
9
9
|
|
|
10
10
|
export { smartpromise, smartrx };
|
|
11
11
|
|