aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/messageevent.rs
diff options
context:
space:
mode:
authorJosh Matthews <josh@joshmatthews.net>2023-05-28 22:43:55 -0400
committerJosh Matthews <josh@joshmatthews.net>2023-05-28 23:23:12 -0400
commitdbff26bce05d404027ef5bbfd85fb5995e4726bc (patch)
tree6ebb631eef396c2f387fe8269b0d59bde0dccae2 /components/script/dom/messageevent.rs
parentd9600ff50f3c1bdd8c44e2dfc15a18416d80cb82 (diff)
downloadservo-dbff26bce05d404027ef5bbfd85fb5995e4726bc.tar.gz
servo-dbff26bce05d404027ef5bbfd85fb5995e4726bc.zip
Support arbitrary protos when wrapping DOM objects with constructors.
Diffstat (limited to 'components/script/dom/messageevent.rs')
-rw-r--r--components/script/dom/messageevent.rs46
1 files changed, 40 insertions, 6 deletions
diff --git a/components/script/dom/messageevent.rs b/components/script/dom/messageevent.rs
index c00e2bc5dec..9c2428912f8 100644
--- a/components/script/dom/messageevent.rs
+++ b/components/script/dom/messageevent.rs
@@ -9,7 +9,7 @@ use crate::dom::bindings::codegen::Bindings::MessageEventBinding::MessageEventMe
use crate::dom::bindings::codegen::UnionTypes::WindowProxyOrMessagePortOrServiceWorker;
use crate::dom::bindings::error::Fallible;
use crate::dom::bindings::inheritance::Castable;
-use crate::dom::bindings::reflector::reflect_dom_object;
+use crate::dom::bindings::reflector::reflect_dom_object2;
use crate::dom::bindings::root::{Dom, DomRoot};
use crate::dom::bindings::str::DOMString;
use crate::dom::bindings::trace::RootedTraceableBox;
@@ -24,7 +24,7 @@ use crate::script_runtime::JSContext;
use dom_struct::dom_struct;
use js::jsapi::Heap;
use js::jsval::JSVal;
-use js::rust::HandleValue;
+use js::rust::{HandleObject, HandleValue};
use servo_atoms::Atom;
#[unrooted_must_root_lint::must_root]
@@ -91,8 +91,13 @@ impl MessageEvent {
}
pub fn new_uninitialized(global: &GlobalScope) -> DomRoot<MessageEvent> {
+ Self::new_uninitialized_with_proto(global, None)
+ }
+
+ fn new_uninitialized_with_proto(global: &GlobalScope, proto: Option<HandleObject>) -> DomRoot<MessageEvent> {
MessageEvent::new_initialized(
global,
+ proto,
HandleValue::undefined(),
DOMString::new(),
None,
@@ -101,8 +106,9 @@ impl MessageEvent {
)
}
- pub fn new_initialized(
+ fn new_initialized(
global: &GlobalScope,
+ proto: Option<HandleObject>,
data: HandleValue,
origin: DOMString,
source: Option<&WindowProxyOrMessagePortOrServiceWorker>,
@@ -115,7 +121,7 @@ impl MessageEvent {
lastEventId,
ports,
));
- let ev = reflect_dom_object(ev, global);
+ let ev = reflect_dom_object2(ev, global, proto);
ev.data.set(data.get());
ev
@@ -132,7 +138,33 @@ impl MessageEvent {
lastEventId: DOMString,
ports: Vec<DomRoot<MessagePort>>,
) -> DomRoot<MessageEvent> {
- let ev = MessageEvent::new_initialized(global, data, origin, source, lastEventId, ports);
+ Self::new_with_proto(
+ global,
+ None,
+ type_,
+ bubbles,
+ cancelable,
+ data,
+ origin,
+ source,
+ lastEventId,
+ ports,
+ )
+ }
+
+ fn new_with_proto(
+ global: &GlobalScope,
+ proto: Option<HandleObject>,
+ type_: Atom,
+ bubbles: bool,
+ cancelable: bool,
+ data: HandleValue,
+ origin: DOMString,
+ source: Option<&WindowProxyOrMessagePortOrServiceWorker>,
+ lastEventId: DOMString,
+ ports: Vec<DomRoot<MessagePort>>,
+ ) -> DomRoot<MessageEvent> {
+ let ev = MessageEvent::new_initialized(global, proto, data, origin, source, lastEventId, ports);
{
let event = ev.upcast::<Event>();
event.init_event(type_, bubbles, cancelable);
@@ -142,11 +174,13 @@ impl MessageEvent {
pub fn Constructor(
global: &GlobalScope,
+ proto: Option<HandleObject>,
type_: DOMString,
init: RootedTraceableBox<MessageEventBinding::MessageEventInit>,
) -> Fallible<DomRoot<MessageEvent>> {
- let ev = MessageEvent::new(
+ let ev = MessageEvent::new_with_proto(
global,
+ proto,
Atom::from(type_),
init.parent.bubbles,
init.parent.cancelable,