summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorstuartmorgan@chromium.org <stuartmorgan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-12-03 22:55:27 +0000
committerstuartmorgan@chromium.org <stuartmorgan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-12-03 22:55:27 +0000
commitb0258ab1379d432f00b41d67bf19c182d45c823e (patch)
tree6a23675d21f24ede8582353f601abc61ba6be89a
parent040f0b84613e1b760aecbf1a0bc0428f4369012b (diff)
downloadchromium_src-b0258ab1379d432f00b41d67bf19c182d45c823e.zip
chromium_src-b0258ab1379d432f00b41d67bf19c182d45c823e.tar.gz
chromium_src-b0258ab1379d432f00b41d67bf19c182d45c823e.tar.bz2
Switch Mac plugins back to a UI runloop
This makes Cocoa-event plugins (e.g., Flash 10.1 preview) happier, and Carbon full-screen still gets key events. BUG=28000 TEST=Flash 10.1 preview should play even without mouse movement. Flash 10 full screen should still accept keyboard commands (e.g., esc). Review URL: http://codereview.chromium.org/460052 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@33743 0039d316-1c4b-4281-b951-d872f2087c98
-rwxr-xr-xchrome/chrome.gyp1
-rw-r--r--chrome/plugin/plugin_main.cc50
-rw-r--r--chrome/plugin/plugin_main_mac.mm42
3 files changed, 49 insertions, 44 deletions
diff --git a/chrome/chrome.gyp b/chrome/chrome.gyp
index cc428ef..5e20d2b 100755
--- a/chrome/chrome.gyp
+++ b/chrome/chrome.gyp
@@ -834,6 +834,7 @@
'plugin/plugin_channel_base.cc',
'plugin/plugin_channel_base.h',
'plugin/plugin_main.cc',
+ 'plugin/plugin_main_mac.mm',
'plugin/plugin_thread.cc',
'plugin/plugin_thread.h',
'plugin/webplugin_delegate_stub.cc',
diff --git a/chrome/plugin/plugin_main.cc b/chrome/plugin/plugin_main.cc
index 9794305..5863621 100644
--- a/chrome/plugin/plugin_main.cc
+++ b/chrome/plugin/plugin_main.cc
@@ -25,8 +25,6 @@
#elif defined(OS_LINUX)
#include "base/global_descriptors_posix.h"
#include "ipc/ipc_descriptors.h"
-#elif defined(OS_MACOSX)
-#include "chrome/common/plugin_carbon_interpose_constants_mac.h"
#endif
#if defined(USE_LINUX_BREAKPAD)
@@ -36,36 +34,10 @@
#if defined(OS_MACOSX)
// Removes our Carbon library interposing from the environment so that it
// doesn't carry into any processes that plugins might start.
-static void TrimInterposeEnvironment() {
- const char* interpose_list =
- getenv(plugin_interpose_strings::kDYLDInsertLibrariesKey);
- if (!interpose_list) {
- NOTREACHED() << "No interposing libraries set";
- return;
- }
+void TrimInterposeEnvironment();
- // The list is a :-separated list of paths. Because we append our interpose
- // library just before forking in plugin_process_host.cc, the only cases we
- // need to handle are:
- // 1) The whole string is "<kInterposeLibraryPath>", so just clear it, or
- // 2) ":<kInterposeLibraryPath>" is the end of the string, so trim and re-set.
- int suffix_offset = strlen(interpose_list) -
- strlen(plugin_interpose_strings::kInterposeLibraryPath);
- if (suffix_offset == 0 &&
- strcmp(interpose_list,
- plugin_interpose_strings::kInterposeLibraryPath) == 0) {
- unsetenv(plugin_interpose_strings::kDYLDInsertLibrariesKey);
- } else if (suffix_offset > 0 && interpose_list[suffix_offset - 1] == ':' &&
- strcmp(interpose_list + suffix_offset,
- plugin_interpose_strings::kInterposeLibraryPath) == 0) {
- std::string trimmed_list =
- std::string(interpose_list).substr(0, suffix_offset - 1);
- setenv(plugin_interpose_strings::kDYLDInsertLibrariesKey,
- trimmed_list.c_str(), 1);
- } else {
- NOTREACHED() << "Missing Carbon interposing library";
- }
-}
+// Initializes the global Cocoa application object.
+void InitializeChromeApplication();
#endif // OS_MACOSX
// main() routine for running as the plugin process.
@@ -77,26 +49,16 @@ int PluginMain(const MainFunctionParams& parameters) {
// The main thread of the plugin services UI.
#if defined(OS_MACOSX)
- // For Mac NPAPI plugins, we don't want a MessageLoop::TYPE_UI because
- // that will cause events to be dispatched via the Cocoa responder chain.
- // If the plugin creates its own windows with Carbon APIs (for example,
- // full screen mode in Flash), those windows would not receive events.
- // Instead, WebPluginDelegateImpl::OnNullEvent will dispatch any pending
- // system events directly to the plugin.
- MessageLoop main_message_loop(MessageLoop::TYPE_DEFAULT);
-#else
- MessageLoop main_message_loop(MessageLoop::TYPE_UI);
+ TrimInterposeEnvironment();
+ InitializeChromeApplication();
#endif
+ MessageLoop main_message_loop(MessageLoop::TYPE_UI);
std::wstring app_name = chrome::kBrowserAppName;
PlatformThread::SetName(WideToASCII(app_name + L"_PluginMain").c_str());
SystemMonitor system_monitor;
HighResolutionTimerManager high_resolution_timer_manager;
-#if defined(OS_MACOSX)
- TrimInterposeEnvironment();
-#endif
-
const CommandLine& parsed_command_line = parameters.command_line_;
#if defined(OS_WIN)
diff --git a/chrome/plugin/plugin_main_mac.mm b/chrome/plugin/plugin_main_mac.mm
new file mode 100644
index 0000000..af428e6
--- /dev/null
+++ b/chrome/plugin/plugin_main_mac.mm
@@ -0,0 +1,42 @@
+// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "base/chrome_application_mac.h"
+#include "base/string_util.h"
+#include "chrome/common/plugin_carbon_interpose_constants_mac.h"
+
+void TrimInterposeEnvironment() {
+ const char* interpose_list =
+ getenv(plugin_interpose_strings::kDYLDInsertLibrariesKey);
+ if (!interpose_list) {
+ NOTREACHED() << "No interposing libraries set";
+ return;
+ }
+
+ // The list is a :-separated list of paths. Because we append our interpose
+ // library just before forking in plugin_process_host.cc, the only cases we
+ // need to handle are:
+ // 1) The whole string is "<kInterposeLibraryPath>", so just clear it, or
+ // 2) ":<kInterposeLibraryPath>" is the end of the string, so trim and re-set.
+ int suffix_offset = strlen(interpose_list) -
+ strlen(plugin_interpose_strings::kInterposeLibraryPath);
+ if (suffix_offset == 0 &&
+ strcmp(interpose_list,
+ plugin_interpose_strings::kInterposeLibraryPath) == 0) {
+ unsetenv(plugin_interpose_strings::kDYLDInsertLibrariesKey);
+ } else if (suffix_offset > 0 && interpose_list[suffix_offset - 1] == ':' &&
+ strcmp(interpose_list + suffix_offset,
+ plugin_interpose_strings::kInterposeLibraryPath) == 0) {
+ std::string trimmed_list =
+ std::string(interpose_list).substr(0, suffix_offset - 1);
+ setenv(plugin_interpose_strings::kDYLDInsertLibrariesKey,
+ trimmed_list.c_str(), 1);
+ } else {
+ NOTREACHED() << "Missing Carbon interposing library";
+ }
+}
+
+void InitializeChromeApplication() {
+ [CrApplication sharedApplication];
+}