@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.
Files changed (34) hide show
  1. package/dist_ts/00_commitinfo_data.js +1 -1
  2. package/dist_ts/smartstream.classes.smartduplex.d.ts +10 -6
  3. package/dist_ts/smartstream.classes.smartduplex.js +182 -72
  4. package/dist_ts/smartstream.classes.streamintake.d.ts +0 -1
  5. package/dist_ts/smartstream.classes.streamintake.js +6 -3
  6. package/dist_ts/smartstream.classes.streamwrapper.js +11 -12
  7. package/dist_ts/smartstream.functions.d.ts +0 -1
  8. package/dist_ts/smartstream.nodewebhelpers.d.ts +2 -3
  9. package/dist_ts/smartstream.nodewebhelpers.js +97 -36
  10. package/dist_ts/smartstream.plugins.d.ts +0 -2
  11. package/dist_ts_web/00_commitinfo_data.js +1 -1
  12. package/dist_ts_web/classes.webduplexstream.js +20 -15
  13. package/dist_ts_web/plugins.js +1 -1
  14. package/npmextra.json +12 -6
  15. package/package.json +21 -17
  16. package/readme.md +335 -238
  17. package/ts/00_commitinfo_data.ts +1 -1
  18. package/ts/smartstream.classes.smartduplex.ts +211 -78
  19. package/ts/smartstream.classes.streamintake.ts +5 -2
  20. package/ts/smartstream.classes.streamwrapper.ts +11 -12
  21. package/ts/smartstream.nodewebhelpers.ts +105 -37
  22. package/ts/tspublish.json +3 -0
  23. package/ts_web/00_commitinfo_data.ts +1 -1
  24. package/ts_web/classes.webduplexstream.ts +20 -13
  25. package/ts_web/plugins.ts +3 -3
  26. package/ts_web/tspublish.json +3 -0
  27. package/dist_ts/smartstream.classes.passthrough.d.ts +0 -8
  28. package/dist_ts/smartstream.classes.passthrough.js +0 -18
  29. package/dist_ts/smartstream.classes.smartstream.d.ts +0 -12
  30. package/dist_ts/smartstream.classes.smartstream.js +0 -48
  31. package/dist_ts/smartstream.duplex.d.ts +0 -23
  32. package/dist_ts/smartstream.duplex.js +0 -48
  33. package/dist_ts_web/convert.d.ts +0 -18
  34. 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: () => writer.close(),
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
- writer.abort(err);
116
- } finally {
117
- writer.releaseLock();
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
  })
@@ -0,0 +1,3 @@
1
+ {
2
+ "order": 0
3
+ }
@@ -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==
@@ -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
- };
@@ -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