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

Unified Diff: content/renderer/render_view_impl.cc

Issue 11192057: [Android] Add supportMultipleWindows setting (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Comments addressed, moved fields in WebPreferences. Created 8 years, 2 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: content/renderer/render_view_impl.cc
diff --git a/content/renderer/render_view_impl.cc b/content/renderer/render_view_impl.cc
index 7b83e8b62c0fb4cb2f9f959088f59562a40c5109..94b4fa95e7cc06a2ac12c4f5ae9e020a5f2e2744 100644
--- a/content/renderer/render_view_impl.cc
+++ b/content/renderer/render_view_impl.cc
@@ -2364,13 +2364,20 @@ void RenderViewImpl::didBlur() {
// created RenderView (i.e., as a blocked popup or as a new tab).
//
void RenderViewImpl::show(WebNavigationPolicy policy) {
- DCHECK(!did_show_) << "received extraneous Show call";
- DCHECK(opener_id_ != MSG_ROUTING_NONE);
-
- if (did_show_)
+ if (did_show_) {
+#if defined(OS_ANDROID)
+ // When supports_multiple_windows is disabled, popups are reusing
+ // the same view. In some scenarios, this makes WebKit to call show() twice.
+ if (!webkit_preferences_.supports_multiple_windows)
+ return;
+#endif
+ NOTREACHED() << "received extraneous Show call";
return;
+ }
did_show_ = true;
+ DCHECK(opener_id_ != MSG_ROUTING_NONE);
+
if (GetContentClient()->renderer()->AllowPopup(creator_url_))
opened_by_user_gesture_ = true;
« no previous file with comments | « content/public/android/java/src/org/chromium/content/browser/ContentSettings.java ('k') | webkit/glue/webpreferences.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698