diff options
author | bors-servo <release+servo@mozilla.com> | 2014-05-09 11:34:07 -0400 |
---|---|---|
committer | bors-servo <release+servo@mozilla.com> | 2014-05-09 11:34:07 -0400 |
commit | 14776522952df9990685e20151e74f4fed8742c9 (patch) | |
tree | 6a7888574b24afe430d54a1cd06f832aa1dce717 /src/components/script/script_task.rs | |
parent | 78917f4e0f15c7e0dad3c9a1fc07c005bd090487 (diff) | |
parent | b40d8b4d539538c0eb73fdfeaa80062ad1e86528 (diff) | |
download | servo-14776522952df9990685e20151e74f4fed8742c9.tar.gz servo-14776522952df9990685e20151e74f4fed8742c9.zip |
auto merge of #2357 : Manishearth/servo/xhr-syncget, r=ms2ger
This gets a basic synchronous GET request working. I've also tried to implement a portion of the procedures mentioned in the spec.
Blocks #2282
Diffstat (limited to 'src/components/script/script_task.rs')
-rw-r--r-- | src/components/script/script_task.rs | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/src/components/script/script_task.rs b/src/components/script/script_task.rs index 3016edad524..8a95e225e34 100644 --- a/src/components/script/script_task.rs +++ b/src/components/script/script_task.rs @@ -153,7 +153,10 @@ pub struct Page { pub resize_event: Untraceable<RefCell<Option<Size2D<uint>>>>, /// Pending scroll to fragment event, if any - pub fragment_node: Traceable<RefCell<Option<JS<Element>>>> + pub fragment_node: Traceable<RefCell<Option<JS<Element>>>>, + + /// Associated resource task for use by DOM objects like XMLHttpRequest + pub resource_task: Untraceable<ResourceTask>, } pub struct PageTree { @@ -166,7 +169,8 @@ pub struct PageTreeIterator<'a> { } impl PageTree { - fn new(id: PipelineId, layout_chan: LayoutChan, window_size: Size2D<uint>) -> PageTree { + fn new(id: PipelineId, layout_chan: LayoutChan, + window_size: Size2D<uint>, resource_task: ResourceTask) -> PageTree { PageTree { page: Rc::new(Page { id: id, @@ -181,6 +185,7 @@ impl PageTree { resize_event: Untraceable::new(RefCell::new(None)), fragment_node: Traceable::new(RefCell::new(None)), last_reflow_id: Traceable::new(RefCell::new(0)), + resource_task: Untraceable::new(resource_task) }), inner: vec!(), } @@ -592,7 +597,8 @@ impl ScriptTask { -> Rc<ScriptTask> { let (js_runtime, js_context) = ScriptTask::new_rt_and_cx(); Rc::new(ScriptTask { - page_tree: RefCell::new(PageTree::new(id, layout_chan, window_size)), + page_tree: RefCell::new(PageTree::new(id, layout_chan, + window_size, resource_task.clone())), image_cache_task: img_cache_task, resource_task: resource_task, @@ -774,7 +780,8 @@ impl ScriptTask { task's page tree. This is a bug."); let new_page_tree = { let window_size = parent_page_tree.page().window_size.deref().borrow(); - PageTree::new(new_id, layout_chan, *window_size) + PageTree::new(new_id, layout_chan, *window_size, + parent_page_tree.page().resource_task.deref().clone()) }; parent_page_tree.inner.push(new_page_tree); } |