node-av 1.0.3 → 1.2.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 (162) hide show
  1. package/README.md +56 -41
  2. package/dist/api/bitstream-filter.d.ts +180 -123
  3. package/dist/api/bitstream-filter.js +182 -126
  4. package/dist/api/bitstream-filter.js.map +1 -1
  5. package/dist/api/decoder.d.ts +286 -130
  6. package/dist/api/decoder.js +321 -159
  7. package/dist/api/decoder.js.map +1 -1
  8. package/dist/api/encoder.d.ts +254 -158
  9. package/dist/api/encoder.js +326 -298
  10. package/dist/api/encoder.js.map +1 -1
  11. package/dist/api/filter-presets.d.ts +912 -0
  12. package/dist/api/filter-presets.js +1407 -0
  13. package/dist/api/filter-presets.js.map +1 -0
  14. package/dist/api/filter.d.ts +280 -284
  15. package/dist/api/filter.js +435 -509
  16. package/dist/api/filter.js.map +1 -1
  17. package/dist/api/hardware.d.ts +226 -159
  18. package/dist/api/hardware.js +405 -287
  19. package/dist/api/hardware.js.map +1 -1
  20. package/dist/api/index.d.ts +3 -2
  21. package/dist/api/index.js +1 -0
  22. package/dist/api/index.js.map +1 -1
  23. package/dist/api/io-stream.d.ts +65 -61
  24. package/dist/api/io-stream.js +45 -47
  25. package/dist/api/io-stream.js.map +1 -1
  26. package/dist/api/media-input.d.ts +244 -141
  27. package/dist/api/media-input.js +207 -104
  28. package/dist/api/media-input.js.map +1 -1
  29. package/dist/api/media-output.d.ts +206 -128
  30. package/dist/api/media-output.js +212 -129
  31. package/dist/api/media-output.js.map +1 -1
  32. package/dist/api/pipeline.d.ts +168 -38
  33. package/dist/api/pipeline.js +238 -14
  34. package/dist/api/pipeline.js.map +1 -1
  35. package/dist/api/types.d.ts +22 -182
  36. package/dist/api/utilities/audio-sample.d.ts +1 -1
  37. package/dist/api/utilities/image.d.ts +1 -1
  38. package/dist/api/utilities/media-type.d.ts +1 -1
  39. package/dist/api/utilities/pixel-format.d.ts +1 -1
  40. package/dist/api/utilities/sample-format.d.ts +1 -1
  41. package/dist/api/utilities/timestamp.d.ts +1 -1
  42. package/dist/api/utils.d.ts +1 -2
  43. package/dist/api/utils.js +9 -0
  44. package/dist/api/utils.js.map +1 -1
  45. package/dist/{lib → constants}/channel-layouts.d.ts +1 -1
  46. package/dist/constants/channel-layouts.js.map +1 -0
  47. package/dist/{lib → constants}/constants.d.ts +19 -4
  48. package/dist/{lib → constants}/constants.js +15 -1
  49. package/dist/constants/constants.js.map +1 -0
  50. package/dist/constants/decoders.d.ts +609 -0
  51. package/dist/constants/decoders.js +617 -0
  52. package/dist/constants/decoders.js.map +1 -0
  53. package/dist/constants/encoders.d.ts +285 -0
  54. package/dist/constants/encoders.js +298 -0
  55. package/dist/constants/encoders.js.map +1 -0
  56. package/dist/constants/index.d.ts +4 -0
  57. package/dist/constants/index.js +5 -0
  58. package/dist/constants/index.js.map +1 -0
  59. package/dist/index.d.ts +1 -0
  60. package/dist/index.js +2 -0
  61. package/dist/index.js.map +1 -1
  62. package/dist/lib/audio-fifo.d.ts +128 -171
  63. package/dist/lib/audio-fifo.js +130 -173
  64. package/dist/lib/audio-fifo.js.map +1 -1
  65. package/dist/lib/binding.d.ts +7 -5
  66. package/dist/lib/binding.js +5 -0
  67. package/dist/lib/binding.js.map +1 -1
  68. package/dist/lib/bitstream-filter-context.d.ts +139 -184
  69. package/dist/lib/bitstream-filter-context.js +139 -188
  70. package/dist/lib/bitstream-filter-context.js.map +1 -1
  71. package/dist/lib/bitstream-filter.d.ts +69 -55
  72. package/dist/lib/bitstream-filter.js +68 -54
  73. package/dist/lib/bitstream-filter.js.map +1 -1
  74. package/dist/lib/codec-context.d.ts +317 -381
  75. package/dist/lib/codec-context.js +316 -381
  76. package/dist/lib/codec-context.js.map +1 -1
  77. package/dist/lib/codec-parameters.d.ts +161 -171
  78. package/dist/lib/codec-parameters.js +162 -172
  79. package/dist/lib/codec-parameters.js.map +1 -1
  80. package/dist/lib/codec-parser.d.ts +92 -105
  81. package/dist/lib/codec-parser.js +92 -103
  82. package/dist/lib/codec-parser.js.map +1 -1
  83. package/dist/lib/codec.d.ts +328 -217
  84. package/dist/lib/codec.js +392 -218
  85. package/dist/lib/codec.js.map +1 -1
  86. package/dist/lib/dictionary.d.ts +150 -204
  87. package/dist/lib/dictionary.js +159 -213
  88. package/dist/lib/dictionary.js.map +1 -1
  89. package/dist/lib/error.d.ts +97 -131
  90. package/dist/lib/error.js +98 -128
  91. package/dist/lib/error.js.map +1 -1
  92. package/dist/lib/filter-context.d.ts +317 -194
  93. package/dist/lib/filter-context.js +335 -200
  94. package/dist/lib/filter-context.js.map +1 -1
  95. package/dist/lib/filter-graph.d.ts +252 -293
  96. package/dist/lib/filter-graph.js +253 -294
  97. package/dist/lib/filter-graph.js.map +1 -1
  98. package/dist/lib/filter-inout.d.ts +87 -95
  99. package/dist/lib/filter-inout.js +87 -95
  100. package/dist/lib/filter-inout.js.map +1 -1
  101. package/dist/lib/filter.d.ts +93 -111
  102. package/dist/lib/filter.js +94 -112
  103. package/dist/lib/filter.js.map +1 -1
  104. package/dist/lib/format-context.d.ts +321 -429
  105. package/dist/lib/format-context.js +314 -386
  106. package/dist/lib/format-context.js.map +1 -1
  107. package/dist/lib/frame.d.ts +263 -406
  108. package/dist/lib/frame.js +263 -408
  109. package/dist/lib/frame.js.map +1 -1
  110. package/dist/lib/hardware-device-context.d.ts +150 -204
  111. package/dist/lib/hardware-device-context.js +149 -203
  112. package/dist/lib/hardware-device-context.js.map +1 -1
  113. package/dist/lib/hardware-frames-context.d.ts +171 -181
  114. package/dist/lib/hardware-frames-context.js +171 -181
  115. package/dist/lib/hardware-frames-context.js.map +1 -1
  116. package/dist/lib/index.d.ts +2 -3
  117. package/dist/lib/index.js +2 -5
  118. package/dist/lib/index.js.map +1 -1
  119. package/dist/lib/input-format.d.ts +90 -118
  120. package/dist/lib/input-format.js +89 -117
  121. package/dist/lib/input-format.js.map +1 -1
  122. package/dist/lib/io-context.d.ts +210 -242
  123. package/dist/lib/io-context.js +221 -253
  124. package/dist/lib/io-context.js.map +1 -1
  125. package/dist/lib/log.d.ts +86 -120
  126. package/dist/lib/log.js +85 -122
  127. package/dist/lib/log.js.map +1 -1
  128. package/dist/lib/native-types.d.ts +127 -112
  129. package/dist/lib/native-types.js +9 -0
  130. package/dist/lib/native-types.js.map +1 -1
  131. package/dist/lib/option.d.ts +285 -242
  132. package/dist/lib/option.js +310 -250
  133. package/dist/lib/option.js.map +1 -1
  134. package/dist/lib/output-format.d.ts +78 -102
  135. package/dist/lib/output-format.js +77 -101
  136. package/dist/lib/output-format.js.map +1 -1
  137. package/dist/lib/packet.d.ts +173 -241
  138. package/dist/lib/packet.js +172 -241
  139. package/dist/lib/packet.js.map +1 -1
  140. package/dist/lib/rational.d.ts +0 -2
  141. package/dist/lib/rational.js +0 -2
  142. package/dist/lib/rational.js.map +1 -1
  143. package/dist/lib/software-resample-context.d.ts +242 -326
  144. package/dist/lib/software-resample-context.js +242 -326
  145. package/dist/lib/software-resample-context.js.map +1 -1
  146. package/dist/lib/software-scale-context.d.ts +130 -174
  147. package/dist/lib/software-scale-context.js +132 -176
  148. package/dist/lib/software-scale-context.js.map +1 -1
  149. package/dist/lib/stream.d.ts +88 -198
  150. package/dist/lib/stream.js +87 -197
  151. package/dist/lib/stream.js.map +1 -1
  152. package/dist/lib/types.d.ts +1 -1
  153. package/dist/lib/utilities.d.ts +372 -181
  154. package/dist/lib/utilities.js +373 -182
  155. package/dist/lib/utilities.js.map +1 -1
  156. package/install/check.js +0 -1
  157. package/package.json +32 -24
  158. package/release_notes.md +43 -13
  159. package/CHANGELOG.md +0 -8
  160. package/dist/lib/channel-layouts.js.map +0 -1
  161. package/dist/lib/constants.js.map +0 -1
  162. /package/dist/{lib → constants}/channel-layouts.js +0 -0
