mirror of
https://github.com/servo/servo.git
synced 2025-06-23 16:44:33 +01:00
auto merge of #1103 : kmcallister/servo/eager-wrap, r=jdm
This commit is contained in:
commit
14d34e73b9
9 changed files with 68 additions and 68 deletions
|
@ -5,6 +5,7 @@
|
||||||
use dom::bindings::codegen::PrototypeList;
|
use dom::bindings::codegen::PrototypeList;
|
||||||
use dom::bindings::codegen::PrototypeList::MAX_PROTO_CHAIN_LENGTH;
|
use dom::bindings::codegen::PrototypeList::MAX_PROTO_CHAIN_LENGTH;
|
||||||
use dom::bindings::node;
|
use dom::bindings::node;
|
||||||
|
use dom::window;
|
||||||
use dom::node::{AbstractNode, ScriptView};
|
use dom::node::{AbstractNode, ScriptView};
|
||||||
|
|
||||||
use std::libc::c_uint;
|
use std::libc::c_uint;
|
||||||
|
@ -544,6 +545,20 @@ pub trait Reflectable {
|
||||||
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable>;
|
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable>;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn reflect_dom_object<T: Reflectable>
|
||||||
|
(obj: @mut T,
|
||||||
|
window: &window::Window,
|
||||||
|
wrap_fn: extern "Rust" fn(*JSContext, *JSObject, @mut T) -> *JSObject)
|
||||||
|
-> @mut T {
|
||||||
|
let cx = window.get_cx();
|
||||||
|
let scope = window.reflector().get_jsobject();
|
||||||
|
if wrap_fn(cx, scope, obj).is_null() {
|
||||||
|
fail!("Could not eagerly wrap object");
|
||||||
|
}
|
||||||
|
assert!(obj.reflector().get_jsobject().is_not_null());
|
||||||
|
obj
|
||||||
|
}
|
||||||
|
|
||||||
pub struct Reflector {
|
pub struct Reflector {
|
||||||
object: *JSObject
|
object: *JSObject
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
* 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/. */
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
|
||||||
use dom::bindings::utils::{Reflectable, Reflector};
|
use dom::bindings::utils::{Reflectable, Reflector, reflect_dom_object};
|
||||||
use dom::bindings::utils::Fallible;
|
use dom::bindings::utils::Fallible;
|
||||||
use dom::bindings::codegen::BlobBinding;
|
use dom::bindings::codegen::BlobBinding;
|
||||||
use dom::window::Window;
|
use dom::window::Window;
|
||||||
|
@ -23,14 +23,7 @@ impl Blob {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new(window: @mut Window) -> @mut Blob {
|
pub fn new(window: @mut Window) -> @mut Blob {
|
||||||
let blob = @mut Blob::new_inherited(window);
|
reflect_dom_object(@mut Blob::new_inherited(window), window, BlobBinding::Wrap)
|
||||||
let cx = window.get_cx();
|
|
||||||
let scope = window.reflector().get_jsobject();
|
|
||||||
if BlobBinding::Wrap(cx, scope, blob).is_null() {
|
|
||||||
fail!("BlobBinding::Wrap failed");
|
|
||||||
}
|
|
||||||
assert!(blob.reflector().get_jsobject().is_not_null());
|
|
||||||
blob
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
use dom::eventtarget::EventTarget;
|
use dom::eventtarget::EventTarget;
|
||||||
use dom::window::Window;
|
use dom::window::Window;
|
||||||
use dom::bindings::codegen::EventBinding;
|
use dom::bindings::codegen::EventBinding;
|
||||||
use dom::bindings::utils::{Reflectable, Reflector};
|
use dom::bindings::utils::{Reflectable, Reflector, reflect_dom_object};
|
||||||
use dom::bindings::utils::{DOMString, ErrorResult, Fallible};
|
use dom::bindings::utils::{DOMString, ErrorResult, Fallible};
|
||||||
|
|
||||||
use geom::point::Point2D;
|
use geom::point::Point2D;
|
||||||
|
@ -31,7 +31,7 @@ pub struct Event {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Event {
|
impl Event {
|
||||||
pub fn new(type_: &DOMString) -> Event {
|
pub fn new_inherited(type_: &DOMString) -> Event {
|
||||||
Event {
|
Event {
|
||||||
reflector_: Reflector::new(),
|
reflector_: Reflector::new(),
|
||||||
type_: (*type_).clone(),
|
type_: (*type_).clone(),
|
||||||
|
@ -42,6 +42,10 @@ impl Event {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn new(window: @mut Window, type_: &DOMString) -> @mut Event {
|
||||||
|
reflect_dom_object(@mut Event::new_inherited(type_), window, EventBinding::Wrap)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn init_wrapper(@mut self, cx: *JSContext, scope: *JSObject) {
|
pub fn init_wrapper(@mut self, cx: *JSContext, scope: *JSObject) {
|
||||||
self.wrap_object_shared(cx, scope);
|
self.wrap_object_shared(cx, scope);
|
||||||
}
|
}
|
||||||
|
@ -102,10 +106,10 @@ impl Event {
|
||||||
self.trusted
|
self.trusted
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn Constructor(_global: @mut Window,
|
pub fn Constructor(global: @mut Window,
|
||||||
type_: &DOMString,
|
type_: &DOMString,
|
||||||
_init: &EventBinding::EventInit) -> Fallible<@mut Event> {
|
_init: &EventBinding::EventInit) -> Fallible<@mut Event> {
|
||||||
Ok(@mut Event::new(type_))
|
Ok(Event::new(global, type_))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,8 +122,8 @@ impl Reflectable for Event {
|
||||||
&mut self.reflector_
|
&mut self.reflector_
|
||||||
}
|
}
|
||||||
|
|
||||||
fn wrap_object_shared(@mut self, cx: *JSContext, scope: *JSObject) -> *JSObject {
|
fn wrap_object_shared(@mut self, _cx: *JSContext, _scope: *JSObject) -> *JSObject {
|
||||||
EventBinding::Wrap(cx, scope, self)
|
unreachable!()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable> {
|
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable> {
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
* 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/. */
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
|
||||||
use dom::bindings::utils::{Reflectable, Reflector};
|
use dom::bindings::utils::{Reflectable, Reflector, reflect_dom_object};
|
||||||
use dom::bindings::utils::{DOMString, null_str_as_empty};
|
use dom::bindings::utils::{DOMString, null_str_as_empty};
|
||||||
use dom::bindings::codegen::FormDataBinding;
|
use dom::bindings::codegen::FormDataBinding;
|
||||||
use dom::blob::Blob;
|
use dom::blob::Blob;
|
||||||
|
@ -33,14 +33,7 @@ impl FormData {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new(window: @mut Window) -> @mut FormData {
|
pub fn new(window: @mut Window) -> @mut FormData {
|
||||||
let formdata = @mut FormData::new_inherited(window);
|
reflect_dom_object(@mut FormData::new_inherited(window), window, FormDataBinding::Wrap)
|
||||||
let cx = window.get_cx();
|
|
||||||
let scope = window.reflector().get_jsobject();
|
|
||||||
if FormDataBinding::Wrap(cx, scope, formdata).is_null() {
|
|
||||||
fail!("FormDataBinding::Wrap failed");
|
|
||||||
}
|
|
||||||
assert!(formdata.reflector().get_jsobject().is_not_null());
|
|
||||||
formdata
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn Append(&mut self, name: &DOMString, value: @mut Blob, filename: Option<DOMString>) {
|
pub fn Append(&mut self, name: &DOMString, value: @mut Blob, filename: Option<DOMString>) {
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
|
|
||||||
use dom::bindings::codegen::MouseEventBinding;
|
use dom::bindings::codegen::MouseEventBinding;
|
||||||
use dom::bindings::utils::{ErrorResult, Fallible, DOMString};
|
use dom::bindings::utils::{ErrorResult, Fallible, DOMString};
|
||||||
use dom::bindings::utils::{Reflectable, Reflector};
|
use dom::bindings::utils::{Reflectable, Reflector, reflect_dom_object};
|
||||||
use dom::eventtarget::EventTarget;
|
use dom::eventtarget::EventTarget;
|
||||||
use dom::uievent::UIEvent;
|
use dom::uievent::UIEvent;
|
||||||
use dom::window::Window;
|
use dom::window::Window;
|
||||||
|
@ -27,13 +27,13 @@ pub struct MouseEvent {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl MouseEvent {
|
impl MouseEvent {
|
||||||
pub fn new(type_: &DOMString, can_bubble: bool, cancelable: bool,
|
pub fn new(window: @mut Window, type_: &DOMString, can_bubble: bool, cancelable: bool,
|
||||||
view: Option<@mut WindowProxy>, detail: i32, screen_x: i32,
|
view: Option<@mut WindowProxy>, detail: i32, screen_x: i32,
|
||||||
screen_y: i32, client_x: i32, client_y: i32, ctrl_key: bool,
|
screen_y: i32, client_x: i32, client_y: i32, ctrl_key: bool,
|
||||||
shift_key: bool, alt_key: bool, meta_key: bool, button: u16,
|
shift_key: bool, alt_key: bool, meta_key: bool, button: u16,
|
||||||
_buttons: u16, related_target: Option<@mut EventTarget>) -> MouseEvent {
|
_buttons: u16, related_target: Option<@mut EventTarget>) -> @mut MouseEvent {
|
||||||
MouseEvent {
|
let ev = @mut MouseEvent {
|
||||||
parent: UIEvent::new(type_, can_bubble, cancelable, view, detail),
|
parent: UIEvent::new_inherited(type_, can_bubble, cancelable, view, detail),
|
||||||
screen_x: screen_x,
|
screen_x: screen_x,
|
||||||
screen_y: screen_y,
|
screen_y: screen_y,
|
||||||
client_x: client_x,
|
client_x: client_x,
|
||||||
|
@ -44,20 +44,21 @@ impl MouseEvent {
|
||||||
meta_key: meta_key,
|
meta_key: meta_key,
|
||||||
button: button,
|
button: button,
|
||||||
related_target: related_target
|
related_target: related_target
|
||||||
}
|
};
|
||||||
|
reflect_dom_object(ev, window, MouseEventBinding::Wrap)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn init_wrapper(@mut self, cx: *JSContext, scope: *JSObject) {
|
pub fn init_wrapper(@mut self, cx: *JSContext, scope: *JSObject) {
|
||||||
self.wrap_object_shared(cx, scope);
|
self.wrap_object_shared(cx, scope);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn Constructor(_owner: @mut Window,
|
pub fn Constructor(owner: @mut Window,
|
||||||
type_: &DOMString,
|
type_: &DOMString,
|
||||||
init: &MouseEventBinding::MouseEventInit) -> Fallible<@mut MouseEvent> {
|
init: &MouseEventBinding::MouseEventInit) -> Fallible<@mut MouseEvent> {
|
||||||
Ok(@mut MouseEvent::new(type_, init.bubbles, init.cancelable, init.view, init.detail,
|
Ok(MouseEvent::new(owner, type_, init.bubbles, init.cancelable, init.view, init.detail,
|
||||||
init.screenX, init.screenY, init.clientX, init.clientY,
|
init.screenX, init.screenY, init.clientX, init.clientY,
|
||||||
init.ctrlKey, init.shiftKey, init.altKey, init.metaKey,
|
init.ctrlKey, init.shiftKey, init.altKey, init.metaKey,
|
||||||
init.button, init.buttons, init.relatedTarget))
|
init.button, init.buttons, init.relatedTarget))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn ScreenX(&self) -> i32 {
|
pub fn ScreenX(&self) -> i32 {
|
||||||
|
@ -150,8 +151,8 @@ impl Reflectable for MouseEvent {
|
||||||
self.parent.mut_reflector()
|
self.parent.mut_reflector()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn wrap_object_shared(@mut self, cx: *JSContext, scope: *JSObject) -> *JSObject {
|
fn wrap_object_shared(@mut self, _cx: *JSContext, _scope: *JSObject) -> *JSObject {
|
||||||
MouseEventBinding::Wrap(cx, scope, self)
|
unreachable!()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable> {
|
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable> {
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
* 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/. */
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
|
||||||
use dom::bindings::utils::{Reflectable, Reflector};
|
use dom::bindings::utils::{Reflectable, Reflector, reflect_dom_object};
|
||||||
use dom::bindings::utils::{DOMString, Fallible};
|
use dom::bindings::utils::{DOMString, Fallible};
|
||||||
use dom::bindings::codegen::NavigatorBinding;
|
use dom::bindings::codegen::NavigatorBinding;
|
||||||
use dom::window::Window;
|
use dom::window::Window;
|
||||||
|
@ -22,14 +22,7 @@ impl Navigator {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new(window: &Window) -> @mut Navigator {
|
pub fn new(window: &Window) -> @mut Navigator {
|
||||||
let nav = @mut Navigator::new_inherited();
|
reflect_dom_object(@mut Navigator::new_inherited(), window, NavigatorBinding::Wrap)
|
||||||
let cx = window.get_cx();
|
|
||||||
let scope = window.reflector().get_jsobject();
|
|
||||||
if NavigatorBinding::Wrap(cx, scope, nav).is_null() {
|
|
||||||
fail!("NavigatorBinding::Wrap failed");
|
|
||||||
}
|
|
||||||
assert!(nav.reflector().get_jsobject().is_not_null());
|
|
||||||
nav
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn DoNotTrack(&self) -> DOMString {
|
pub fn DoNotTrack(&self) -> DOMString {
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
|
|
||||||
use dom::bindings::codegen::UIEventBinding;
|
use dom::bindings::codegen::UIEventBinding;
|
||||||
use dom::bindings::utils::{DOMString, Fallible};
|
use dom::bindings::utils::{DOMString, Fallible};
|
||||||
use dom::bindings::utils::{Reflectable, Reflector};
|
use dom::bindings::utils::{Reflectable, Reflector, reflect_dom_object};
|
||||||
use dom::node::{AbstractNode, ScriptView};
|
use dom::node::{AbstractNode, ScriptView};
|
||||||
use dom::event::Event;
|
use dom::event::Event;
|
||||||
use dom::window::Window;
|
use dom::window::Window;
|
||||||
|
@ -21,10 +21,10 @@ pub struct UIEvent {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl UIEvent {
|
impl UIEvent {
|
||||||
pub fn new(type_: &DOMString, can_bubble: bool, cancelable: bool,
|
pub fn new_inherited(type_: &DOMString, can_bubble: bool, cancelable: bool,
|
||||||
view: Option<@mut WindowProxy>, detail: i32) -> UIEvent {
|
view: Option<@mut WindowProxy>, detail: i32) -> UIEvent {
|
||||||
UIEvent {
|
UIEvent {
|
||||||
parent: Event::new(type_),
|
parent: Event::new_inherited(type_),
|
||||||
can_bubble: can_bubble,
|
can_bubble: can_bubble,
|
||||||
cancelable: cancelable,
|
cancelable: cancelable,
|
||||||
view: view,
|
view: view,
|
||||||
|
@ -32,15 +32,22 @@ impl UIEvent {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn new(window: @mut Window, type_: &DOMString, can_bubble: bool, cancelable: bool,
|
||||||
|
view: Option<@mut WindowProxy>, detail: i32) -> @mut UIEvent {
|
||||||
|
reflect_dom_object(@mut UIEvent::new_inherited(type_, can_bubble, cancelable, view, detail),
|
||||||
|
window,
|
||||||
|
UIEventBinding::Wrap)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn init_wrapper(@mut self, cx: *JSContext, scope: *JSObject) {
|
pub fn init_wrapper(@mut self, cx: *JSContext, scope: *JSObject) {
|
||||||
self.wrap_object_shared(cx, scope);
|
self.wrap_object_shared(cx, scope);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn Constructor(_owner: @mut Window,
|
pub fn Constructor(owner: @mut Window,
|
||||||
type_: &DOMString,
|
type_: &DOMString,
|
||||||
init: &UIEventBinding::UIEventInit) -> Fallible<@mut UIEvent> {
|
init: &UIEventBinding::UIEventInit) -> Fallible<@mut UIEvent> {
|
||||||
Ok(@mut UIEvent::new(type_, init.parent.bubbles, init.parent.cancelable,
|
Ok(UIEvent::new(owner, type_, init.parent.bubbles, init.parent.cancelable,
|
||||||
init.view, init.detail))
|
init.view, init.detail))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn GetView(&self) -> Option<@mut WindowProxy> {
|
pub fn GetView(&self) -> Option<@mut WindowProxy> {
|
||||||
|
@ -123,8 +130,8 @@ impl Reflectable for UIEvent {
|
||||||
self.parent.mut_reflector()
|
self.parent.mut_reflector()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn wrap_object_shared(@mut self, cx: *JSContext, scope: *JSObject) -> *JSObject {
|
fn wrap_object_shared(@mut self, _cx: *JSContext, _scope: *JSObject) -> *JSObject {
|
||||||
UIEventBinding::Wrap(cx, scope, self)
|
unreachable!()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable> {
|
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable> {
|
||||||
|
|
|
@ -4,16 +4,13 @@
|
||||||
<script>
|
<script>
|
||||||
is_function(Event, "Event");
|
is_function(Event, "Event");
|
||||||
|
|
||||||
/* broken due to #1042
|
|
||||||
let ev = new Event("foopy");
|
let ev = new Event("foopy");
|
||||||
is_a(ev, Event);
|
is_a(ev, Event);
|
||||||
|
|
||||||
// FIXME: assert correct values
|
is(ev.type, 'foopy');
|
||||||
alert(ev.type);
|
is(ev.defaultPrevented, false);
|
||||||
alert(ev.defaultPrevented);
|
|
||||||
ev.preventDefault();
|
ev.preventDefault();
|
||||||
alert(ev.defaultPrevented);
|
is(ev.defaultPrevented, true);
|
||||||
*/
|
|
||||||
|
|
||||||
finish();
|
finish();
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -4,17 +4,14 @@
|
||||||
<script>
|
<script>
|
||||||
is_function(MouseEvent, "MouseEvent");
|
is_function(MouseEvent, "MouseEvent");
|
||||||
|
|
||||||
/* broken due to #1042
|
|
||||||
let ev = new MouseEvent("press", {bubbles: true, screenX: 150, detail: 100});
|
let ev = new MouseEvent("press", {bubbles: true, screenX: 150, detail: 100});
|
||||||
|
|
||||||
// FIXME: assert correct values
|
|
||||||
alert(ev);
|
|
||||||
alert(ev.screenX);
|
|
||||||
alert(ev.detail);
|
|
||||||
alert(ev.getModifierState("ctrl"));
|
|
||||||
is_a(ev, Event);
|
is_a(ev, Event);
|
||||||
is_a(ev, UIEvent);
|
is_a(ev, UIEvent);
|
||||||
*/
|
is_a(ev, MouseEvent);
|
||||||
|
is(ev.screenX, 150);
|
||||||
|
is(ev.detail, 100);
|
||||||
|
is(ev.getModifierState("ctrl"), false);
|
||||||
|
|
||||||
finish();
|
finish();
|
||||||
</script>
|
</script>
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue