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

Unified Diff: chrome/common/platform_util_linux.cc

Issue 1705009: Changing linux platform for chromeos. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 10 years, 8 months 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 side-by-side diff with in-line comments
Download patch
Index: chrome/common/platform_util_linux.cc
===================================================================
--- chrome/common/platform_util_linux.cc (revision 45985)
+++ chrome/common/platform_util_linux.cc (working copy)
@@ -1,132 +0,0 @@
-// Copyright (c) 2009 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "chrome/common/platform_util.h"
-
-#include <gtk/gtk.h>
-
-#include "app/gtk_util.h"
-#include "base/file_util.h"
-#include "base/process_util.h"
-#include "base/utf_string_conversions.h"
-#include "chrome/common/process_watcher.h"
-#include "googleurl/src/gurl.h"
-
-namespace {
-
-void XDGOpen(const std::string& path) {
- std::vector<std::string> argv;
- argv.push_back("xdg-open");
- argv.push_back(path);
-
- base::environment_vector env;
- // xdg-open can fall back on mailcap which eventually might plumb through
- // to a command that needs a terminal. Set the environment variable telling
- // it that we definitely don't have a terminal available and that it should
- // bring up a new terminal if necessary. See "man mailcap".
- env.push_back(std::make_pair("MM_NOTTTY", "1"));
-
- // In Google Chrome, we do not let GNOME's bug-buddy intercept our crashes.
- // However, we do not want this environment variable to propagate to external
- // applications. See http://crbug.com/24120
- char* disable_gnome_bug_buddy = getenv("GNOME_DISABLE_CRASH_DIALOG");
- if (disable_gnome_bug_buddy &&
- disable_gnome_bug_buddy == std::string("SET_BY_GOOGLE_CHROME")) {
- env.push_back(std::make_pair("GNOME_DISABLE_CRASH_DIALOG", ""));
- }
-
- base::file_handle_mapping_vector no_files;
- base::ProcessHandle handle;
- if (base::LaunchApp(argv, env, no_files, false, &handle))
- ProcessWatcher::EnsureProcessGetsReaped(handle);
-}
-
-} // namespace
-
-namespace platform_util {
-
-// TODO(estade): It would be nice to be able to select the file in the file
-// manager, but that probably requires extending xdg-open. For now just
-// show the folder.
-void ShowItemInFolder(const FilePath& full_path) {
- FilePath dir = full_path.DirName();
- if (!file_util::DirectoryExists(dir))
- return;
-
- XDGOpen(dir.value());
-}
-
-void OpenItem(const FilePath& full_path) {
- XDGOpen(full_path.value());
-}
-
-void OpenExternal(const GURL& url) {
- XDGOpen(url.spec());
-}
-
-gfx::NativeWindow GetTopLevel(gfx::NativeView view) {
- // A detached widget won't have a toplevel window as an ancestor, so we can't
- // assume that the query for toplevel will return a window.
- GtkWidget* toplevel = gtk_widget_get_ancestor(view, GTK_TYPE_WINDOW);
- return GTK_IS_WINDOW(toplevel) ? GTK_WINDOW(toplevel) : NULL;
-}
-
-bool IsWindowActive(gfx::NativeWindow window) {
- return gtk_window_is_active(window);
-}
-
-bool IsVisible(gfx::NativeView view) {
- return GTK_WIDGET_VISIBLE(view);
-}
-
-void SimpleErrorBox(gfx::NativeWindow parent,
- const string16& title,
- const string16& message) {
- GtkWidget* dialog = gtk_message_dialog_new(parent, GTK_DIALOG_MODAL,
- GTK_MESSAGE_ERROR, GTK_BUTTONS_OK, "%s", UTF16ToUTF8(message).c_str());
- gtk_util::ApplyMessageDialogQuirks(dialog);
- gtk_window_set_title(GTK_WINDOW(dialog), UTF16ToUTF8(title).c_str());
-
- g_signal_connect(dialog, "response", G_CALLBACK(gtk_widget_destroy), NULL);
- gtk_widget_show_all(dialog);
-
- // Make sure it's big enough to show the title.
- GtkRequisition req;
- gtk_widget_size_request(dialog, &req);
- int width;
- gtk_util::GetWidgetSizeFromCharacters(dialog, title.length(), 0,
- &width, NULL);
- // The fudge factor accounts for extra space needed by the frame
- // decorations as well as width differences between average text and the
- // actual title text.
- width = width * 1.2 + 50;
-
- if (width > req.width)
- gtk_widget_set_size_request(dialog, width, -1);
-}
-
-/* Warning: this may be either Linux or ChromeOS */
-string16 GetVersionStringModifier() {
- char* env = getenv("CHROME_VERSION_EXTRA");
- if (!env)
- return string16();
- std::string modifier(env);
-
-#if defined(GOOGLE_CHROME_BUILD)
- // Only ever return "", "unknown", "dev" or "beta" in a branded build.
- if (modifier == "unstable") // linux version of "dev"
- modifier = "dev";
- if (modifier == "stable") {
- modifier = "";
- } else if ((modifier == "dev") || (modifier == "beta")) {
- // do nothing.
- } else {
- modifier = "unknown";
- }
-#endif
-
- return ASCIIToUTF16(modifier);
-}
-
-} // namespace platform_util

Powered by Google App Engine
This is Rietveld 408576698