@@ -1,11 +1,12 @@
1
1
  import type { NativeFilter, NativeWrapper } from './native-types.js';
2
2
  import type { FilterPad } from './types.js';
3
3
  /**
4
- * Filter definition for media processing.
4
+ * Filter descriptor for video/audio processing.
5
5
  *
6
- * Represents a static filter definition (immutable template).
7
- * Defines the filter's capabilities, inputs, outputs, and properties.
8
- * Actual filtering operations are performed through FilterContext instances.
6
+ * Represents a filter that can be used in filter graphs for processing
7
+ * audio and video frames. Filters can be sources (no inputs), sinks (no outputs),
8
+ * or processors (with both inputs and outputs). Each filter has specific
9
+ * capabilities and pad configurations.
9
10
  *
10
11
  * Direct mapping to FFmpeg's AVFilter.
11
12
  *
@@ -13,219 +14,200 @@ import type { FilterPad } from './types.js';
13
14
  * ```typescript
14
15
  * import { Filter } from 'node-av';
15
16
  *
16
- * // Find a filter by name
17
+ * // Get a specific filter
17
18
  * const scaleFilter = Filter.getByName('scale');
18
- * if (!scaleFilter) throw new Error('Scale filter not found');
19
+ * if (scaleFilter) {
20
+ * console.log(`Filter: ${scaleFilter.name}`);
21
+ * console.log(`Description: ${scaleFilter.description}`);
22
+ * console.log(`Inputs: ${scaleFilter.inputs.length}`);
23
+ * console.log(`Outputs: ${scaleFilter.outputs.length}`);
24
+ * }
19
25
  *
20
- * // Check filter properties
21
- * console.log(`Filter: ${scaleFilter.name}`);
22
- * console.log(`Description: ${scaleFilter.description}`);
23
- * console.log(`Inputs: ${scaleFilter.inputs.length}`);
24
- * console.log(`Outputs: ${scaleFilter.outputs.length}`);
25
- *
26
- * // Get all video filters
27
- * const allFilters = Filter.getList();
28
- * const videoFilters = allFilters.filter(f => f.isVideo());
26
+ * // List all video filters
27
+ * const filters = Filter.getList();
28
+ * const videoFilters = filters.filter(f => f.isVideo());
29
29
  * console.log(`Found ${videoFilters.length} video filters`);
30
30
  * ```
31
+ *
32
+ * @see [AVFilter](https://ffmpeg.org/doxygen/trunk/structAVFilter.html) - FFmpeg Doxygen
33
+ * @see {@link FilterContext} For using filters in graphs
34
+ * @see {@link FilterGraph} For building filter pipelines
31
35
  */
