Index: gfx/gtk_preserve_window.cc |
=================================================================== |
--- gfx/gtk_preserve_window.cc (revision 73487) |
+++ gfx/gtk_preserve_window.cc (working copy) |
@@ -1,200 +0,0 @@ |
-// Copyright (c) 2010 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 "gfx/gtk_preserve_window.h" |
- |
-#include <gdk/gdkwindow.h> |
-#include <gtk/gtk.h> |
-#include <gtk/gtkwidget.h> |
-#include <gtk/gtkfixed.h> |
- |
-G_BEGIN_DECLS |
- |
-#define GTK_PRESERVE_WINDOW_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), \ |
- GTK_TYPE_PRESERVE_WINDOW, \ |
- GtkPreserveWindowPrivate)) |
- |
-typedef struct _GtkPreserveWindowPrivate GtkPreserveWindowPrivate; |
- |
-struct _GtkPreserveWindowPrivate { |
- // If true, don't create/destroy windows on realize/unrealize. |
- gboolean preserve_window; |
- |
- // Whether or not we delegate the resize of the GdkWindow |
- // to someone else. |
- gboolean delegate_resize; |
-}; |
- |
-G_DEFINE_TYPE(GtkPreserveWindow, gtk_preserve_window, GTK_TYPE_FIXED) |
- |
-static void gtk_preserve_window_destroy(GtkObject* object); |
-static void gtk_preserve_window_realize(GtkWidget* widget); |
-static void gtk_preserve_window_unrealize(GtkWidget* widget); |
-static void gtk_preserve_window_size_allocate(GtkWidget* widget, |
- GtkAllocation* allocation); |
- |
-static void gtk_preserve_window_class_init(GtkPreserveWindowClass *klass) { |
- GtkWidgetClass* widget_class = reinterpret_cast<GtkWidgetClass*>(klass); |
- widget_class->realize = gtk_preserve_window_realize; |
- widget_class->unrealize = gtk_preserve_window_unrealize; |
- widget_class->size_allocate = gtk_preserve_window_size_allocate; |
- |
- GtkObjectClass* object_class = reinterpret_cast<GtkObjectClass*>(klass); |
- object_class->destroy = gtk_preserve_window_destroy; |
- |
- GObjectClass* gobject_class = G_OBJECT_CLASS(klass); |
- g_type_class_add_private(gobject_class, sizeof(GtkPreserveWindowPrivate)); |
-} |
- |
-static void gtk_preserve_window_init(GtkPreserveWindow* widget) { |
- GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(widget); |
- priv->preserve_window = FALSE; |
- |
- // These widgets always have their own window. |
- gtk_fixed_set_has_window(GTK_FIXED(widget), TRUE); |
-} |
- |
-GtkWidget* gtk_preserve_window_new() { |
- return GTK_WIDGET(g_object_new(GTK_TYPE_PRESERVE_WINDOW, NULL)); |
-} |
- |
-static void gtk_preserve_window_destroy(GtkObject* object) { |
- GtkWidget* widget = reinterpret_cast<GtkWidget*>(object); |
- GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(widget); |
- |
- if (widget->window) { |
- gdk_window_set_user_data(widget->window, NULL); |
- // If the window is preserved, someone else must destroy it. |
- if (!priv->preserve_window) |
- gdk_window_destroy(widget->window); |
- widget->window = NULL; |
- } |
- |
- GTK_OBJECT_CLASS(gtk_preserve_window_parent_class)->destroy(object); |
-} |
- |
-static void gtk_preserve_window_realize(GtkWidget* widget) { |
- g_return_if_fail(GTK_IS_PRESERVE_WINDOW(widget)); |
- |
- if (widget->window) { |
- gdk_window_reparent(widget->window, |
- gtk_widget_get_parent_window(widget), |
- widget->allocation.x, |
- widget->allocation.y); |
- widget->style = gtk_style_attach(widget->style, widget->window); |
- gtk_style_set_background(widget->style, widget->window, GTK_STATE_NORMAL); |
- |
- gint event_mask = gtk_widget_get_events(widget); |
- event_mask |= GDK_EXPOSURE_MASK | GDK_BUTTON_PRESS_MASK; |
- gdk_window_set_events(widget->window, (GdkEventMask) event_mask); |
- gdk_window_set_user_data(widget->window, widget); |
- |
- // Deprecated as of GTK 2.22. Used for compatibility. |
- // It should be: gtk_widget_set_realized(widget, TRUE) |
- GTK_WIDGET_SET_FLAGS(widget, GTK_REALIZED); |
- } else { |
- GTK_WIDGET_CLASS(gtk_preserve_window_parent_class)->realize(widget); |
- } |
-} |
- |
-static void gtk_preserve_window_unrealize(GtkWidget* widget) { |
- g_return_if_fail(GTK_IS_PRESERVE_WINDOW(widget)); |
- |
- GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(widget); |
- if (priv->preserve_window) { |
- GtkWidgetClass* widget_class = |
- GTK_WIDGET_CLASS(gtk_preserve_window_parent_class); |
- GtkContainerClass* container_class = |
- GTK_CONTAINER_CLASS(gtk_preserve_window_parent_class); |
- |
- // Deprecated as of GTK 2.22. Used for compatibility. |
- // It should be: gtk_widget_get_mapped() |
- if (GTK_WIDGET_MAPPED(widget)) { |
- widget_class->unmap(widget); |
- |
- // Deprecated as of GTK 2.22. Used for compatibility. |
- // It should be: gtk_widget_set_mapped(widget, FALSE) |
- GTK_WIDGET_UNSET_FLAGS(widget, GTK_MAPPED); |
- } |
- |
- // This is the behavior from GtkWidget, inherited by GtkFixed. |
- // It is unclear why we should not call the potentially overridden |
- // unrealize method (via the callback), but doing so causes errors. |
- container_class->forall( |
- GTK_CONTAINER(widget), FALSE, |
- reinterpret_cast<GtkCallback>(gtk_widget_unrealize), NULL); |
- |
- gtk_style_detach(widget->style); |
- gdk_window_reparent(widget->window, gdk_get_default_root_window(), 0, 0); |
- gtk_selection_remove_all(widget); |
- gdk_window_set_user_data(widget->window, NULL); |
- |
- // Deprecated as of GTK 2.22. Used for compatibility. |
- // It should be: gtk_widget_set_realized(widget, FALSE) |
- GTK_WIDGET_UNSET_FLAGS(widget, GTK_REALIZED); |
- } else { |
- GTK_WIDGET_CLASS(gtk_preserve_window_parent_class)->unrealize(widget); |
- } |
-} |
- |
-gboolean gtk_preserve_window_get_preserve(GtkPreserveWindow* window) { |
- g_return_val_if_fail(GTK_IS_PRESERVE_WINDOW(window), FALSE); |
- GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(window); |
- |
- return priv->preserve_window; |
-} |
- |
-void gtk_preserve_window_set_preserve(GtkPreserveWindow* window, |
- gboolean value) { |
- g_return_if_fail(GTK_IS_PRESERVE_WINDOW(window)); |
- GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(window); |
- priv->preserve_window = value; |
- |
- GtkWidget* widget = GTK_WIDGET(window); |
- if (value && !widget->window) { |
- GdkWindowAttr attributes; |
- gint attributes_mask; |
- |
- // We may not know the width and height, so we rely on the fact |
- // that a size-allocation will resize it later. |
- attributes.width = 1; |
- attributes.height = 1; |
- |
- attributes.window_type = GDK_WINDOW_CHILD; |
- attributes.wclass = GDK_INPUT_OUTPUT; |
- |
- attributes.visual = gtk_widget_get_visual(widget); |
- attributes.colormap = gtk_widget_get_colormap(widget); |
- |
- attributes_mask = GDK_WA_VISUAL | GDK_WA_COLORMAP; |
- widget->window = gdk_window_new( |
- gdk_get_default_root_window(), &attributes, attributes_mask); |
- } else if (!value && widget->window && !GTK_WIDGET_REALIZED(widget)) { |
- gdk_window_destroy(widget->window); |
- widget->window = NULL; |
- } |
-} |
- |
-void gtk_preserve_window_size_allocate(GtkWidget* widget, |
- GtkAllocation* allocation) { |
- g_return_if_fail(GTK_IS_PRESERVE_WINDOW(widget)); |
- GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(widget); |
- |
- if (priv->delegate_resize) { |
- // Just update the state. Someone else will gdk_window_resize the |
- // associated GdkWindow. |
- widget->allocation = *allocation; |
- } else { |
- GTK_WIDGET_CLASS(gtk_preserve_window_parent_class)->size_allocate( |
- widget, allocation); |
- } |
-} |
- |
-void gtk_preserve_window_delegate_resize(GtkPreserveWindow* widget, |
- gboolean delegate) { |
- GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(widget); |
- priv->delegate_resize = delegate; |
-} |
- |
-G_END_DECLS |