| Index: chrome/browser/gtk/options/advanced_contents_gtk.cc
|
| diff --git a/chrome/browser/gtk/options/advanced_contents_gtk.cc b/chrome/browser/gtk/options/advanced_contents_gtk.cc
|
| index 8f7a6d540d5e258a5686b942518c9c3f04b1ee9a..5cf714177bb6129d6f454a9d2824b62104004707 100644
|
| --- a/chrome/browser/gtk/options/advanced_contents_gtk.cc
|
| +++ b/chrome/browser/gtk/options/advanced_contents_gtk.cc
|
| @@ -4,9 +4,14 @@
|
|
|
| #include "chrome/browser/gtk/options/advanced_contents_gtk.h"
|
|
|
| +#include <sys/types.h>
|
| +#include <sys/wait.h>
|
| +
|
| #include "app/l10n_util.h"
|
| #include "base/basictypes.h"
|
| +#include "base/linux_util.h"
|
| #include "base/path_service.h"
|
| +#include "base/process_util.h"
|
| #include "chrome/browser/browser_list.h"
|
| #include "chrome/browser/browser_process.h"
|
| #include "chrome/browser/download/download_manager.h"
|
| @@ -22,6 +27,7 @@
|
| #include "chrome/common/gtk_util.h"
|
| #include "chrome/common/pref_member.h"
|
| #include "chrome/common/pref_names.h"
|
| +#include "chrome/common/process_watcher.h"
|
| #include "grit/chromium_strings.h"
|
| #include "grit/generated_resources.h"
|
| #include "grit/locale_settings.h"
|
| @@ -29,6 +35,9 @@
|
|
|
| namespace {
|
|
|
| +// Command used to configure the gconf proxy settings.
|
| +const char kProxyConfigBinary[] = "gnome-network-preferences";
|
| +
|
| // The pixel width we wrap labels at.
|
| // TODO(evanm): make the labels wrap at the appropriate width.
|
| const int kWrapWidth = 475;
|
| @@ -250,6 +259,10 @@ class NetworkSection : public OptionsPageBase {
|
| }
|
|
|
| private:
|
| + // The callback functions for invoking the proxy config dialog.
|
| + static void OnChangeProxiesButtonClicked(GtkButton *button,
|
| + NetworkSection* section);
|
| +
|
| // The widget containing the options for this section.
|
| GtkWidget* page_;
|
|
|
| @@ -259,8 +272,53 @@ class NetworkSection : public OptionsPageBase {
|
| NetworkSection::NetworkSection(Profile* profile)
|
| : OptionsPageBase(profile) {
|
| page_ = gtk_vbox_new(FALSE, gtk_util::kControlSpacing);
|
| - gtk_box_pack_start(GTK_BOX(page_), gtk_label_new("TODO network options"),
|
| +
|
| + GtkWidget* proxy_description_label = CreateWrappedLabel(
|
| + IDS_OPTIONS_PROXIES_LABEL);
|
| + gtk_misc_set_alignment(GTK_MISC(proxy_description_label), 0, 0);
|
| + gtk_box_pack_start(GTK_BOX(page_), proxy_description_label,
|
| + FALSE, FALSE, 0);
|
| +
|
| + GtkWidget* change_proxies_button = gtk_button_new_with_label(
|
| + l10n_util::GetStringUTF8(
|
| + IDS_OPTIONS_PROXIES_CONFIGURE_BUTTON).c_str());
|
| + g_signal_connect(change_proxies_button, "clicked",
|
| + G_CALLBACK(OnChangeProxiesButtonClicked), this);
|
| + // Stick it in an hbox so it doesn't expand to the whole width.
|
| + GtkWidget* button_hbox = gtk_hbox_new(FALSE, 0);
|
| + gtk_box_pack_start(GTK_BOX(button_hbox),
|
| + change_proxies_button,
|
| FALSE, FALSE, 0);
|
| + gtk_box_pack_start(GTK_BOX(page_),
|
| + OptionsLayoutBuilderGtk::IndentWidget(button_hbox),
|
| + FALSE, FALSE, 0);
|
| +}
|
| +
|
| +// static
|
| +void NetworkSection::OnChangeProxiesButtonClicked(GtkButton *button,
|
| + NetworkSection* section) {
|
| + section->UserMetricsRecordAction(L"Options_ChangeProxies", NULL);
|
| +
|
| + scoped_ptr<base::EnvironmentVariableGetter> env_getter(
|
| + base::EnvironmentVariableGetter::Create());
|
| + if (base::UseGnomeForSettings(env_getter.get())) {
|
| + std::vector<std::string> argv;
|
| + argv.push_back(kProxyConfigBinary);
|
| + base::file_handle_mapping_vector no_files;
|
| + base::environment_vector env;
|
| + base::ProcessHandle handle;
|
| + env.push_back(std::make_pair("GTK_PATH",
|
| + getenv("CHROMIUM_SAVED_GTK_PATH")));
|
| + if (!base::LaunchApp(argv, env, no_files, false, &handle)) {
|
| + LOG(ERROR) << "OpenProxyConfigDialogTask failed";
|
| + return;
|
| + }
|
| + ProcessWatcher::EnsureProcessGetsReaped(handle);
|
| + } else {
|
| + BrowserList::GetLastActive()->
|
| + OpenURL(GURL(l10n_util::GetStringUTF8(IDS_LINUX_PROXY_CONFIG_URL)),
|
| + GURL(), NEW_FOREGROUND_TAB, PageTransition::LINK);
|
| + }
|
| }
|
|
|
| ///////////////////////////////////////////////////////////////////////////////
|
|
|