diff options
-rw-r--r-- | components/script/dom/audionode.rs | 10 | ||||
-rw-r--r-- | components/script/dom/channelmergernode.rs | 83 | ||||
-rw-r--r-- | components/script/dom/mod.rs | 1 | ||||
-rw-r--r-- | components/script/dom/webidls/ChannelMergerNode.webidl | 16 |
4 files changed, 110 insertions, 0 deletions
diff --git a/components/script/dom/audionode.rs b/components/script/dom/audionode.rs index 4690f74245e..b48a902a8b4 100644 --- a/components/script/dom/audionode.rs +++ b/components/script/dom/audionode.rs @@ -218,6 +218,11 @@ impl AudioNodeMethods for AudioNode { return Err(Error::NotSupported) } } + EventTargetTypeId::AudioNode(AudioNodeTypeId::ChannelMergerNode) => { + if value != 1 { + return Err(Error::InvalidState) + } + } // XXX We do not support any of the other AudioNodes with // constraints yet. Add more cases here as we add support // for new AudioNodes. @@ -256,6 +261,11 @@ impl AudioNodeMethods for AudioNode { return Err(Error::NotSupported) } } + EventTargetTypeId::AudioNode(AudioNodeTypeId::ChannelMergerNode) => { + if value != ChannelCountMode::Explicit { + return Err(Error::InvalidState) + } + } // XXX We do not support any of the other AudioNodes with // constraints yet. Add more cases here as we add support // for new AudioNodes. diff --git a/components/script/dom/channelmergernode.rs b/components/script/dom/channelmergernode.rs new file mode 100644 index 00000000000..93fcf51b27a --- /dev/null +++ b/components/script/dom/channelmergernode.rs @@ -0,0 +1,83 @@ +/* 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 http://mozilla.org/MPL/2.0/. */ + +use dom::audionode::{AudioNode, MAX_CHANNEL_COUNT}; +use dom::baseaudiocontext::BaseAudioContext; +use dom::bindings::codegen::Bindings::AudioNodeBinding::{ChannelCountMode, ChannelInterpretation}; +use dom::bindings::codegen::Bindings::AudioNodeBinding::AudioNodeOptions; +use dom::bindings::codegen::Bindings::ChannelMergerNodeBinding::{self, ChannelMergerOptions}; +use dom::bindings::error::{Error, Fallible}; +use dom::bindings::reflector::reflect_dom_object; +use dom::bindings::root::DomRoot; +use dom::window::Window; +use dom_struct::dom_struct; +use servo_media::audio::channel_node::ChannelNodeOptions; +use servo_media::audio::node::AudioNodeInit; + +#[dom_struct] +pub struct ChannelMergerNode { + node: AudioNode, +} + +impl ChannelMergerNode { + #[allow(unrooted_must_root)] + pub fn new_inherited( + _: &Window, + context: &BaseAudioContext, + options: &ChannelMergerOptions, + ) -> Fallible<ChannelMergerNode> { + let mut node_options = AudioNodeOptions::empty(); + let count = options.parent.channelCount.unwrap_or(1); + let mode = options.parent.channelCountMode.unwrap_or(ChannelCountMode::Explicit); + let interpretation = options.parent.channelInterpretation.unwrap_or(ChannelInterpretation::Speakers); + + if count != 1 || mode != ChannelCountMode::Explicit { + return Err(Error::InvalidState) + } + + if options.numberOfInputs < 1 || options.numberOfInputs > MAX_CHANNEL_COUNT { + return Err(Error::IndexSize) + } + + node_options.channelCount = Some(count); + node_options.channelCountMode = Some(mode); + node_options.channelInterpretation = Some(interpretation); + let node = AudioNode::new_inherited( + AudioNodeInit::ChannelMergerNode(options.into()), + context, + &node_options, + options.numberOfInputs, // inputs + 1, // outputs + ); + Ok(ChannelMergerNode { + node, + }) + } + + #[allow(unrooted_must_root)] + pub fn new( + window: &Window, + context: &BaseAudioContext, + options: &ChannelMergerOptions, + ) -> Fallible<DomRoot<ChannelMergerNode>> { + let node = ChannelMergerNode::new_inherited(window, context, options)?; + Ok(reflect_dom_object(Box::new(node), window, ChannelMergerNodeBinding::Wrap)) + } + + pub fn Constructor( + window: &Window, + context: &BaseAudioContext, + options: &ChannelMergerOptions, + ) -> Fallible<DomRoot<ChannelMergerNode>> { + ChannelMergerNode::new(window, context, options) + } +} + +impl<'a> From<&'a ChannelMergerOptions> for ChannelNodeOptions { + fn from(options: &'a ChannelMergerOptions) -> Self { + Self { + channels: options.numberOfInputs as u8, + } + } +} diff --git a/components/script/dom/mod.rs b/components/script/dom/mod.rs index 758c4284979..04a234a80d3 100644 --- a/components/script/dom/mod.rs +++ b/components/script/dom/mod.rs @@ -241,6 +241,7 @@ pub mod bluetoothuuid; pub mod canvasgradient; pub mod canvaspattern; pub mod canvasrenderingcontext2d; +pub mod channelmergernode; pub mod characterdata; pub mod client; pub mod closeevent; diff --git a/components/script/dom/webidls/ChannelMergerNode.webidl b/components/script/dom/webidls/ChannelMergerNode.webidl new file mode 100644 index 00000000000..071da8971a0 --- /dev/null +++ b/components/script/dom/webidls/ChannelMergerNode.webidl @@ -0,0 +1,16 @@ +/* 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 http://mozilla.org/MPL/2.0/. */ +/* + * The origin of this IDL file is + * https://webaudio.github.io/web-audio-api/#channelmergernode + */ + +dictionary ChannelMergerOptions : AudioNodeOptions { + unsigned long numberOfInputs = 6; +}; + +[Exposed=Window, + Constructor (BaseAudioContext context, optional ChannelMergerOptions options)] +interface ChannelMergerNode : AudioNode { +}; |