aboutsummaryrefslogtreecommitdiffstats
path: root/components
diff options
context:
space:
mode:
Diffstat (limited to 'components')
-rw-r--r--components/script/lib.rs10
-rw-r--r--components/servo/lib.rs9
2 files changed, 13 insertions, 6 deletions
diff --git a/components/script/lib.rs b/components/script/lib.rs
index 94e9683ffaf..91ccc817cf8 100644
--- a/components/script/lib.rs
+++ b/components/script/lib.rs
@@ -163,15 +163,17 @@ fn perform_platform_specific_initialization() {
#[cfg(not(target_os = "linux"))]
fn perform_platform_specific_initialization() {}
+pub fn init_service_workers(sw_senders: SWManagerSenders) {
+ // Spawn the service worker manager passing the constellation sender
+ ServiceWorkerManager::spawn_manager(sw_senders);
+}
+
#[allow(unsafe_code)]
-pub fn init(sw_senders: SWManagerSenders) {
+pub fn init() {
unsafe {
proxyhandler::init();
}
- // Spawn the service worker manager passing the constellation sender
- ServiceWorkerManager::spawn_manager(sw_senders);
-
// Create the global vtables used by the (generated) DOM
// bindings to implement JS proxies.
RegisterBindings::RegisterProxyHandlers();
diff --git a/components/servo/lib.rs b/components/servo/lib.rs
index 909daec3002..83de1b52db1 100644
--- a/components/servo/lib.rs
+++ b/components/servo/lib.rs
@@ -170,6 +170,10 @@ impl<Window> Browser<Window> where Window: WindowMethods + 'static {
})
};
+ // Important that this call is done in a single-threaded fashion, we
+ // can't defer it after `create_constellation` has started.
+ script::init();
+
// Create the constellation, which maintains the engine
// pipelines, including the script and layout threads, as well
// as the navigation context.
@@ -183,7 +187,7 @@ impl<Window> Browser<Window> where Window: WindowMethods + 'static {
webrender_api_sender.clone());
// Send the constellation's swmanager sender to service worker manager thread
- script::init(sw_senders);
+ script::init_service_workers(sw_senders);
if cfg!(feature = "webdriver") {
if let Some(port) = opts.webdriver_port {
@@ -339,7 +343,8 @@ pub fn run_content_process(token: String) {
// send the required channels to the service worker manager
let sw_senders = unprivileged_content.swmanager_senders();
- script::init(sw_senders);
+ script::init();
+ script::init_service_workers(sw_senders);
unprivileged_content.start_all::<script_layout_interface::message::Msg,
layout_thread::LayoutThread,