mirror of
https://github.com/Ryujinx/GtkSharp.git
synced 2025-01-11 20:55:32 +00:00
12bc3b0550
* gnome/CanvasItem.custom: Changed from OnXXX vmethods to XXX vmethods * gnome/CanvasProxy.cs: removed, unused code * gnome/GtkSharp.BoundsHandler.cs: removed * gnome/GtkSharp.DrawHandler.cs: removed * gnome/GtkSharp.PointHandler.cs: removed * gnome/GtkSharp.RenderHandler.cs: removed * gnome/GtkSharp.UpdateHandler.cs: removed * gnome/Makefile.am: updated to reflect removing of old files. * gtk/CellRenderer.custom: Changed from OnXXX vmethods to XXX vmethods, and added StartEditing vmethod * gtk/Container.custom: Changed from OnForall to ForAll * gtk/Gtk.metadata: hide CellRenderer.GetSize and StartEditing * gtk/glue/cellrenderer.c: new glue for CellRenderer.StartEditing override. * sample/CustomCellRenderer.cs: updated signatures to reflect new code. svn path=/trunk/gtk-sharp/; revision=28815
74 lines
2.9 KiB
C
74 lines
2.9 KiB
C
/* cellrenderer.c : Glue for overriding pieces of GtkCellRenderer
|
|
*
|
|
* Author: Todd Berman (tberman@sevenl.net)
|
|
*
|
|
* Copyright (C) 2004 Todd Berman
|
|
*/
|
|
|
|
#include <gtk/gtkcellrenderer.h>
|
|
|
|
void gtksharp_cellrenderer_base_get_size (GtkCellRenderer *cell, GtkWidget *widget, GdkRectangle *cell_area, gint *x_offset, gint *y_offset, gint *width, gint *height);
|
|
|
|
void
|
|
gtksharp_cellrenderer_base_get_size (GtkCellRenderer *cell, GtkWidget *widget, GdkRectangle *cell_area, gint *x_offset, gint *y_offset, gint *width, gint *height)
|
|
{
|
|
GtkCellRendererClass *parent = g_type_class_peek_parent (G_OBJECT_GET_CLASS (cell));
|
|
if (parent->get_size)
|
|
(*parent->get_size) (cell, widget, cell_area, x_offset, y_offset, width, height);
|
|
}
|
|
|
|
void gtksharp_cellrenderer_override_get_size (GType gtype, gpointer cb);
|
|
|
|
void
|
|
gtksharp_cellrenderer_override_get_size (GType gtype, gpointer cb)
|
|
{
|
|
GtkCellRendererClass *klass = g_type_class_peek (gtype);
|
|
if (!klass)
|
|
klass = g_type_class_ref (gtype);
|
|
((GtkCellRendererClass *) klass)->get_size = cb;
|
|
}
|
|
|
|
void gtksharp_cellrenderer_base_render (GtkCellRenderer *cell, GdkDrawable *window, GtkWidget *widget, GdkRectangle *background_area, GdkRectangle *cell_area, GdkRectangle *expose_area, GtkCellRendererState flags);
|
|
|
|
void
|
|
gtksharp_cellrenderer_base_render (GtkCellRenderer *cell, GdkDrawable *window, GtkWidget *widget, GdkRectangle *background_area, GdkRectangle *cell_area, GdkRectangle *expose_area, GtkCellRendererState flags)
|
|
{
|
|
GtkCellRendererClass *parent = g_type_class_peek_parent (G_OBJECT_GET_CLASS (cell));
|
|
if (parent->render)
|
|
(*parent->render) (cell, window, widget, background_area, cell_area, expose_area, flags);
|
|
}
|
|
|
|
void gtksharp_cellrenderer_override_render (GType gtype, gpointer cb);
|
|
|
|
void
|
|
gtksharp_cellrenderer_override_render (GType gtype, gpointer cb)
|
|
{
|
|
GtkCellRendererClass *klass = g_type_class_peek (gtype);
|
|
if (!klass)
|
|
klass = g_type_class_ref (gtype);
|
|
((GtkCellRendererClass *) klass)->render = cb;
|
|
}
|
|
|
|
GtkCellEditable * gtksharp_cellrenderer_base_start_editing (GtkCellRenderer *cell, GdkEvent *event, GtkWidget *widget, const gchar *path, GdkRectangle *background_area, GdkRectangle *cell_area, GtkCellRendererState flags);
|
|
|
|
GtkCellEditable *
|
|
gtksharp_cellrenderer_base_start_editing (GtkCellRenderer *cell, GdkEvent *event, GtkWidget *widget, const gchar *path, GdkRectangle *background_area, GdkRectangle *cell_area, GtkCellRendererState flags)
|
|
{
|
|
GtkCellRendererClass *parent = g_type_class_peek_parent (G_OBJECT_GET_CLASS (cell));
|
|
if (parent->start_editing)
|
|
return (*parent->start_editing) (cell, event, widget, path, background_area, cell_area, flags);
|
|
return NULL;
|
|
}
|
|
|
|
|
|
void gtksharp_cellrenderer_override_start_editing (GType gtype, gpointer cb);
|
|
|
|
void
|
|
gtksharp_cellrenderer_override_start_editing (GType gtype, gpointer cb)
|
|
{
|
|
GtkCellRendererClass *klass = g_type_class_peek (gtype);
|
|
if (!klass)
|
|
klass = g_type_class_ref (gtype);
|
|
((GtkCellRendererClass *) klass)->start_editing = cb;
|
|
}
|