aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/mediastream.rs
diff options
context:
space:
mode:
authorManish Goregaokar <manishsmail@gmail.com>2019-05-07 12:49:47 -0700
committerManish Goregaokar <manishsmail@gmail.com>2019-05-07 17:09:04 -0700
commita9ab13b279d8234a56c58a6907362c4f48dd6138 (patch)
tree30dbd456f915ba1340e2ad326ef1c9d9da2e7c81 /components/script/dom/mediastream.rs
parent106cc4a1f7a9454e0f551d13806cf44a02bc32c9 (diff)
downloadservo-a9ab13b279d8234a56c58a6907362c4f48dd6138.tar.gz
servo-a9ab13b279d8234a56c58a6907362c4f48dd6138.zip
Use MediaStreamTracks in MediaStreams
Diffstat (limited to 'components/script/dom/mediastream.rs')
-rw-r--r--components/script/dom/mediastream.rs37
1 files changed, 26 insertions, 11 deletions
diff --git a/components/script/dom/mediastream.rs b/components/script/dom/mediastream.rs
index 42588afc476..ed80b2c8cb1 100644
--- a/components/script/dom/mediastream.rs
+++ b/components/script/dom/mediastream.rs
@@ -3,38 +3,53 @@
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */
use crate::dom::bindings::cell::DomRefCell;
-use crate::dom::bindings::codegen::Bindings::MediaStreamBinding;
+use crate::dom::bindings::codegen::Bindings::MediaStreamBinding::{self, MediaStreamMethods};
use crate::dom::bindings::reflector::reflect_dom_object;
-use crate::dom::bindings::root::DomRoot;
+use crate::dom::bindings::root::{Dom, DomRoot};
use crate::dom::eventtarget::EventTarget;
use crate::dom::globalscope::GlobalScope;
+use crate::dom::mediastreamtrack::MediaStreamTrack;
use dom_struct::dom_struct;
-use servo_media::streams::registry::MediaStreamId;
+use std::cell::Ref;
#[dom_struct]
pub struct MediaStream {
eventtarget: EventTarget,
- #[ignore_malloc_size_of = "defined in servo-media"]
- tracks: DomRefCell<Vec<MediaStreamId>>,
+ tracks: DomRefCell<Vec<Dom<MediaStreamTrack>>>,
}
impl MediaStream {
- pub fn new_inherited(tracks: Vec<MediaStreamId>) -> MediaStream {
+ pub fn new_inherited() -> MediaStream {
MediaStream {
eventtarget: EventTarget::new_inherited(),
- tracks: DomRefCell::new(tracks),
+ tracks: DomRefCell::new(vec![]),
}
}
- pub fn new(global: &GlobalScope, tracks: Vec<MediaStreamId>) -> DomRoot<MediaStream> {
+ pub fn new(global: &GlobalScope) -> DomRoot<MediaStream> {
reflect_dom_object(
- Box::new(MediaStream::new_inherited(tracks)),
+ Box::new(MediaStream::new_inherited()),
global,
MediaStreamBinding::Wrap,
)
}
- pub fn get_tracks(&self) -> Vec<MediaStreamId> {
- self.tracks.borrow_mut().clone()
+ pub fn get_tracks(&self) -> Ref<[Dom<MediaStreamTrack>]> {
+ Ref::map(self.tracks.borrow(), |tracks| &**tracks)
+ }
+
+ pub fn add_track(&self, track: &MediaStreamTrack) {
+ self.tracks.borrow_mut().push(Dom::from_ref(track))
+ }
+}
+
+impl MediaStreamMethods for MediaStream {
+ /// https://w3c.github.io/mediacapture-main/#dom-mediastream-gettracks
+ fn GetTracks(&self) -> Vec<DomRoot<MediaStreamTrack>> {
+ self.tracks
+ .borrow()
+ .iter()
+ .map(|x| DomRoot::from_ref(&**x))
+ .collect()
}
}