@push.rocks/smartstream 3.2.5 → 3.4.0
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 +1 -1
- package/dist_ts/smartstream.classes.smartduplex.d.ts +10 -6
- package/dist_ts/smartstream.classes.smartduplex.js +182 -72
- package/dist_ts/smartstream.classes.streamintake.d.ts +0 -1
- package/dist_ts/smartstream.classes.streamintake.js +6 -3
- package/dist_ts/smartstream.classes.streamwrapper.js +11 -12
- package/dist_ts/smartstream.functions.d.ts +0 -1
- package/dist_ts/smartstream.nodewebhelpers.d.ts +2 -3
- package/dist_ts/smartstream.nodewebhelpers.js +97 -36
- package/dist_ts/smartstream.plugins.d.ts +0 -2
- package/dist_ts_web/00_commitinfo_data.js +1 -1
- package/dist_ts_web/classes.webduplexstream.js +20 -15
- package/dist_ts_web/plugins.js +1 -1
- package/npmextra.json +12 -6
- package/package.json +21 -17
- package/readme.md +335 -238
- package/ts/00_commitinfo_data.ts +1 -1
- package/ts/smartstream.classes.smartduplex.ts +211 -78
- package/ts/smartstream.classes.streamintake.ts +5 -2
- package/ts/smartstream.classes.streamwrapper.ts +11 -12
- package/ts/smartstream.nodewebhelpers.ts +105 -37
- package/ts/tspublish.json +3 -0
- package/ts_web/00_commitinfo_data.ts +1 -1
- package/ts_web/classes.webduplexstream.ts +20 -13
- package/ts_web/plugins.ts +3 -3
- package/ts_web/tspublish.json +3 -0
- package/dist_ts/smartstream.classes.passthrough.d.ts +0 -8
- package/dist_ts/smartstream.classes.passthrough.js +0 -18
- package/dist_ts/smartstream.classes.smartstream.d.ts +0 -12
- package/dist_ts/smartstream.classes.smartstream.js +0 -48
- package/dist_ts/smartstream.duplex.d.ts +0 -23
- package/dist_ts/smartstream.duplex.js +0 -48
- package/dist_ts_web/convert.d.ts +0 -18
- package/dist_ts_web/convert.js +0 -45
|
@@ -78,17 +78,14 @@ export class WebDuplexStream<TInput = any, TOutput = any> extends TransformStrea
|
|
|
78
78
|
|
|
79
79
|
try {
|
|
80
80
|
const finalChunk = await optionsArg.finalFunction(tools);
|
|
81
|
-
if (finalChunk) {
|
|
82
|
-
controller.enqueue(finalChunk);
|
|
81
|
+
if (finalChunk !== undefined && finalChunk !== null) {
|
|
82
|
+
controller.enqueue(finalChunk as TOutput);
|
|
83
83
|
}
|
|
84
84
|
} catch (err) {
|
|
85
85
|
controller.error(err);
|
|
86
|
-
} finally {
|
|
87
|
-
controller.terminate();
|
|
88
86
|
}
|
|
89
|
-
} else {
|
|
90
|
-
controller.terminate();
|
|
91
87
|
}
|
|
88
|
+
// TransformStream auto-closes readable after flush resolves — no terminate() needed
|
|
92
89
|
},
|
|
93
90
|
});
|
|
94
91
|
|
|
@@ -96,7 +93,9 @@ export class WebDuplexStream<TInput = any, TOutput = any> extends TransformStrea
|
|
|
96
93
|
|
|
97
94
|
// Start producing data if readFunction is provided
|
|
98
95
|
if (this.options.readFunction) {
|
|
99
|
-
this._startReading()
|
|
96
|
+
this._startReading().catch((err) => {
|
|
97
|
+
// Prevent unhandled rejection — the error is propagated through the writable side
|
|
98
|
+
});
|
|
100
99
|
}
|
|
101
100
|
}
|
|
102
101
|
|
|
@@ -104,17 +103,25 @@ export class WebDuplexStream<TInput = any, TOutput = any> extends TransformStrea
|
|
|
104
103
|
const writable = this.writable;
|
|
105
104
|
const writer = writable.getWriter();
|
|
106
105
|
|
|
106
|
+
let doneSignaled = false;
|
|
107
107
|
const tools: IStreamToolsRead<TInput, TOutput> = {
|
|
108
|
-
done: () =>
|
|
108
|
+
done: () => {
|
|
109
|
+
doneSignaled = true;
|
|
110
|
+
},
|
|
109
111
|
write: async (writeArg) => await writer.write(writeArg),
|
|
110
112
|
};
|
|
111
113
|
|
|
112
114
|
try {
|
|
113
115
|
await this.options.readFunction(tools);
|
|
116
|
+
if (doneSignaled) {
|
|
117
|
+
await writer.close();
|
|
118
|
+
}
|
|
114
119
|
} catch (err) {
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
120
|
+
try {
|
|
121
|
+
await writer.abort(err);
|
|
122
|
+
} catch (_) {
|
|
123
|
+
// Writer may already be in error state
|
|
124
|
+
}
|
|
118
125
|
}
|
|
119
126
|
}
|
|
120
127
|
|
|
@@ -128,8 +135,8 @@ export class WebDuplexStream<TInput = any, TOutput = any> extends TransformStrea
|
|
|
128
135
|
});
|
|
129
136
|
|
|
130
137
|
const writer = stream.writable.getWriter();
|
|
131
|
-
writer.write(uint8Array).then(() => writer.close());
|
|
138
|
+
writer.write(uint8Array).then(() => writer.close()).catch(() => {});
|
|
132
139
|
|
|
133
140
|
return stream;
|
|
134
141
|
}
|
|
135
|
-
}
|
|
142
|
+
}
|
package/ts_web/plugins.ts
CHANGED
|
@@ -9,7 +9,7 @@ export {
|
|
|
9
9
|
const smartenvInstance = new smartenv.Smartenv();
|
|
10
10
|
|
|
11
11
|
await smartenvInstance.getSafeNodeModule<typeof import('stream/web')>('stream/web', async (moduleArg) => {
|
|
12
|
-
globalThis.ReadableStream = moduleArg.ReadableStream;
|
|
13
|
-
globalThis.WritableStream = moduleArg.WritableStream;
|
|
14
|
-
globalThis.TransformStream = moduleArg.TransformStream;
|
|
12
|
+
globalThis.ReadableStream = moduleArg.ReadableStream as any;
|
|
13
|
+
globalThis.WritableStream = moduleArg.WritableStream as any;
|
|
14
|
+
globalThis.TransformStream = moduleArg.TransformStream as any;
|
|
15
15
|
})
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
-
/// <reference types="node" resolution-mode="require"/>
|
|
3
|
-
import * as plugins from './smartstream.plugins.js';
|
|
4
|
-
export declare class PassThrough extends plugins.stream.Duplex {
|
|
5
|
-
constructor(options?: plugins.stream.DuplexOptions);
|
|
6
|
-
_read(size: number): void;
|
|
7
|
-
_write(chunk: any, encoding: BufferEncoding, callback: (error?: Error | null) => void): void;
|
|
8
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import * as plugins from './smartstream.plugins.js';
|
|
2
|
-
export class PassThrough extends plugins.stream.Duplex {
|
|
3
|
-
constructor(options) {
|
|
4
|
-
super(options);
|
|
5
|
-
}
|
|
6
|
-
_read(size) {
|
|
7
|
-
// No-op: Data written will be automatically available for reading.
|
|
8
|
-
}
|
|
9
|
-
_write(chunk, encoding, callback) {
|
|
10
|
-
if (this.push(chunk, encoding)) {
|
|
11
|
-
callback();
|
|
12
|
-
}
|
|
13
|
-
else {
|
|
14
|
-
this.once('drain', callback);
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzdHJlYW0uY2xhc3Nlcy5wYXNzdGhyb3VnaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0c3RyZWFtLmNsYXNzZXMucGFzc3Rocm91Z2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSwwQkFBMEIsQ0FBQztBQUVwRCxNQUFNLE9BQU8sV0FBWSxTQUFRLE9BQU8sQ0FBQyxNQUFNLENBQUMsTUFBTTtJQUNwRCxZQUFZLE9BQXNDO1FBQ2hELEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqQixDQUFDO0lBRUQsS0FBSyxDQUFDLElBQVk7UUFDaEIsbUVBQW1FO0lBQ3JFLENBQUM7SUFFRCxNQUFNLENBQUMsS0FBVSxFQUFFLFFBQXdCLEVBQUUsUUFBd0M7UUFDbkYsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxRQUFRLENBQUMsRUFBRTtZQUM5QixRQUFRLEVBQUUsQ0FBQztTQUNaO2FBQU07WUFDTCxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxRQUFRLENBQUMsQ0FBQztTQUM5QjtJQUNILENBQUM7Q0FDRiJ9
|
|
@@ -1,12 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,48 +0,0 @@
|
|
|
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,23 +0,0 @@
|
|
|
1
|
-
import * as plugins from './smartstream.plugins.js';
|
|
2
|
-
export interface ITruncateFunc {
|
|
3
|
-
(): void;
|
|
4
|
-
}
|
|
5
|
-
export interface IPipeMoreFunc {
|
|
6
|
-
(pipeObject: any): void;
|
|
7
|
-
}
|
|
8
|
-
export interface IStreamTools {
|
|
9
|
-
truncate: ITruncateFunc;
|
|
10
|
-
pipeMore: IPipeMoreFunc;
|
|
11
|
-
}
|
|
12
|
-
export interface IStreamFunction<T, rT> {
|
|
13
|
-
(chunkArg: T, toolsArg: IStreamTools): Promise<rT>;
|
|
14
|
-
}
|
|
15
|
-
export interface IStreamEndFunction<rT> {
|
|
16
|
-
(toolsArg: IStreamTools): Promise<rT>;
|
|
17
|
-
}
|
|
18
|
-
export interface IStreamOptions {
|
|
19
|
-
objectMode?: boolean;
|
|
20
|
-
readableObjectMode?: boolean;
|
|
21
|
-
writableObjectMode?: boolean;
|
|
22
|
-
}
|
|
23
|
-
export declare let createDuplexStream: <T, rT>(funcArg: IStreamFunction<T, rT>, endFuncArg?: IStreamEndFunction<rT>, optionsArg?: IStreamOptions) => plugins.stream.Transform;
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
import * as plugins from './smartstream.plugins.js';
|
|
2
|
-
export let createDuplexStream = (funcArg, endFuncArg, optionsArg = {
|
|
3
|
-
objectMode: false,
|
|
4
|
-
readableObjectMode: true,
|
|
5
|
-
writableObjectMode: true,
|
|
6
|
-
}) => {
|
|
7
|
-
return plugins.through2(optionsArg, function (chunk, enc, cb) {
|
|
8
|
-
let truncated = false;
|
|
9
|
-
const tools = {
|
|
10
|
-
truncate: () => {
|
|
11
|
-
truncated = true;
|
|
12
|
-
cb(null, null);
|
|
13
|
-
},
|
|
14
|
-
pipeMore: (pipeObject) => {
|
|
15
|
-
this.push(pipeObject);
|
|
16
|
-
},
|
|
17
|
-
};
|
|
18
|
-
const asyncWrapper = async () => {
|
|
19
|
-
const resultChunk = await funcArg(chunk, tools);
|
|
20
|
-
if (!truncated) {
|
|
21
|
-
cb(null, resultChunk);
|
|
22
|
-
}
|
|
23
|
-
};
|
|
24
|
-
asyncWrapper().catch((err) => {
|
|
25
|
-
console.log(err);
|
|
26
|
-
});
|
|
27
|
-
}, function (cb) {
|
|
28
|
-
const tools = {
|
|
29
|
-
truncate: () => {
|
|
30
|
-
cb();
|
|
31
|
-
},
|
|
32
|
-
pipeMore: (pushArg) => {
|
|
33
|
-
this.push(pushArg);
|
|
34
|
-
},
|
|
35
|
-
};
|
|
36
|
-
const asyncWrapper = async () => {
|
|
37
|
-
if (endFuncArg) {
|
|
38
|
-
const result = await endFuncArg(tools);
|
|
39
|
-
this.push(result);
|
|
40
|
-
}
|
|
41
|
-
cb();
|
|
42
|
-
};
|
|
43
|
-
asyncWrapper().catch((err) => {
|
|
44
|
-
console.log(err);
|
|
45
|
-
});
|
|
46
|
-
});
|
|
47
|
-
};
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzdHJlYW0uZHVwbGV4LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRzdHJlYW0uZHVwbGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sMEJBQTBCLENBQUM7QUE2QnBELE1BQU0sQ0FBQyxJQUFJLGtCQUFrQixHQUFHLENBQzlCLE9BQStCLEVBQy9CLFVBQW1DLEVBQ25DLGFBQTZCO0lBQzNCLFVBQVUsRUFBRSxLQUFLO0lBQ2pCLGtCQUFrQixFQUFFLElBQUk7SUFDeEIsa0JBQWtCLEVBQUUsSUFBSTtDQUN6QixFQUNELEVBQUU7SUFDRixPQUFPLE9BQU8sQ0FBQyxRQUFRLENBQ3JCLFVBQVUsRUFDVixVQUFVLEtBQUssRUFBRSxHQUFHLEVBQUUsRUFBRTtRQUN0QixJQUFJLFNBQVMsR0FBRyxLQUFLLENBQUM7UUFDdEIsTUFBTSxLQUFLLEdBQWlCO1lBQzFCLFFBQVEsRUFBRSxHQUFHLEVBQUU7Z0JBQ2IsU0FBUyxHQUFHLElBQUksQ0FBQztnQkFDakIsRUFBRSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztZQUNqQixDQUFDO1lBQ0QsUUFBUSxFQUFFLENBQUMsVUFBVSxFQUFFLEVBQUU7Z0JBQ3ZCLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDeEIsQ0FBQztTQUNGLENBQUM7UUFDRixNQUFNLFlBQVksR0FBRyxLQUFLLElBQUksRUFBRTtZQUM5QixNQUFNLFdBQVcsR0FBTyxNQUFNLE9BQU8sQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFDcEQsSUFBSSxDQUFDLFNBQVMsRUFBRTtnQkFDZCxFQUFFLENBQUMsSUFBSSxFQUFFLFdBQVcsQ0FBQyxDQUFDO2FBQ3ZCO1FBQ0gsQ0FBQyxDQUFDO1FBQ0YsWUFBWSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDM0IsT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNuQixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsRUFDRCxVQUFVLEVBQUU7UUFDVixNQUFNLEtBQUssR0FBaUI7WUFDMUIsUUFBUSxFQUFFLEdBQUcsRUFBRTtnQkFDYixFQUFFLEVBQUUsQ0FBQztZQUNQLENBQUM7WUFDRCxRQUFRLEVBQUUsQ0FBQyxPQUFPLEVBQUUsRUFBRTtnQkFDcEIsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUNyQixDQUFDO1NBQ0YsQ0FBQztRQUNGLE1BQU0sWUFBWSxHQUFHLEtBQUssSUFBSSxFQUFFO1lBQzlCLElBQUksVUFBVSxFQUFFO2dCQUNkLE1BQU0sTUFBTSxHQUFHLE1BQU0sVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUN2QyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO2FBQ25CO1lBQ0QsRUFBRSxFQUFFLENBQUM7UUFDUCxDQUFDLENBQUM7UUFDRixZQUFZLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtZQUMzQixPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ25CLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUNGLENBQUM7QUFDSixDQUFDLENBQUMifQ==
|
package/dist_ts_web/convert.d.ts
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
export interface IDuplexStream {
|
|
2
|
-
read(): any;
|
|
3
|
-
write(chunk: any, callback?: (error?: Error | null) => void): boolean;
|
|
4
|
-
on(event: string, listener: (...args: any[]) => void): this;
|
|
5
|
-
once(event: string, listener: (...args: any[]) => void): this;
|
|
6
|
-
end(callback?: () => void): void;
|
|
7
|
-
destroy(error?: Error): void;
|
|
8
|
-
}
|
|
9
|
-
export interface IReadableStreamOptions {
|
|
10
|
-
highWaterMark?: number;
|
|
11
|
-
}
|
|
12
|
-
export interface IWritableStreamOptions {
|
|
13
|
-
highWaterMark?: number;
|
|
14
|
-
}
|
|
15
|
-
export declare function convertDuplexToWebStream(duplex: IDuplexStream): {
|
|
16
|
-
readable: ReadableStream;
|
|
17
|
-
writable: WritableStream;
|
|
18
|
-
};
|
package/dist_ts_web/convert.js
DELETED
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
export function convertDuplexToWebStream(duplex) {
|
|
2
|
-
const readable = new ReadableStream({
|
|
3
|
-
start(controller) {
|
|
4
|
-
duplex.on('readable', () => {
|
|
5
|
-
let chunk;
|
|
6
|
-
while (null !== (chunk = duplex.read())) {
|
|
7
|
-
controller.enqueue(chunk);
|
|
8
|
-
}
|
|
9
|
-
});
|
|
10
|
-
duplex.on('end', () => {
|
|
11
|
-
controller.close();
|
|
12
|
-
});
|
|
13
|
-
},
|
|
14
|
-
cancel(reason) {
|
|
15
|
-
duplex.destroy(new Error(reason));
|
|
16
|
-
}
|
|
17
|
-
});
|
|
18
|
-
const writable = new WritableStream({
|
|
19
|
-
write(chunk) {
|
|
20
|
-
return new Promise((resolve, reject) => {
|
|
21
|
-
const isBackpressured = !duplex.write(chunk, (error) => {
|
|
22
|
-
if (error) {
|
|
23
|
-
reject(error);
|
|
24
|
-
}
|
|
25
|
-
else {
|
|
26
|
-
resolve();
|
|
27
|
-
}
|
|
28
|
-
});
|
|
29
|
-
if (isBackpressured) {
|
|
30
|
-
duplex.once('drain', resolve);
|
|
31
|
-
}
|
|
32
|
-
});
|
|
33
|
-
},
|
|
34
|
-
close() {
|
|
35
|
-
return new Promise((resolve, reject) => {
|
|
36
|
-
duplex.end(resolve);
|
|
37
|
-
});
|
|
38
|
-
},
|
|
39
|
-
abort(reason) {
|
|
40
|
-
duplex.destroy(new Error(reason));
|
|
41
|
-
}
|
|
42
|
-
});
|
|
43
|
-
return { readable, writable };
|
|
44
|
-
}
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udmVydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzX3dlYi9jb252ZXJ0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCQSxNQUFNLFVBQVUsd0JBQXdCLENBQUMsTUFBcUI7SUFDNUQsTUFBTSxRQUFRLEdBQUcsSUFBSSxjQUFjLENBQUM7UUFDbEMsS0FBSyxDQUFDLFVBQVU7WUFDZCxNQUFNLENBQUMsRUFBRSxDQUFDLFVBQVUsRUFBRSxHQUFHLEVBQUU7Z0JBQ3pCLElBQUksS0FBSyxDQUFDO2dCQUNWLE9BQU8sSUFBSSxLQUFLLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUM7b0JBQ3hDLFVBQVUsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBQzVCLENBQUM7WUFDSCxDQUFDLENBQUMsQ0FBQztZQUVILE1BQU0sQ0FBQyxFQUFFLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRTtnQkFDcEIsVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ3JCLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztRQUNELE1BQU0sQ0FBQyxNQUFNO1lBQ1gsTUFBTSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBQ3BDLENBQUM7S0FDRixDQUFDLENBQUM7SUFFSCxNQUFNLFFBQVEsR0FBRyxJQUFJLGNBQWMsQ0FBQztRQUNsQyxLQUFLLENBQUMsS0FBSztZQUNULE9BQU8sSUFBSSxPQUFPLENBQU8sQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7Z0JBQzNDLE1BQU0sZUFBZSxHQUFHLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxLQUFLLEVBQUUsQ0FBQyxLQUFLLEVBQUUsRUFBRTtvQkFDckQsSUFBSSxLQUFLLEVBQUUsQ0FBQzt3QkFDVixNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7b0JBQ2hCLENBQUM7eUJBQU0sQ0FBQzt3QkFDTixPQUFPLEVBQUUsQ0FBQztvQkFDWixDQUFDO2dCQUNILENBQUMsQ0FBQyxDQUFDO2dCQUVILElBQUksZUFBZSxFQUFFLENBQUM7b0JBQ3BCLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDO2dCQUNoQyxDQUFDO1lBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsS0FBSztZQUNILE9BQU8sSUFBSSxPQUFPLENBQU8sQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7Z0JBQzNDLE1BQU0sQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDdEIsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsS0FBSyxDQUFDLE1BQU07WUFDVixNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7UUFDcEMsQ0FBQztLQUNGLENBQUMsQ0FBQztJQUVILE9BQU8sRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLENBQUM7QUFDaEMsQ0FBQyJ9
|