| Index: chrome/plugin/plugin_thread.cc
|
| diff --git a/chrome/plugin/plugin_thread.cc b/chrome/plugin/plugin_thread.cc
|
| index 0e169e41ac8f3063da08ca0993bfa97cd7639f8e..588c53213f8ba1f7a7c6d6975c59bda55907449e 100644
|
| --- a/chrome/plugin/plugin_thread.cc
|
| +++ b/chrome/plugin/plugin_thread.cc
|
| @@ -27,6 +27,7 @@
|
| #include "chrome/plugin/chrome_plugin_host.h"
|
| #include "chrome/plugin/npobject_util.h"
|
| #include "chrome/renderer/render_thread.h"
|
| +#include "gfx/gtk_util.h"
|
| #include "ipc/ipc_channel_handle.h"
|
| #include "net/base/net_errors.h"
|
| #include "webkit/glue/plugins/plugin_lib.h"
|
| @@ -58,33 +59,18 @@ PluginThread::PluginThread()
|
| // XEmbed plugins assume they are hosted in a Gtk application, so we need
|
| // to initialize Gtk in the plugin process.
|
| g_thread_init(NULL);
|
| - const std::vector<std::string>& args =
|
| - CommandLine::ForCurrentProcess()->argv();
|
| - int argc = args.size();
|
| - scoped_array<char *> argv(new char *[argc + 1]);
|
| - for (size_t i = 0; i < args.size(); ++i) {
|
| - // TODO(piman@google.com): can gtk_init modify argv? Just being safe
|
| - // here.
|
| - argv[i] = strdup(args[i].c_str());
|
| - }
|
| - argv[argc] = NULL;
|
| - char **argv_pointer = argv.get();
|
|
|
| // Flash has problems receiving clicks with newer GTKs due to the
|
| // client-side windows change. To be safe, we just always set the
|
| // backwards-compat environment variable.
|
| setenv("GDK_NATIVE_WINDOWS", "1", 1);
|
|
|
| - gtk_init(&argc, &argv_pointer);
|
| + gfx::GtkInitFromCommandLine(*CommandLine::ForCurrentProcess());
|
|
|
| // GTK after 2.18 resets the environment variable. But if we're using
|
| // nspluginwrapper, that means it'll spawn its subprocess without the
|
| // environment variable! So set it again.
|
| setenv("GDK_NATIVE_WINDOWS", "1", 1);
|
| -
|
| - for (size_t i = 0; i < args.size(); ++i) {
|
| - free(argv[i]);
|
| - }
|
| }
|
|
|
| x11_util::SetDefaultX11ErrorHandlers();
|
|
|