diff --git a/components/config/prefs.rs b/components/config/prefs.rs index d2eb988f91f..8b790575073 100644 --- a/components/config/prefs.rs +++ b/components/config/prefs.rs @@ -3,10 +3,12 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ use basedir::default_config_dir; +use num_cpus; use opts; use resource_files::resources_dir_path; use rustc_serialize::json::{Json, ToJson}; use std::borrow::ToOwned; +use std::cmp::max; use std::collections::HashMap; use std::fs::File; use std::io::{Read, Write, stderr}; @@ -15,8 +17,11 @@ use std::sync::{Arc, RwLock}; lazy_static! { pub static ref PREFS: Preferences = { - let prefs = read_prefs().ok().unwrap_or_else(HashMap::new); - Preferences(Arc::new(RwLock::new(prefs))) + let defaults = default_prefs(); + if let Ok(prefs) = read_prefs() { + defaults.extend(prefs); + } + defaults }; } @@ -144,6 +149,13 @@ impl ToJson for Pref { } } +pub fn default_prefs() -> Preferences { + let prefs = Preferences(Arc::new(RwLock::new(HashMap::new()))); + prefs.set("layout.threads", PrefValue::Number( + max(num_cpus::get() * 3 / 4, 1) as f64)); + prefs +} + pub fn read_prefs_from_file(mut file: T) -> Result, ()> where T: Read { let json = try!(Json::from_reader(&mut file).or_else(|e| {