summaryrefslogtreecommitdiffstats
path: root/chrome/browser/plugin_process_host.h
diff options
context:
space:
mode:
authorstuartmorgan@chromium.org <stuartmorgan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-11-04 17:27:08 +0000
committerstuartmorgan@chromium.org <stuartmorgan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-11-04 17:27:08 +0000
commita96ec6a0045c0b1926c9e4c553b67e42a43a430b (patch)
tree017387bccd62964c28a0892b78614a0f1820282e /chrome/browser/plugin_process_host.h
parent39a2e833dc1983b78e9cf78df3d8f3cda3f150c9 (diff)
downloadchromium_src-a96ec6a0045c0b1926c9e4c553b67e42a43a430b.zip
chromium_src-a96ec6a0045c0b1926c9e4c553b67e42a43a430b.tar.gz
chromium_src-a96ec6a0045c0b1926c9e4c553b67e42a43a430b.tar.bz2
Don't allow the browser to stay above a modal plugin window (Mac)
There's a flicker of the modal window being hidden then coming forward again, and the menus still work, so we'll most likely have fake the modality more aggressively at some point. This gets us the basic infrastructure though, and solves the severe usability problem. BUG=20798 TEST=Open a modal plugin window (e.g., Gmail upload). Switch to another app, then back to Chrome; the plugin window should come to the front. Review URL: http://codereview.chromium.org/355021 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@30965 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/plugin_process_host.h')
-rw-r--r--chrome/browser/plugin_process_host.h14
1 files changed, 12 insertions, 2 deletions
diff --git a/chrome/browser/plugin_process_host.h b/chrome/browser/plugin_process_host.h
index 3ce66b2..2717e0c 100644
--- a/chrome/browser/plugin_process_host.h
+++ b/chrome/browser/plugin_process_host.h
@@ -72,6 +72,12 @@ class PluginProcessHost : public ChildProcessHost,
void OnModalDialogResponse(const std::string& json_retval,
IPC::Message* sync_result);
+#if defined(OS_MACOSX)
+ // This function is called on the IO thread when the browser becomes the
+ // active application.
+ void OnAppActivation();
+#endif
+
const WebPluginInfo& info() const { return info_; }
#if defined(OS_WIN)
@@ -113,8 +119,10 @@ class PluginProcessHost : public ChildProcessHost,
#endif
#if defined(OS_MACOSX)
- void OnPluginSelectWindow(uint32 window_id, gfx::Rect window_rect);
- void OnPluginShowWindow(uint32 window_id, gfx::Rect window_rect);
+ void OnPluginSelectWindow(uint32 window_id, gfx::Rect window_rect,
+ bool modal);
+ void OnPluginShowWindow(uint32 window_id, gfx::Rect window_rect,
+ bool modal);
void OnPluginHideWindow(uint32 window_id, gfx::Rect window_rect);
void OnPluginDisposeWindow(uint32 window_id, gfx::Rect window_rect);
#endif
@@ -155,6 +163,8 @@ class PluginProcessHost : public ChildProcessHost,
std::set<uint32> plugin_visible_windows_set_;
// Tracks full screen windows currently visible
std::set<uint32> plugin_fullscreen_windows_set_;
+ // Tracks modal windows currently visible
+ std::set<uint32> plugin_modal_windows_set_;
#endif
DISALLOW_COPY_AND_ASSIGN(PluginProcessHost);