mirror of
https://github.com/servo/servo.git
synced 2025-06-21 07:38:59 +01:00
Eagerly reflect the navigator object. Fixes #1042.
This commit is contained in:
parent
5c725b31af
commit
fda77aa36b
2 changed files with 18 additions and 6 deletions
|
@ -5,21 +5,33 @@
|
||||||
use dom::bindings::utils::{Reflectable, Reflector};
|
use dom::bindings::utils::{Reflectable, Reflector};
|
||||||
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 script_task::{page_from_context};
|
use script_task::{page_from_context};
|
||||||
|
|
||||||
use js::jsapi::{JSContext, JSObject};
|
use js::jsapi::{JSContext, JSObject};
|
||||||
|
|
||||||
pub struct Navigator {
|
pub struct Navigator {
|
||||||
reflector_: Reflector
|
reflector_: Reflector //XXXjdm cycle: window->navigator->window
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Navigator {
|
impl Navigator {
|
||||||
pub fn new() -> @mut Navigator {
|
pub fn new_inherited() -> Navigator {
|
||||||
@mut Navigator {
|
Navigator {
|
||||||
reflector_: Reflector::new()
|
reflector_: Reflector::new()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn new(window: &Window) -> @mut Navigator {
|
||||||
|
let nav = @mut Navigator::new_inherited();
|
||||||
|
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 {
|
||||||
Some(~"unspecified")
|
Some(~"unspecified")
|
||||||
}
|
}
|
||||||
|
@ -94,8 +106,8 @@ impl Reflectable for Navigator {
|
||||||
&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 {
|
||||||
NavigatorBinding::Wrap(cx, scope, self)
|
unreachable!();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable> {
|
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable> {
|
||||||
|
|
|
@ -119,7 +119,7 @@ impl Window {
|
||||||
|
|
||||||
pub fn Navigator(&mut self) -> @mut Navigator {
|
pub fn Navigator(&mut self) -> @mut Navigator {
|
||||||
if self.navigator.is_none() {
|
if self.navigator.is_none() {
|
||||||
self.navigator = Some(Navigator::new());
|
self.navigator = Some(Navigator::new(self));
|
||||||
}
|
}
|
||||||
self.navigator.unwrap()
|
self.navigator.unwrap()
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue