node-av 3.1.3 → 5.0.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/README.md +88 -52
- package/binding.gyp +23 -11
- package/dist/api/audio-frame-buffer.d.ts +201 -0
- package/dist/api/audio-frame-buffer.js +275 -0
- package/dist/api/audio-frame-buffer.js.map +1 -0
- package/dist/api/bitstream-filter.d.ts +320 -78
- package/dist/api/bitstream-filter.js +684 -151
- package/dist/api/bitstream-filter.js.map +1 -1
- package/dist/api/constants.d.ts +44 -0
- package/dist/api/constants.js +45 -0
- package/dist/api/constants.js.map +1 -0
- package/dist/api/data/test_av1.ivf +0 -0
- package/dist/api/data/test_mjpeg.mjpeg +0 -0
- package/dist/api/data/test_vp8.ivf +0 -0
- package/dist/api/data/test_vp9.ivf +0 -0
- package/dist/api/decoder.d.ts +454 -77
- package/dist/api/decoder.js +1081 -271
- package/dist/api/decoder.js.map +1 -1
- package/dist/api/{media-input.d.ts → demuxer.d.ts} +295 -45
- package/dist/api/demuxer.js +1965 -0
- package/dist/api/demuxer.js.map +1 -0
- package/dist/api/encoder.d.ts +423 -132
- package/dist/api/encoder.js +1089 -240
- package/dist/api/encoder.js.map +1 -1
- package/dist/api/filter-complex.d.ts +769 -0
- package/dist/api/filter-complex.js +1596 -0
- package/dist/api/filter-complex.js.map +1 -0
- package/dist/api/filter-presets.d.ts +80 -5
- package/dist/api/filter-presets.js +117 -7
- package/dist/api/filter-presets.js.map +1 -1
- package/dist/api/filter.d.ts +561 -125
- package/dist/api/filter.js +1083 -274
- package/dist/api/filter.js.map +1 -1
- package/dist/api/{fmp4.d.ts → fmp4-stream.d.ts} +141 -140
- package/dist/api/fmp4-stream.js +539 -0
- package/dist/api/fmp4-stream.js.map +1 -0
- package/dist/api/hardware.d.ts +58 -6
- package/dist/api/hardware.js +127 -11
- package/dist/api/hardware.js.map +1 -1
- package/dist/api/index.d.ts +8 -4
- package/dist/api/index.js +17 -8
- package/dist/api/index.js.map +1 -1
- package/dist/api/io-stream.d.ts +6 -6
- package/dist/api/io-stream.js +5 -4
- package/dist/api/io-stream.js.map +1 -1
- package/dist/api/{media-output.d.ts → muxer.d.ts} +280 -66
- package/dist/api/muxer.js +1934 -0
- package/dist/api/muxer.js.map +1 -0
- package/dist/api/pipeline.d.ts +77 -29
- package/dist/api/pipeline.js +449 -439
- package/dist/api/pipeline.js.map +1 -1
- package/dist/api/rtp-stream.d.ts +312 -0
- package/dist/api/rtp-stream.js +630 -0
- package/dist/api/rtp-stream.js.map +1 -0
- package/dist/api/types.d.ts +533 -56
- package/dist/api/utilities/async-queue.d.ts +91 -0
- package/dist/api/utilities/async-queue.js +162 -0
- package/dist/api/utilities/async-queue.js.map +1 -0
- package/dist/api/utilities/audio-sample.d.ts +11 -1
- package/dist/api/utilities/audio-sample.js +10 -0
- package/dist/api/utilities/audio-sample.js.map +1 -1
- package/dist/api/utilities/channel-layout.d.ts +1 -0
- package/dist/api/utilities/channel-layout.js +1 -0
- package/dist/api/utilities/channel-layout.js.map +1 -1
- package/dist/api/utilities/image.d.ts +39 -1
- package/dist/api/utilities/image.js +38 -0
- package/dist/api/utilities/image.js.map +1 -1
- package/dist/api/utilities/index.d.ts +3 -0
- package/dist/api/utilities/index.js +6 -0
- package/dist/api/utilities/index.js.map +1 -1
- package/dist/api/utilities/media-type.d.ts +2 -1
- package/dist/api/utilities/media-type.js +1 -0
- package/dist/api/utilities/media-type.js.map +1 -1
- package/dist/api/utilities/pixel-format.d.ts +4 -1
- package/dist/api/utilities/pixel-format.js +3 -0
- package/dist/api/utilities/pixel-format.js.map +1 -1
- package/dist/api/utilities/sample-format.d.ts +6 -1
- package/dist/api/utilities/sample-format.js +5 -0
- package/dist/api/utilities/sample-format.js.map +1 -1
- package/dist/api/utilities/scheduler.d.ts +138 -0
- package/dist/api/utilities/scheduler.js +98 -0
- package/dist/api/utilities/scheduler.js.map +1 -0
- package/dist/api/utilities/streaming.d.ts +105 -15
- package/dist/api/utilities/streaming.js +201 -12
- package/dist/api/utilities/streaming.js.map +1 -1
- package/dist/api/utilities/timestamp.d.ts +15 -1
- package/dist/api/utilities/timestamp.js +14 -0
- package/dist/api/utilities/timestamp.js.map +1 -1
- package/dist/api/utilities/whisper-model.d.ts +310 -0
- package/dist/api/utilities/whisper-model.js +528 -0
- package/dist/api/utilities/whisper-model.js.map +1 -0
- package/dist/api/webrtc-stream.d.ts +288 -0
- package/dist/api/webrtc-stream.js +440 -0
- package/dist/api/webrtc-stream.js.map +1 -0
- package/dist/api/whisper.d.ts +324 -0
- package/dist/api/whisper.js +362 -0
- package/dist/api/whisper.js.map +1 -0
- package/dist/constants/constants.d.ts +54 -2
- package/dist/constants/constants.js +48 -1
- package/dist/constants/constants.js.map +1 -1
- package/dist/constants/encoders.d.ts +2 -1
- package/dist/constants/encoders.js +4 -3
- package/dist/constants/encoders.js.map +1 -1
- package/dist/constants/hardware.d.ts +26 -0
- package/dist/constants/hardware.js +27 -0
- package/dist/constants/hardware.js.map +1 -0
- package/dist/constants/index.d.ts +1 -0
- package/dist/constants/index.js +1 -0
- package/dist/constants/index.js.map +1 -1
- package/dist/ffmpeg/index.d.ts +3 -3
- package/dist/ffmpeg/index.js +3 -3
- package/dist/ffmpeg/utils.d.ts +27 -0
- package/dist/ffmpeg/utils.js +28 -16
- package/dist/ffmpeg/utils.js.map +1 -1
- package/dist/lib/binding.d.ts +22 -11
- package/dist/lib/binding.js.map +1 -1
- package/dist/lib/codec-context.d.ts +87 -0
- package/dist/lib/codec-context.js +125 -4
- package/dist/lib/codec-context.js.map +1 -1
- package/dist/lib/codec-parameters.d.ts +229 -1
- package/dist/lib/codec-parameters.js +264 -0
- package/dist/lib/codec-parameters.js.map +1 -1
- package/dist/lib/codec-parser.d.ts +23 -0
- package/dist/lib/codec-parser.js +25 -0
- package/dist/lib/codec-parser.js.map +1 -1
- package/dist/lib/codec.d.ts +26 -4
- package/dist/lib/codec.js +35 -0
- package/dist/lib/codec.js.map +1 -1
- package/dist/lib/dictionary.js +1 -0
- package/dist/lib/dictionary.js.map +1 -1
- package/dist/lib/error.js +1 -1
- package/dist/lib/error.js.map +1 -1
- package/dist/lib/fifo.d.ts +416 -0
- package/dist/lib/fifo.js +453 -0
- package/dist/lib/fifo.js.map +1 -0
- package/dist/lib/filter-context.d.ts +52 -11
- package/dist/lib/filter-context.js +56 -12
- package/dist/lib/filter-context.js.map +1 -1
- package/dist/lib/filter-graph.d.ts +9 -0
- package/dist/lib/filter-graph.js +13 -0
- package/dist/lib/filter-graph.js.map +1 -1
- package/dist/lib/filter.d.ts +21 -0
- package/dist/lib/filter.js +28 -0
- package/dist/lib/filter.js.map +1 -1
- package/dist/lib/format-context.d.ts +48 -14
- package/dist/lib/format-context.js +76 -7
- package/dist/lib/format-context.js.map +1 -1
- package/dist/lib/frame.d.ts +264 -1
- package/dist/lib/frame.js +351 -1
- package/dist/lib/frame.js.map +1 -1
- package/dist/lib/hardware-device-context.d.ts +3 -2
- package/dist/lib/hardware-device-context.js.map +1 -1
- package/dist/lib/index.d.ts +2 -0
- package/dist/lib/index.js +4 -0
- package/dist/lib/index.js.map +1 -1
- package/dist/lib/input-format.d.ts +21 -0
- package/dist/lib/input-format.js +42 -2
- package/dist/lib/input-format.js.map +1 -1
- package/dist/lib/native-types.d.ts +76 -27
- package/dist/lib/option.d.ts +25 -13
- package/dist/lib/option.js +28 -0
- package/dist/lib/option.js.map +1 -1
- package/dist/lib/output-format.d.ts +22 -1
- package/dist/lib/output-format.js +28 -0
- package/dist/lib/output-format.js.map +1 -1
- package/dist/lib/packet.d.ts +35 -0
- package/dist/lib/packet.js +52 -2
- package/dist/lib/packet.js.map +1 -1
- package/dist/lib/rational.d.ts +18 -0
- package/dist/lib/rational.js +19 -0
- package/dist/lib/rational.js.map +1 -1
- package/dist/lib/stream.d.ts +126 -0
- package/dist/lib/stream.js +188 -5
- package/dist/lib/stream.js.map +1 -1
- package/dist/lib/sync-queue.d.ts +179 -0
- package/dist/lib/sync-queue.js +197 -0
- package/dist/lib/sync-queue.js.map +1 -0
- package/dist/lib/types.d.ts +49 -1
- package/dist/lib/utilities.d.ts +281 -53
- package/dist/lib/utilities.js +298 -55
- package/dist/lib/utilities.js.map +1 -1
- package/install/check.js +2 -2
- package/package.json +37 -26
- package/dist/api/fmp4.js +0 -710
- package/dist/api/fmp4.js.map +0 -1
- package/dist/api/media-input.js +0 -1075
- package/dist/api/media-input.js.map +0 -1
- package/dist/api/media-output.js +0 -1040
- package/dist/api/media-output.js.map +0 -1
- package/dist/api/webrtc.d.ts +0 -664
- package/dist/api/webrtc.js +0 -1132
- package/dist/api/webrtc.js.map +0 -1
package/dist/lib/codec.d.ts
CHANGED
|
@@ -2,6 +2,7 @@ import { Rational } from './rational.js';
|
|
|
2
2
|
import type { AVCodecCap, AVCodecID, AVHWDeviceType, AVMediaType, AVPixelFormat, AVSampleFormat } from '../constants/constants.js';
|
|
3
3
|
import type { FFDecoderCodec } from '../constants/decoders.js';
|
|
4
4
|
import type { FFEncoderCodec } from '../constants/encoders.js';
|
|
5
|
+
import type { FFHWDeviceType } from '../constants/hardware.js';
|
|
5
6
|
import type { NativeCodec, NativeWrapper } from './native-types.js';
|
|
6
7
|
import type { ChannelLayout, CodecProfile } from './types.js';
|
|
7
8
|
/**
|
|
@@ -260,6 +261,27 @@ export declare class Codec implements NativeWrapper<NativeCodec> {
|
|
|
260
261
|
* Direct mapping to AVCodec->capabilities.
|
|
261
262
|
*/
|
|
262
263
|
get capabilities(): AVCodecCap;
|
|
264
|
+
/**
|
|
265
|
+
* Check if codec has specific capabilities.
|
|
266
|
+
*
|
|
267
|
+
* Tests whether all specified capabilities are present using bitwise AND.
|
|
268
|
+
*
|
|
269
|
+
* @param caps - One or more capability values to check
|
|
270
|
+
*
|
|
271
|
+
* @returns true if all specified capabilities are present, false otherwise
|
|
272
|
+
*
|
|
273
|
+
* @example
|
|
274
|
+
* ```typescript
|
|
275
|
+
* import { AV_CODEC_CAP_HARDWARE } from 'node-av/constants';
|
|
276
|
+
*
|
|
277
|
+
* if (codec.hasCapabilities(AV_CODEC_CAP_HARDWARE)) {
|
|
278
|
+
* console.log('This codec supports hardware acceleration');
|
|
279
|
+
* }
|
|
280
|
+
* ```
|
|
281
|
+
*
|
|
282
|
+
* @see {@link capabilities} For direct capabilities access
|
|
283
|
+
*/
|
|
284
|
+
hasCapabilities(...caps: AVCodecCap[]): boolean;
|
|
263
285
|
/**
|
|
264
286
|
* Maximum lowres value.
|
|
265
287
|
*
|
|
@@ -413,7 +435,7 @@ export declare class Codec implements NativeWrapper<NativeCodec> {
|
|
|
413
435
|
*
|
|
414
436
|
* @see {@link getSupportedDeviceTypes} For all supported types
|
|
415
437
|
*/
|
|
416
|
-
supportsDevice(deviceType: AVHWDeviceType): boolean;
|
|
438
|
+
supportsDevice(deviceType: AVHWDeviceType | FFHWDeviceType): boolean;
|
|
417
439
|
/**
|
|
418
440
|
* Check if decoder supports hardware acceleration.
|
|
419
441
|
*
|
|
@@ -436,7 +458,7 @@ export declare class Codec implements NativeWrapper<NativeCodec> {
|
|
|
436
458
|
* }
|
|
437
459
|
* ```
|
|
438
460
|
*/
|
|
439
|
-
isHardwareAcceleratedDecoder(deviceType?: AVHWDeviceType): boolean;
|
|
461
|
+
isHardwareAcceleratedDecoder(deviceType?: AVHWDeviceType | FFHWDeviceType): boolean;
|
|
440
462
|
/**
|
|
441
463
|
* Check if encoder supports hardware acceleration.
|
|
442
464
|
*
|
|
@@ -459,7 +481,7 @@ export declare class Codec implements NativeWrapper<NativeCodec> {
|
|
|
459
481
|
* }
|
|
460
482
|
* ```
|
|
461
483
|
*/
|
|
462
|
-
isHardwareAcceleratedEncoder(deviceType?: AVHWDeviceType): boolean;
|
|
484
|
+
isHardwareAcceleratedEncoder(deviceType?: AVHWDeviceType | FFHWDeviceType): boolean;
|
|
463
485
|
/**
|
|
464
486
|
* Get supported hardware device types.
|
|
465
487
|
*
|
|
@@ -503,7 +525,7 @@ export declare class Codec implements NativeWrapper<NativeCodec> {
|
|
|
503
525
|
* }
|
|
504
526
|
* ```
|
|
505
527
|
*/
|
|
506
|
-
getHardwareMethod(deviceType: AVHWDeviceType): number | null;
|
|
528
|
+
getHardwareMethod(deviceType: AVHWDeviceType | FFHWDeviceType): number | null;
|
|
507
529
|
/**
|
|
508
530
|
* Get hardware configuration at index.
|
|
509
531
|
*
|
package/dist/lib/codec.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { AV_CODEC_HW_CONFIG_METHOD_HW_DEVICE_CTX, AV_CODEC_HW_CONFIG_METHOD_HW_FRAMES_CTX } from '../constants/constants.js';
|
|
2
2
|
import { bindings } from './binding.js';
|
|
3
3
|
import { Rational } from './rational.js';
|
|
4
|
+
import { avGetHardwareDeviceTypeFromName } from './utilities.js';
|
|
4
5
|
/**
|
|
5
6
|
* Codec descriptor for audio/video encoding and decoding.
|
|
6
7
|
*
|
|
@@ -289,6 +290,34 @@ export class Codec {
|
|
|
289
290
|
get capabilities() {
|
|
290
291
|
return this.native.capabilities;
|
|
291
292
|
}
|
|
293
|
+
/**
|
|
294
|
+
* Check if codec has specific capabilities.
|
|
295
|
+
*
|
|
296
|
+
* Tests whether all specified capabilities are present using bitwise AND.
|
|
297
|
+
*
|
|
298
|
+
* @param caps - One or more capability values to check
|
|
299
|
+
*
|
|
300
|
+
* @returns true if all specified capabilities are present, false otherwise
|
|
301
|
+
*
|
|
302
|
+
* @example
|
|
303
|
+
* ```typescript
|
|
304
|
+
* import { AV_CODEC_CAP_HARDWARE } from 'node-av/constants';
|
|
305
|
+
*
|
|
306
|
+
* if (codec.hasCapabilities(AV_CODEC_CAP_HARDWARE)) {
|
|
307
|
+
* console.log('This codec supports hardware acceleration');
|
|
308
|
+
* }
|
|
309
|
+
* ```
|
|
310
|
+
*
|
|
311
|
+
* @see {@link capabilities} For direct capabilities access
|
|
312
|
+
*/
|
|
313
|
+
hasCapabilities(...caps) {
|
|
314
|
+
for (const cap of caps) {
|
|
315
|
+
if ((this.native.capabilities & cap) !== cap) {
|
|
316
|
+
return false;
|
|
317
|
+
}
|
|
318
|
+
}
|
|
319
|
+
return true;
|
|
320
|
+
}
|
|
292
321
|
/**
|
|
293
322
|
* Maximum lowres value.
|
|
294
323
|
*
|
|
@@ -486,6 +515,9 @@ export class Codec {
|
|
|
486
515
|
const config = this.getHwConfig(i);
|
|
487
516
|
if (!config)
|
|
488
517
|
break;
|
|
518
|
+
if (typeof deviceType === 'string') {
|
|
519
|
+
deviceType = avGetHardwareDeviceTypeFromName(deviceType);
|
|
520
|
+
}
|
|
489
521
|
// Check if this config is for the requested device type
|
|
490
522
|
if (config.deviceType === deviceType) {
|
|
491
523
|
// Check if it has any valid hardware method
|
|
@@ -616,6 +648,9 @@ export class Codec {
|
|
|
616
648
|
const config = this.getHwConfig(i);
|
|
617
649
|
if (!config)
|
|
618
650
|
break;
|
|
651
|
+
if (typeof deviceType === 'string') {
|
|
652
|
+
deviceType = avGetHardwareDeviceTypeFromName(deviceType);
|
|
653
|
+
}
|
|
619
654
|
if (config.deviceType === deviceType) {
|
|
620
655
|
return config.methods;
|
|
621
656
|
}
|
package/dist/lib/codec.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"codec.js","sourceRoot":"","sources":["../../src/lib/codec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uCAAuC,EAAE,uCAAuC,EAAE,MAAM,2BAA2B,CAAC;AAC7H,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"codec.js","sourceRoot":"","sources":["../../src/lib/codec.ts"],"names":[],"mappings":"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"}
|
package/dist/lib/dictionary.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dictionary.js","sourceRoot":"","sources":["../../src/lib/dictionary.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"dictionary.js","sourceRoot":"","sources":["../../src/lib/dictionary.ts"],"names":[],"mappings":"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"}
|
package/dist/lib/error.js
CHANGED
|
@@ -245,7 +245,7 @@ export class FFmpegError extends Error {
|
|
|
245
245
|
if (FFmpegError.isFFmpegError(code)) {
|
|
246
246
|
const error = new FFmpegError(code);
|
|
247
247
|
if (operation) {
|
|
248
|
-
error.message = `${operation}
|
|
248
|
+
error.message = `${operation}: ${error.message}`;
|
|
249
249
|
}
|
|
250
250
|
throw error;
|
|
251
251
|
}
|
package/dist/lib/error.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"error.js","sourceRoot":"","sources":["../../src/lib/error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAKxC;;;;;;;;;;;;GAYG;AACH,MAAM,CAAN,IAAY,UAiBX;AAjBD,WAAY,UAAU;IACpB,+BAAiB,CAAA;IACjB,+BAAiB,CAAA;IACjB,+BAAiB,CAAA;IACjB,yBAAW,CAAA;IACX,6BAAe,CAAA;IACf,+BAAiB,CAAA;IACjB,+BAAiB,CAAA;IACjB,+BAAiB,CAAA;IACjB,6BAAe,CAAA;IACf,+BAAiB,CAAA;IACjB,+BAAiB,CAAA;IACjB,iCAAmB,CAAA;IACnB,+BAAiB,CAAA;IACjB,6BAAe,CAAA;IACf,+BAAiB,CAAA;IACjB,+BAAiB,CAAA;AACnB,CAAC,EAjBW,UAAU,KAAV,UAAU,QAiBrB;AAED,uDAAuD;AACvD,MAAM,UAAU,GAA4B,EAAE,CAAC;AAE/C;;;;;;;;GAQG;AACH,SAAS,cAAc,CAAC,IAAgB;IACtC,IAAI,CAAC,CAAC,IAAI,IAAI,UAAU,CAAC,EAAE,CAAC;QAC1B,UAAU,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IAC3D,CAAC;IACD,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAED,gDAAgD;AAChD,8DAA8D;AAC9D,iFAAiF;AAEjF,sEAAsE;AACtE,MAAM,CAAC,MAAM,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEhE,mDAAmD;AACnD,MAAM,CAAC,MAAM,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEhE,sDAAsD;AACtD,MAAM,CAAC,MAAM,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEhE,4CAA4C;AAC5C,MAAM,CAAC,MAAM,WAAW,GAAG,cAAc,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;AAE1D,gDAAgD;AAChD,MAAM,CAAC,MAAM,aAAa,GAAG,cAAc,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;AAE9D,6DAA6D;AAC7D,MAAM,CAAC,MAAM,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEhE,+DAA+D;AAC/D,MAAM,CAAC,MAAM,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEhE,uDAAuD;AACvD,MAAM,CAAC,MAAM,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEhE,4DAA4D;AAC5D,MAAM,CAAC,MAAM,aAAa,GAAG,cAAc,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;AAE9D,iDAAiD;AACjD,MAAM,CAAC,MAAM,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEhE,oDAAoD;AACpD,MAAM,CAAC,MAAM,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEhE,sDAAsD;AACtD,MAAM,CAAC,MAAM,eAAe,GAAG,cAAc,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;AAElE,oDAAoD;AACpD,MAAM,CAAC,MAAM,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEhE,4DAA4D;AAC5D,MAAM,CAAC,MAAM,aAAa,GAAG,cAAc,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;AAE9D,yDAAyD;AACzD,MAAM,CAAC,MAAM,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEhE,sDAAsD;AACtD,MAAM,CAAC,MAAM,cAAc,GAAG,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEhE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AACH,MAAM,OAAO,WAAY,SAAQ,KAAK;IAC5B,MAAM,CAAoB;IAElC,YAAY,IAAa;QACvB,MAAM,MAAM,GAAG,IAAI,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAC9C,MAAM,OAAO,GAAG,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC;QACrE,KAAK,CAAC,OAAO,CAAC,CAAC;QAEf,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,IAAI,GAAG,aAAa,CAAC;QAE1B,oFAAoF;QACpF,IAAI,KAAK,CAAC,iBAAiB,EAAE,CAAC;YAC5B,KAAK,CAAC,iBAAiB,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;QAC7C,CAAC;IACH,CAAC;IAED;;;;;;;;;;;;;;;;OAgBG;IACH,MAAM,CAAC,QAAQ,CAAC,MAAc;QAC5B,OAAO,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IAC/C,CAAC;IAED;;;;;;;;;;;;;;;;;;;;OAoBG;IACH,MAAM,CAAC,OAAO,CAAC,SAAqB;QAClC,OAAO,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;IACpD,CAAC;IAED;;;;;;;;;;;;;;;;OAgBG;IACH,MAAM,CAAC,aAAa,CAAC,IAAY;QAC/B,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC7B,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,IAAI,GAAG,CAAC,CAAC;IAClB,CAAC;IAED;;;;;;;;;;;;;;;;OAgBG;IACH,MAAM,CAAC,QAAQ,CAAC,IAAY;QAC1B,IAAI,IAAI,IAAI,CAAC,EAAE,CAAC;YACd,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;OAuBG;IACH,MAAM,CAAC,YAAY,CAAC,IAAY,EAAE,SAAkB;QAClD,IAAI,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC;YACpC,MAAM,KAAK,GAAG,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC;YACpC,IAAI,SAAS,EAAE,CAAC;gBACb,KAAa,CAAC,OAAO,GAAG,GAAG,SAAS,
|
|
1
|
+
{"version":3,"file":"error.js","sourceRoot":"","sources":["../../src/lib/error.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,416 @@
|
|
|
1
|
+
import type { AVFifoFlag } from '../constants/index.js';
|
|
2
|
+
import type { NativeFifo, NativeWrapper } from './native-types.js';
|
|
3
|
+
/**
|
|
4
|
+
* Generic FIFO (First-In-First-Out) buffer for arbitrary data types.
|
|
5
|
+
*
|
|
6
|
+
* Provides a thread-safe buffer for generic data elements. Unlike AudioFifo which is
|
|
7
|
+
* specialized for audio samples, Fifo can handle any data type by specifying the element size.
|
|
8
|
+
* Supports automatic growth and manual size management.
|
|
9
|
+
*
|
|
10
|
+
* Direct mapping to FFmpeg's AVFifo.
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```typescript
|
|
14
|
+
* import { Fifo, FFmpegError } from 'node-av';
|
|
15
|
+
* import { AV_FIFO_FLAG_AUTO_GROW } from 'node-av/constants';
|
|
16
|
+
*
|
|
17
|
+
* // Create FIFO for 32-bit integers
|
|
18
|
+
* const fifo = new Fifo();
|
|
19
|
+
* fifo.alloc(100, 4, AV_FIFO_FLAG_AUTO_GROW);
|
|
20
|
+
* fifo.setAutoGrowLimit(1000);
|
|
21
|
+
*
|
|
22
|
+
* // Write data
|
|
23
|
+
* const data = Buffer.from([1, 2, 3, 4, 5, 6, 7, 8]);
|
|
24
|
+
* const written = await fifo.write(data, 2); // Write 2 elements (8 bytes)
|
|
25
|
+
* FFmpegError.throwIfError(written, 'write');
|
|
26
|
+
*
|
|
27
|
+
* // Read data
|
|
28
|
+
* const outBuffer = Buffer.alloc(8);
|
|
29
|
+
* const read = await fifo.read(outBuffer, 2); // Read 2 elements
|
|
30
|
+
* FFmpegError.throwIfError(read, 'read');
|
|
31
|
+
*
|
|
32
|
+
* // Cleanup
|
|
33
|
+
* fifo.free();
|
|
34
|
+
* ```
|
|
35
|
+
*
|
|
36
|
+
* @see [AVFifo](https://ffmpeg.org/doxygen/trunk/structAVFifo.html) - FFmpeg Doxygen
|
|
37
|
+
*/
|
|
38
|
+
export declare class Fifo implements Disposable, NativeWrapper<NativeFifo> {
|
|
39
|
+
private native;
|
|
40
|
+
constructor();
|
|
41
|
+
/**
|
|
42
|
+
* Number of elements currently in the FIFO.
|
|
43
|
+
*
|
|
44
|
+
* Direct mapping to av_fifo_can_read().
|
|
45
|
+
*/
|
|
46
|
+
get size(): number;
|
|
47
|
+
/**
|
|
48
|
+
* Number of elements that can be read from the FIFO.
|
|
49
|
+
*
|
|
50
|
+
* Direct mapping to av_fifo_can_read().
|
|
51
|
+
*/
|
|
52
|
+
get canRead(): number;
|
|
53
|
+
/**
|
|
54
|
+
* Number of elements that can be written without reallocation.
|
|
55
|
+
*
|
|
56
|
+
* Direct mapping to av_fifo_can_write().
|
|
57
|
+
*/
|
|
58
|
+
get canWrite(): number;
|
|
59
|
+
/**
|
|
60
|
+
* Size in bytes of a single element.
|
|
61
|
+
*
|
|
62
|
+
* Direct mapping to av_fifo_elem_size().
|
|
63
|
+
*/
|
|
64
|
+
get elemSize(): number;
|
|
65
|
+
/**
|
|
66
|
+
* Allocate an AVFifo buffer.
|
|
67
|
+
*
|
|
68
|
+
* Creates a FIFO buffer with the specified element count, size and flags.
|
|
69
|
+
* The FIFO can be configured to automatically grow when full.
|
|
70
|
+
*
|
|
71
|
+
* Direct mapping to av_fifo_alloc2().
|
|
72
|
+
*
|
|
73
|
+
* @param nbElems - Initial number of elements to allocate
|
|
74
|
+
*
|
|
75
|
+
* @param elemSize - Size in bytes of each element
|
|
76
|
+
*
|
|
77
|
+
* @param flags - Optional flags (e.g., AV_FIFO_FLAG_AUTO_GROW). Defaults to 0
|
|
78
|
+
*
|
|
79
|
+
* @throws {Error} If allocation fails (ENOMEM)
|
|
80
|
+
*
|
|
81
|
+
* @example
|
|
82
|
+
* ```typescript
|
|
83
|
+
* import { Fifo } from 'node-av';
|
|
84
|
+
* import { AV_FIFO_FLAG_AUTO_GROW } from 'node-av/constants';
|
|
85
|
+
*
|
|
86
|
+
* // Fixed size FIFO for 100 32-bit integers
|
|
87
|
+
* const fifo1 = new Fifo();
|
|
88
|
+
* fifo1.alloc(100, 4);
|
|
89
|
+
*
|
|
90
|
+
* // Auto-growing FIFO for 8-byte structures
|
|
91
|
+
* const fifo2 = new Fifo();
|
|
92
|
+
* fifo2.alloc(50, 8, AV_FIFO_FLAG_AUTO_GROW);
|
|
93
|
+
* fifo2.setAutoGrowLimit(1000); // Max 1000 elements
|
|
94
|
+
* ```
|
|
95
|
+
*
|
|
96
|
+
* @see {@link grow} To manually grow the FIFO
|
|
97
|
+
* @see {@link setAutoGrowLimit} To set auto-grow limit
|
|
98
|
+
* @see {@link free} To release the FIFO
|
|
99
|
+
*/
|
|
100
|
+
alloc(nbElems: number, elemSize: number, flags?: AVFifoFlag): void;
|
|
101
|
+
/**
|
|
102
|
+
* Free the FIFO buffer and all associated resources.
|
|
103
|
+
*
|
|
104
|
+
* After calling this, the FIFO is invalid and must be reallocated before use.
|
|
105
|
+
*
|
|
106
|
+
* Direct mapping to av_fifo_freep().
|
|
107
|
+
*
|
|
108
|
+
* @example
|
|
109
|
+
* ```typescript
|
|
110
|
+
* fifo.free();
|
|
111
|
+
* // FIFO is now invalid, must call alloc() before using again
|
|
112
|
+
* ```
|
|
113
|
+
*
|
|
114
|
+
* @see {@link Symbol.dispose} For automatic cleanup
|
|
115
|
+
* @see {@link alloc} To allocate
|
|
116
|
+
*/
|
|
117
|
+
free(): void;
|
|
118
|
+
/**
|
|
119
|
+
* Write elements to the FIFO.
|
|
120
|
+
*
|
|
121
|
+
* Writes elements to the FIFO buffer. If AV_FIFO_FLAG_AUTO_GROW was set,
|
|
122
|
+
* automatically reallocates if more space is needed (up to auto-grow limit).
|
|
123
|
+
*
|
|
124
|
+
* Direct mapping to av_fifo_write().
|
|
125
|
+
*
|
|
126
|
+
* @param buf - Data buffer containing elements to write
|
|
127
|
+
*
|
|
128
|
+
* @param nbElems - Number of elements to write
|
|
129
|
+
*
|
|
130
|
+
* @returns Number of elements written (>= 0), or negative AVERROR:
|
|
131
|
+
* - AVERROR_EINVAL: Invalid parameters
|
|
132
|
+
* - AVERROR_ENOMEM: Not enough space and auto-grow failed/disabled
|
|
133
|
+
*
|
|
134
|
+
* @example
|
|
135
|
+
* ```typescript
|
|
136
|
+
* import { FFmpegError } from 'node-av';
|
|
137
|
+
*
|
|
138
|
+
* // Write 4 32-bit integers (16 bytes)
|
|
139
|
+
* const data = Buffer.from([
|
|
140
|
+
* 0x01, 0x00, 0x00, 0x00, // 1
|
|
141
|
+
* 0x02, 0x00, 0x00, 0x00, // 2
|
|
142
|
+
* 0x03, 0x00, 0x00, 0x00, // 3
|
|
143
|
+
* 0x04, 0x00, 0x00, 0x00, // 4
|
|
144
|
+
* ]);
|
|
145
|
+
* const written = await fifo.write(data, 4);
|
|
146
|
+
* FFmpegError.throwIfError(written, 'write');
|
|
147
|
+
* console.log(`Wrote ${written} elements`);
|
|
148
|
+
* ```
|
|
149
|
+
*
|
|
150
|
+
* @see {@link read} To retrieve elements from FIFO
|
|
151
|
+
* @see {@link canWrite} To check available space
|
|
152
|
+
*/
|
|
153
|
+
write(buf: Buffer, nbElems: number): Promise<number>;
|
|
154
|
+
/**
|
|
155
|
+
* Write elements to the FIFO synchronously.
|
|
156
|
+
* Synchronous version of write.
|
|
157
|
+
*
|
|
158
|
+
* Writes elements to the FIFO buffer. Can write fewer elements than requested
|
|
159
|
+
* if space is limited and auto-grow is disabled or has reached the limit.
|
|
160
|
+
*
|
|
161
|
+
* Direct mapping to av_fifo_write().
|
|
162
|
+
*
|
|
163
|
+
* @param buf - Data buffer containing elements to write
|
|
164
|
+
*
|
|
165
|
+
* @param nbElems - Number of elements to write
|
|
166
|
+
*
|
|
167
|
+
* @returns Number of elements written (>= 0), or negative AVERROR:
|
|
168
|
+
* - AVERROR_EINVAL: Invalid parameters
|
|
169
|
+
* - AVERROR_ENOMEM: Not enough space
|
|
170
|
+
*
|
|
171
|
+
* @example
|
|
172
|
+
* ```typescript
|
|
173
|
+
* import { FFmpegError } from 'node-av';
|
|
174
|
+
*
|
|
175
|
+
* const buffer = Buffer.alloc(32); // 8 elements of 4 bytes each
|
|
176
|
+
* // Fill with data...
|
|
177
|
+
*
|
|
178
|
+
* const written = fifo.writeSync(buffer, 8);
|
|
179
|
+
* FFmpegError.throwIfError(written, 'writeSync');
|
|
180
|
+
* console.log(`Wrote ${written} elements`);
|
|
181
|
+
* ```
|
|
182
|
+
*
|
|
183
|
+
* @see {@link write} For async version
|
|
184
|
+
*/
|
|
185
|
+
writeSync(buf: Buffer, nbElems: number): number;
|
|
186
|
+
/**
|
|
187
|
+
* Read and remove elements from the FIFO.
|
|
188
|
+
*
|
|
189
|
+
* Reads up to the specified number of elements from the FIFO.
|
|
190
|
+
* The elements are removed from the FIFO after reading.
|
|
191
|
+
* Buffer must be pre-allocated with sufficient size (nbElems * elemSize).
|
|
192
|
+
*
|
|
193
|
+
* Direct mapping to av_fifo_read().
|
|
194
|
+
*
|
|
195
|
+
* @param buf - Pre-allocated buffer to read into
|
|
196
|
+
*
|
|
197
|
+
* @param nbElems - Maximum number of elements to read
|
|
198
|
+
*
|
|
199
|
+
* @returns Number of elements read (>= 0), or negative AVERROR:
|
|
200
|
+
* - AVERROR_EINVAL: Invalid parameters or insufficient buffer size
|
|
201
|
+
*
|
|
202
|
+
* @example
|
|
203
|
+
* ```typescript
|
|
204
|
+
* import { FFmpegError } from 'node-av';
|
|
205
|
+
*
|
|
206
|
+
* // Check available elements
|
|
207
|
+
* const available = fifo.canRead;
|
|
208
|
+
* if (available >= 10) {
|
|
209
|
+
* // Read 10 elements (40 bytes for 4-byte elements)
|
|
210
|
+
* const outBuffer = Buffer.alloc(40);
|
|
211
|
+
* const read = await fifo.read(outBuffer, 10);
|
|
212
|
+
* FFmpegError.throwIfError(read, 'read');
|
|
213
|
+
* console.log(`Read ${read} elements`);
|
|
214
|
+
* }
|
|
215
|
+
* ```
|
|
216
|
+
*
|
|
217
|
+
* @see {@link peek} To read without removing
|
|
218
|
+
* @see {@link canRead} To check available elements
|
|
219
|
+
*/
|
|
220
|
+
read(buf: Buffer, nbElems: number): Promise<number>;
|
|
221
|
+
/**
|
|
222
|
+
* Read and remove elements from the FIFO synchronously.
|
|
223
|
+
* Synchronous version of read.
|
|
224
|
+
*
|
|
225
|
+
* Reads up to the specified number of elements from the FIFO.
|
|
226
|
+
* The elements are removed from the FIFO after reading.
|
|
227
|
+
* Buffer must be pre-allocated with sufficient size.
|
|
228
|
+
*
|
|
229
|
+
* Direct mapping to av_fifo_read().
|
|
230
|
+
*
|
|
231
|
+
* @param buf - Pre-allocated buffer to read into
|
|
232
|
+
*
|
|
233
|
+
* @param nbElems - Maximum number of elements to read
|
|
234
|
+
*
|
|
235
|
+
* @returns Number of elements read (>= 0), or negative AVERROR:
|
|
236
|
+
* - AVERROR_EINVAL: Invalid parameters
|
|
237
|
+
*
|
|
238
|
+
* @example
|
|
239
|
+
* ```typescript
|
|
240
|
+
* import { FFmpegError } from 'node-av';
|
|
241
|
+
*
|
|
242
|
+
* // Read up to 20 elements
|
|
243
|
+
* const readBuffer = Buffer.alloc(20 * fifo.elemSize);
|
|
244
|
+
* const read = fifo.readSync(readBuffer, 20);
|
|
245
|
+
* FFmpegError.throwIfError(read, 'readSync');
|
|
246
|
+
*
|
|
247
|
+
* console.log(`Read ${read} elements from FIFO`);
|
|
248
|
+
* console.log(`FIFO now has ${fifo.canRead} elements remaining`);
|
|
249
|
+
* ```
|
|
250
|
+
*
|
|
251
|
+
* @see {@link read} For async version
|
|
252
|
+
*/
|
|
253
|
+
readSync(buf: Buffer, nbElems: number): number;
|
|
254
|
+
/**
|
|
255
|
+
* Read elements from the FIFO without removing them.
|
|
256
|
+
*
|
|
257
|
+
* Similar to read() but leaves the elements in the FIFO.
|
|
258
|
+
* Useful for inspecting upcoming data without consuming it.
|
|
259
|
+
* Optionally start reading from an offset.
|
|
260
|
+
*
|
|
261
|
+
* Direct mapping to av_fifo_peek().
|
|
262
|
+
*
|
|
263
|
+
* @param buf - Pre-allocated buffer to peek into
|
|
264
|
+
*
|
|
265
|
+
* @param nbElems - Maximum number of elements to peek
|
|
266
|
+
*
|
|
267
|
+
* @param offset - Offset in elements from start of FIFO. Defaults to 0
|
|
268
|
+
*
|
|
269
|
+
* @returns Number of elements peeked (>= 0), or negative AVERROR:
|
|
270
|
+
* - AVERROR_EINVAL: Invalid parameters or offset too large
|
|
271
|
+
*
|
|
272
|
+
* @example
|
|
273
|
+
* ```typescript
|
|
274
|
+
* import { FFmpegError } from 'node-av';
|
|
275
|
+
*
|
|
276
|
+
* // Peek at next 5 elements without removing them
|
|
277
|
+
* const peekBuffer = Buffer.alloc(5 * fifo.elemSize);
|
|
278
|
+
* const peeked = await fifo.peek(peekBuffer, 5);
|
|
279
|
+
* FFmpegError.throwIfError(peeked, 'peek');
|
|
280
|
+
*
|
|
281
|
+
* // Peek at elements starting at offset 10
|
|
282
|
+
* const peeked2 = await fifo.peek(peekBuffer, 5, 10);
|
|
283
|
+
* FFmpegError.throwIfError(peeked2, 'peek');
|
|
284
|
+
*
|
|
285
|
+
* // Elements are still in FIFO
|
|
286
|
+
* console.log(`FIFO still has ${fifo.canRead} elements`);
|
|
287
|
+
* ```
|
|
288
|
+
*
|
|
289
|
+
* @see {@link read} To read and remove elements
|
|
290
|
+
*/
|
|
291
|
+
peek(buf: Buffer, nbElems: number, offset?: number): Promise<number>;
|
|
292
|
+
/**
|
|
293
|
+
* Read elements from the FIFO without removing them synchronously.
|
|
294
|
+
* Synchronous version of peek.
|
|
295
|
+
*
|
|
296
|
+
* Similar to readSync() but leaves the elements in the FIFO.
|
|
297
|
+
* Useful for inspecting upcoming data without consuming it.
|
|
298
|
+
* Optionally start reading from an offset.
|
|
299
|
+
*
|
|
300
|
+
* Direct mapping to av_fifo_peek().
|
|
301
|
+
*
|
|
302
|
+
* @param buf - Pre-allocated buffer to peek into
|
|
303
|
+
*
|
|
304
|
+
* @param nbElems - Maximum number of elements to peek
|
|
305
|
+
*
|
|
306
|
+
* @param offset - Offset in elements from start of FIFO. Defaults to 0
|
|
307
|
+
*
|
|
308
|
+
* @returns Number of elements peeked (>= 0), or negative AVERROR:
|
|
309
|
+
* - AVERROR_EINVAL: Invalid parameters or offset too large
|
|
310
|
+
*
|
|
311
|
+
* @example
|
|
312
|
+
* ```typescript
|
|
313
|
+
* import { FFmpegError } from 'node-av';
|
|
314
|
+
*
|
|
315
|
+
* // Peek at next elements without removing them
|
|
316
|
+
* const peekBuffer = Buffer.alloc(10 * fifo.elemSize);
|
|
317
|
+
* const peeked = fifo.peekSync(peekBuffer, 10);
|
|
318
|
+
* FFmpegError.throwIfError(peeked, 'peekSync');
|
|
319
|
+
*
|
|
320
|
+
* // Elements are still in FIFO
|
|
321
|
+
* console.log(`FIFO still has ${fifo.canRead} elements`);
|
|
322
|
+
* ```
|
|
323
|
+
*
|
|
324
|
+
* @see {@link peek} For async version
|
|
325
|
+
*/
|
|
326
|
+
peekSync(buf: Buffer, nbElems: number, offset?: number): number;
|
|
327
|
+
/**
|
|
328
|
+
* Grow the FIFO buffer by the specified number of elements.
|
|
329
|
+
*
|
|
330
|
+
* Increases the allocated size of the FIFO by adding more space.
|
|
331
|
+
* Existing elements are preserved.
|
|
332
|
+
*
|
|
333
|
+
* Direct mapping to av_fifo_grow2().
|
|
334
|
+
*
|
|
335
|
+
* @param inc - Number of additional elements to allocate
|
|
336
|
+
*
|
|
337
|
+
* @returns 0 on success, negative AVERROR on error:
|
|
338
|
+
* - AVERROR_EINVAL: Invalid size
|
|
339
|
+
* - AVERROR_ENOMEM: Memory allocation failure
|
|
340
|
+
*
|
|
341
|
+
* @example
|
|
342
|
+
* ```typescript
|
|
343
|
+
* import { FFmpegError } from 'node-av';
|
|
344
|
+
*
|
|
345
|
+
* // Grow FIFO to handle more elements
|
|
346
|
+
* const ret = fifo.grow(100);
|
|
347
|
+
* FFmpegError.throwIfError(ret, 'grow');
|
|
348
|
+
* console.log(`New write capacity: ${fifo.canWrite} elements`);
|
|
349
|
+
* ```
|
|
350
|
+
*
|
|
351
|
+
* @see {@link alloc} For initial allocation
|
|
352
|
+
*/
|
|
353
|
+
grow(inc: number): number;
|
|
354
|
+
/**
|
|
355
|
+
* Remove all elements from the FIFO.
|
|
356
|
+
*
|
|
357
|
+
* Empties the FIFO buffer without deallocating it.
|
|
358
|
+
* The FIFO remains allocated and ready for new data.
|
|
359
|
+
*
|
|
360
|
+
* Direct mapping to av_fifo_reset2().
|
|
361
|
+
*
|
|
362
|
+
* @example
|
|
363
|
+
* ```typescript
|
|
364
|
+
* fifo.reset();
|
|
365
|
+
* console.log(fifo.canRead); // 0
|
|
366
|
+
* console.log(fifo.canWrite); // Original allocation size
|
|
367
|
+
* ```
|
|
368
|
+
*/
|
|
369
|
+
reset(): void;
|
|
370
|
+
/**
|
|
371
|
+
* Set the maximum number of elements for auto-grow.
|
|
372
|
+
*
|
|
373
|
+
* When AV_FIFO_FLAG_AUTO_GROW is set, the FIFO will automatically grow
|
|
374
|
+
* up to this limit when full. After reaching the limit, writes will fail.
|
|
375
|
+
*
|
|
376
|
+
* Direct mapping to av_fifo_auto_grow_limit().
|
|
377
|
+
*
|
|
378
|
+
* @param maxElems - Maximum number of elements (0 = unlimited)
|
|
379
|
+
*
|
|
380
|
+
* @example
|
|
381
|
+
* ```typescript
|
|
382
|
+
* import { AV_FIFO_FLAG_AUTO_GROW } from 'node-av/constants';
|
|
383
|
+
*
|
|
384
|
+
* const fifo = new Fifo();
|
|
385
|
+
* fifo.alloc(100, 4, AV_FIFO_FLAG_AUTO_GROW);
|
|
386
|
+
* fifo.setAutoGrowLimit(10000); // Limit to 10000 elements
|
|
387
|
+
* ```
|
|
388
|
+
*
|
|
389
|
+
* @see {@link alloc} For setting auto-grow flag
|
|
390
|
+
*/
|
|
391
|
+
setAutoGrowLimit(maxElems: number): void;
|
|
392
|
+
/**
|
|
393
|
+
* Get the underlying native Fifo object.
|
|
394
|
+
*
|
|
395
|
+
* @returns The native Fifo binding object
|
|
396
|
+
*
|
|
397
|
+
* @internal
|
|
398
|
+
*/
|
|
399
|
+
getNative(): NativeFifo;
|
|
400
|
+
/**
|
|
401
|
+
* Dispose of the FIFO buffer.
|
|
402
|
+
*
|
|
403
|
+
* Implements the Disposable interface for automatic cleanup.
|
|
404
|
+
* Equivalent to calling free().
|
|
405
|
+
*
|
|
406
|
+
* @example
|
|
407
|
+
* ```typescript
|
|
408
|
+
* {
|
|
409
|
+
* using fifo = new Fifo();
|
|
410
|
+
* fifo.alloc(100, 4);
|
|
411
|
+
* // Use fifo...
|
|
412
|
+
* } // Automatically freed when leaving scope
|
|
413
|
+
* ```
|
|
414
|
+
*/
|
|
415
|
+
[Symbol.dispose](): void;
|
|
416
|
+
}
|