diff options
author | Josh Matthews <josh@joshmatthews.net> | 2014-04-22 17:14:48 -0400 |
---|---|---|
committer | Ms2ger <ms2ger@gmail.com> | 2014-05-27 20:43:52 +0200 |
commit | 003e5bcd4674fc0e78b36ecd783f3045cba852d2 (patch) | |
tree | 8206e58c032795db83c392167129483200ff0f2b /src/components/script/dom/bindings/callback.rs | |
parent | 04931adf70e6dc70d09c2ceb42e2add85f58051d (diff) | |
download | servo-003e5bcd4674fc0e78b36ecd783f3045cba852d2.tar.gz servo-003e5bcd4674fc0e78b36ecd783f3045cba852d2.zip |
Port modern callback handling code from Gecko, and copy related WebIDL parser bits too.
Diffstat (limited to 'src/components/script/dom/bindings/callback.rs')
-rw-r--r-- | src/components/script/dom/bindings/callback.rs | 70 |
1 files changed, 43 insertions, 27 deletions
diff --git a/src/components/script/dom/bindings/callback.rs b/src/components/script/dom/bindings/callback.rs index 8a29c382ca9..deebc53d6e3 100644 --- a/src/components/script/dom/bindings/callback.rs +++ b/src/components/script/dom/bindings/callback.rs @@ -2,13 +2,13 @@ * 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::bindings::trace::trace_object; -use dom::bindings::utils::Reflectable; +use dom::bindings::js::JSRef; +use dom::bindings::trace::Traceable; +use dom::bindings::utils::{Reflectable, global_object_for_js_object}; use js::jsapi::{JSContext, JSObject, JS_WrapObject, JS_ObjectIsCallable}; -use js::jsapi::{JS_GetProperty, JSTracer}; +use js::jsapi::JS_GetProperty; use js::jsval::{JSVal, UndefinedValue}; -use std::cast; use std::ptr; use serialize::{Encodable, Encoder}; @@ -24,42 +24,61 @@ pub enum ExceptionHandling { RethrowExceptions } -#[deriving(Clone,Eq)] -pub struct CallbackInterface { - pub callback: *mut JSObject +#[deriving(Clone,Eq,Encodable)] +pub struct CallbackFunction { + object: CallbackObject } -impl<S: Encoder<E>, E> Encodable<S, E> for CallbackInterface { - fn encode(&self, s: &mut S) -> Result<(), E> { - unsafe { - let tracer: *mut JSTracer = cast::transmute(s); - trace_object(tracer, "callback", self.callback); +impl CallbackFunction { + pub fn new(callback: *mut JSObject) -> CallbackFunction { + CallbackFunction { + object: CallbackObject { + callback: Traceable::new(callback) + } } - Ok(()) } } +#[deriving(Clone,Eq,Encodable)] +pub struct CallbackInterface { + object: CallbackObject +} + +#[deriving(Clone,Eq,Encodable)] +struct CallbackObject { + callback: Traceable<*mut JSObject>, +} + pub trait CallbackContainer { + fn new(callback: *mut JSObject) -> Self; fn callback(&self) -> *mut JSObject; } -impl CallbackContainer for CallbackInterface { - fn callback(&self) -> *mut JSObject { - self.callback +impl CallbackInterface { + pub fn callback(&self) -> *mut JSObject { + *self.object.callback + } +} + +impl CallbackFunction { + pub fn callback(&self) -> *mut JSObject { + *self.object.callback } } impl CallbackInterface { pub fn new(callback: *mut JSObject) -> CallbackInterface { CallbackInterface { - callback: callback + object: CallbackObject { + callback: Traceable::new(callback) + } } } pub fn GetCallableProperty(&self, cx: *mut JSContext, name: &str) -> Result<JSVal, ()> { let mut callable = UndefinedValue(); unsafe { - if name.to_c_str().with_ref(|name| JS_GetProperty(cx, self.callback, name, &mut callable)) == 0 { + if name.to_c_str().with_ref(|name| JS_GetProperty(cx, self.callback(), name, &mut callable)) == 0 { return Err(()); } @@ -73,14 +92,9 @@ impl CallbackInterface { } } -pub fn GetJSObjectFromCallback<T: CallbackContainer>(callback: &T) -> *mut JSObject { - callback.callback() -} - -pub fn WrapCallThisObject<T: 'static + CallbackContainer + Reflectable>(cx: *mut JSContext, - _scope: *mut JSObject, - p: Box<T>) -> *mut JSObject { - let mut obj = GetJSObjectFromCallback(p); +pub fn WrapCallThisObject<T: Reflectable>(cx: *mut JSContext, + p: &JSRef<T>) -> *mut JSObject { + let mut obj = p.reflector().get_jsobject(); assert!(obj.is_not_null()); unsafe { @@ -98,7 +112,9 @@ pub struct CallSetup { } impl CallSetup { - pub fn new(cx: *mut JSContext, handling: ExceptionHandling) -> CallSetup { + pub fn new<T: CallbackContainer>(callback: &T, handling: ExceptionHandling) -> CallSetup { + let win = global_object_for_js_object(callback.callback()).root(); + let cx = win.deref().get_cx(); CallSetup { cx: cx, handling: handling |