diff options
Diffstat (limited to 'src/components/script/dom')
-rw-r--r-- | src/components/script/dom/dedicatedworkerglobalscope.rs | 10 | ||||
-rw-r--r-- | src/components/script/dom/worker.rs | 26 |
2 files changed, 34 insertions, 2 deletions
diff --git a/src/components/script/dom/dedicatedworkerglobalscope.rs b/src/components/script/dom/dedicatedworkerglobalscope.rs index 80c6fd762ba..1373c8c5653 100644 --- a/src/components/script/dom/dedicatedworkerglobalscope.rs +++ b/src/components/script/dom/dedicatedworkerglobalscope.rs @@ -10,8 +10,12 @@ use dom::eventtarget::EventTarget; use dom::eventtarget::WorkerGlobalScopeTypeId; use dom::workerglobalscope::DedicatedGlobalScope; use dom::workerglobalscope::WorkerGlobalScope; +use script_task::ScriptTask; use js::jsapi::JSContext; +use js::rust::Cx; + +use std::rc::Rc; #[deriving(Encodable)] pub struct DedicatedWorkerGlobalScope { @@ -29,6 +33,12 @@ impl DedicatedWorkerGlobalScope { let scope = box DedicatedWorkerGlobalScope::new_inherited(); DedicatedWorkerGlobalScopeBinding::Wrap(cx, scope) } + + pub fn init() -> (Rc<Cx>, Temporary<DedicatedWorkerGlobalScope>) { + let (_js_runtime, js_context) = ScriptTask::new_rt_and_cx(); + let global = DedicatedWorkerGlobalScope::new(js_context.ptr); + (js_context, global) + } } pub trait DedicatedWorkerGlobalScopeMethods { diff --git a/src/components/script/dom/worker.rs b/src/components/script/dom/worker.rs index 09b5072a06d..63a1da6ce6c 100644 --- a/src/components/script/dom/worker.rs +++ b/src/components/script/dom/worker.rs @@ -4,10 +4,13 @@ use dom::bindings::error::{Fallible, Security, Syntax}; use dom::bindings::global::GlobalRef; -use dom::bindings::js::Temporary; +use dom::bindings::js::{Temporary, RootCollection}; use dom::bindings::utils::{Reflectable, Reflector}; +use dom::dedicatedworkerglobalscope::DedicatedWorkerGlobalScope; use dom::eventtarget::EventTarget; +use script_task::StackRootTLS; +use servo_net::resource_task::load_whole_resource; use servo_util::str::DOMString; use servo_util::url::try_parse_url; @@ -27,8 +30,27 @@ impl Worker { }; let name = format!("Web Worker at {}", worker_url); + let resource_task = global.page().resource_task.deref().clone(); TaskBuilder::new().named(name).spawn(proc() { - println!("Spawned!"); + let roots = RootCollection::new(); + let _stack_roots_tls = StackRootTLS::new(&roots); + + let (filename, source) = match load_whole_resource(&resource_task, worker_url.clone()) { + Err(_) => { + println!("error loading script {}", worker_url); + return; + } + Ok((metadata, bytes)) => { + (metadata.final_url, String::from_utf8(bytes).unwrap()) + } + }; + + let (cx, global) = DedicatedWorkerGlobalScope::init(); + let global = global.root(); + match cx.evaluate_script(global.reflector().get_jsobject(), source, filename.to_str(), 1) { + Ok(_) => (), + Err(_) => println!("evaluate_script failed") + } }); Err(Security) } |