summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-11-05 20:40:29 +0000
committerevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-11-05 20:40:29 +0000
commit583335e29fb77b9a18f43c6804b8bfcd1b3f1d52 (patch)
tree2f398fa736cd9abe092a61912bdeffafc7c0f1be
parent0a8b97bce41cba47185d5fbee6a6850f175e9513 (diff)
downloadchromium_src-583335e29fb77b9a18f43c6804b8bfcd1b3f1d52.zip
chromium_src-583335e29fb77b9a18f43c6804b8bfcd1b3f1d52.tar.gz
chromium_src-583335e29fb77b9a18f43c6804b8bfcd1b3f1d52.tar.bz2
Revert "gtk: refactor copy-pasted code"
Build break. git-svn-id: svn://svn.chromium.org/chrome/trunk/src@65247 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--chrome/gpu/gpu_thread.cc18
-rw-r--r--chrome/plugin/plugin_thread.cc18
-rw-r--r--gfx/gtk_util.cc19
-rw-r--r--gfx/gtk_util.h6
4 files changed, 32 insertions, 29 deletions
diff --git a/chrome/gpu/gpu_thread.cc b/chrome/gpu/gpu_thread.cc
index 85aea62..8c1059f 100644
--- a/chrome/gpu/gpu_thread.cc
+++ b/chrome/gpu/gpu_thread.cc
@@ -15,7 +15,6 @@
#include "chrome/common/gpu_info.h"
#include "chrome/common/gpu_messages.h"
#include "chrome/gpu/gpu_info_collector.h"
-#include "gfx/gtk_util.h"
#include "ipc/ipc_channel_handle.h"
#if defined(OS_WIN)
@@ -44,7 +43,22 @@ GpuThread::GpuThread() {
// rethink whether initializing Gtk is really necessary or whether we
// should just send the display connection down to the GPUProcessor.
g_thread_init(NULL);
- gfx::GtkInitFromCommandLine(*CommandLine::ForCurrentProcess());
+ 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();
+
+ gtk_init(&argc, &argv_pointer);
+ for (size_t i = 0; i < args.size(); ++i) {
+ free(argv[i]);
+ }
x11_util::SetDefaultX11ErrorHandlers();
}
#endif
diff --git a/chrome/plugin/plugin_thread.cc b/chrome/plugin/plugin_thread.cc
index 588c532..0e169e4 100644
--- a/chrome/plugin/plugin_thread.cc
+++ b/chrome/plugin/plugin_thread.cc
@@ -27,7 +27,6 @@
#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"
@@ -59,18 +58,33 @@ 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);
- gfx::GtkInitFromCommandLine(*CommandLine::ForCurrentProcess());
+ gtk_init(&argc, &argv_pointer);
// 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();
diff --git a/gfx/gtk_util.cc b/gfx/gtk_util.cc
index b30b827..c45e133 100644
--- a/gfx/gtk_util.cc
+++ b/gfx/gtk_util.cc
@@ -9,7 +9,6 @@
#include <stdlib.h>
#include "base/basictypes.h"
-#include "base/command_line.h"
#include "base/linux_util.h"
#include "gfx/rect.h"
#include "third_party/skia/include/core/SkBitmap.h"
@@ -53,24 +52,6 @@ std::string ConvertAmperstandsTo(const std::string& label,
namespace gfx {
-void GtkInitFromCommandLine(const CommandLine& command_line) {
- const std::vector<std::string>& args = command_line.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();
-
- gtk_init(&argc, &argv_pointer);
- for (size_t i = 0; i < args.size(); ++i) {
- free(argv[i]);
- }
-}
-
GdkPixbuf* GdkPixbufFromSkBitmap(const SkBitmap* bitmap) {
if (bitmap->isNull())
return NULL;
diff --git a/gfx/gtk_util.h b/gfx/gtk_util.h
index 8f9618d..5c4ad94 100644
--- a/gfx/gtk_util.h
+++ b/gfx/gtk_util.h
@@ -17,18 +17,12 @@
typedef struct _GdkPixbuf GdkPixbuf;
typedef struct _GdkRegion GdkRegion;
-class CommandLine;
class SkBitmap;
namespace gfx {
class Rect;
-// Call gtk_init() using the argc and argv from command_line.
-// gtk_init() wants an argc and argv that it can mutate; we provide those,
-// but leave the original CommandLine unaltered.
-void GtkInitFromCommandLine(const CommandLine& command_line);
-
// Convert and copy a SkBitmap to a GdkPixbuf. NOTE: this uses BGRAToRGBA, so
// it is an expensive operation. The returned GdkPixbuf will have a refcount of
// 1, and the caller is responsible for unrefing it when done.