Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(64)

Unified Diff: android_webview/native/aw_settings.cc

Issue 143803016: [Android WebView] Fix thread unsafety in accessing Java side getters (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fixed maybeRunOnUiThreadBlocking in a better way Created 6 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: android_webview/native/aw_settings.cc
diff --git a/android_webview/native/aw_settings.cc b/android_webview/native/aw_settings.cc
index 13c7f0879fca577eecf784776f3dc0db70999fc2..cb2cbf1e500003a0d32ad8f491f4bdda7dc2a557 100644
--- a/android_webview/native/aw_settings.cc
+++ b/android_webview/native/aw_settings.cc
@@ -188,14 +188,20 @@ void AwSettings::PopulateFixedPreferences(WebPreferences* web_prefs) {
void AwSettings::PopulateWebPreferences(WebPreferences* web_prefs) {
JNIEnv* env = base::android::AttachCurrentThread();
CHECK(env);
-
- AwRenderViewHostExt* render_view_host_ext = GetAwRenderViewHostExt();
- if (!render_view_host_ext) return;
-
ScopedJavaLocalRef<jobject> scoped_obj = aw_settings_.get(env);
jobject obj = scoped_obj.obj();
if (!obj) return;
+ // Grab the lock and call PopulateWebPreferencesLocked.
+ Java_AwSettings_populateWebPreferences(
+ env, obj, reinterpret_cast<jlong>(web_prefs));
+}
+
+void AwSettings::PopulateWebPreferencesLocked(
+ JNIEnv* env, jobject obj, jlong web_prefs_ptr) {
+ AwRenderViewHostExt* render_view_host_ext = GetAwRenderViewHostExt();
+ if (!render_view_host_ext) return;
+ WebPreferences* web_prefs = reinterpret_cast<WebPreferences*>(web_prefs_ptr);
PopulateFixedPreferences(web_prefs);
web_prefs->text_autosizing_enabled =

Powered by Google App Engine
This is Rietveld 408576698