Skip to content

Commit

Permalink
[WebAudio] Unused method in BaseAudioContext
Browse files Browse the repository at this point in the history
https://bugs.webkit.org/show_bug.cgi?id=263480
rdar://117283688

Reviewed by Chris Dumez.

One of the decodeAudioData method is unused, we can remove it which also allow to simplify the code and remove unnecessary tests.

* Source/WebCore/Modules/webaudio/BaseAudioContext.cpp:
(WebCore::BaseAudioContext::decodeAudioData):
* Source/WebCore/Modules/webaudio/BaseAudioContext.h:

Canonical link: https://commits.webkit.org/269616@main
  • Loading branch information
jyavenard committed Oct 21, 2023
1 parent b572a08 commit e854e78
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 14 deletions.
17 changes: 5 additions & 12 deletions Source/WebCore/Modules/webaudio/BaseAudioContext.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -284,15 +284,10 @@ ExceptionOr<Ref<AudioBuffer>> BaseAudioContext::createBuffer(unsigned numberOfCh
return AudioBuffer::create(AudioBufferOptions {numberOfChannels, length, sampleRate});
}

void BaseAudioContext::decodeAudioData(Ref<ArrayBuffer>&& audioData, RefPtr<AudioBufferCallback>&& successCallback, RefPtr<AudioBufferCallback>&& errorCallback)
void BaseAudioContext::decodeAudioData(Ref<ArrayBuffer>&& audioData, RefPtr<AudioBufferCallback>&& successCallback, RefPtr<AudioBufferCallback>&& errorCallback, Ref<DeferredPromise>&& promise)
{
decodeAudioData(WTFMove(audioData), WTFMove(successCallback), WTFMove(errorCallback), std::nullopt);
}

void BaseAudioContext::decodeAudioData(Ref<ArrayBuffer>&& audioData, RefPtr<AudioBufferCallback>&& successCallback, RefPtr<AudioBufferCallback>&& errorCallback, std::optional<Ref<DeferredPromise>>&& promise)
{
if (promise && (!document() || !document()->isFullyActive())) {
promise.value()->reject(Exception { InvalidStateError, "Document is not fully active"_s });
if (!document() || !document()->isFullyActive()) {
promise->reject(Exception { InvalidStateError, "Document is not fully active"_s });
return;
}

Expand All @@ -303,15 +298,13 @@ void BaseAudioContext::decodeAudioData(Ref<ArrayBuffer>&& audioData, RefPtr<Audi
p->whenSettled(RunLoop::main(), [this, activity = makePendingActivity(*this), successCallback = WTFMove(successCallback), errorCallback = WTFMove(errorCallback), promise = WTFMove(promise)] (DecodingTaskPromise::Result&& result) mutable {
queueTaskKeepingObjectAlive(*this, TaskSource::InternalAsyncTask, [successCallback = WTFMove(successCallback), errorCallback = WTFMove(errorCallback), promise = WTFMove(promise), result = WTFMove(result)]() mutable {
if (!result) {
if (promise)
promise.value()->reject(WTFMove(result.error()));
promise->reject(WTFMove(result.error()));
if (errorCallback)
errorCallback->handleEvent(nullptr);
return;
}
auto audioBuffer = WTFMove(result.value());
if (promise)
promise.value()->resolve<IDLInterface<AudioBuffer>>(audioBuffer.get());
promise->resolve<IDLInterface<AudioBuffer>>(audioBuffer.get());
if (successCallback)
successCallback->handleEvent(audioBuffer.ptr());
});
Expand Down
3 changes: 1 addition & 2 deletions Source/WebCore/Modules/webaudio/BaseAudioContext.h
Original file line number Diff line number Diff line change
Expand Up @@ -118,8 +118,7 @@ class BaseAudioContext
float sampleRate() const { return destination().sampleRate(); }

// Asynchronous audio file data decoding.
void decodeAudioData(Ref<JSC::ArrayBuffer>&&, RefPtr<AudioBufferCallback>&&, RefPtr<AudioBufferCallback>&&);
void decodeAudioData(Ref<JSC::ArrayBuffer>&&, RefPtr<AudioBufferCallback>&&, RefPtr<AudioBufferCallback>&&, std::optional<Ref<DeferredPromise>>&&);
void decodeAudioData(Ref<JSC::ArrayBuffer>&&, RefPtr<AudioBufferCallback>&&, RefPtr<AudioBufferCallback>&&, Ref<DeferredPromise>&&);

AudioListener& listener() { return m_listener; }

Expand Down

0 comments on commit e854e78

Please sign in to comment.