Add 'web-preferences' options in BrowserWindow.

This commit is contained in:
Cheng Zhao 2014-05-22 22:54:09 +08:00
parent 34fa0f1ff8
commit 2204e9bb15
4 changed files with 34 additions and 0 deletions

View file

@ -76,6 +76,11 @@ NativeWindow::NativeWindow(content::WebContents* web_contents,
// Read iframe security before any navigation.
options->GetString(switches::kNodeIntegration, &node_integration_);
// Read the web preferences.
base::DictionaryValue* web_preferences;
if (options->GetDictionary(switches::kWebPreferences, &web_preferences))
web_preferences_.reset(web_preferences->DeepCopy());
web_contents->SetDelegate(this);
inspectable_web_contents()->SetDelegate(this);
@ -348,6 +353,28 @@ void NativeWindow::OverrideWebkitPrefs(const GURL& url, WebPreferences* prefs) {
// FIXME Disable accelerated composition in frameless window.
if (!has_frame_)
prefs->accelerated_compositing_enabled = false;
bool b;
if (!web_preferences_)
return;
else if (web_preferences_->GetBoolean("javascript", &b))
prefs->javascript_enabled = b;
else if (web_preferences_->GetBoolean("web-security", &b))
prefs->web_security_enabled = b;
else if (web_preferences_->GetBoolean("images", &b))
prefs->images_enabled = b;
else if (web_preferences_->GetBoolean("plugins", &b))
prefs->plugins_enabled = b;
else if (web_preferences_->GetBoolean("java", &b))
prefs->java_enabled = b;
else if (web_preferences_->GetBoolean("text-areas-are-resizable", &b))
prefs->text_areas_are_resizable = b;
else if (web_preferences_->GetBoolean("webgl", &b))
prefs->experimental_webgl_enabled = b;
else if (web_preferences_->GetBoolean("webaudio", &b))
prefs->webaudio_enabled = b;
else if (web_preferences_->GetBoolean("accelerated-compositing", &b))
prefs->accelerated_compositing_enabled = b;
}
void NativeWindow::NotifyWindowClosed() {

View file

@ -290,6 +290,9 @@ class NativeWindow : public brightray::DefaultWebContentsDelegate,
// it should be cancelled when we can prove that the window is responsive.
base::CancelableClosure window_unresposive_closure_;
// web preferences.
scoped_ptr<base::DictionaryValue> web_preferences_;
base::WeakPtrFactory<NativeWindow> weak_factory_;
base::WeakPtr<NativeWindow> devtools_window_;

View file

@ -39,6 +39,9 @@ const char kAcceptFirstMouse[] = "accept-first-mouse";
// Whether window size should include window frame.
const char kUseContentSize[] = "use-content-size";
// The WebPreferences.
const char kWebPreferences[] = "web-preferences";
} // namespace switches
} // namespace atom

View file

@ -29,6 +29,7 @@ extern const char kAlwaysOnTop[];
extern const char kNodeIntegration[];
extern const char kAcceptFirstMouse[];
extern const char kUseContentSize[];
extern const char kWebPreferences[];
} // namespace switches