aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/script/dom/navigator.rs
diff options
context:
space:
mode:
authorJosh Matthews <josh@joshmatthews.net>2013-10-21 12:08:22 +0200
committerJosh Matthews <josh@joshmatthews.net>2013-10-21 12:11:14 +0200
commitfda77aa36bde36fd650505d2571e614350bd143d (patch)
tree0c1ebd78eeb0e7ed56cb1a4d76909f87a7050b0f /src/components/script/dom/navigator.rs
parent5c725b31af4632407c201ae2727698a06e0bfd78 (diff)
downloadservo-fda77aa36bde36fd650505d2571e614350bd143d.tar.gz
servo-fda77aa36bde36fd650505d2571e614350bd143d.zip
Eagerly reflect the navigator object. Fixes #1042.
Diffstat (limited to 'src/components/script/dom/navigator.rs')
-rw-r--r--src/components/script/dom/navigator.rs22
1 files changed, 17 insertions, 5 deletions
diff --git a/src/components/script/dom/navigator.rs b/src/components/script/dom/navigator.rs
index 99b75a39030..fc60c8486b3 100644
--- a/src/components/script/dom/navigator.rs
+++ b/src/components/script/dom/navigator.rs
@@ -5,21 +5,33 @@
use dom::bindings::utils::{Reflectable, Reflector};
use dom::bindings::utils::{DOMString, Fallible};
use dom::bindings::codegen::NavigatorBinding;
+use dom::window::Window;
use script_task::{page_from_context};
use js::jsapi::{JSContext, JSObject};
pub struct Navigator {
- reflector_: Reflector
+ reflector_: Reflector //XXXjdm cycle: window->navigator->window
}
impl Navigator {
- pub fn new() -> @mut Navigator {
- @mut Navigator {
+ pub fn new_inherited() -> Navigator {
+ Navigator {
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 {
Some(~"unspecified")
}
@@ -94,8 +106,8 @@ impl Reflectable for Navigator {
&mut self.reflector_
}
- fn wrap_object_shared(@mut self, cx: *JSContext, scope: *JSObject) -> *JSObject {
- NavigatorBinding::Wrap(cx, scope, self)
+ fn wrap_object_shared(@mut self, _cx: *JSContext, _scope: *JSObject) -> *JSObject {
+ unreachable!();
}
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable> {