node-web-audio-api
Version:
Web Audio API implementation for Node.js
269 lines (223 loc) • 10.8 kB
JavaScript
// -------------------------------------------------------------------------- //
// -------------------------------------------------------------------------- //
// //
// //
// //
// ██╗ ██╗ █████╗ ██████╗ ███╗ ██╗██╗███╗ ██╗ ██████╗ //
// ██║ ██║██╔══██╗██╔══██╗████╗ ██║██║████╗ ██║██╔════╝ //
// ██║ █╗ ██║███████║██████╔╝██╔██╗ ██║██║██╔██╗ ██║██║ ███╗ //
// ██║███╗██║██╔══██║██╔══██╗██║╚██╗██║██║██║╚██╗██║██║ ██║ //
// ╚███╔███╔╝██║ ██║██║ ██║██║ ╚████║██║██║ ╚████║╚██████╔╝ //
// ╚══╝╚══╝ ╚═╝ ╚═╝╚═╝ ╚═╝╚═╝ ╚═══╝╚═╝╚═╝ ╚═══╝ ╚═════╝ //
// //
// //
// - This file has been generated --------------------------- //
// //
// //
// -------------------------------------------------------------------------- //
// -------------------------------------------------------------------------- //
/* eslint-disable no-unused-vars */
const conversions = require('webidl-conversions');
const {
toSanitizedSequence,
} = require('./lib/cast.js');
const {
isFunction,
kEnumerableProperty,
} = require('./lib/utils.js');
const {
throwSanitizedError,
} = require('./lib/errors.js');
const {
kNapiObj,
kAudioBuffer,
} = require('./lib/symbols.js');
/* eslint-enable no-unused-vars */
const AudioNode = require('./AudioNode.js');
module.exports = (jsExport, nativeBinding) => {
class BiquadFilterNode extends AudioNode {
constructor(context, options) {
if (arguments.length < 1) {
throw new TypeError(`Failed to construct 'BiquadFilterNode': 1 argument required, but only ${arguments.length} present`);
}
if (!(context instanceof jsExport.BaseAudioContext)) {
throw new TypeError(`Failed to construct 'BiquadFilterNode': argument 1 is not of type BaseAudioContext`);
}
// parsed version of the option to be passed to NAPI
const parsedOptions = {};
if (options && typeof options !== 'object') {
throw new TypeError('Failed to construct \'BiquadFilterNode\': argument 2 is not of type \'BiquadFilterOptions\'');
}
if (options && options.type !== undefined) {
if (!['lowpass', 'highpass', 'bandpass', 'lowshelf', 'highshelf', 'peaking', 'notch', 'allpass'].includes(options.type)) {
throw new TypeError(`Failed to construct 'BiquadFilterNode': Failed to read the 'type' property from BiquadFilterOptions: The provided value '${options.type}' is not a valid enum value of type BiquadFilterType`);
}
parsedOptions.type = conversions['DOMString'](options.type, {
context: `Failed to construct 'BiquadFilterNode': Failed to read the 'type' property from BiquadFilterOptions: The provided value '${options.type}'`,
});
} else {
parsedOptions.type = 'lowpass';
}
if (options && options.Q !== undefined) {
parsedOptions.Q = conversions['float'](options.Q, {
context: `Failed to construct 'BiquadFilterNode': Failed to read the 'Q' property from BiquadFilterOptions: The provided value (${options.Q}})`,
});
} else {
parsedOptions.Q = 1;
}
if (options && options.detune !== undefined) {
parsedOptions.detune = conversions['float'](options.detune, {
context: `Failed to construct 'BiquadFilterNode': Failed to read the 'detune' property from BiquadFilterOptions: The provided value (${options.detune}})`,
});
} else {
parsedOptions.detune = 0;
}
if (options && options.frequency !== undefined) {
parsedOptions.frequency = conversions['float'](options.frequency, {
context: `Failed to construct 'BiquadFilterNode': Failed to read the 'frequency' property from BiquadFilterOptions: The provided value (${options.frequency}})`,
});
} else {
parsedOptions.frequency = 350;
}
if (options && options.gain !== undefined) {
parsedOptions.gain = conversions['float'](options.gain, {
context: `Failed to construct 'BiquadFilterNode': Failed to read the 'gain' property from BiquadFilterOptions: The provided value (${options.gain}})`,
});
} else {
parsedOptions.gain = 0;
}
if (options && options.channelCount !== undefined) {
parsedOptions.channelCount = conversions['unsigned long'](options.channelCount, {
enforceRange: true,
context: `Failed to construct 'BiquadFilterNode': Failed to read the 'channelCount' property from BiquadFilterOptions: The provided value '${options.channelCount}'`,
});
}
if (options && options.channelCountMode !== undefined) {
parsedOptions.channelCountMode = conversions['DOMString'](options.channelCountMode, {
context: `Failed to construct 'BiquadFilterNode': Failed to read the 'channelCount' property from BiquadFilterOptions: The provided value '${options.channelCountMode}'`,
});
}
if (options && options.channelInterpretation !== undefined) {
parsedOptions.channelInterpretation = conversions['DOMString'](options.channelInterpretation, {
context: `Failed to construct 'BiquadFilterNode': Failed to read the 'channelInterpretation' property from BiquadFilterOptions: The provided value '${options.channelInterpretation}'`,
});
}
let napiObj;
try {
napiObj = new nativeBinding.BiquadFilterNode(context[kNapiObj], parsedOptions);
} catch (err) {
throwSanitizedError(err);
}
super(context, {
[]: napiObj,
});
this.
[]: this[kNapiObj].frequency,
});
this.
[]: this[kNapiObj].detune,
});
this.
[]: this[kNapiObj].Q,
});
this.
[]: this[kNapiObj].gain,
});
}
get frequency() {
if (!(this instanceof BiquadFilterNode)) {
throw new TypeError('Invalid Invocation: Value of \'this\' must be of type \'BiquadFilterNode\'');
}
return this.
}
get detune() {
if (!(this instanceof BiquadFilterNode)) {
throw new TypeError('Invalid Invocation: Value of \'this\' must be of type \'BiquadFilterNode\'');
}
return this.
}
get Q() {
if (!(this instanceof BiquadFilterNode)) {
throw new TypeError('Invalid Invocation: Value of \'this\' must be of type \'BiquadFilterNode\'');
}
return this.
}
get gain() {
if (!(this instanceof BiquadFilterNode)) {
throw new TypeError('Invalid Invocation: Value of \'this\' must be of type \'BiquadFilterNode\'');
}
return this.
}
get type() {
if (!(this instanceof BiquadFilterNode)) {
throw new TypeError('Invalid Invocation: Value of \'this\' must be of type \'BiquadFilterNode\'');
}
return this[kNapiObj].type;
}
set type(value) {
if (!(this instanceof BiquadFilterNode)) {
throw new TypeError('Invalid Invocation: Value of \'this\' must be of type \'BiquadFilterNode\'');
}
if (!['lowpass', 'highpass', 'bandpass', 'lowshelf', 'highshelf', 'peaking', 'notch', 'allpass'].includes(value)) {
console.warn(`Failed to set the 'type' property on 'BiquadFilterNode': Value '${value}' is not a valid 'BiquadFilterType' enum value`);
return;
}
try {
this[kNapiObj].type = value;
} catch (err) {
throwSanitizedError(err);
}
}
getFrequencyResponse(frequencyHz, magResponse, phaseResponse) {
if (!(this instanceof BiquadFilterNode)) {
throw new TypeError('Invalid Invocation: Value of \'this\' must be of type \'BiquadFilterNode\'');
}
if (arguments.length < 3) {
throw new TypeError(`Failed to execute 'getFrequencyResponse' on 'BiquadFilterNode': 3 argument required, but only ${arguments.length} present`);
}
if (!(frequencyHz instanceof Float32Array)) {
throw new TypeError(`Failed to execute 'getFrequencyResponse' on 'BiquadFilterNode': Parameter 1 is not of type 'Float32Array'`);
}
if (!(magResponse instanceof Float32Array)) {
throw new TypeError(`Failed to execute 'getFrequencyResponse' on 'BiquadFilterNode': Parameter 2 is not of type 'Float32Array'`);
}
if (!(phaseResponse instanceof Float32Array)) {
throw new TypeError(`Failed to execute 'getFrequencyResponse' on 'BiquadFilterNode': Parameter 3 is not of type 'Float32Array'`);
}
try {
return this[kNapiObj].getFrequencyResponse(frequencyHz, magResponse, phaseResponse);
} catch (err) {
throwSanitizedError(err);
}
}
}
Object.defineProperties(BiquadFilterNode, {
length: {
__proto__: null,
writable: false,
enumerable: false,
configurable: true,
value: 1,
},
});
Object.defineProperties(BiquadFilterNode.prototype, {
[]: {
__proto__: null,
writable: false,
enumerable: false,
configurable: true,
value: 'BiquadFilterNode',
},
frequency: kEnumerableProperty,
detune: kEnumerableProperty,
Q: kEnumerableProperty,
gain: kEnumerableProperty,
type: kEnumerableProperty,
getFrequencyResponse: kEnumerableProperty,
});
return BiquadFilterNode;
};