[evolution/rendering-cleanup: 45/97] gnome-canvas: Update GnomeCanvasPixbuf for gobject niceties
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution/rendering-cleanup: 45/97] gnome-canvas: Update GnomeCanvasPixbuf for gobject niceties
- Date: Thu, 21 Oct 2010 09:47:49 +0000 (UTC)
commit 8d4a1f11808a1ee0ae71b59a0aa036ace9847d5f
Author: Benjamin Otte <otte redhat com>
Date: Fri Oct 15 12:54:34 2010 +0200
gnome-canvas: Update GnomeCanvasPixbuf for gobject niceties
G_DEFINE_TYPE and private data, here we come!
libgnomecanvas/gnome-canvas-pixbuf.c | 94 ++++++++++------------------------
libgnomecanvas/gnome-canvas-pixbuf.h | 3 +-
2 files changed, 29 insertions(+), 68 deletions(-)
---
diff --git a/libgnomecanvas/gnome-canvas-pixbuf.c b/libgnomecanvas/gnome-canvas-pixbuf.c
index 558d50e..5147854 100644
--- a/libgnomecanvas/gnome-canvas-pixbuf.c
+++ b/libgnomecanvas/gnome-canvas-pixbuf.c
@@ -30,7 +30,7 @@
#include "gnome-canvas-pixbuf.h"
/* Private part of the GnomeCanvasPixbuf structure */
-typedef struct {
+struct _GnomeCanvasPixbufPrivate {
/* Our gdk-pixbuf */
GdkPixbuf *pixbuf;
@@ -56,7 +56,7 @@ typedef struct {
/* Anchor */
GtkAnchorType anchor;
-} PixbufPrivate;
+};
/* Object argument IDs */
enum {
@@ -75,8 +75,6 @@ enum {
PROP_ANCHOR
};
-static void gnome_canvas_pixbuf_class_init (GnomeCanvasPixbufClass *class);
-static void gnome_canvas_pixbuf_init (GnomeCanvasPixbuf *cpb);
static void gnome_canvas_pixbuf_destroy (GnomeCanvasItem *object);
static void gnome_canvas_pixbuf_set_property (GObject *object,
guint param_id,
@@ -99,45 +97,10 @@ static GnomeCanvasItem *gnome_canvas_pixbuf_point (GnomeCanvasItem *item,
static void gnome_canvas_pixbuf_bounds (GnomeCanvasItem *item,
gdouble *x1, gdouble *y1, gdouble *x2, gdouble *y2);
-static GnomeCanvasItemClass *parent_class;
+G_DEFINE_TYPE (GnomeCanvasPixbuf, gnome_canvas_pixbuf, GNOME_TYPE_CANVAS_ITEM)
-/**
- * gnome_canvas_pixbuf_get_type:
- * @void:
- *
- * Registers the #GnomeCanvasPixbuf class if necessary, and returns the type ID
- * associated to it.
- *
- * Return value: The type ID of the #GnomeCanvasPixbuf class.
- **/
-GType
-gnome_canvas_pixbuf_get_type (void)
-{
- static GType pixbuf_type;
-
- if (!pixbuf_type) {
- const GTypeInfo object_info = {
- sizeof (GnomeCanvasPixbufClass),
- (GBaseInitFunc) NULL,
- (GBaseFinalizeFunc) NULL,
- (GClassInitFunc) gnome_canvas_pixbuf_class_init,
- (GClassFinalizeFunc) NULL,
- NULL, /* class_data */
- sizeof (GnomeCanvasPixbuf),
- 0, /* n_preallocs */
- (GInstanceInitFunc) gnome_canvas_pixbuf_init,
- NULL /* value_table */
- };
-
- pixbuf_type = g_type_register_static (GNOME_TYPE_CANVAS_ITEM, "GnomeCanvasPixbuf",
- &object_info, 0);
- }
-
- return pixbuf_type;
-}
-
/* Class initialization function for the pixbuf canvas item */
static void
gnome_canvas_pixbuf_class_init (GnomeCanvasPixbufClass *class)
@@ -148,8 +111,6 @@ gnome_canvas_pixbuf_class_init (GnomeCanvasPixbufClass *class)
gobject_class = (GObjectClass *) class;
item_class = (GnomeCanvasItemClass *) class;
- parent_class = g_type_class_peek_parent (class);
-
gobject_class->set_property = gnome_canvas_pixbuf_set_property;
gobject_class->get_property = gnome_canvas_pixbuf_get_property;
@@ -232,17 +193,20 @@ gnome_canvas_pixbuf_class_init (GnomeCanvasPixbufClass *class)
item_class->draw = gnome_canvas_pixbuf_draw;
item_class->point = gnome_canvas_pixbuf_point;
item_class->bounds = gnome_canvas_pixbuf_bounds;
+
+ g_type_class_add_private (class, sizeof (GnomeCanvasPixbufPrivate));
}
/* Object initialization function for the pixbuf canvas item */
static void
gnome_canvas_pixbuf_init (GnomeCanvasPixbuf *gcp)
{
- PixbufPrivate *priv;
-
- priv = g_new0 (PixbufPrivate, 1);
- gcp->priv = priv;
+ GnomeCanvasPixbufPrivate *priv;
+ priv = gcp->priv = G_TYPE_INSTANCE_GET_PRIVATE (gcp,
+ GNOME_TYPE_CANVAS_PIXBUF,
+ GnomeCanvasPixbufPrivate);
+
priv->width = 0.0;
priv->height = 0.0;
priv->x = 0.0;
@@ -256,27 +220,23 @@ gnome_canvas_pixbuf_destroy (GnomeCanvasItem *object)
{
GnomeCanvasItem *item;
GnomeCanvasPixbuf *gcp;
- PixbufPrivate *priv;
+ GnomeCanvasPixbufPrivate *priv;
g_return_if_fail (object != NULL);
g_return_if_fail (GNOME_IS_CANVAS_PIXBUF (object));
item = GNOME_CANVAS_ITEM (object);
- gcp = (GNOME_CANVAS_PIXBUF (object));
+ gcp = GNOME_CANVAS_PIXBUF (object);
priv = gcp->priv;
/* remember, destroy can be run multiple times! */
-
- if (priv) {
- if (priv->pixbuf)
- g_object_unref (priv->pixbuf);
-
- g_free (priv);
- gcp->priv = NULL;
+ if (priv->pixbuf) {
+ g_object_unref (priv->pixbuf);
+ priv->pixbuf = NULL;
}
- if (GNOME_CANVAS_ITEM_CLASS (parent_class)->destroy)
- GNOME_CANVAS_ITEM_CLASS (parent_class)->destroy (object);
+ if (GNOME_CANVAS_ITEM_CLASS (gnome_canvas_pixbuf_parent_class)->destroy)
+ GNOME_CANVAS_ITEM_CLASS (gnome_canvas_pixbuf_parent_class)->destroy (object);
}
@@ -290,7 +250,7 @@ gnome_canvas_pixbuf_set_property (GObject *object,
{
GnomeCanvasItem *item;
GnomeCanvasPixbuf *gcp;
- PixbufPrivate *priv;
+ GnomeCanvasPixbufPrivate *priv;
GdkPixbuf *pixbuf;
gdouble val;
@@ -387,7 +347,7 @@ gnome_canvas_pixbuf_get_property (GObject *object,
GParamSpec *pspec)
{
GnomeCanvasPixbuf *gcp;
- PixbufPrivate *priv;
+ GnomeCanvasPixbufPrivate *priv;
g_return_if_fail (object != NULL);
g_return_if_fail (GNOME_IS_CANVAS_PIXBUF (object));
@@ -493,7 +453,7 @@ compute_viewport_affine (GnomeCanvasPixbuf *gcp,
gdouble *viewport_affine,
gdouble *i2c)
{
- PixbufPrivate *priv;
+ GnomeCanvasPixbufPrivate *priv;
ArtPoint i_c, j_c;
gdouble i_len, j_len;
gdouble si_len, sj_len;
@@ -645,7 +605,7 @@ static void
recompute_bounding_box (GnomeCanvasPixbuf *gcp, gdouble *i2c)
{
GnomeCanvasItem *item;
- PixbufPrivate *priv;
+ GnomeCanvasPixbufPrivate *priv;
gdouble ra[6];
ArtDRect rect;
@@ -694,13 +654,13 @@ gnome_canvas_pixbuf_update (GnomeCanvasItem *item,
gint flags)
{
GnomeCanvasPixbuf *gcp;
- PixbufPrivate *priv;
+ GnomeCanvasPixbufPrivate *priv;
gcp = GNOME_CANVAS_PIXBUF (item);
priv = gcp->priv;
- if (parent_class->update)
- (* parent_class->update) (item, affine, clip_path, flags);
+ if (GNOME_CANVAS_ITEM_CLASS (gnome_canvas_pixbuf_parent_class)->update)
+ GNOME_CANVAS_ITEM_CLASS (gnome_canvas_pixbuf_parent_class)->update (item, affine, clip_path, flags);
/* ordinary update logic */
gnome_canvas_request_redraw (
@@ -781,7 +741,7 @@ gnome_canvas_pixbuf_draw (GnomeCanvasItem *item, GdkDrawable *drawable,
gint x, gint y, gint width, gint height)
{
GnomeCanvasPixbuf *gcp;
- PixbufPrivate *priv;
+ GnomeCanvasPixbufPrivate *priv;
gdouble i2c[6], render_affine[6];
guchar *buf;
GdkPixbuf *pixbuf;
@@ -853,7 +813,7 @@ gnome_canvas_pixbuf_point (GnomeCanvasItem *item,
gint cy)
{
GnomeCanvasPixbuf *gcp;
- PixbufPrivate *priv;
+ GnomeCanvasPixbufPrivate *priv;
gdouble i2c[6], render_affine[6], inv[6];
ArtPoint c, p;
gint px, py;
@@ -908,7 +868,7 @@ gnome_canvas_pixbuf_bounds (GnomeCanvasItem *item,
gdouble *y2)
{
GnomeCanvasPixbuf *gcp;
- PixbufPrivate *priv;
+ GnomeCanvasPixbufPrivate *priv;
gdouble i2c[6], viewport_affine[6];
ArtDRect rect;
diff --git a/libgnomecanvas/gnome-canvas-pixbuf.h b/libgnomecanvas/gnome-canvas-pixbuf.h
index f8f4d72..3c4141d 100644
--- a/libgnomecanvas/gnome-canvas-pixbuf.h
+++ b/libgnomecanvas/gnome-canvas-pixbuf.h
@@ -38,12 +38,13 @@ G_BEGIN_DECLS
typedef struct _GnomeCanvasPixbuf GnomeCanvasPixbuf;
typedef struct _GnomeCanvasPixbufClass GnomeCanvasPixbufClass;
+typedef struct _GnomeCanvasPixbufPrivate GnomeCanvasPixbufPrivate;
struct _GnomeCanvasPixbuf {
GnomeCanvasItem item;
/* Private data */
- gpointer priv;
+ GnomeCanvasPixbufPrivate *priv;
};
struct _GnomeCanvasPixbufClass {
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]