summaryrefslogtreecommitdiff
path: root/Source/WebCore/Modules/webaudio/DelayNode.cpp
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@lorry>2017-06-27 06:07:23 +0000
committerLorry Tar Creator <lorry-tar-importer@lorry>2017-06-27 06:07:23 +0000
commit1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c (patch)
tree46dcd36c86e7fbc6e5df36deb463b33e9967a6f7 /Source/WebCore/Modules/webaudio/DelayNode.cpp
parent32761a6cee1d0dee366b885b7b9c777e67885688 (diff)
downloadWebKitGtk-tarball-master.tar.gz
Diffstat (limited to 'Source/WebCore/Modules/webaudio/DelayNode.cpp')
-rw-r--r--Source/WebCore/Modules/webaudio/DelayNode.cpp17
1 files changed, 11 insertions, 6 deletions
diff --git a/Source/WebCore/Modules/webaudio/DelayNode.cpp b/Source/WebCore/Modules/webaudio/DelayNode.cpp
index 0b0452ceb..7eae8091c 100644
--- a/Source/WebCore/Modules/webaudio/DelayNode.cpp
+++ b/Source/WebCore/Modules/webaudio/DelayNode.cpp
@@ -28,24 +28,29 @@
#include "DelayNode.h"
+#include "DelayProcessor.h"
+
namespace WebCore {
const double maximumAllowedDelayTime = 180;
-DelayNode::DelayNode(AudioContext* context, float sampleRate, double maxDelayTime, ExceptionCode& ec)
+inline DelayNode::DelayNode(AudioContext& context, float sampleRate, double maxDelayTime)
: AudioBasicProcessorNode(context, sampleRate)
{
- if (maxDelayTime <= 0 || maxDelayTime >= maximumAllowedDelayTime) {
- ec = NOT_SUPPORTED_ERR;
- return;
- }
m_processor = std::make_unique<DelayProcessor>(context, sampleRate, 1, maxDelayTime);
setNodeType(NodeTypeDelay);
}
+ExceptionOr<Ref<DelayNode>> DelayNode::create(AudioContext& context, float sampleRate, double maxDelayTime)
+{
+ if (maxDelayTime <= 0 || maxDelayTime >= maximumAllowedDelayTime)
+ return Exception { NOT_SUPPORTED_ERR };
+ return adoptRef(*new DelayNode(context, sampleRate, maxDelayTime));
+}
+
AudioParam* DelayNode::delayTime()
{
- return delayProcessor()->delayTime();
+ return static_cast<DelayProcessor&>(*m_processor).delayTime();
}
} // namespace WebCore