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

Unified Diff: content/common/cursors/webcursor_gtk.cc

Issue 231733005: Delete the GTK+ port of Chrome. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Remerge to ToT Created 6 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: content/common/cursors/webcursor_gtk.cc
diff --git a/content/common/cursors/webcursor_gtk.cc b/content/common/cursors/webcursor_gtk.cc
deleted file mode 100644
index a20db7b02ec8cfcb6112372ca3546d47de951ec0..0000000000000000000000000000000000000000
--- a/content/common/cursors/webcursor_gtk.cc
+++ /dev/null
@@ -1,226 +0,0 @@
-// Copyright (c) 2012 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 "content/common/cursors/webcursor.h"
-
-#include <gdk/gdk.h>
-#include <gtk/gtk.h>
-
-#include "base/logging.h"
-#include "third_party/WebKit/public/platform/WebCursorInfo.h"
-#include "ui/gfx/gtk_util.h"
-
-using blink::WebCursorInfo;
-
-namespace {
-
-// webcursor_gtk_data.h is taken directly from WebKit's CursorGtk.h.
-#include "content/common/cursors/webcursor_gtk_data.h"
-
-// This helper function is taken directly from WebKit's CursorGtk.cpp.
-// It attempts to create a custom cursor from the data inlined in
-// webcursor_gtk_data.h.
-GdkCursor* GetInlineCustomCursor(CustomCursorType type) {
- static GdkCursor* CustomCursorsGdk[G_N_ELEMENTS(CustomCursors)];
- GdkCursor* cursor = CustomCursorsGdk[type];
- if (cursor)
- return cursor;
- const CustomCursor& custom = CustomCursors[type];
- cursor = gdk_cursor_new_from_name(gdk_display_get_default(), custom.name);
- if (!cursor) {
- const GdkColor fg = { 0, 0, 0, 0 };
- const GdkColor bg = { 65535, 65535, 65535, 65535 };
- GdkPixmap* source = gdk_bitmap_create_from_data(
- NULL, reinterpret_cast<const gchar*>(custom.bits), 32, 32);
- GdkPixmap* mask = gdk_bitmap_create_from_data(
- NULL, reinterpret_cast<const gchar*>(custom.mask_bits), 32, 32);
- cursor = gdk_cursor_new_from_pixmap(source, mask, &fg, &bg,
- custom.hot_x, custom.hot_y);
- g_object_unref(source);
- g_object_unref(mask);
- }
- CustomCursorsGdk[type] = cursor;
- return cursor;
-}
-
-} // namespace
-
-namespace content {
-
-int WebCursor::GetCursorType() const {
- // http://library.gnome.org/devel/gdk/2.12/gdk-Cursors.html has images
- // of the default X theme, but beware that the user's cursor theme can
- // change everything.
- switch (type_) {
- case WebCursorInfo::TypePointer:
- return GDK_LAST_CURSOR;
- case WebCursorInfo::TypeCross:
- return GDK_CROSS;
- case WebCursorInfo::TypeHand:
- return GDK_HAND2;
- case WebCursorInfo::TypeIBeam:
- return GDK_XTERM;
- case WebCursorInfo::TypeWait:
- return GDK_WATCH;
- case WebCursorInfo::TypeHelp:
- return GDK_QUESTION_ARROW;
- case WebCursorInfo::TypeEastResize:
- return GDK_RIGHT_SIDE;
- case WebCursorInfo::TypeNorthResize:
- return GDK_TOP_SIDE;
- case WebCursorInfo::TypeNorthEastResize:
- return GDK_TOP_RIGHT_CORNER;
- case WebCursorInfo::TypeNorthWestResize:
- return GDK_TOP_LEFT_CORNER;
- case WebCursorInfo::TypeSouthResize:
- return GDK_BOTTOM_SIDE;
- case WebCursorInfo::TypeSouthEastResize:
- return GDK_BOTTOM_RIGHT_CORNER;
- case WebCursorInfo::TypeSouthWestResize:
- return GDK_BOTTOM_LEFT_CORNER;
- case WebCursorInfo::TypeWestResize:
- return GDK_LEFT_SIDE;
- case WebCursorInfo::TypeNorthSouthResize:
- return GDK_SB_V_DOUBLE_ARROW;
- case WebCursorInfo::TypeEastWestResize:
- return GDK_SB_H_DOUBLE_ARROW;
- case WebCursorInfo::TypeNorthEastSouthWestResize:
- case WebCursorInfo::TypeNorthWestSouthEastResize:
- // There isn't really a useful cursor available for these.
- return GDK_LAST_CURSOR;
- case WebCursorInfo::TypeColumnResize:
- return GDK_SB_H_DOUBLE_ARROW; // TODO(evanm): is this correct?
- case WebCursorInfo::TypeRowResize:
- return GDK_SB_V_DOUBLE_ARROW; // TODO(evanm): is this correct?
- case WebCursorInfo::TypeMiddlePanning:
- return GDK_FLEUR;
- case WebCursorInfo::TypeEastPanning:
- return GDK_SB_RIGHT_ARROW;
- case WebCursorInfo::TypeNorthPanning:
- return GDK_SB_UP_ARROW;
- case WebCursorInfo::TypeNorthEastPanning:
- return GDK_TOP_RIGHT_CORNER;
- case WebCursorInfo::TypeNorthWestPanning:
- return GDK_TOP_LEFT_CORNER;
- case WebCursorInfo::TypeSouthPanning:
- return GDK_SB_DOWN_ARROW;
- case WebCursorInfo::TypeSouthEastPanning:
- return GDK_BOTTOM_RIGHT_CORNER;
- case WebCursorInfo::TypeSouthWestPanning:
- return GDK_BOTTOM_LEFT_CORNER;
- case WebCursorInfo::TypeWestPanning:
- return GDK_SB_LEFT_ARROW;
- case WebCursorInfo::TypeMove:
- return GDK_FLEUR;
- case WebCursorInfo::TypeVerticalText:
- return GDK_LAST_CURSOR;
- case WebCursorInfo::TypeCell:
- return GDK_LAST_CURSOR;
- case WebCursorInfo::TypeContextMenu:
- return GDK_LAST_CURSOR;
- case WebCursorInfo::TypeAlias:
- return GDK_LAST_CURSOR;
- case WebCursorInfo::TypeProgress:
- return GDK_WATCH;
- case WebCursorInfo::TypeNoDrop:
- return GDK_LAST_CURSOR;
- case WebCursorInfo::TypeCopy:
- return GDK_LAST_CURSOR;
- case WebCursorInfo::TypeNone:
- return GDK_BLANK_CURSOR;
- case WebCursorInfo::TypeNotAllowed:
- return GDK_LAST_CURSOR;
- case WebCursorInfo::TypeZoomIn:
- case WebCursorInfo::TypeZoomOut:
- case WebCursorInfo::TypeGrab:
- case WebCursorInfo::TypeGrabbing:
- case WebCursorInfo::TypeCustom:
- return GDK_CURSOR_IS_PIXMAP;
- }
- NOTREACHED();
- return GDK_LAST_CURSOR;
-}
-
-gfx::NativeCursor WebCursor::GetNativeCursor() {
- int type = GetCursorType();
- if (type == GDK_CURSOR_IS_PIXMAP)
- return GetCustomCursor();
- return gfx::GetCursor(type);
-}
-
-GdkCursor* WebCursor::GetCustomCursor() {
- switch (type_) {
- case WebCursorInfo::TypeZoomIn:
- return GetInlineCustomCursor(CustomCursorZoomIn);
- case WebCursorInfo::TypeZoomOut:
- return GetInlineCustomCursor(CustomCursorZoomOut);
- case WebCursorInfo::TypeGrab:
- return GetInlineCustomCursor(CustomCursorGrab);
- case WebCursorInfo::TypeGrabbing:
- return GetInlineCustomCursor(CustomCursorGrabbing);
- }
-
- if (type_ != WebCursorInfo::TypeCustom) {
- NOTREACHED();
- return NULL;
- }
-
- if (custom_size_.width() == 0 || custom_size_.height() == 0) {
- // Some websites specify cursor images that are 0 sized, such as Bing Maps.
- // Don't crash on this; just use the default cursor.
- return NULL;
- }
-
- SkBitmap bitmap;
- bitmap.setConfig(SkBitmap::kARGB_8888_Config,
- custom_size_.width(), custom_size_.height());
- bitmap.allocPixels();
- memcpy(bitmap.getAddr32(0, 0), custom_data_.data(), custom_data_.size());
-
- GdkPixbuf* pixbuf = gfx::GdkPixbufFromSkBitmap(bitmap);
- GdkCursor* cursor = gdk_cursor_new_from_pixbuf(gdk_display_get_default(),
- pixbuf,
- hotspot_.x(),
- hotspot_.y());
-
- g_object_unref(pixbuf);
-
- if (unref_)
- gdk_cursor_unref(unref_);
- unref_ = cursor;
- return cursor;
-}
-
-void WebCursor::InitPlatformData() {
- unref_ = NULL;
- return;
-}
-
-bool WebCursor::SerializePlatformData(Pickle* pickle) const {
- return true;
-}
-
-bool WebCursor::DeserializePlatformData(PickleIterator* iter) {
- return true;
-}
-
-bool WebCursor::IsPlatformDataEqual(const WebCursor& other) const {
- return true;
-}
-
-void WebCursor::CleanupPlatformData() {
- if (unref_) {
- gdk_cursor_unref(unref_);
- unref_ = NULL;
- }
- return;
-}
-
-void WebCursor::CopyPlatformData(const WebCursor& other) {
- if (other.unref_)
- unref_ = gdk_cursor_ref(other.unref_);
- return;
-}
-
-} // namespace content

Powered by Google App Engine
This is Rietveld 408576698