Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(107)

Side by Side Diff: chrome/browser/chrome_browser_parts_gtk.cc

Issue 8539038: Add ChromeBrowserMainExtraParts for non main parts. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase again + explicit reset of parts_ Created 9 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « chrome/browser/chrome_browser_parts_gtk.h ('k') | chrome/browser/chrome_browser_parts_touch.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/chrome_browser_parts_gtk.h"
6
7 #include <gtk/gtk.h>
8
9 #include "base/command_line.h"
10 #include "chrome/common/chrome_switches.h"
11 #include "grit/chromium_strings.h"
12 #include "grit/generated_resources.h"
13 #include "ui/base/l10n/l10n_util.h"
14 #include "ui/base/resource/resource_bundle.h"
15 #include "ui/gfx/gtk_util.h"
16
17 ChromeBrowserPartsGtk::ChromeBrowserPartsGtk()
18 : content::BrowserMainParts() {
19 }
20
21 void ChromeBrowserPartsGtk::PreEarlyInitialization() {
22 DetectRunningAsRoot();
23 }
24
25 void ChromeBrowserPartsGtk::PostEarlyInitialization() {
26 }
27
28 void ChromeBrowserPartsGtk::ToolkitInitialized() {
29 }
30
31 void ChromeBrowserPartsGtk::PreMainMessageLoopStart() {
32 }
33
34 void ChromeBrowserPartsGtk::PostMainMessageLoopStart() {
35 }
36
37 void ChromeBrowserPartsGtk::PreMainMessageLoopRun() {
38 }
39
40 bool ChromeBrowserPartsGtk::MainMessageLoopRun(int* result_code) {
41 return false;
42 }
43
44 void ChromeBrowserPartsGtk::PostMainMessageLoopRun() {
45 }
46
47 void ChromeBrowserPartsGtk::DetectRunningAsRoot() {
48 if (geteuid() == 0) {
49 const CommandLine& command_line = *CommandLine::ForCurrentProcess();
50 if (command_line.HasSwitch(switches::kUserDataDir))
51 return;
52
53 gfx::GtkInitFromCommandLine(command_line);
54
55 // Get just enough of our resource machinery up so we can extract the
56 // locale appropriate string. Note that the GTK implementation ignores the
57 // passed in parameter and checks the LANG environment variables instead.
58 ResourceBundle::InitSharedInstance("");
59
60 std::string message = l10n_util::GetStringFUTF8(
61 IDS_REFUSE_TO_RUN_AS_ROOT,
62 l10n_util::GetStringUTF16(IDS_PRODUCT_NAME));
63 GtkWidget* dialog = gtk_message_dialog_new(
64 NULL,
65 static_cast<GtkDialogFlags>(0),
66 GTK_MESSAGE_ERROR,
67 GTK_BUTTONS_CLOSE,
68 "%s",
69 message.c_str());
70
71 LOG(ERROR) << "Startup refusing to run as root.";
72 message = l10n_util::GetStringFUTF8(
73 IDS_REFUSE_TO_RUN_AS_ROOT_2,
74 l10n_util::GetStringUTF16(IDS_PRODUCT_NAME));
75 gtk_message_dialog_format_secondary_text(GTK_MESSAGE_DIALOG(dialog),
76 "%s",
77 message.c_str());
78
79 message = l10n_util::GetStringUTF8(IDS_PRODUCT_NAME);
80 gtk_window_set_title(GTK_WINDOW(dialog), message.c_str());
81
82 gtk_dialog_run(GTK_DIALOG(dialog));
83 gtk_widget_destroy(dialog);
84 exit(EXIT_FAILURE);
85 }
86 }
87
88 // static
89 void ChromeBrowserPartsGtk::ShowMessageBox(const char* message) {
90 GtkWidget* dialog = gtk_message_dialog_new(
91 NULL,
92 static_cast<GtkDialogFlags>(0),
93 GTK_MESSAGE_ERROR,
94 GTK_BUTTONS_CLOSE,
95 "%s",
96 message);
97
98 gtk_window_set_title(GTK_WINDOW(dialog), message);
99 gtk_dialog_run(GTK_DIALOG(dialog));
100 gtk_widget_destroy(dialog);
101 }
OLDNEW
« no previous file with comments | « chrome/browser/chrome_browser_parts_gtk.h ('k') | chrome/browser/chrome_browser_parts_touch.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698