summaryrefslogtreecommitdiffstats
path: root/core/java/android/webkit
diff options
context:
space:
mode:
authorJonathan Dixon <joth@google.com>2013-07-25 19:52:47 -0700
committerJonathan Dixon <joth@google.com>2013-07-29 11:45:34 -0700
commita7eaa8ee222611c28f050158db4b68c4d893a8a9 (patch)
treed632dc1216e08c9e7fea3c18a36523fdab1700ba /core/java/android/webkit
parentcb92a8d9428c2e4a9f038cd5f10e9d61bf265cd4 (diff)
downloadframeworks_base-a7eaa8ee222611c28f050158db4b68c4d893a8a9.zip
frameworks_base-a7eaa8ee222611c28f050158db4b68c4d893a8a9.tar.gz
frameworks_base-a7eaa8ee222611c28f050158db4b68c4d893a8a9.tar.bz2
Add accessors for WebViewFactory.UseExperimentalWebView
In preperation for flag-flip, have Settings app access the current state via methods that are neutral to the on/off state. Also setup the property to change name when enabled by default, to reset any user changes to this setting. Change-Id: I55017bcd89573c1ecac7de8913264d9cf66fdcd9
Diffstat (limited to 'core/java/android/webkit')
-rw-r--r--core/java/android/webkit/WebViewFactory.java29
1 files changed, 23 insertions, 6 deletions
diff --git a/core/java/android/webkit/WebViewFactory.java b/core/java/android/webkit/WebViewFactory.java
index 2ee0961..53abf19 100644
--- a/core/java/android/webkit/WebViewFactory.java
+++ b/core/java/android/webkit/WebViewFactory.java
@@ -28,8 +28,15 @@ import android.util.Log;
* @hide
*/
public final class WebViewFactory {
- public static final boolean DEFAULT_TO_EXPERIMENTAL_WEBVIEW = false;
- public static final String WEBVIEW_EXPERIMENTAL_PROPERTY = "persist.sys.webview.exp";
+ private static final boolean DEFAULT_TO_EXPERIMENTAL_WEBVIEW = false;
+ private static final String EXPERIMENTAL_PROPERTY_DEFAULT_OFF = "persist.sys.webview.exp";
+ private static final String EXPERIMENTAL_PROPERTY_DEFAULT_ON = "persist.sys.webview.exp_on";
+
+ // Modify the persisted property name when the experiment is on-by-default, so that any user
+ // setting override lives in a different property namespace.
+ private static final String WEBVIEW_EXPERIMENTAL_PROPERTY = DEFAULT_TO_EXPERIMENTAL_WEBVIEW ?
+ EXPERIMENTAL_PROPERTY_DEFAULT_ON : EXPERIMENTAL_PROPERTY_DEFAULT_OFF;
+
private static final String FORCE_PROVIDER_PROPERTY = "webview.force_provider";
private static final String FORCE_PROVIDER_PROPERTY_VALUE_CHROMIUM = "chromium";
private static final String FORCE_PROVIDER_PROPERTY_VALUE_CLASSIC = "classic";
@@ -71,6 +78,18 @@ public final class WebViewFactory {
}
}
+ /** @hide */
+ public static void setUseExperimentalWebView(boolean enable) {
+ SystemProperties.set(WebViewFactory.WEBVIEW_EXPERIMENTAL_PROPERTY,
+ enable ? "true" : "false");
+ }
+
+ /** @hide */
+ public static boolean useExperimentalWebView() {
+ return SystemProperties.getBoolean(WEBVIEW_EXPERIMENTAL_PROPERTY,
+ DEFAULT_TO_EXPERIMENTAL_WEBVIEW);
+ }
+
static WebViewFactoryProvider getProvider() {
synchronized (sProviderLock) {
// For now the main purpose of this function (and the factory abstraction) is to keep
@@ -112,17 +131,15 @@ public final class WebViewFactory {
// WebView. This enables us to switch between implementations at runtime.
private static boolean isExperimentalWebViewEnabled() {
if (!isExperimentalWebViewAvailable()) return false;
- boolean use_experimental_webview = SystemProperties.getBoolean(
- WEBVIEW_EXPERIMENTAL_PROPERTY, DEFAULT_TO_EXPERIMENTAL_WEBVIEW);
String forceProviderName = SystemProperties.get(FORCE_PROVIDER_PROPERTY);
- if (forceProviderName.isEmpty()) return use_experimental_webview;
+ if (forceProviderName.isEmpty()) return useExperimentalWebView();
Log.i(LOGTAG, String.format("Provider overridden by property: %s=%s",
FORCE_PROVIDER_PROPERTY, forceProviderName));
if (forceProviderName.equals(FORCE_PROVIDER_PROPERTY_VALUE_CHROMIUM)) return true;
if (forceProviderName.equals(FORCE_PROVIDER_PROPERTY_VALUE_CLASSIC)) return false;
Log.e(LOGTAG, String.format("Unrecognized provider: %s", forceProviderName));
- return use_experimental_webview;
+ return useExperimentalWebView();
}
private static Class<WebViewFactoryProvider> getFactoryClass() throws ClassNotFoundException {