diff options
author | Zhen Zhang <izgzhen@gmail.com> | 2016-07-06 01:12:50 +0800 |
---|---|---|
committer | Zhen Zhang <izgzhen@gmail.com> | 2016-07-08 19:57:02 +0800 |
commit | bf18225ba26da127cc8ffb574d1b95add853636a (patch) | |
tree | 7439f92f7f3f6dc8af08ca580d99149b44cf421f /components/script/dom/url.rs | |
parent | b9af49f12093dfacdd3d8831efab4a58bee2e458 (diff) | |
download | servo-bf18225ba26da127cc8ffb574d1b95add853636a.tar.gz servo-bf18225ba26da127cc8ffb574d1b95add853636a.zip |
Spawn threads for requests in file manager and other style fixes
Diffstat (limited to 'components/script/dom/url.rs')
-rw-r--r-- | components/script/dom/url.rs | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/components/script/dom/url.rs b/components/script/dom/url.rs index 9a47be034f8..c2d7516dd6f 100644 --- a/components/script/dom/url.rs +++ b/components/script/dom/url.rs @@ -13,6 +13,7 @@ use dom::bindings::str::{DOMString, USVString}; use dom::blob::Blob; use dom::urlhelper::UrlHelper; use dom::urlsearchparams::URLSearchParams; +use ipc_channel::ipc; use net_traits::IpcSend; use net_traits::blob_url_store::parse_blob_url; use net_traits::filemanager_thread::{SelectedFileId, FileManagerThreadMsg}; @@ -142,17 +143,16 @@ impl URL { */ let origin = global.get_url().origin().unicode_serialization(); - match Url::parse(&url) { - Ok(url) => match parse_blob_url(&url) { - Some((id, _)) => { - let filemanager = global.resource_threads().sender(); - let id = SelectedFileId(id.simple().to_string()); - let msg = FileManagerThreadMsg::DecRef(id, origin); - let _ = filemanager.send(msg); - } - None => {} - }, - Err(_) => {} + if let Ok(url) = Url::parse(&url) { + if let Some((id, _)) = parse_blob_url(&url) { + let filemanager = global.resource_threads().sender(); + let id = SelectedFileId(id.simple().to_string()); + let (tx, rx) = ipc::channel().unwrap(); + let msg = FileManagerThreadMsg::DecRef(id, origin, tx); + let _ = filemanager.send(msg); + + let _ = rx.recv().unwrap(); + } } } |