Refactor options before super (#1244)

This commit is contained in:
Yotam Mann 2024-05-06 10:55:55 -04:00 committed by GitHub
parent aaf880c925
commit 56fea7cb70
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
104 changed files with 109 additions and 525 deletions

View file

@ -62,17 +62,12 @@ export class Analyser extends ToneAudioNode<AnalyserOptions> {
constructor(type?: AnalyserType, size?: number); constructor(type?: AnalyserType, size?: number);
constructor(options?: Partial<AnalyserOptions>); constructor(options?: Partial<AnalyserOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Analyser.getDefaults(), arguments, [
"type",
"size",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
Analyser.getDefaults(), Analyser.getDefaults(),
arguments, arguments,
["type", "size"] ["type", "size"]
); );
super(options);
this.input = this.input =
this.output = this.output =

View file

@ -32,10 +32,10 @@ export class FFT extends MeterBase<FFTOptions> {
constructor(size?: PowerOfTwo); constructor(size?: PowerOfTwo);
constructor(options?: Partial<FFTOptions>); constructor(options?: Partial<FFTOptions>);
constructor() { constructor() {
super(optionsFromArguments(FFT.getDefaults(), arguments, ["size"]));
const options = optionsFromArguments(FFT.getDefaults(), arguments, [ const options = optionsFromArguments(FFT.getDefaults(), arguments, [
"size", "size",
]); ]);
super(options);
this.normalRange = options.normalRange; this.normalRange = options.normalRange;
this._analyser.type = "fft"; this._analyser.type = "fft";

View file

@ -50,16 +50,12 @@ export class Follower extends ToneAudioNode<FollowerOptions> {
constructor(smoothing?: Time); constructor(smoothing?: Time);
constructor(options?: Partial<FollowerOptions>); constructor(options?: Partial<FollowerOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Follower.getDefaults(), arguments, [
"smoothing",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
Follower.getDefaults(), Follower.getDefaults(),
arguments, arguments,
["smoothing"] ["smoothing"]
); );
super(options);
this._abs = this.input = new Abs({ context: this.context }); this._abs = this.input = new Abs({ context: this.context });
this._lowpass = this.output = new OnePoleFilter({ this._lowpass = this.output = new OnePoleFilter({

View file

@ -55,12 +55,10 @@ export class Meter extends MeterBase<MeterOptions> {
constructor(smoothing?: NormalRange); constructor(smoothing?: NormalRange);
constructor(options?: Partial<MeterOptions>); constructor(options?: Partial<MeterOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Meter.getDefaults(), arguments, ["smoothing"])
);
const options = optionsFromArguments(Meter.getDefaults(), arguments, [ const options = optionsFromArguments(Meter.getDefaults(), arguments, [
"smoothing", "smoothing",
]); ]);
super(options);
this.input = this.input =
this.output = this.output =

View file

@ -22,14 +22,12 @@ export class Waveform extends MeterBase<WaveformOptions> {
constructor(size?: PowerOfTwo); constructor(size?: PowerOfTwo);
constructor(options?: Partial<WaveformOptions>); constructor(options?: Partial<WaveformOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Waveform.getDefaults(), arguments, ["size"])
);
const options = optionsFromArguments( const options = optionsFromArguments(
Waveform.getDefaults(), Waveform.getDefaults(),
arguments, arguments,
["size"] ["size"]
); );
super(options);
this._analyser.type = "waveform"; this._analyser.type = "waveform";
this.size = options.size; this.size = options.size;

View file

@ -63,16 +63,11 @@ export class Channel extends ToneAudioNode<ChannelOptions> {
constructor(volume?: Decibels, pan?: AudioRange); constructor(volume?: Decibels, pan?: AudioRange);
constructor(options?: Partial<ChannelOptions>); constructor(options?: Partial<ChannelOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Channel.getDefaults(), arguments, [
"volume",
"pan",
])
);
const options = optionsFromArguments(Channel.getDefaults(), arguments, [ const options = optionsFromArguments(Channel.getDefaults(), arguments, [
"volume", "volume",
"pan", "pan",
]); ]);
super(options);
this._solo = this.input = new Solo({ this._solo = this.input = new Solo({
solo: options.solo, solo: options.solo,

View file

@ -100,18 +100,12 @@ export class CrossFade extends ToneAudioNode<CrossFadeOptions> {
constructor(fade?: NormalRange); constructor(fade?: NormalRange);
constructor(options?: Partial<CrossFadeOptions>); constructor(options?: Partial<CrossFadeOptions>);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(CrossFade.getDefaults(), arguments, [
"fade",
])
)
);
const options = optionsFromArguments( const options = optionsFromArguments(
CrossFade.getDefaults(), CrossFade.getDefaults(),
arguments, arguments,
["fade"] ["fade"]
); );
super(options);
this.fade = new Signal({ this.fade = new Signal({
context: this.context, context: this.context,

View file

@ -44,12 +44,10 @@ export class Merge extends ToneAudioNode<MergeOptions> {
constructor(channels?: Positive); constructor(channels?: Positive);
constructor(options?: Partial<MergeOptions>); constructor(options?: Partial<MergeOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Merge.getDefaults(), arguments, ["channels"])
);
const options = optionsFromArguments(Merge.getDefaults(), arguments, [ const options = optionsFromArguments(Merge.getDefaults(), arguments, [
"channels", "channels",
]); ]);
super(options);
this._merger = this._merger =
this.output = this.output =

View file

@ -106,17 +106,12 @@ export class MultibandSplit extends ToneAudioNode<MultibandSplitOptions> {
constructor(lowFrequency?: Frequency, highFrequency?: Frequency); constructor(lowFrequency?: Frequency, highFrequency?: Frequency);
constructor(options?: Partial<MultibandSplitOptions>); constructor(options?: Partial<MultibandSplitOptions>);
constructor() { constructor() {
super(
optionsFromArguments(MultibandSplit.getDefaults(), arguments, [
"lowFrequency",
"highFrequency",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
MultibandSplit.getDefaults(), MultibandSplit.getDefaults(),
arguments, arguments,
["lowFrequency", "highFrequency"] ["lowFrequency", "highFrequency"]
); );
super(options);
this.lowFrequency = new Signal({ this.lowFrequency = new Signal({
context: this.context, context: this.context,

View file

@ -61,16 +61,11 @@ export class PanVol extends ToneAudioNode<PanVolOptions> {
constructor(pan?: AudioRange, volume?: Decibels); constructor(pan?: AudioRange, volume?: Decibels);
constructor(options?: Partial<PanVolOptions>); constructor(options?: Partial<PanVolOptions>);
constructor() { constructor() {
super(
optionsFromArguments(PanVol.getDefaults(), arguments, [
"pan",
"volume",
])
);
const options = optionsFromArguments(PanVol.getDefaults(), arguments, [ const options = optionsFromArguments(PanVol.getDefaults(), arguments, [
"pan", "pan",
"volume", "volume",
]); ]);
super(options);
this._panner = this.input = new Panner({ this._panner = this.input = new Panner({
context: this.context, context: this.context,

View file

@ -54,14 +54,10 @@ export class Panner extends ToneAudioNode<TonePannerOptions> {
*/ */
constructor(pan?: AudioRange); constructor(pan?: AudioRange);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(Panner.getDefaults(), arguments, ["pan"])
)
);
const options = optionsFromArguments(Panner.getDefaults(), arguments, [ const options = optionsFromArguments(Panner.getDefaults(), arguments, [
"pan", "pan",
]); ]);
super(options);
this.pan = new Param({ this.pan = new Param({
context: this.context, context: this.context,

View file

@ -54,18 +54,12 @@ export class Panner3D extends ToneAudioNode<Panner3DOptions> {
constructor(positionX: number, positionY: number, positionZ: number); constructor(positionX: number, positionY: number, positionZ: number);
constructor(options?: Partial<Panner3DOptions>); constructor(options?: Partial<Panner3DOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Panner3D.getDefaults(), arguments, [
"positionX",
"positionY",
"positionZ",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
Panner3D.getDefaults(), Panner3D.getDefaults(),
arguments, arguments,
["positionX", "positionY", "positionZ"] ["positionX", "positionY", "positionZ"]
); );
super(options);
this._panner = this.input = this.output = this.context.createPanner(); this._panner = this.input = this.output = this.context.createPanner();
// set some values // set some values

View file

@ -57,8 +57,8 @@ export class Recorder extends ToneAudioNode<RecorderOptions> {
constructor(options?: Partial<RecorderOptions>); constructor(options?: Partial<RecorderOptions>);
constructor() { constructor() {
super(optionsFromArguments(Recorder.getDefaults(), arguments));
const options = optionsFromArguments(Recorder.getDefaults(), arguments); const options = optionsFromArguments(Recorder.getDefaults(), arguments);
super(options);
this.input = new Gain({ this.input = new Gain({
context: this.context, context: this.context,

View file

@ -34,10 +34,10 @@ export class Solo extends ToneAudioNode<SoloOptions> {
constructor(solo?: boolean); constructor(solo?: boolean);
constructor(options?: Partial<SoloOptions>); constructor(options?: Partial<SoloOptions>);
constructor() { constructor() {
super(optionsFromArguments(Solo.getDefaults(), arguments, ["solo"]));
const options = optionsFromArguments(Solo.getDefaults(), arguments, [ const options = optionsFromArguments(Solo.getDefaults(), arguments, [
"solo", "solo",
]); ]);
super(options);
this.input = this.output = new Gain({ this.input = this.output = new Gain({
context: this.context, context: this.context,

View file

@ -33,12 +33,10 @@ export class Split extends ToneAudioNode<SplitOptions> {
constructor(channels?: number); constructor(channels?: number);
constructor(options?: Partial<SplitOptions>); constructor(options?: Partial<SplitOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Split.getDefaults(), arguments, ["channels"])
);
const options = optionsFromArguments(Split.getDefaults(), arguments, [ const options = optionsFromArguments(Split.getDefaults(), arguments, [
"channels", "channels",
]); ]);
super(options);
this._splitter = this._splitter =
this.input = this.input =

View file

@ -54,12 +54,10 @@ export class Volume extends ToneAudioNode<VolumeOptions> {
constructor(volume?: Decibels); constructor(volume?: Decibels);
constructor(options?: Partial<VolumeOptions>); constructor(options?: Partial<VolumeOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Volume.getDefaults(), arguments, ["volume"])
);
const options = optionsFromArguments(Volume.getDefaults(), arguments, [ const options = optionsFromArguments(Volume.getDefaults(), arguments, [
"volume", "volume",
]); ]);
super(options);
this.input = this.output = new Gain({ this.input = this.output = new Gain({
context: this.context, context: this.context,

View file

@ -79,17 +79,12 @@ export class Compressor extends ToneAudioNode<CompressorOptions> {
constructor(threshold?: Decibels, ratio?: Positive); constructor(threshold?: Decibels, ratio?: Positive);
constructor(options?: Partial<CompressorOptions>); constructor(options?: Partial<CompressorOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Compressor.getDefaults(), arguments, [
"threshold",
"ratio",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
Compressor.getDefaults(), Compressor.getDefaults(),
arguments, arguments,
["threshold", "ratio"] ["threshold", "ratio"]
); );
super(options);
this.threshold = new Param({ this.threshold = new Param({
minValue: this._compressor.threshold.minValue, minValue: this._compressor.threshold.minValue,

View file

@ -54,18 +54,11 @@ export class Gate extends ToneAudioNode<GateOptions> {
constructor(threshold?: Decibels, smoothing?: Time); constructor(threshold?: Decibels, smoothing?: Time);
constructor(options?: Partial<GateOptions>); constructor(options?: Partial<GateOptions>);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(Gate.getDefaults(), arguments, [
"threshold",
"smoothing",
])
)
);
const options = optionsFromArguments(Gate.getDefaults(), arguments, [ const options = optionsFromArguments(Gate.getDefaults(), arguments, [
"threshold", "threshold",
"smoothing", "smoothing",
]); ]);
super(options);
this._follower = new Follower({ this._follower = new Follower({
context: this.context, context: this.context,

View file

@ -44,16 +44,10 @@ export class Limiter extends ToneAudioNode<LimiterOptions> {
constructor(threshold?: Decibels); constructor(threshold?: Decibels);
constructor(options?: Partial<LimiterOptions>); constructor(options?: Partial<LimiterOptions>);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(Limiter.getDefaults(), arguments, [
"threshold",
])
)
);
const options = optionsFromArguments(Limiter.getDefaults(), arguments, [ const options = optionsFromArguments(Limiter.getDefaults(), arguments, [
"threshold", "threshold",
]); ]);
super(options);
this._compressor = this._compressor =
this.input = this.input =

View file

@ -49,15 +49,11 @@ export class MidSideCompressor extends ToneAudioNode<MidSideCompressorOptions> {
constructor(options?: RecursivePartial<MidSideCompressorOptions>); constructor(options?: RecursivePartial<MidSideCompressorOptions>);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(MidSideCompressor.getDefaults(), arguments)
)
);
const options = optionsFromArguments( const options = optionsFromArguments(
MidSideCompressor.getDefaults(), MidSideCompressor.getDefaults(),
arguments arguments
); );
super(options);
this._midSideSplit = this.input = new MidSideSplit({ this._midSideSplit = this.input = new MidSideSplit({
context: this.context, context: this.context,

View file

@ -71,18 +71,11 @@ export class MultibandCompressor extends ToneAudioNode<MultibandCompressorOption
constructor(options?: RecursivePartial<MultibandCompressorOptions>); constructor(options?: RecursivePartial<MultibandCompressorOptions>);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(
MultibandCompressor.getDefaults(),
arguments
)
)
);
const options = optionsFromArguments( const options = optionsFromArguments(
MultibandCompressor.getDefaults(), MultibandCompressor.getDefaults(),
arguments arguments
); );
super(options);
this._splitter = this.input = new MultibandSplit({ this._splitter = this.input = new MultibandSplit({
context: this.context, context: this.context,

View file

@ -186,19 +186,12 @@ export class Envelope extends ToneAudioNode<EnvelopeOptions> {
); );
constructor(options?: Partial<EnvelopeOptions>); constructor(options?: Partial<EnvelopeOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Envelope.getDefaults(), arguments, [
"attack",
"decay",
"sustain",
"release",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
Envelope.getDefaults(), Envelope.getDefaults(),
arguments, arguments,
["attack", "decay", "sustain", "release"] ["attack", "decay", "sustain", "release"]
); );
super(options);
this.attack = options.attack; this.attack = options.attack;
this.decay = options.decay; this.decay = options.decay;

View file

@ -62,19 +62,12 @@ export class FrequencyEnvelope extends Envelope {
); );
constructor(options?: Partial<FrequencyEnvelopeOptions>); constructor(options?: Partial<FrequencyEnvelopeOptions>);
constructor() { constructor() {
super(
optionsFromArguments(FrequencyEnvelope.getDefaults(), arguments, [
"attack",
"decay",
"sustain",
"release",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
FrequencyEnvelope.getDefaults(), FrequencyEnvelope.getDefaults(),
arguments, arguments,
["attack", "decay", "sustain", "release"] ["attack", "decay", "sustain", "release"]
); );
super(options);
this._octaves = options.octaves; this._octaves = options.octaves;
this._baseFrequency = this.toFrequency(options.baseFrequency); this._baseFrequency = this.toFrequency(options.baseFrequency);

View file

@ -61,17 +61,12 @@ export class BiquadFilter extends ToneAudioNode<BiquadFilterOptions> {
constructor(frequency?: Frequency, type?: BiquadFilterType); constructor(frequency?: Frequency, type?: BiquadFilterType);
constructor(options?: Partial<BiquadFilterOptions>); constructor(options?: Partial<BiquadFilterOptions>);
constructor() { constructor() {
super(
optionsFromArguments(BiquadFilter.getDefaults(), arguments, [
"frequency",
"type",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
BiquadFilter.getDefaults(), BiquadFilter.getDefaults(),
arguments, arguments,
["frequency", "type"] ["frequency", "type"]
); );
super(options);
this._filter = this.context.createBiquadFilter(); this._filter = this.context.createBiquadFilter();
this.input = this.output = this._filter; this.input = this.output = this._filter;

View file

@ -50,17 +50,12 @@ export class Convolver extends ToneAudioNode<ConvolverOptions> {
); );
constructor(options?: Partial<ConvolverOptions>); constructor(options?: Partial<ConvolverOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Convolver.getDefaults(), arguments, [
"url",
"onload",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
Convolver.getDefaults(), Convolver.getDefaults(),
arguments, arguments,
["url", "onload"] ["url", "onload"]
); );
super(options);
this._buffer = new ToneAudioBuffer(options.url, (buffer) => { this._buffer = new ToneAudioBuffer(options.url, (buffer) => {
this.buffer = buffer; this.buffer = buffer;

View file

@ -90,18 +90,12 @@ export class EQ3 extends ToneAudioNode<EQ3Options> {
constructor(lowLevel?: Decibels, midLevel?: Decibels, highLevel?: Decibels); constructor(lowLevel?: Decibels, midLevel?: Decibels, highLevel?: Decibels);
constructor(options: Partial<EQ3Options>); constructor(options: Partial<EQ3Options>);
constructor() { constructor() {
super(
optionsFromArguments(EQ3.getDefaults(), arguments, [
"low",
"mid",
"high",
])
);
const options = optionsFromArguments(EQ3.getDefaults(), arguments, [ const options = optionsFromArguments(EQ3.getDefaults(), arguments, [
"low", "low",
"mid", "mid",
"high", "high",
]); ]);
super(options);
this.input = this._multibandSplit = new MultibandSplit({ this.input = this._multibandSplit = new MultibandSplit({
context: this.context, context: this.context,

View file

@ -48,17 +48,12 @@ export class FeedbackCombFilter extends ToneAudioWorklet<FeedbackCombFilterOptio
constructor(delayTime?: Time, resonance?: NormalRange); constructor(delayTime?: Time, resonance?: NormalRange);
constructor(options?: RecursivePartial<FeedbackCombFilterOptions>); constructor(options?: RecursivePartial<FeedbackCombFilterOptions>);
constructor() { constructor() {
super(
optionsFromArguments(FeedbackCombFilter.getDefaults(), arguments, [
"delayTime",
"resonance",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
FeedbackCombFilter.getDefaults(), FeedbackCombFilter.getDefaults(),
arguments, arguments,
["delayTime", "resonance"] ["delayTime", "resonance"]
); );
super(options);
this.input = new Gain({ context: this.context }); this.input = new Gain({ context: this.context });
this.output = new Gain({ context: this.context }); this.output = new Gain({ context: this.context });

View file

@ -73,18 +73,12 @@ export class Filter extends ToneAudioNode<FilterOptions> {
); );
constructor(options?: Partial<FilterOptions>); constructor(options?: Partial<FilterOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Filter.getDefaults(), arguments, [
"frequency",
"type",
"rolloff",
])
);
const options = optionsFromArguments(Filter.getDefaults(), arguments, [ const options = optionsFromArguments(Filter.getDefaults(), arguments, [
"frequency", "frequency",
"type", "type",
"rolloff", "rolloff",
]); ]);
super(options);
this._filters = []; this._filters = [];

View file

@ -60,18 +60,12 @@ export class LowpassCombFilter extends ToneAudioNode<LowpassCombFilterOptions> {
); );
constructor(options?: RecursivePartial<LowpassCombFilterOptions>); constructor(options?: RecursivePartial<LowpassCombFilterOptions>);
constructor() { constructor() {
super(
optionsFromArguments(LowpassCombFilter.getDefaults(), arguments, [
"delayTime",
"resonance",
"dampening",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
LowpassCombFilter.getDefaults(), LowpassCombFilter.getDefaults(),
arguments, arguments,
["delayTime", "resonance", "dampening"] ["delayTime", "resonance", "dampening"]
); );
super(options);
this._combFilter = this.output = new FeedbackCombFilter({ this._combFilter = this.output = new FeedbackCombFilter({
context: this.context, context: this.context,

View file

@ -51,17 +51,12 @@ export class OnePoleFilter extends ToneAudioNode<OnePoleFilterOptions> {
constructor(frequency?: Frequency, type?: OnePoleFilterType); constructor(frequency?: Frequency, type?: OnePoleFilterType);
constructor(options?: Partial<OnePoleFilterOptions>); constructor(options?: Partial<OnePoleFilterOptions>);
constructor() { constructor() {
super(
optionsFromArguments(OnePoleFilter.getDefaults(), arguments, [
"frequency",
"type",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
OnePoleFilter.getDefaults(), OnePoleFilter.getDefaults(),
arguments, arguments,
["frequency", "type"] ["frequency", "type"]
); );
super(options);
this._frequency = options.frequency; this._frequency = options.frequency;
this._type = options.type; this._type = options.type;

View file

@ -80,16 +80,11 @@ export class Clock<TypeName extends "bpm" | "hertz" = "hertz">
constructor(callback?: ClockCallback, frequency?: Frequency); constructor(callback?: ClockCallback, frequency?: Frequency);
constructor(options: Partial<ClockOptions>); constructor(options: Partial<ClockOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Clock.getDefaults(), arguments, [
"callback",
"frequency",
])
);
const options = optionsFromArguments(Clock.getDefaults(), arguments, [ const options = optionsFromArguments(Clock.getDefaults(), arguments, [
"callback", "callback",
"frequency", "frequency",
]); ]);
super(options);
this.callback = options.callback; this.callback = options.callback;
this._tickSource = new TickSource({ this._tickSource = new TickSource({

View file

@ -44,14 +44,12 @@ export class TickParam<
constructor(value?: number); constructor(value?: number);
constructor(options: Partial<TickParamOptions<TypeName>>); constructor(options: Partial<TickParamOptions<TypeName>>);
constructor() { constructor() {
super(
optionsFromArguments(TickParam.getDefaults(), arguments, ["value"])
);
const options = optionsFromArguments( const options = optionsFromArguments(
TickParam.getDefaults(), TickParam.getDefaults(),
arguments, arguments,
["value"] ["value"]
); );
super(options);
// set the multiplier // set the multiplier
this._multiplier = options.multiplier; this._multiplier = options.multiplier;

View file

@ -36,14 +36,12 @@ export class TickSignal<
constructor(value?: UnitMap[TypeName]); constructor(value?: UnitMap[TypeName]);
constructor(options: Partial<TickSignalOptions<TypeName>>); constructor(options: Partial<TickSignalOptions<TypeName>>);
constructor() { constructor() {
super(
optionsFromArguments(TickSignal.getDefaults(), arguments, ["value"])
);
const options = optionsFromArguments( const options = optionsFromArguments(
TickSignal.getDefaults(), TickSignal.getDefaults(),
arguments, arguments,
["value"] ["value"]
); );
super(options);
this.input = this._param = new TickParam({ this.input = this._param = new TickParam({
context: this.context, context: this.context,

View file

@ -79,16 +79,12 @@ export class TickSource<
constructor(frequency?: number); constructor(frequency?: number);
constructor(options?: Partial<TickSourceOptions>); constructor(options?: Partial<TickSourceOptions>);
constructor() { constructor() {
super(
optionsFromArguments(TickSource.getDefaults(), arguments, [
"frequency",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
TickSource.getDefaults(), TickSource.getDefaults(),
arguments, arguments,
["frequency"] ["frequency"]
); );
super(options);
this.frequency = new TickSignal({ this.frequency = new TickSignal({
context: this.context, context: this.context,

View file

@ -188,11 +188,11 @@ export class TransportClass
constructor(options?: Partial<TransportOptions>); constructor(options?: Partial<TransportOptions>);
constructor() { constructor() {
super(optionsFromArguments(TransportClass.getDefaults(), arguments));
const options = optionsFromArguments( const options = optionsFromArguments(
TransportClass.getDefaults(), TransportClass.getDefaults(),
arguments arguments
); );
super(options);
// CLOCK/TEMPO // CLOCK/TEMPO
this._ppq = options.ppq; this._ppq = options.ppq;

View file

@ -54,17 +54,11 @@ export class Delay extends ToneAudioNode<DelayOptions> {
constructor(delayTime?: Time, maxDelay?: Time); constructor(delayTime?: Time, maxDelay?: Time);
constructor(options?: Partial<DelayOptions>); constructor(options?: Partial<DelayOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Delay.getDefaults(), arguments, [
"delayTime",
"maxDelay",
])
);
const options = optionsFromArguments(Delay.getDefaults(), arguments, [ const options = optionsFromArguments(Delay.getDefaults(), arguments, [
"delayTime", "delayTime",
"maxDelay", "maxDelay",
]); ]);
super(options);
const maxDelayInSeconds = this.toSeconds(options.maxDelay); const maxDelayInSeconds = this.toSeconds(options.maxDelay);
this._maxDelay = Math.max( this._maxDelay = Math.max(

View file

@ -48,11 +48,11 @@ export class DestinationClass extends ToneAudioNode<DestinationOptions> {
constructor(options: Partial<DestinationOptions>); constructor(options: Partial<DestinationOptions>);
constructor() { constructor() {
super(optionsFromArguments(DestinationClass.getDefaults(), arguments));
const options = optionsFromArguments( const options = optionsFromArguments(
DestinationClass.getDefaults(), DestinationClass.getDefaults(),
arguments arguments
); );
super(options);
connectSeries( connectSeries(
this.input, this.input,

View file

@ -56,16 +56,11 @@ export class Gain<
constructor(gain?: UnitMap[TypeName], units?: TypeName); constructor(gain?: UnitMap[TypeName], units?: TypeName);
constructor(options?: Partial<GainOptions<TypeName>>); constructor(options?: Partial<GainOptions<TypeName>>);
constructor() { constructor() {
super(
optionsFromArguments(Gain.getDefaults(), arguments, [
"gain",
"units",
])
);
const options = optionsFromArguments(Gain.getDefaults(), arguments, [ const options = optionsFromArguments(Gain.getDefaults(), arguments, [
"gain", "gain",
"units", "units",
]); ]);
super(options);
this.gain = new Param({ this.gain = new Param({
context: this.context, context: this.context,

View file

@ -113,19 +113,12 @@ export class Param<TypeName extends UnitName = "number">
constructor(param: AudioParam, units?: TypeName, convert?: boolean); constructor(param: AudioParam, units?: TypeName, convert?: boolean);
constructor(options: Partial<ParamOptions<TypeName>>); constructor(options: Partial<ParamOptions<TypeName>>);
constructor() { constructor() {
super(
optionsFromArguments(Param.getDefaults(), arguments, [
"param",
"units",
"convert",
])
);
const options = optionsFromArguments(Param.getDefaults(), arguments, [ const options = optionsFromArguments(Param.getDefaults(), arguments, [
"param", "param",
"units", "units",
"convert", "convert",
]); ]);
super(options);
assert( assert(
isDefined(options.param) && isDefined(options.param) &&

View file

@ -50,18 +50,12 @@ export class AutoFilter extends LFOEffect<AutoFilterOptions> {
); );
constructor(options?: Partial<AutoFilterOptions>); constructor(options?: Partial<AutoFilterOptions>);
constructor() { constructor() {
super(
optionsFromArguments(AutoFilter.getDefaults(), arguments, [
"frequency",
"baseFrequency",
"octaves",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
AutoFilter.getDefaults(), AutoFilter.getDefaults(),
arguments, arguments,
["frequency", "baseFrequency", "octaves"] ["frequency", "baseFrequency", "octaves"]
); );
super(options);
this.filter = new Filter( this.filter = new Filter(
Object.assign(options.filter, { Object.assign(options.filter, {

View file

@ -32,16 +32,12 @@ export class AutoPanner extends LFOEffect<AutoPannerOptions> {
constructor(frequency?: Frequency); constructor(frequency?: Frequency);
constructor(options?: Partial<AutoPannerOptions>); constructor(options?: Partial<AutoPannerOptions>);
constructor() { constructor() {
super(
optionsFromArguments(AutoPanner.getDefaults(), arguments, [
"frequency",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
AutoPanner.getDefaults(), AutoPanner.getDefaults(),
arguments, arguments,
["frequency"] ["frequency"]
); );
super(options);
this._panner = new Panner({ this._panner = new Panner({
context: this.context, context: this.context,

View file

@ -101,18 +101,12 @@ export class AutoWah extends Effect<AutoWahOptions> {
); );
constructor(options?: Partial<AutoWahOptions>); constructor(options?: Partial<AutoWahOptions>);
constructor() { constructor() {
super(
optionsFromArguments(AutoWah.getDefaults(), arguments, [
"baseFrequency",
"octaves",
"sensitivity",
])
);
const options = optionsFromArguments(AutoWah.getDefaults(), arguments, [ const options = optionsFromArguments(AutoWah.getDefaults(), arguments, [
"baseFrequency", "baseFrequency",
"octaves", "octaves",
"sensitivity", "sensitivity",
]); ]);
super(options);
this._follower = new Follower({ this._follower = new Follower({
context: this.context, context: this.context,

View file

@ -44,14 +44,12 @@ export class BitCrusher extends Effect<BitCrusherOptions> {
constructor(bits?: Positive); constructor(bits?: Positive);
constructor(options?: Partial<BitCrusherWorkletOptions>); constructor(options?: Partial<BitCrusherWorkletOptions>);
constructor() { constructor() {
super(
optionsFromArguments(BitCrusher.getDefaults(), arguments, ["bits"])
);
const options = optionsFromArguments( const options = optionsFromArguments(
BitCrusher.getDefaults(), BitCrusher.getDefaults(),
arguments, arguments,
["bits"] ["bits"]
); );
super(options);
this._bitCrusherWorklet = new BitCrusherWorklet({ this._bitCrusherWorklet = new BitCrusherWorklet({
context: this.context, context: this.context,
@ -93,11 +91,11 @@ class BitCrusherWorklet extends ToneAudioWorklet<BitCrusherWorkletOptions> {
constructor(options?: Partial<BitCrusherWorkletOptions>); constructor(options?: Partial<BitCrusherWorkletOptions>);
constructor() { constructor() {
super(optionsFromArguments(BitCrusherWorklet.getDefaults(), arguments));
const options = optionsFromArguments( const options = optionsFromArguments(
BitCrusherWorklet.getDefaults(), BitCrusherWorklet.getDefaults(),
arguments arguments
); );
super(options);
this.input = new Gain({ context: this.context }); this.input = new Gain({ context: this.context });
this.output = new Gain({ context: this.context }); this.output = new Gain({ context: this.context });

View file

@ -42,14 +42,12 @@ export class Chebyshev extends Effect<ChebyshevOptions> {
constructor(order?: Positive); constructor(order?: Positive);
constructor(options?: Partial<ChebyshevOptions>); constructor(options?: Partial<ChebyshevOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Chebyshev.getDefaults(), arguments, ["order"])
);
const options = optionsFromArguments( const options = optionsFromArguments(
Chebyshev.getDefaults(), Chebyshev.getDefaults(),
arguments, arguments,
["order"] ["order"]
); );
super(options);
this._shaper = new WaveShaper({ this._shaper = new WaveShaper({
context: this.context, context: this.context,

View file

@ -88,18 +88,12 @@ export class Chorus extends StereoFeedbackEffect<ChorusOptions> {
); );
constructor(options?: Partial<ChorusOptions>); constructor(options?: Partial<ChorusOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Chorus.getDefaults(), arguments, [
"frequency",
"delayTime",
"depth",
])
);
const options = optionsFromArguments(Chorus.getDefaults(), arguments, [ const options = optionsFromArguments(Chorus.getDefaults(), arguments, [
"frequency", "frequency",
"delayTime", "delayTime",
"depth", "depth",
]); ]);
super(options);
this._depth = options.depth; this._depth = options.depth;
this._delayTime = options.delayTime / 1000; this._delayTime = options.delayTime / 1000;

View file

@ -36,16 +36,12 @@ export class Distortion extends Effect<DistortionOptions> {
constructor(distortion?: number); constructor(distortion?: number);
constructor(options?: Partial<DistortionOptions>); constructor(options?: Partial<DistortionOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Distortion.getDefaults(), arguments, [
"distortion",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
Distortion.getDefaults(), Distortion.getDefaults(),
arguments, arguments,
["distortion"] ["distortion"]
); );
super(options);
this._shaper = new WaveShaper({ this._shaper = new WaveShaper({
context: this.context, context: this.context,

View file

@ -40,17 +40,12 @@ export class FeedbackDelay extends FeedbackEffect<FeedbackDelayOptions> {
constructor(delayTime?: Time, feedback?: NormalRange); constructor(delayTime?: Time, feedback?: NormalRange);
constructor(options?: Partial<FeedbackDelayOptions>); constructor(options?: Partial<FeedbackDelayOptions>);
constructor() { constructor() {
super(
optionsFromArguments(FeedbackDelay.getDefaults(), arguments, [
"delayTime",
"feedback",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
FeedbackDelay.getDefaults(), FeedbackDelay.getDefaults(),
arguments, arguments,
["delayTime", "feedback"] ["delayTime", "feedback"]
); );
super(options);
this._delayNode = new Delay({ this._delayNode = new Delay({
context: this.context, context: this.context,

View file

@ -71,17 +71,12 @@ export class Freeverb extends StereoEffect<FreeverbOptions> {
constructor(roomSize?: NormalRange, dampening?: Frequency); constructor(roomSize?: NormalRange, dampening?: Frequency);
constructor(options?: Partial<FreeverbOptions>); constructor(options?: Partial<FreeverbOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Freeverb.getDefaults(), arguments, [
"roomSize",
"dampening",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
Freeverb.getDefaults(), Freeverb.getDefaults(),
arguments, arguments,
["roomSize", "dampening"] ["roomSize", "dampening"]
); );
super(options);
this.roomSize = new Signal({ this.roomSize = new Signal({
context: this.context, context: this.context,

View file

@ -81,16 +81,12 @@ export class FrequencyShifter extends Effect<FrequencyShifterOptions> {
constructor(frequency?: Frequency); constructor(frequency?: Frequency);
constructor(options?: Partial<FrequencyShifterOptions>); constructor(options?: Partial<FrequencyShifterOptions>);
constructor() { constructor() {
super(
optionsFromArguments(FrequencyShifter.getDefaults(), arguments, [
"frequency",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
FrequencyShifter.getDefaults(), FrequencyShifter.getDefaults(),
arguments, arguments,
["frequency"] ["frequency"]
); );
super(options);
this.frequency = new Signal({ this.frequency = new Signal({
context: this.context, context: this.context,

View file

@ -73,16 +73,12 @@ export class JCReverb extends StereoEffect<JCReverbOptions> {
constructor(roomSize?: NormalRange); constructor(roomSize?: NormalRange);
constructor(options?: Partial<JCReverbOptions>); constructor(options?: Partial<JCReverbOptions>);
constructor() { constructor() {
super(
optionsFromArguments(JCReverb.getDefaults(), arguments, [
"roomSize",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
JCReverb.getDefaults(), JCReverb.getDefaults(),
arguments, arguments,
["roomSize"] ["roomSize"]
); );
super(options);
this.roomSize = new Signal({ this.roomSize = new Signal({
context: this.context, context: this.context,

View file

@ -83,18 +83,12 @@ export class Phaser extends StereoEffect<PhaserOptions> {
); );
constructor(options?: Partial<PhaserOptions>); constructor(options?: Partial<PhaserOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Phaser.getDefaults(), arguments, [
"frequency",
"octaves",
"baseFrequency",
])
);
const options = optionsFromArguments(Phaser.getDefaults(), arguments, [ const options = optionsFromArguments(Phaser.getDefaults(), arguments, [
"frequency", "frequency",
"octaves", "octaves",
"baseFrequency", "baseFrequency",
]); ]);
super(options);
this._lfoL = new LFO({ this._lfoL = new LFO({
context: this.context, context: this.context,

View file

@ -57,17 +57,12 @@ export class PingPongDelay extends StereoXFeedbackEffect<PingPongDelayOptions> {
constructor(delayTime?: Time, feedback?: NormalRange); constructor(delayTime?: Time, feedback?: NormalRange);
constructor(options?: Partial<PingPongDelayOptions>); constructor(options?: Partial<PingPongDelayOptions>);
constructor() { constructor() {
super(
optionsFromArguments(PingPongDelay.getDefaults(), arguments, [
"delayTime",
"feedback",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
PingPongDelay.getDefaults(), PingPongDelay.getDefaults(),
arguments, arguments,
["delayTime", "feedback"] ["delayTime", "feedback"]
); );
super(options);
this._leftDelay = new Delay({ this._leftDelay = new Delay({
context: this.context, context: this.context,

View file

@ -88,14 +88,12 @@ export class PitchShift extends FeedbackEffect<PitchShiftOptions> {
constructor(pitch?: Interval); constructor(pitch?: Interval);
constructor(options?: Partial<PitchShiftOptions>); constructor(options?: Partial<PitchShiftOptions>);
constructor() { constructor() {
super(
optionsFromArguments(PitchShift.getDefaults(), arguments, ["pitch"])
);
const options = optionsFromArguments( const options = optionsFromArguments(
PitchShift.getDefaults(), PitchShift.getDefaults(),
arguments, arguments,
["pitch"] ["pitch"]
); );
super(options);
this._frequency = new Signal({ context: this.context }); this._frequency = new Signal({ context: this.context });
this._delayA = new Delay({ this._delayA = new Delay({

View file

@ -56,10 +56,10 @@ export class Reverb extends Effect<ReverbOptions> {
constructor(decay?: Seconds); constructor(decay?: Seconds);
constructor(options?: Partial<ReverbOptions>); constructor(options?: Partial<ReverbOptions>);
constructor() { constructor() {
super(optionsFromArguments(Reverb.getDefaults(), arguments, ["decay"]));
const options = optionsFromArguments(Reverb.getDefaults(), arguments, [ const options = optionsFromArguments(Reverb.getDefaults(), arguments, [
"decay", "decay",
]); ]);
super(options);
this._decay = options.decay; this._decay = options.decay;
this._preDelay = options.preDelay; this._preDelay = options.preDelay;

View file

@ -63,16 +63,13 @@ export class StereoWidener extends MidSideEffect<StereoWidenerOptions> {
constructor(width?: NormalRange); constructor(width?: NormalRange);
constructor(options?: Partial<StereoWidenerOptions>); constructor(options?: Partial<StereoWidenerOptions>);
constructor() { constructor() {
super(
optionsFromArguments(StereoWidener.getDefaults(), arguments, [
"width",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
StereoWidener.getDefaults(), StereoWidener.getDefaults(),
arguments, arguments,
["width"] ["width"]
); );
super(options);
this.width = new Signal({ this.width = new Signal({
context: this.context, context: this.context,
value: options.width, value: options.width,

View file

@ -68,16 +68,11 @@ export class Tremolo extends StereoEffect<TremoloOptions> {
constructor(frequency?: Frequency, depth?: NormalRange); constructor(frequency?: Frequency, depth?: NormalRange);
constructor(options?: Partial<TremoloOptions>); constructor(options?: Partial<TremoloOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Tremolo.getDefaults(), arguments, [
"frequency",
"depth",
])
);
const options = optionsFromArguments(Tremolo.getDefaults(), arguments, [ const options = optionsFromArguments(Tremolo.getDefaults(), arguments, [
"frequency", "frequency",
"depth", "depth",
]); ]);
super(options);
this._lfoL = new LFO({ this._lfoL = new LFO({
context: this.context, context: this.context,

View file

@ -48,16 +48,11 @@ export class Vibrato extends Effect<VibratoOptions> {
constructor(frequency?: Frequency, depth?: NormalRange); constructor(frequency?: Frequency, depth?: NormalRange);
constructor(options?: Partial<VibratoOptions>); constructor(options?: Partial<VibratoOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Vibrato.getDefaults(), arguments, [
"frequency",
"depth",
])
);
const options = optionsFromArguments(Vibrato.getDefaults(), arguments, [ const options = optionsFromArguments(Vibrato.getDefaults(), arguments, [
"frequency", "frequency",
"depth", "depth",
]); ]);
super(options);
this._delayNode = new Delay({ this._delayNode = new Delay({
context: this.context, context: this.context,

View file

@ -59,16 +59,11 @@ export class Loop<
constructor(callback?: (time: Seconds) => void, interval?: Time); constructor(callback?: (time: Seconds) => void, interval?: Time);
constructor(options?: Partial<LoopOptions>); constructor(options?: Partial<LoopOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Loop.getDefaults(), arguments, [
"callback",
"interval",
])
);
const options = optionsFromArguments(Loop.getDefaults(), arguments, [ const options = optionsFromArguments(Loop.getDefaults(), arguments, [
"callback", "callback",
"interval", "interval",
]); ]);
super(options);
this._event = new ToneEvent({ this._event = new ToneEvent({
context: this.context, context: this.context,

View file

@ -83,16 +83,11 @@ export class Part<ValueType = any> extends ToneEvent<ValueType> {
); );
constructor(options?: Partial<PartOptions<ValueType>>); constructor(options?: Partial<PartOptions<ValueType>>);
constructor() { constructor() {
super(
optionsFromArguments(Part.getDefaults(), arguments, [
"callback",
"events",
])
);
const options = optionsFromArguments(Part.getDefaults(), arguments, [ const options = optionsFromArguments(Part.getDefaults(), arguments, [
"callback", "callback",
"events", "events",
]); ]);
super(options);
// make sure things are assigned in the right order // make sure things are assigned in the right order
this._state.increasing = true; this._state.increasing = true;

View file

@ -65,18 +65,12 @@ export class Pattern<ValueType> extends Loop<PatternOptions<ValueType>> {
); );
constructor(options?: Partial<PatternOptions<ValueType>>); constructor(options?: Partial<PatternOptions<ValueType>>);
constructor() { constructor() {
super(
optionsFromArguments(Pattern.getDefaults(), arguments, [
"callback",
"values",
"pattern",
])
);
const options = optionsFromArguments(Pattern.getDefaults(), arguments, [ const options = optionsFromArguments(Pattern.getDefaults(), arguments, [
"callback", "callback",
"values", "values",
"pattern", "pattern",
]); ]);
super(options);
this.callback = options.callback; this.callback = options.callback;
this._values = options.values; this._values = options.values;

View file

@ -75,18 +75,12 @@ export class Sequence<ValueType = any> extends ToneEvent<ValueType> {
); );
constructor(options?: Partial<SequenceOptions<ValueType>>); constructor(options?: Partial<SequenceOptions<ValueType>>);
constructor() { constructor() {
super(
optionsFromArguments(Sequence.getDefaults(), arguments, [
"callback",
"events",
"subdivision",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
Sequence.getDefaults(), Sequence.getDefaults(),
arguments, arguments,
["callback", "events", "subdivision"] ["callback", "events", "subdivision"]
); );
super(options);
this._subdivision = this.toTicks(options.subdivision); this._subdivision = this.toTicks(options.subdivision);

View file

@ -124,17 +124,12 @@ export class ToneEvent<ValueType = any> extends ToneWithContext<
constructor(callback?: ToneEventCallback<ValueType>, value?: ValueType); constructor(callback?: ToneEventCallback<ValueType>, value?: ValueType);
constructor(options?: Partial<ToneEventOptions<ValueType>>); constructor(options?: Partial<ToneEventOptions<ValueType>>);
constructor() { constructor() {
super(
optionsFromArguments(ToneEvent.getDefaults(), arguments, [
"callback",
"value",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
ToneEvent.getDefaults(), ToneEvent.getDefaults(),
arguments, arguments,
["callback", "value"] ["callback", "value"]
); );
super(options);
this._loop = options.loop; this._loop = options.loop;
this.callback = options.callback; this.callback = options.callback;

View file

@ -84,8 +84,8 @@ export class DuoSynth extends Monophonic<DuoSynthOptions> {
constructor(options?: RecursivePartial<DuoSynthOptions>); constructor(options?: RecursivePartial<DuoSynthOptions>);
constructor() { constructor() {
super(optionsFromArguments(DuoSynth.getDefaults(), arguments));
const options = optionsFromArguments(DuoSynth.getDefaults(), arguments); const options = optionsFromArguments(DuoSynth.getDefaults(), arguments);
super(options);
this.voice0 = new MonoSynth( this.voice0 = new MonoSynth(
Object.assign(options.voice0, { Object.assign(options.voice0, {

View file

@ -33,8 +33,8 @@ export class FMSynth extends ModulationSynth<FMSynthOptions> {
constructor(options?: RecursivePartial<FMSynthOptions>); constructor(options?: RecursivePartial<FMSynthOptions>);
constructor() { constructor() {
super(optionsFromArguments(FMSynth.getDefaults(), arguments));
const options = optionsFromArguments(FMSynth.getDefaults(), arguments); const options = optionsFromArguments(FMSynth.getDefaults(), arguments);
super(options);
this.modulationIndex = new Multiply({ this.modulationIndex = new Multiply({
context: this.context, context: this.context,

View file

@ -52,11 +52,11 @@ export abstract class Instrument<
constructor(options?: Partial<InstrumentOptions>); constructor(options?: Partial<InstrumentOptions>);
constructor() { constructor() {
super(optionsFromArguments(Instrument.getDefaults(), arguments));
const options = optionsFromArguments( const options = optionsFromArguments(
Instrument.getDefaults(), Instrument.getDefaults(),
arguments arguments
); );
super(options);
this._volume = this.output = new Volume({ this._volume = this.output = new Volume({
context: this.context, context: this.context,

View file

@ -53,11 +53,11 @@ export class MembraneSynth extends Synth<MembraneSynthOptions> {
*/ */
constructor(options?: RecursivePartial<MembraneSynthOptions>); constructor(options?: RecursivePartial<MembraneSynthOptions>);
constructor() { constructor() {
super(optionsFromArguments(MembraneSynth.getDefaults(), arguments));
const options = optionsFromArguments( const options = optionsFromArguments(
MembraneSynth.getDefaults(), MembraneSynth.getDefaults(),
arguments arguments
); );
super(options);
this.pitchDecay = options.pitchDecay; this.pitchDecay = options.pitchDecay;
this.octaves = options.octaves; this.octaves = options.octaves;

View file

@ -97,11 +97,11 @@ export class MetalSynth extends Monophonic<MetalSynthOptions> {
constructor(options?: RecursivePartial<MetalSynthOptions>); constructor(options?: RecursivePartial<MetalSynthOptions>);
constructor() { constructor() {
super(optionsFromArguments(MetalSynth.getDefaults(), arguments));
const options = optionsFromArguments( const options = optionsFromArguments(
MetalSynth.getDefaults(), MetalSynth.getDefaults(),
arguments arguments
); );
super(options);
this.detune = new Signal({ this.detune = new Signal({
context: this.context, context: this.context,

View file

@ -88,11 +88,11 @@ export abstract class ModulationSynth<
constructor(options?: RecursivePartial<ModulationSynthOptions>); constructor(options?: RecursivePartial<ModulationSynthOptions>);
constructor() { constructor() {
super(optionsFromArguments(ModulationSynth.getDefaults(), arguments));
const options = optionsFromArguments( const options = optionsFromArguments(
ModulationSynth.getDefaults(), ModulationSynth.getDefaults(),
arguments arguments
); );
super(options);
this._carrier = new Synth({ this._carrier = new Synth({
context: this.context, context: this.context,

View file

@ -77,11 +77,11 @@ export class MonoSynth extends Monophonic<MonoSynthOptions> {
constructor(options?: RecursivePartial<MonoSynthOptions>); constructor(options?: RecursivePartial<MonoSynthOptions>);
constructor() { constructor() {
super(optionsFromArguments(MonoSynth.getDefaults(), arguments));
const options = optionsFromArguments( const options = optionsFromArguments(
MonoSynth.getDefaults(), MonoSynth.getDefaults(),
arguments arguments
); );
super(options);
this.oscillator = new OmniOscillator( this.oscillator = new OmniOscillator(
Object.assign(options.oscillator, { Object.assign(options.oscillator, {

View file

@ -49,11 +49,11 @@ export abstract class Monophonic<
constructor(options?: Partial<MonophonicOptions>); constructor(options?: Partial<MonophonicOptions>);
constructor() { constructor() {
super(optionsFromArguments(Monophonic.getDefaults(), arguments));
const options = optionsFromArguments( const options = optionsFromArguments(
Monophonic.getDefaults(), Monophonic.getDefaults(),
arguments arguments
); );
super(options);
this.portamento = options.portamento; this.portamento = options.portamento;
this.onsilence = options.onsilence; this.onsilence = options.onsilence;

View file

@ -43,11 +43,12 @@ export class NoiseSynth extends Instrument<NoiseSynthOptions> {
constructor(options?: RecursivePartial<NoiseSynthOptions>); constructor(options?: RecursivePartial<NoiseSynthOptions>);
constructor() { constructor() {
super(optionsFromArguments(NoiseSynth.getDefaults(), arguments));
const options = optionsFromArguments( const options = optionsFromArguments(
NoiseSynth.getDefaults(), NoiseSynth.getDefaults(),
arguments arguments
); );
super(options);
this.noise = new Noise( this.noise = new Noise(
Object.assign( Object.assign(
{ {

View file

@ -52,11 +52,11 @@ export class PluckSynth extends Instrument<PluckSynthOptions> {
constructor(options?: RecursivePartial<PluckSynthOptions>); constructor(options?: RecursivePartial<PluckSynthOptions>);
constructor() { constructor() {
super(optionsFromArguments(PluckSynth.getDefaults(), arguments));
const options = optionsFromArguments( const options = optionsFromArguments(
PluckSynth.getDefaults(), PluckSynth.getDefaults(),
arguments arguments
); );
super(options);
this._noise = new Noise({ this._noise = new Noise({
context: this.context, context: this.context,

View file

@ -137,17 +137,12 @@ export class PolySynth<
); );
constructor(options?: Partial<PolySynthOptions<Voice>>); constructor(options?: Partial<PolySynthOptions<Voice>>);
constructor() { constructor() {
super(
optionsFromArguments(PolySynth.getDefaults(), arguments, [
"voice",
"options",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
PolySynth.getDefaults(), PolySynth.getDefaults(),
arguments, arguments,
["voice", "options"] ["voice", "options"]
); );
super(options);
// check against the old API (pre 14.3.0) // check against the old API (pre 14.3.0)
assert( assert(

View file

@ -110,20 +110,13 @@ export class Sampler extends Instrument<SamplerOptions> {
); );
constructor(options?: Partial<SamplerOptions>); constructor(options?: Partial<SamplerOptions>);
constructor() { constructor() {
super(
optionsFromArguments(
Sampler.getDefaults(),
arguments,
["urls", "onload", "baseUrl"],
"urls"
)
);
const options = optionsFromArguments( const options = optionsFromArguments(
Sampler.getDefaults(), Sampler.getDefaults(),
arguments, arguments,
["urls", "onload", "baseUrl"], ["urls", "onload", "baseUrl"],
"urls" "urls"
); );
super(options);
const urlMap = {}; const urlMap = {};
Object.keys(options.urls).forEach((note) => { Object.keys(options.urls).forEach((note) => {

View file

@ -64,8 +64,8 @@ export class Synth<
*/ */
constructor(options?: RecursivePartial<SynthOptions>); constructor(options?: RecursivePartial<SynthOptions>);
constructor() { constructor() {
super(optionsFromArguments(Synth.getDefaults(), arguments));
const options = optionsFromArguments(Synth.getDefaults(), arguments); const options = optionsFromArguments(Synth.getDefaults(), arguments);
super(options);
this.oscillator = new OmniOscillator( this.oscillator = new OmniOscillator(
Object.assign( Object.assign(

View file

@ -43,11 +43,7 @@ export class Add extends Signal {
constructor(value?: number); constructor(value?: number);
constructor(options?: Partial<SignalOptions<"number">>); constructor(options?: Partial<SignalOptions<"number">>);
constructor() { constructor() {
super( super(optionsFromArguments(Add.getDefaults(), arguments, ["value"]));
Object.assign(
optionsFromArguments(Add.getDefaults(), arguments, ["value"])
)
);
connectSeries(this._constantSource, this._sum); connectSeries(this._constantSource, this._sum);
} }

View file

@ -55,18 +55,12 @@ export class GreaterThan extends Signal<"number"> {
constructor(value?: number); constructor(value?: number);
constructor(options?: Partial<GreaterThanOptions>); constructor(options?: Partial<GreaterThanOptions>);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(GreaterThan.getDefaults(), arguments, [
"value",
])
)
);
const options = optionsFromArguments( const options = optionsFromArguments(
GreaterThan.getDefaults(), GreaterThan.getDefaults(),
arguments, arguments,
["value"] ["value"]
); );
super(options);
this._subtract = this.input = new Subtract({ this._subtract = this.input = new Subtract({
context: this.context, context: this.context,

View file

@ -35,11 +35,7 @@ export class GreaterThanZero extends SignalOperator<GreaterThanZeroOptions> {
constructor(options?: Partial<GreaterThanZeroOptions>); constructor(options?: Partial<GreaterThanZeroOptions>);
constructor() { constructor() {
super( super(optionsFromArguments(GreaterThanZero.getDefaults(), arguments));
Object.assign(
optionsFromArguments(GreaterThanZero.getDefaults(), arguments)
)
);
this._thresh = this.output = new WaveShaper({ this._thresh = this.output = new WaveShaper({
context: this.context, context: this.context,

View file

@ -59,18 +59,12 @@ export class Multiply<
constructor(value?: number); constructor(value?: number);
constructor(options?: Partial<SignalOptions<TypeName>>); constructor(options?: Partial<SignalOptions<TypeName>>);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(Multiply.getDefaults(), arguments, [
"value",
])
)
);
const options = optionsFromArguments( const options = optionsFromArguments(
Multiply.getDefaults(), Multiply.getDefaults(),
arguments, arguments,
["value"] ["value"]
); );
super(options);
this._mult = this._mult =
this.input = this.input =

View file

@ -33,14 +33,10 @@ export class Pow extends SignalOperator<PowOptions> {
constructor(value?: number); constructor(value?: number);
constructor(options?: Partial<PowOptions>); constructor(options?: Partial<PowOptions>);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(Pow.getDefaults(), arguments, ["value"])
)
);
const options = optionsFromArguments(Pow.getDefaults(), arguments, [ const options = optionsFromArguments(Pow.getDefaults(), arguments, [
"value", "value",
]); ]);
super(options);
this._exponentScaler = this._exponentScaler =
this.input = this.input =

View file

@ -59,18 +59,11 @@ export class Scale<
constructor(min?: number, max?: number); constructor(min?: number, max?: number);
constructor(options?: Partial<ScaleOptions>); constructor(options?: Partial<ScaleOptions>);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(Scale.getDefaults(), arguments, [
"min",
"max",
])
)
);
const options = optionsFromArguments(Scale.getDefaults(), arguments, [ const options = optionsFromArguments(Scale.getDefaults(), arguments, [
"min", "min",
"max", "max",
]); ]);
super(options as Options);
this._mult = this.input = new Multiply({ this._mult = this.input = new Multiply({
context: this.context, context: this.context,

View file

@ -32,20 +32,12 @@ export class ScaleExp extends Scale<ScaleExpOptions> {
constructor(min?: number, max?: number, exponent?: number); constructor(min?: number, max?: number, exponent?: number);
constructor(options?: Partial<ScaleExpOptions>); constructor(options?: Partial<ScaleExpOptions>);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(ScaleExp.getDefaults(), arguments, [
"min",
"max",
"exponent",
])
)
);
const options = optionsFromArguments( const options = optionsFromArguments(
ScaleExp.getDefaults(), ScaleExp.getDefaults(),
arguments, arguments,
["min", "max", "exponent"] ["min", "max", "exponent"]
); );
super(options);
this.input = this._exp = new Pow({ this.input = this._exp = new Pow({
context: this.context, context: this.context,

View file

@ -66,17 +66,11 @@ export class Signal<TypeName extends UnitName = "number">
constructor(value?: UnitMap[TypeName], units?: TypeName); constructor(value?: UnitMap[TypeName], units?: TypeName);
constructor(options?: Partial<SignalOptions<TypeName>>); constructor(options?: Partial<SignalOptions<TypeName>>);
constructor() { constructor() {
super(
optionsFromArguments(Signal.getDefaults(), arguments, [
"value",
"units",
])
);
const options = optionsFromArguments(Signal.getDefaults(), arguments, [ const options = optionsFromArguments(Signal.getDefaults(), arguments, [
"value", "value",
"units", "units",
]) as SignalOptions<TypeName>; ]) as SignalOptions<TypeName>;
super(options);
this.output = this._constantSource = new ToneConstantSource({ this.output = this._constantSource = new ToneConstantSource({
context: this.context, context: this.context,

View file

@ -17,11 +17,9 @@ export abstract class SignalOperator<
constructor(options?: Partial<Options>); constructor(options?: Partial<Options>);
constructor() { constructor() {
super( super(
Object.assign( optionsFromArguments(SignalOperator.getDefaults(), arguments, [
optionsFromArguments(SignalOperator.getDefaults(), arguments, [ "context",
"context", ])
])
)
); );
} }

View file

@ -54,11 +54,7 @@ export class Subtract extends Signal {
constructor(options?: Partial<SignalOptions<"number">>); constructor(options?: Partial<SignalOptions<"number">>);
constructor() { constructor() {
super( super(
Object.assign( optionsFromArguments(Subtract.getDefaults(), arguments, ["value"])
optionsFromArguments(Subtract.getDefaults(), arguments, [
"value",
])
)
); );
connectSeries(this._constantSource, this._neg, this._sum); connectSeries(this._constantSource, this._neg, this._sum);

View file

@ -51,16 +51,11 @@ export class SyncedSignal<
constructor(value?: UnitMap[TypeName], units?: TypeName); constructor(value?: UnitMap[TypeName], units?: TypeName);
constructor(options?: Partial<SignalOptions<TypeName>>); constructor(options?: Partial<SignalOptions<TypeName>>);
constructor() { constructor() {
super(
optionsFromArguments(Signal.getDefaults(), arguments, [
"value",
"units",
])
);
const options = optionsFromArguments(Signal.getDefaults(), arguments, [ const options = optionsFromArguments(Signal.getDefaults(), arguments, [
"value", "value",
"units", "units",
]) as SignalOptions<TypeName>; ]) as SignalOptions<TypeName>;
super(options);
this._lastVal = options.value; this._lastVal = options.value;
this._synced = this.context.transport.scheduleRepeat( this._synced = this.context.transport.scheduleRepeat(

View file

@ -42,16 +42,12 @@ export class ToneConstantSource<
constructor(offset: UnitMap[TypeName]); constructor(offset: UnitMap[TypeName]);
constructor(options?: Partial<ToneConstantSourceOptions<TypeName>>); constructor(options?: Partial<ToneConstantSourceOptions<TypeName>>);
constructor() { constructor() {
super(
optionsFromArguments(ToneConstantSource.getDefaults(), arguments, [
"offset",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
ToneConstantSource.getDefaults(), ToneConstantSource.getDefaults(),
arguments, arguments,
["offset"] ["offset"]
); );
super(options);
connect(this._source, this._gainNode); connect(this._source, this._gainNode);

View file

@ -59,19 +59,12 @@ export class WaveShaper extends SignalOperator<WaveShaperOptions> {
constructor(mapping?: WaveShaperMapping, length?: number); constructor(mapping?: WaveShaperMapping, length?: number);
constructor(options?: Partial<WaveShaperOptions>); constructor(options?: Partial<WaveShaperOptions>);
constructor() { constructor() {
super(
Object.assign(
optionsFromArguments(WaveShaper.getDefaults(), arguments, [
"mapping",
"length",
])
)
);
const options = optionsFromArguments( const options = optionsFromArguments(
WaveShaper.getDefaults(), WaveShaper.getDefaults(),
arguments, arguments,
["mapping", "length"] ["mapping", "length"]
); );
super(options);
if ( if (
isArray(options.mapping) || isArray(options.mapping) ||

View file

@ -33,9 +33,7 @@ export class Zero extends SignalOperator<ToneAudioNodeOptions> {
constructor(options?: Partial<ToneAudioNodeOptions>); constructor(options?: Partial<ToneAudioNodeOptions>);
constructor() { constructor() {
super( super(optionsFromArguments(Zero.getDefaults(), arguments));
Object.assign(optionsFromArguments(Zero.getDefaults(), arguments))
);
connect(this.context.getConstant(0), this._gain); connect(this.context.getConstant(0), this._gain);
} }

View file

@ -69,10 +69,10 @@ export class Noise extends Source<NoiseOptions> {
constructor(type?: NoiseType); constructor(type?: NoiseType);
constructor(options?: Partial<NoiseOptions>); constructor(options?: Partial<NoiseOptions>);
constructor() { constructor() {
super(optionsFromArguments(Noise.getDefaults(), arguments, ["type"]));
const options = optionsFromArguments(Noise.getDefaults(), arguments, [ const options = optionsFromArguments(Noise.getDefaults(), arguments, [
"type", "type",
]); ]);
super(options);
this._playbackRate = options.playbackRate; this._playbackRate = options.playbackRate;
this.type = options.type; this.type = options.type;

View file

@ -73,14 +73,12 @@ export class UserMedia extends ToneAudioNode<UserMediaOptions> {
constructor(volume?: Decibels); constructor(volume?: Decibels);
constructor(options?: Partial<UserMediaOptions>); constructor(options?: Partial<UserMediaOptions>);
constructor() { constructor() {
super(
optionsFromArguments(UserMedia.getDefaults(), arguments, ["volume"])
);
const options = optionsFromArguments( const options = optionsFromArguments(
UserMedia.getDefaults(), UserMedia.getDefaults(),
arguments, arguments,
["volume"] ["volume"]
); );
super(options);
this._volume = this.output = new Volume({ this._volume = this.output = new Volume({
context: this.context, context: this.context,

View file

@ -92,17 +92,12 @@ export class GrainPlayer extends Source<GrainPlayerOptions> {
); );
constructor(options?: Partial<GrainPlayerOptions>); constructor(options?: Partial<GrainPlayerOptions>);
constructor() { constructor() {
super(
optionsFromArguments(GrainPlayer.getDefaults(), arguments, [
"url",
"onload",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
GrainPlayer.getDefaults(), GrainPlayer.getDefaults(),
arguments, arguments,
["url", "onload"] ["url", "onload"]
); );
super(options);
this.buffer = new ToneAudioBuffer({ this.buffer = new ToneAudioBuffer({
onload: options.onload, onload: options.onload,

View file

@ -91,16 +91,11 @@ export class Player extends Source<PlayerOptions> {
); );
constructor(options?: Partial<PlayerOptions>); constructor(options?: Partial<PlayerOptions>);
constructor() { constructor() {
super(
optionsFromArguments(Player.getDefaults(), arguments, [
"url",
"onload",
])
);
const options = optionsFromArguments(Player.getDefaults(), arguments, [ const options = optionsFromArguments(Player.getDefaults(), arguments, [
"url", "url",
"onload", "onload",
]); ]);
super(options);
this._buffer = new ToneAudioBuffer({ this._buffer = new ToneAudioBuffer({
onload: this._onload.bind(this, options.onload), onload: this._onload.bind(this, options.onload),

View file

@ -87,20 +87,13 @@ export class Players extends ToneAudioNode<PlayersOptions> {
); );
constructor(options?: Partial<PlayersOptions>); constructor(options?: Partial<PlayersOptions>);
constructor() { constructor() {
super(
optionsFromArguments(
Players.getDefaults(),
arguments,
["urls", "onload"],
"urls"
)
);
const options = optionsFromArguments( const options = optionsFromArguments(
Players.getDefaults(), Players.getDefaults(),
arguments, arguments,
["urls", "onload"], ["urls", "onload"],
"urls" "urls"
); );
super(options);
/** /**
* The output volume node * The output volume node

View file

@ -67,17 +67,12 @@ export class ToneBufferSource extends OneShotSource<ToneBufferSourceOptions> {
); );
constructor(options?: Partial<ToneBufferSourceOptions>); constructor(options?: Partial<ToneBufferSourceOptions>);
constructor() { constructor() {
super(
optionsFromArguments(ToneBufferSource.getDefaults(), arguments, [
"url",
"onload",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
ToneBufferSource.getDefaults(), ToneBufferSource.getDefaults(),
arguments, arguments,
["url", "onload"] ["url", "onload"]
); );
super(options);
connect(this._source, this._gainNode); connect(this._source, this._gainNode);
this._source.onended = () => this._stopSource(); this._source.onended = () => this._stopSource();

View file

@ -97,18 +97,12 @@ export class AMOscillator
); );
constructor(options?: Partial<AMConstructorOptions>); constructor(options?: Partial<AMConstructorOptions>);
constructor() { constructor() {
super(
optionsFromArguments(AMOscillator.getDefaults(), arguments, [
"frequency",
"type",
"modulationType",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
AMOscillator.getDefaults(), AMOscillator.getDefaults(),
arguments, arguments,
["frequency", "type", "modulationType"] ["frequency", "type", "modulationType"]
); );
super(options);
this._carrier = new Oscillator({ this._carrier = new Oscillator({
context: this.context, context: this.context,

View file

@ -99,18 +99,12 @@ export class FMOscillator
); );
constructor(options?: Partial<FMConstructorOptions>); constructor(options?: Partial<FMConstructorOptions>);
constructor() { constructor() {
super(
optionsFromArguments(FMOscillator.getDefaults(), arguments, [
"frequency",
"type",
"modulationType",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
FMOscillator.getDefaults(), FMOscillator.getDefaults(),
arguments, arguments,
["frequency", "type", "modulationType"] ["frequency", "type", "modulationType"]
); );
super(options);
this._carrier = new Oscillator({ this._carrier = new Oscillator({
context: this.context, context: this.context,

View file

@ -79,18 +79,12 @@ export class FatOscillator
); );
constructor(options?: Partial<FatConstructorOptions>); constructor(options?: Partial<FatConstructorOptions>);
constructor() { constructor() {
super(
optionsFromArguments(FatOscillator.getDefaults(), arguments, [
"frequency",
"type",
"spread",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
FatOscillator.getDefaults(), FatOscillator.getDefaults(),
arguments, arguments,
["frequency", "type", "spread"] ["frequency", "type", "spread"]
); );
super(options);
this.frequency = new Signal({ this.frequency = new Signal({
context: this.context, context: this.context,

View file

@ -124,18 +124,12 @@ export class LFO extends ToneAudioNode<LFOOptions> {
constructor(frequency?: Frequency, min?: number, max?: number); constructor(frequency?: Frequency, min?: number, max?: number);
constructor(options?: Partial<LFOOptions>); constructor(options?: Partial<LFOOptions>);
constructor() { constructor() {
super(
optionsFromArguments(LFO.getDefaults(), arguments, [
"frequency",
"min",
"max",
])
);
const options = optionsFromArguments(LFO.getDefaults(), arguments, [ const options = optionsFromArguments(LFO.getDefaults(), arguments, [
"frequency", "frequency",
"min", "min",
"max", "max",
]); ]);
super(options);
this._oscillator = new Oscillator( this._oscillator = new Oscillator(
options as ToneOscillatorConstructorOptions options as ToneOscillatorConstructorOptions

View file

@ -114,17 +114,12 @@ export class OmniOscillator<OscType extends AnyOscillator>
constructor(frequency?: Frequency, type?: OmniOscillatorType); constructor(frequency?: Frequency, type?: OmniOscillatorType);
constructor(options?: Partial<OmniOscillatorOptions>); constructor(options?: Partial<OmniOscillatorOptions>);
constructor() { constructor() {
super(
optionsFromArguments(OmniOscillator.getDefaults(), arguments, [
"frequency",
"type",
])
);
const options = optionsFromArguments( const options = optionsFromArguments(
OmniOscillator.getDefaults(), OmniOscillator.getDefaults(),
arguments, arguments,
["frequency", "type"] ["frequency", "type"]
); );
super(options);
this.frequency = new Signal({ this.frequency = new Signal({
context: this.context, context: this.context,

Some files were not shown because too many files have changed in this diff Show more