32
36
  export declare class Filter implements NativeWrapper<NativeFilter> {
33
37
  private native;
34
38
  /**
35
- * Constructor is internal - use static factory methods.
36
- *
37
- * Filters are global immutable objects managed by FFmpeg.
38
- * Use the static factory methods to obtain filter instances.
39
- *
39
+ * @param native - The native filter instance
40
40
  * @internal
41
- *
42
- * @param native - Native AVFilter to wrap
43
- *
44
- * @example
45
- * ```typescript
46
- * import { Filter } from 'node-av';
47
- *
48
- * // Don't use constructor directly
49
- * // const filter = new Filter(); // Wrong
50
- *
51
- * // Use static factory methods instead
52
- * const filter = Filter.getByName('scale'); // Correct
53
- * const filters = Filter.getList(); // Correct
54
- * ```
55
41
  */
56
42
  constructor(native: NativeFilter);
57
43
  /**
58
- * Find a filter by name.
44
+ * Get a filter by name.
59
45
  *
60
- * Searches for a filter by its exact name.
61
- * Returns the filter definition if found.
46
+ * Retrieves a specific filter descriptor by its name.
47
+ * Common filter names include 'scale', 'crop', 'overlay', 'aformat', etc.
62
48
  *
63
- * Direct mapping to avfilter_get_by_name()
49
+ * Direct mapping to avfilter_get_by_name().
64
50
  *
65
- * @param name - Filter name (e.g., "scale", "overlay", "volume")
66
- *
67
- * @returns The filter if found, null otherwise
51
+ * @param name - Name of the filter
52
+ * @returns Filter instance if found, null otherwise
68
53
  *
69
54
  * @example
70
55
  * ```typescript
71
- * import { Filter } from 'node-av';
72
- *
73
- * // Find the scale filter
74
- * const scaleFilter = Filter.getByName('scale');
75
- * if (!scaleFilter) {
56
+ * // Get video scaling filter
57
+ * const scale = Filter.getByName('scale');
58
+ * if (!scale) {
76
59
  * throw new Error('Scale filter not available');
77
60
  * }
78
61
  *
79
- * // Find audio volume filter
80
- * const volumeFilter = Filter.getByName('volume');
81
- * if (!volumeFilter) {
82
- * throw new Error('Volume filter not available');
83
- * }
62
+ * // Get audio format filter
63
+ * const aformat = Filter.getByName('aformat');
84
64
  * ```
85
65
  *
86
- * @see {@link getList} To get all available filters
66
+ * @see {@link getList} To list all available filters
87
67
  */
88
68
  static getByName(name: string): Filter | null;
89
69
  /**
90
70
  * Get list of all available filters.
91
71
  *
92
- * Returns all registered filters in the system.
93
- * Internally uses avfilter_iterate() to collect all filters.
94
- *
95
- * Direct mapping to avfilter_iterate()
72
+ * Returns an array of all registered filters in FFmpeg.
73
+ * Useful for discovering available filters or building filter lists.
96
74
  *
97
- * @returns Array of all registered filters
75
+ * @returns Array of all available filters
98
76
  *
99
77
  * @example
100
78
  * ```typescript
101
- * import { Filter } from 'node-av';
102
- *
103
- * // Get all video filters
104
- * const allFilters = Filter.getList();
105
- * const videoFilters = allFilters.filter(f => f.isVideo());
106
- * console.log(`Found ${videoFilters.length} video filters`);
107
- *
108
- * // Find all source filters
109
- * const sourceFilters = allFilters.filter(f => f.isSource());
110
- * sourceFilters.forEach(f => {
111
- * console.log(`Source filter: ${f.name}`);
112
- * });
79
+ * // List all filters
80
+ * const filters = Filter.getList();
81
+ * console.log(`Total filters: ${filters.length}`);
82
+ *
83
+ * // Find all source filters (generators)
84
+ * const sources = filters.filter(f => f.isSource());
85
+ * console.log(`Source filters: ${sources.length}`);
86
+ *
87
+ * // Find all sink filters (outputs)
88
+ * const sinks = filters.filter(f => f.isSink());
89
+ * console.log(`Sink filters: ${sinks.length}`);
113
90
  * ```
114
91
  *
115
- * @see {@link getByName} To find a specific filter
92
+ * @see {@link getByName} To get a specific filter
116
93
  */
117
94
  static getList(): Filter[];
118
95
  /**
119
96
  * Filter name.
120
97
  *
121
- * Direct mapping to AVFilter->name
98
+ * Unique identifier for the filter (e.g., 'scale', 'overlay').
122
99
  *
123
- * The short name of the filter (e.g., "scale", "overlay", "volume").
100
+ * Direct mapping to AVFilter->name.
124
101
  */
125
102
  get name(): string | null;
126
103
  /**
127
104
  * Filter description.
128
105
  *
129
- * Direct mapping to AVFilter->description
130
- *
131
106
  * Human-readable description of what the filter does.
107
+ *
108
+ * Direct mapping to AVFilter->description.
132
109
  */
133
110
  get description(): string | null;
134
111
  /**
135
112
  * Input pads.
136
113
  *
137
- * Direct mapping to AVFilter->inputs
138
- *
139
- * Array of input connection points for the filter.
114
+ * Array of input pad descriptors.
140
115
  * Empty array for source filters.
116
+ *
117
+ * Direct mapping to AVFilter->inputs.
141
118
  */
142
119
  get inputs(): FilterPad[];
143
120
  /**
144
121
  * Output pads.
145
122
  *
146
- * Direct mapping to AVFilter->outputs
147
- *
148
- * Array of output connection points for the filter.
123
+ * Array of output pad descriptors.
149
124
  * Empty array for sink filters.
125
+ *
126
+ * Direct mapping to AVFilter->outputs.
150
127
  */
151
128
  get outputs(): FilterPad[];
152
129
  /**
153
130
  * Filter flags.
154
131
  *
155
- * Direct mapping to AVFilter->flags
132
+ * Combination of AVFILTER_FLAG_* values indicating filter capabilities.
156
133
  *
157
- * Bitwise flags indicating filter capabilities (AVFILTER_FLAG_*).
134
+ * Direct mapping to AVFilter->flags.
158
135
  */
159
136
  get flags(): number;
160
137
  /**
161
- * Check if this is a source filter.
138
+ * Check if filter is a source.
162
139
  *
163
- * Source filters have no inputs and generate data.
140
+ * Source filters generate frames without input
141
+ * (e.g., 'testsrc', 'color', 'anullsrc').
164
142
  *
165
- * @returns true if the filter has no input pads, false otherwise
143
+ * @returns True if filter has no inputs
166
144
  *
167
145
  * @example
168
146
  * ```typescript
169
- * const filter = Filter.getByName('buffer');
170
- * if (filter && filter.isSource()) {
147
+ * const filter = Filter.getByName('testsrc');
148
+ * if (filter?.isSource()) {
171
149
  * console.log('This is a source filter');
172
150
  * }
173
151
  * ```
152
+ *
153
+ * @see {@link isSink} To check for sink filters
174
154
  */
175
155
  isSource(): boolean;
176
156
  /**
177
- * Check if this is a sink filter.
157
+ * Check if filter is a sink.
178
158
  *
179
- * Sink filters have no outputs and consume data.
159
+ * Sink filters consume frames without output
160
+ * (e.g., 'nullsink', 'buffersink').
180
161
  *
181
- * @returns true if the filter has no output pads, false otherwise
162
+ * @returns True if filter has no outputs
182
163
  *
183
164
  * @example
184
165
  * ```typescript
185
- * const filter = Filter.getByName('buffersink');
186
- * if (filter && filter.isSink()) {
166
+ * const filter = Filter.getByName('nullsink');
167
+ * if (filter?.isSink()) {
187
168
  * console.log('This is a sink filter');
188
169
  * }
189
170
  * ```
171
+ *
172
+ * @see {@link isSource} To check for source filters
190
173
  */
191
174
  isSink(): boolean;
192
175
  /**
193
- * Check if this is a video filter.
176
+ * Check if filter processes video.
194
177
  *
195
- * Checks if any input or output pad handles video data.
196
- *
197
- * @returns true if the filter processes video data, false otherwise
178
+ * @returns True if filter has video inputs or outputs
198
179
  *
199
180
  * @example
200
181
  * ```typescript
201
- * const filter = Filter.getByName('scale');
202
- * if (filter && filter.isVideo()) {
203
- * console.log('This filter processes video');
204
- * }
182
+ * const filters = Filter.getList();
183
+ * const videoFilters = filters.filter(f => f.isVideo());
184
+ * console.log(`Video filters: ${videoFilters.length}`);
205
185
  * ```
186
+ *
187
+ * @see {@link isAudio} To check for audio filters
206
188
  */
207
189
  isVideo(): boolean;
208
190
  /**
209
- * Check if this is an audio filter.
210
- *
211
- * Checks if any input or output pad handles audio data.
191
+ * Check if filter processes audio.
212
192
  *
213
- * @returns true if the filter processes audio data, false otherwise
193
+ * @returns True if filter has audio inputs or outputs
214
194
  *
215
195
  * @example
216
196
  * ```typescript
217
- * const filter = Filter.getByName('volume');
218
- * if (filter && filter.isAudio()) {
219
- * console.log('This filter processes audio');
220
- * }
197
+ * const filters = Filter.getList();
198
+ * const audioFilters = filters.filter(f => f.isAudio());
199
+ * console.log(`Audio filters: ${audioFilters.length}`);
221
200
  * ```
201
+ *
202
+ * @see {@link isVideo} To check for video filters
222
203
  */
223
204
  isAudio(): boolean;
224
205
  /**
225
- * Get the native FFmpeg AVFilter pointer.
206
+ * Get the underlying native Filter object.
226
207
  *
227
- * @internal For use by other wrapper classes
228
- * @returns The underlying native filter object
208
+ * @returns The native Filter binding object
209
+ *
210
+ * @internal
229
211
  */
230
212
  getNative(): NativeFilter;
231
213
  }