UNPKG

mediabunny

Version:

Pure TypeScript media toolkit for reading, writing, and converting media files, directly in the browser.

112 lines (111 loc) 4.1 kB
/*! * Copyright (c) 2025-present, Vanilagy and contributors * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at https://mozilla.org/MPL/2.0/. */ /** * Base class for custom video decoders. To add your own custom video decoder, extend this class, implement the * abstract methods and static `supports` method, and register the decoder using `registerDecoder`. * @public */ export class CustomVideoDecoder { /** Returns true iff the decoder can decode the given codec configuration. */ // eslint-disable-next-line @typescript-eslint/no-unused-vars static supports(codec, config) { return false; } } /** * Base class for custom audio decoders. To add your own custom audio decoder, extend this class, implement the * abstract methods and static `supports` method, and register the decoder using `registerDecoder`. * @public */ export class CustomAudioDecoder { /** Returns true iff the decoder can decode the given codec configuration. */ // eslint-disable-next-line @typescript-eslint/no-unused-vars static supports(codec, config) { return false; } } /** * Base class for custom video encoders. To add your own custom video encoder, extend this class, implement the * abstract methods and static `supports` method, and register the encoder using `registerEncoder`. * @public */ export class CustomVideoEncoder { /** Returns true iff the encoder can encode the given codec configuration. */ // eslint-disable-next-line @typescript-eslint/no-unused-vars static supports(codec, config) { return false; } } /** * Base class for custom audio encoders. To add your own custom audio encoder, extend this class, implement the * abstract methods and static `supports` method, and register the encoder using `registerEncoder`. * @public */ export class CustomAudioEncoder { /** Returns true iff the encoder can encode the given codec configuration. */ // eslint-disable-next-line @typescript-eslint/no-unused-vars static supports(codec, config) { return false; } } export const customVideoDecoders = []; export const customAudioDecoders = []; export const customVideoEncoders = []; export const customAudioEncoders = []; /** * Registers a custom video or audio decoder. Registered decoders will automatically be used for decoding whenever * possible. * @public */ export const registerDecoder = (decoder) => { if (decoder.prototype instanceof CustomVideoDecoder) { const casted = decoder; if (customVideoDecoders.includes(casted)) { console.warn('Video decoder already registered.'); return; } customVideoDecoders.push(casted); } else if (decoder.prototype instanceof CustomAudioDecoder) { const casted = decoder; if (customAudioDecoders.includes(casted)) { console.warn('Audio decoder already registered.'); return; } customAudioDecoders.push(casted); } else { throw new TypeError('Decoder must be a CustomVideoDecoder or CustomAudioDecoder.'); } }; /** * Registers a custom video or audio encoder. Registered encoders will automatically be used for encoding whenever * possible. * @public */ export const registerEncoder = (encoder) => { if (encoder.prototype instanceof CustomVideoEncoder) { const casted = encoder; if (customVideoEncoders.includes(casted)) { console.warn('Video encoder already registered.'); return; } customVideoEncoders.push(casted); } else if (encoder.prototype instanceof CustomAudioEncoder) { const casted = encoder; if (customAudioEncoders.includes(casted)) { console.warn('Audio encoder already registered.'); return; } customAudioEncoders.push(casted); } else { throw new TypeError('Encoder must be a CustomVideoEncoder or CustomAudioEncoder.'); } };