OLD | NEW |
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/gtk/options/advanced_contents_gtk.h" | 5 #include "chrome/browser/gtk/options/advanced_contents_gtk.h" |
6 | 6 |
7 #include <sys/types.h> | 7 #include <sys/types.h> |
8 #include <sys/wait.h> | 8 #include <sys/wait.h> |
9 | 9 |
10 #include "app/l10n_util.h" | 10 #include "app/l10n_util.h" |
(...skipping 284 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
295 FALSE, FALSE, 0); | 295 FALSE, FALSE, 0); |
296 } | 296 } |
297 | 297 |
298 // static | 298 // static |
299 void NetworkSection::OnChangeProxiesButtonClicked(GtkButton *button, | 299 void NetworkSection::OnChangeProxiesButtonClicked(GtkButton *button, |
300 NetworkSection* section) { | 300 NetworkSection* section) { |
301 section->UserMetricsRecordAction(L"Options_ChangeProxies", NULL); | 301 section->UserMetricsRecordAction(L"Options_ChangeProxies", NULL); |
302 | 302 |
303 scoped_ptr<base::EnvironmentVariableGetter> env_getter( | 303 scoped_ptr<base::EnvironmentVariableGetter> env_getter( |
304 base::EnvironmentVariableGetter::Create()); | 304 base::EnvironmentVariableGetter::Create()); |
305 if (base::UseGnomeForSettings(env_getter.get())) { | 305 |
306 std::vector<std::string> argv; | 306 switch (base::GetDesktopEnvironment(env_getter.get())) { |
307 argv.push_back(kProxyConfigBinary); | 307 case base::DESKTOP_ENVIRONMENT_GNOME: { |
308 base::file_handle_mapping_vector no_files; | 308 std::vector<std::string> argv; |
309 base::environment_vector env; | 309 argv.push_back(kProxyConfigBinary); |
310 base::ProcessHandle handle; | 310 base::file_handle_mapping_vector no_files; |
311 env.push_back(std::make_pair("GTK_PATH", | 311 base::environment_vector env; |
312 getenv("CHROMIUM_SAVED_GTK_PATH"))); | 312 base::ProcessHandle handle; |
313 if (!base::LaunchApp(argv, env, no_files, false, &handle)) { | 313 env.push_back(std::make_pair("GTK_PATH", |
314 LOG(ERROR) << "OpenProxyConfigDialogTask failed"; | 314 getenv("CHROMIUM_SAVED_GTK_PATH"))); |
315 return; | 315 if (!base::LaunchApp(argv, env, no_files, false, &handle)) { |
| 316 LOG(ERROR) << "OpenProxyConfigDialogTask failed"; |
| 317 return; |
| 318 } |
| 319 ProcessWatcher::EnsureProcessGetsReaped(handle); |
| 320 break; |
316 } | 321 } |
317 ProcessWatcher::EnsureProcessGetsReaped(handle); | 322 |
318 } else { | 323 case base::DESKTOP_ENVIRONMENT_KDE: |
319 BrowserList::GetLastActive()-> | 324 NOTIMPLEMENTED() << "Bug 17363: obey KDE proxy settings."; |
320 OpenURL(GURL(l10n_util::GetStringUTF8(IDS_LINUX_PROXY_CONFIG_URL)), | 325 // Fall through to default behavior for now. |
321 GURL(), NEW_FOREGROUND_TAB, PageTransition::LINK); | 326 |
| 327 case base::DESKTOP_ENVIRONMENT_OTHER: |
| 328 BrowserList::GetLastActive()-> |
| 329 OpenURL(GURL(l10n_util::GetStringUTF8(IDS_LINUX_PROXY_CONFIG_URL)), |
| 330 GURL(), NEW_FOREGROUND_TAB, PageTransition::LINK); |
| 331 break; |
322 } | 332 } |
323 } | 333 } |
324 | 334 |
325 /////////////////////////////////////////////////////////////////////////////// | 335 /////////////////////////////////////////////////////////////////////////////// |
326 // PrivacySection | 336 // PrivacySection |
327 | 337 |
328 class PrivacySection : public OptionsPageBase { | 338 class PrivacySection : public OptionsPageBase { |
329 public: | 339 public: |
330 explicit PrivacySection(Profile* profile); | 340 explicit PrivacySection(Profile* profile); |
331 virtual ~PrivacySection() {} | 341 virtual ~PrivacySection() {} |
(...skipping 507 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
839 l10n_util::GetStringUTF8(IDS_OPTIONS_ADVANCED_SECTION_TITLE_CONTENT), | 849 l10n_util::GetStringUTF8(IDS_OPTIONS_ADVANCED_SECTION_TITLE_CONTENT), |
840 web_content_section_->get_page_widget(), false); | 850 web_content_section_->get_page_widget(), false); |
841 | 851 |
842 security_section_.reset(new SecuritySection(profile_)); | 852 security_section_.reset(new SecuritySection(profile_)); |
843 options_builder.AddOptionGroup( | 853 options_builder.AddOptionGroup( |
844 l10n_util::GetStringUTF8(IDS_OPTIONS_ADVANCED_SECTION_TITLE_SECURITY), | 854 l10n_util::GetStringUTF8(IDS_OPTIONS_ADVANCED_SECTION_TITLE_SECURITY), |
845 security_section_->get_page_widget(), false); | 855 security_section_->get_page_widget(), false); |
846 | 856 |
847 page_ = options_builder.get_page_widget(); | 857 page_ = options_builder.get_page_widget(); |
848 } | 858 } |
OLD | NEW |