aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/script/dom/blob.rs
diff options
context:
space:
mode:
authorMs2ger <ms2ger@gmail.com>2013-10-17 21:44:14 +0200
committerMs2ger <ms2ger@gmail.com>2013-10-18 19:28:21 +0200
commit9046085506e30b5fbcd92d51a122abe077be0caf (patch)
treefb977393ea406d12f7429b29fa01462e8270e9b5 /src/components/script/dom/blob.rs
parent284ad5ee8eb43274036b05ae400fccb823313d15 (diff)
downloadservo-9046085506e30b5fbcd92d51a122abe077be0caf.tar.gz
servo-9046085506e30b5fbcd92d51a122abe077be0caf.zip
Make Blob create its binding eagerly.
Diffstat (limited to 'src/components/script/dom/blob.rs')
-rw-r--r--src/components/script/dom/blob.rs34
1 files changed, 22 insertions, 12 deletions
diff --git a/src/components/script/dom/blob.rs b/src/components/script/dom/blob.rs
index 3d17c44bc26..b981786f0f0 100644
--- a/src/components/script/dom/blob.rs
+++ b/src/components/script/dom/blob.rs
@@ -4,20 +4,33 @@
use dom::bindings::utils::{Reflectable, Reflector};
use dom::bindings::codegen::BlobBinding;
-use script_task::{page_from_context};
+use dom::window::Window;
use js::jsapi::{JSContext, JSObject};
pub struct Blob {
- reflector_: Reflector
+ reflector_: Reflector,
+ window: @mut Window,
}
impl Blob {
- pub fn new() -> @mut Blob {
- @mut Blob {
- reflector_: Reflector::new()
+ pub fn new_inherited(window: @mut Window) -> Blob {
+ Blob {
+ reflector_: Reflector::new(),
+ window: window,
}
}
+
+ pub fn new(window: @mut Window) -> @mut Blob {
+ let blob = @mut Blob::new_inherited(window);
+ 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
+ }
}
impl Reflectable for Blob {
@@ -29,14 +42,11 @@ impl Reflectable for Blob {
&mut self.reflector_
}
- fn wrap_object_shared(@mut self, cx: *JSContext, scope: *JSObject) -> *JSObject {
- BlobBinding::Wrap(cx, scope, self)
+ fn wrap_object_shared(@mut self, _cx: *JSContext, _scope: *JSObject) -> *JSObject {
+ unreachable!();
}
- fn GetParentObject(&self, cx: *JSContext) -> Option<@mut Reflectable> {
- let page = page_from_context(cx);
- unsafe {
- Some((*page).frame.get_ref().window as @mut Reflectable)
- }
+ fn GetParentObject(&self, _cx: *JSContext) -> Option<@mut Reflectable> {
+ Some(self.window as @mut Reflectable)
}
}