diff options
author | stuartmorgan@chromium.org <stuartmorgan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-11-04 17:27:08 +0000 |
---|---|---|
committer | stuartmorgan@chromium.org <stuartmorgan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-11-04 17:27:08 +0000 |
commit | a96ec6a0045c0b1926c9e4c553b67e42a43a430b (patch) | |
tree | 017387bccd62964c28a0892b78614a0f1820282e /chrome/browser/plugin_process_host.h | |
parent | 39a2e833dc1983b78e9cf78df3d8f3cda3f150c9 (diff) | |
download | chromium_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.h | 14 |
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); |