use dom_struct::dom_struct;
use js::rust::HandleObject;
use crate::dom::bindings::codegen::Bindings::MessageChannelBinding::MessageChannelMethods;
use crate::dom::bindings::reflector::{reflect_dom_object_with_proto, Reflector};
use crate::dom::bindings::root::{Dom, DomRoot};
use crate::dom::globalscope::GlobalScope;
use crate::dom::messageport::MessagePort;
use crate::script_runtime::CanGc;
#[dom_struct]
pub struct MessageChannel {
reflector_: Reflector,
port1: Dom<MessagePort>,
port2: Dom<MessagePort>,
}
impl MessageChannel {
fn new(
incumbent: &GlobalScope,
proto: Option<HandleObject>,
can_gc: CanGc,
) -> DomRoot<MessageChannel> {
let port1 = MessagePort::new(incumbent);
let port2 = MessagePort::new(incumbent);
incumbent.track_message_port(&port1, None);
incumbent.track_message_port(&port2, None);
incumbent.entangle_ports(*port1.message_port_id(), *port2.message_port_id());
reflect_dom_object_with_proto(
Box::new(MessageChannel::new_inherited(&port1, &port2)),
incumbent,
proto,
can_gc,
)
}
pub fn new_inherited(port1: &MessagePort, port2: &MessagePort) -> MessageChannel {
MessageChannel {
reflector_: Reflector::new(),
port1: Dom::from_ref(port1),
port2: Dom::from_ref(port2),
}
}
}
impl MessageChannelMethods<crate::DomTypeHolder> for MessageChannel {
fn Constructor(
global: &GlobalScope,
proto: Option<HandleObject>,
can_gc: CanGc,
) -> DomRoot<MessageChannel> {
MessageChannel::new(global, proto, can_gc)
}
fn Port1(&self) -> DomRoot<MessagePort> {
DomRoot::from_ref(&*self.port1)
}
fn Port2(&self) -> DomRoot<MessagePort> {
DomRoot::from_ref(&*self.port2)
}
}