@push.rocks/smartstream 3.2.4 → 3.3.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 +0 -2
- package/dist_ts/smartstream.classes.streamintake.d.ts +0 -1
- package/dist_ts/smartstream.functions.d.ts +0 -1
- package/dist_ts/smartstream.nodewebhelpers.d.ts +29 -0
- package/dist_ts/smartstream.nodewebhelpers.js +117 -3
- package/dist_ts/smartstream.plugins.d.ts +2 -2
- package/dist_ts/smartstream.plugins.js +3 -2
- package/dist_ts_web/00_commitinfo_data.js +1 -1
- 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.nodewebhelpers.ts +119 -2
- package/ts/smartstream.plugins.ts +2 -1
- package/ts/tspublish.json +3 -0
- package/ts_web/00_commitinfo_data.ts +1 -1
- 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
package/ts/00_commitinfo_data.ts
CHANGED
|
@@ -3,6 +3,6 @@
|
|
|
3
3
|
*/
|
|
4
4
|
export const commitinfo = {
|
|
5
5
|
name: '@push.rocks/smartstream',
|
|
6
|
-
version: '3.
|
|
6
|
+
version: '3.3.0',
|
|
7
7
|
description: 'A library to simplify the creation and manipulation of Node.js streams, providing utilities for handling transform, duplex, and readable/writable streams effectively in TypeScript.'
|
|
8
8
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import
|
|
1
|
+
import * as plugins from './smartstream.plugins.js';
|
|
2
2
|
|
|
3
3
|
/**
|
|
4
4
|
* Creates a Web ReadableStream from a file.
|
|
@@ -7,7 +7,7 @@ import { createReadStream } from 'fs';
|
|
|
7
7
|
* @returns A Web ReadableStream that reads the file in chunks
|
|
8
8
|
*/
|
|
9
9
|
export function createWebReadableStreamFromFile(filePath: string): ReadableStream<Uint8Array> {
|
|
10
|
-
const fileStream = createReadStream(filePath);
|
|
10
|
+
const fileStream = plugins.fs.createReadStream(filePath);
|
|
11
11
|
|
|
12
12
|
return new ReadableStream({
|
|
13
13
|
start(controller) {
|
|
@@ -31,4 +31,121 @@ export function createWebReadableStreamFromFile(filePath: string): ReadableStrea
|
|
|
31
31
|
fileStream.destroy();
|
|
32
32
|
}
|
|
33
33
|
});
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Converts a Web ReadableStream to a Node.js Readable stream.
|
|
38
|
+
*
|
|
39
|
+
* @param webStream - The Web ReadableStream to convert
|
|
40
|
+
* @returns A Node.js Readable stream that reads data from the Web ReadableStream
|
|
41
|
+
*/
|
|
42
|
+
export function convertWebReadableToNodeReadable(webStream: ReadableStream<Uint8Array>): plugins.stream.Readable {
|
|
43
|
+
const reader = webStream.getReader();
|
|
44
|
+
|
|
45
|
+
return new plugins.stream.Readable({
|
|
46
|
+
async read() {
|
|
47
|
+
try {
|
|
48
|
+
const { value, done } = await reader.read();
|
|
49
|
+
if (done) {
|
|
50
|
+
this.push(null); // Signal end of stream
|
|
51
|
+
} else {
|
|
52
|
+
this.push(Buffer.from(value)); // Convert Uint8Array to Buffer for Node.js Readable
|
|
53
|
+
}
|
|
54
|
+
} catch (err) {
|
|
55
|
+
this.destroy(err); // Handle errors by destroying the stream
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* Converts a Node.js Readable stream to a Web ReadableStream.
|
|
63
|
+
*
|
|
64
|
+
* @param nodeStream - The Node.js Readable stream to convert
|
|
65
|
+
* @returns A Web ReadableStream that reads data from the Node.js Readable stream
|
|
66
|
+
*/
|
|
67
|
+
export function convertNodeReadableToWebReadable(nodeStream: plugins.stream.Readable): ReadableStream<Uint8Array> {
|
|
68
|
+
return new ReadableStream({
|
|
69
|
+
start(controller) {
|
|
70
|
+
nodeStream.on('data', (chunk) => {
|
|
71
|
+
controller.enqueue(new Uint8Array(chunk));
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
nodeStream.on('end', () => {
|
|
75
|
+
controller.close();
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
nodeStream.on('error', (err) => {
|
|
79
|
+
controller.error(err);
|
|
80
|
+
});
|
|
81
|
+
},
|
|
82
|
+
cancel() {
|
|
83
|
+
nodeStream.destroy();
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* Converts a Web WritableStream to a Node.js Writable stream.
|
|
90
|
+
*
|
|
91
|
+
* @param webWritable - The Web WritableStream to convert
|
|
92
|
+
* @returns A Node.js Writable stream that writes data to the Web WritableStream
|
|
93
|
+
*/
|
|
94
|
+
export function convertWebWritableToNodeWritable(webWritable: WritableStream<Uint8Array>): plugins.stream.Writable {
|
|
95
|
+
const writer = webWritable.getWriter();
|
|
96
|
+
|
|
97
|
+
return new plugins.stream.Writable({
|
|
98
|
+
async write(chunk, encoding, callback) {
|
|
99
|
+
try {
|
|
100
|
+
await writer.write(new Uint8Array(chunk));
|
|
101
|
+
callback();
|
|
102
|
+
} catch (err) {
|
|
103
|
+
callback(err);
|
|
104
|
+
}
|
|
105
|
+
},
|
|
106
|
+
final(callback) {
|
|
107
|
+
writer.close().then(() => callback()).catch(callback);
|
|
108
|
+
},
|
|
109
|
+
destroy(err, callback) {
|
|
110
|
+
writer.abort(err).then(() => callback(err)).catch(callback);
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
/**
|
|
116
|
+
* Converts a Node.js Writable stream to a Web WritableStream.
|
|
117
|
+
*
|
|
118
|
+
* @param nodeWritable - The Node.js Writable stream to convert
|
|
119
|
+
* @returns A Web WritableStream that writes data to the Node.js Writable stream
|
|
120
|
+
*/
|
|
121
|
+
export function convertNodeWritableToWebWritable(nodeWritable: plugins.stream.Writable): WritableStream<Uint8Array> {
|
|
122
|
+
return new WritableStream({
|
|
123
|
+
write(chunk) {
|
|
124
|
+
return new Promise((resolve, reject) => {
|
|
125
|
+
nodeWritable.write(Buffer.from(chunk), (err) => {
|
|
126
|
+
if (err) {
|
|
127
|
+
reject(err);
|
|
128
|
+
} else {
|
|
129
|
+
resolve();
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
});
|
|
133
|
+
},
|
|
134
|
+
close() {
|
|
135
|
+
return new Promise((resolve, reject) => {
|
|
136
|
+
nodeWritable.end((err) => {
|
|
137
|
+
if (err) {
|
|
138
|
+
reject(err);
|
|
139
|
+
} else {
|
|
140
|
+
resolve();
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
});
|
|
144
|
+
},
|
|
145
|
+
abort(reason) {
|
|
146
|
+
return new Promise((resolve, reject) => {
|
|
147
|
+
nodeWritable.destroy(reason);
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
});
|
|
34
151
|
}
|
|
@@ -3,6 +3,6 @@
|
|
|
3
3
|
*/
|
|
4
4
|
export const commitinfo = {
|
|
5
5
|
name: '@push.rocks/smartstream',
|
|
6
|
-
version: '3.
|
|
6
|
+
version: '3.3.0',
|
|
7
7
|
description: 'A library to simplify the creation and manipulation of Node.js streams, providing utilities for handling transform, duplex, and readable/writable streams effectively in TypeScript.'
|
|
8
8
|
}
|
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
|