diff options
author | bors-servo <release+servo@mozilla.com> | 2013-10-21 05:57:59 -0700 |
---|---|---|
committer | bors-servo <release+servo@mozilla.com> | 2013-10-21 05:57:59 -0700 |
commit | accec9c113e85f285e69149413944a94d507f75b (patch) | |
tree | e77aba60d3c369bf0bb43195b436e24da3bf12ab | |
parent | 16eb557978c96f6580bc031b05aad21c7886ead0 (diff) | |
parent | fda77aa36bde36fd650505d2571e614350bd143d (diff) | |
download | servo-accec9c113e85f285e69149413944a94d507f75b.tar.gz servo-accec9c113e85f285e69149413944a94d507f75b.zip |
auto merge of #1098 : jdm/servo/borrow-fix, r=metajack
Needed for #1067.
-rw-r--r-- | src/components/script/dom/navigator.rs | 22 | ||||
-rw-r--r-- | src/components/script/dom/window.rs | 2 |
2 files changed, 18 insertions, 6 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> { diff --git a/src/components/script/dom/window.rs b/src/components/script/dom/window.rs index 82d098d9b22..1c42dde5d9d 100644 --- a/src/components/script/dom/window.rs +++ b/src/components/script/dom/window.rs @@ -119,7 +119,7 @@ impl Window { pub fn Navigator(&mut self) -> @mut Navigator { if self.navigator.is_none() { - self.navigator = Some(Navigator::new()); + self.navigator = Some(Navigator::new(self)); } self.navigator.unwrap() } |