[gtk+/treeview-refactor: 66/102] Adding initial code skeleton for GtkCellAreaBox.
- From: Tristan Van Berkom <tvb src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/treeview-refactor: 66/102] Adding initial code skeleton for GtkCellAreaBox.
- Date: Tue, 26 Oct 2010 09:21:51 +0000 (UTC)
commit 741d10ca4fcb835e134a4ab84c7833dd2577b2c5
Author: Tristan Van Berkom <tristan van berkom gmail com>
Date: Sat Oct 23 17:01:58 2010 +0900
Adding initial code skeleton for GtkCellAreaBox.
gtk/Makefile.am | 2 +
gtk/gtkcellarea.c | 138 +++++++++++-----------
gtk/gtkcellarea.h | 110 +++++++++---------
gtk/gtkcellareabox.c | 327 ++++++++++++++++++++++++++++++++++++++++++++++++++
gtk/gtkcellareabox.h | 71 +++++++++++
5 files changed, 524 insertions(+), 124 deletions(-)
---
diff --git a/gtk/Makefile.am b/gtk/Makefile.am
index cc02f2c..eae08f0 100644
--- a/gtk/Makefile.am
+++ b/gtk/Makefile.am
@@ -169,6 +169,7 @@ gtk_public_h_sources = \
gtkbutton.h \
gtkcalendar.h \
gtkcellarea.h \
+ gtkcellareabox.h \
gtkcelleditable.h \
gtkcelllayout.h \
gtkcellrenderer.h \
@@ -432,6 +433,7 @@ gtk_base_c_sources = \
gtkbutton.c \
gtkcalendar.c \
gtkcellarea.c \
+ gtkcellareabox.c \
gtkcelleditable.c \
gtkcelllayout.c \
gtkcellrenderer.c \
diff --git a/gtk/gtkcellarea.c b/gtk/gtkcellarea.c
index a1bdb04..cb85f5a 100644
--- a/gtk/gtkcellarea.c
+++ b/gtk/gtkcellarea.c
@@ -63,27 +63,27 @@ gtk_cell_area_init (GtkCellArea *area)
}
static void
-gtk_cell_area_class_init (GtkCellAreaClass *klass)
+gtk_cell_area_class_init (GtkCellAreaClass *class)
{
/* general */
- klass->add = NULL;
- klass->remove = NULL;
- klass->forall = NULL;
- klass->event = NULL;
- klass->render = NULL;
+ class->add = NULL;
+ class->remove = NULL;
+ class->forall = NULL;
+ class->event = NULL;
+ class->render = NULL;
/* attributes */
- klass->attribute_connect = NULL;
- klass->attribute_disconnect = NULL;
- klass->attribute_apply = NULL;
- klass->attribute_forall = NULL;
+ class->attribute_connect = NULL;
+ class->attribute_disconnect = NULL;
+ class->attribute_apply = NULL;
+ class->attribute_forall = NULL;
/* geometry */
- klass->get_request_mode = NULL;
- klass->get_preferred_width = NULL;
- klass->get_preferred_height = NULL;
- klass->get_preferred_height_for_width = gtk_cell_area_real_get_preferred_height_for_width;
- klass->get_preferred_width_for_height = gtk_cell_area_real_get_preferred_width_for_height;
+ class->get_request_mode = NULL;
+ class->get_preferred_width = NULL;
+ class->get_preferred_height = NULL;
+ class->get_preferred_height_for_width = gtk_cell_area_real_get_preferred_height_for_width;
+ class->get_preferred_width_for_height = gtk_cell_area_real_get_preferred_width_for_height;
}
@@ -237,15 +237,15 @@ void
gtk_cell_area_add (GtkCellArea *area,
GtkCellRenderer *renderer)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (GTK_IS_CELL_RENDERER (renderer));
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->add)
- klass->add (area, renderer);
+ if (class->add)
+ class->add (area, renderer);
else
g_warning ("GtkCellAreaClass::add not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -255,15 +255,15 @@ void
gtk_cell_area_remove (GtkCellArea *area,
GtkCellRenderer *renderer)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (GTK_IS_CELL_RENDERER (renderer));
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->remove)
- klass->remove (area, renderer);
+ if (class->remove)
+ class->remove (area, renderer);
else
g_warning ("GtkCellAreaClass::remove not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -274,15 +274,15 @@ gtk_cell_area_forall (GtkCellArea *area,
GtkCellCallback callback,
gpointer callback_data)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (callback != NULL);
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->forall)
- klass->forall (area, callback, callback_data);
+ if (class->forall)
+ class->forall (area, callback, callback_data);
else
g_warning ("GtkCellAreaClass::forall not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -294,17 +294,17 @@ gtk_cell_area_event (GtkCellArea *area,
GdkEvent *event,
const GdkRectangle *cell_area)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_val_if_fail (GTK_IS_CELL_AREA (area), 0);
g_return_val_if_fail (GTK_IS_WIDGET (widget), 0);
g_return_val_if_fail (event != NULL, 0);
g_return_val_if_fail (cell_area != NULL, 0);
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->event)
- return klass->event (area, widget, event, cell_area);
+ if (class->event)
+ return class->event (area, widget, event, cell_area);
g_warning ("GtkCellAreaClass::event not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -317,17 +317,17 @@ gtk_cell_area_render (GtkCellArea *area,
GtkWidget *widget,
const GdkRectangle *cell_area)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (cr != NULL);
g_return_if_fail (GTK_IS_WIDGET (widget));
g_return_if_fail (cell_area != NULL);
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->render)
- klass->render (area, cr, widget, cell_area);
+ if (class->render)
+ class->render (area, cr, widget, cell_area);
else
g_warning ("GtkCellAreaClass::render not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -341,16 +341,16 @@ gtk_cell_area_attribute_connect (GtkCellArea *area,
const gchar *attribute,
gint id)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (GTK_IS_CELL_RENDERER (renderer));
g_return_if_fail (attribute != NULL);
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->attribute_connect)
- klass->attribute_connect (area, renderer, attribute, id);
+ if (class->attribute_connect)
+ class->attribute_connect (area, renderer, attribute, id);
else
g_warning ("GtkCellAreaClass::attribute_connect not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -362,16 +362,16 @@ gtk_cell_area_attribute_disconnect (GtkCellArea *area,
const gchar *attribute,
gint id)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (GTK_IS_CELL_RENDERER (renderer));
g_return_if_fail (attribute != NULL);
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->attribute_disconnect)
- klass->attribute_disconnect (area, renderer, attribute, id);
+ if (class->attribute_disconnect)
+ class->attribute_disconnect (area, renderer, attribute, id);
else
g_warning ("GtkCellAreaClass::attribute_disconnect not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -382,15 +382,15 @@ gtk_cell_area_attribute_apply (GtkCellArea *area,
gint id,
GValue *value)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (G_IS_VALUE (value));
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->attribute_apply)
- klass->attribute_apply (area, id, value);
+ if (class->attribute_apply)
+ class->attribute_apply (area, id, value);
else
g_warning ("GtkCellAreaClass::attribute_apply not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -402,16 +402,16 @@ gtk_cell_area_attribute_forall (GtkCellArea *area,
GtkCellAttributeCallback callback,
gpointer user_data)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (GTK_IS_CELL_RENDERER (renderer));
g_return_if_fail (callback != NULL);
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->attribute_forall)
- klass->attribute_forall (area, renderer, callback, user_data);
+ if (class->attribute_forall)
+ class->attribute_forall (area, renderer, callback, user_data);
else
g_warning ("GtkCellAreaClass::attribute_forall not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -422,15 +422,15 @@ gtk_cell_area_attribute_forall (GtkCellArea *area,
GtkSizeRequestMode
gtk_cell_area_get_request_mode (GtkCellArea *area)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_val_if_fail (GTK_IS_CELL_AREA (area),
GTK_SIZE_REQUEST_HEIGHT_FOR_WIDTH);
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->get_request_mode)
- return klass->get_request_mode (area);
+ if (class->get_request_mode)
+ return class->get_request_mode (area);
g_warning ("GtkCellAreaClass::get_request_mode not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -444,15 +444,15 @@ gtk_cell_area_get_preferred_width (GtkCellArea *area,
gint *minimum_size,
gint *natural_size)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (GTK_IS_WIDGET (widget));
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->get_preferred_width)
- klass->get_preferred_width (area, widget, minimum_size, natural_size);
+ if (class->get_preferred_width)
+ class->get_preferred_width (area, widget, minimum_size, natural_size);
else
g_warning ("GtkCellAreaClass::get_preferred_width not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -465,13 +465,13 @@ gtk_cell_area_get_preferred_height_for_width (GtkCellArea *area,
gint *minimum_height,
gint *natural_height)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (GTK_IS_WIDGET (widget));
- klass = GTK_CELL_AREA_GET_CLASS (area);
- klass->get_preferred_height_for_width (area, widget, width, minimum_height, natural_height);
+ class = GTK_CELL_AREA_GET_CLASS (area);
+ class->get_preferred_height_for_width (area, widget, width, minimum_height, natural_height);
}
void
@@ -480,15 +480,15 @@ gtk_cell_area_get_preferred_height (GtkCellArea *area,
gint *minimum_size,
gint *natural_size)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (GTK_IS_WIDGET (widget));
- klass = GTK_CELL_AREA_GET_CLASS (area);
+ class = GTK_CELL_AREA_GET_CLASS (area);
- if (klass->get_preferred_height)
- klass->get_preferred_height (area, widget, minimum_size, natural_size);
+ if (class->get_preferred_height)
+ class->get_preferred_height (area, widget, minimum_size, natural_size);
else
g_warning ("GtkCellAreaClass::get_preferred_height not implemented for `%s'",
g_type_name (G_TYPE_FROM_INSTANCE (area)));
@@ -501,11 +501,11 @@ gtk_cell_area_get_preferred_width_for_height (GtkCellArea *area,
gint *minimum_width,
gint *natural_width)
{
- GtkCellAreaClass *klass;
+ GtkCellAreaClass *class;
g_return_if_fail (GTK_IS_CELL_AREA (area));
g_return_if_fail (GTK_IS_WIDGET (widget));
- klass = GTK_CELL_AREA_GET_CLASS (area);
- klass->get_preferred_width_for_height (area, widget, height, minimum_width, natural_width);
+ class = GTK_CELL_AREA_GET_CLASS (area);
+ class->get_preferred_width_for_height (area, widget, height, minimum_width, natural_width);
}
diff --git a/gtk/gtkcellarea.h b/gtk/gtkcellarea.h
index 20da8c4..5da2772 100644
--- a/gtk/gtkcellarea.h
+++ b/gtk/gtkcellarea.h
@@ -88,33 +88,33 @@ struct _GtkCellAreaClass
/* vtable - not signals */
/* Basic methods */
- void (* add) (GtkCellArea *area,
- GtkCellRenderer *renderer);
- void (* remove) (GtkCellArea *area,
- GtkCellRenderer *renderer);
- void (* forall) (GtkCellArea *area,
- GtkCellCallback callback,
- gpointer callback_data);
- gint (* event) (GtkCellArea *area,
- GtkWidget *widget,
- GdkEvent *event,
- const GdkRectangle *cell_area);
- void (* render) (GtkCellArea *area,
- cairo_t *cr,
- GtkWidget *widget,
- const GdkRectangle *cell_area);
+ void (* add) (GtkCellArea *area,
+ GtkCellRenderer *renderer);
+ void (* remove) (GtkCellArea *area,
+ GtkCellRenderer *renderer);
+ void (* forall) (GtkCellArea *area,
+ GtkCellCallback callback,
+ gpointer callback_data);
+ gint (* event) (GtkCellArea *area,
+ GtkWidget *widget,
+ GdkEvent *event,
+ const GdkRectangle *cell_area);
+ void (* render) (GtkCellArea *area,
+ cairo_t *cr,
+ GtkWidget *widget,
+ const GdkRectangle *cell_area);
/* Attributes */
- void (* attribute_connect) (GtkCellArea *area,
- GtkCellRenderer *renderer,
- const gchar *attribute,
- gint id);
- void (* attribute_disconnect) (GtkCellArea *area,
- GtkCellRenderer *renderer,
- const gchar *attribute,
- gint id);
- void (* attribute_apply) (GtkCellArea *area,
- gint id,
+ void (* attribute_connect) (GtkCellArea *area,
+ GtkCellRenderer *renderer,
+ const gchar *attribute,
+ gint id);
+ void (* attribute_disconnect) (GtkCellArea *area,
+ GtkCellRenderer *renderer,
+ const gchar *attribute,
+ gint id);
+ void (* attribute_apply) (GtkCellArea *area,
+ gint id,
GValue *value);
void (* attribute_forall) (GtkCellArea *area,
GtkCellRenderer *renderer,
@@ -122,25 +122,25 @@ struct _GtkCellAreaClass
gpointer user_data);
/* Geometry */
- GtkSizeRequestMode (* get_request_mode) (GtkCellArea *area);
- void (* get_preferred_width) (GtkCellArea *area,
- GtkWidget *widget,
- gint *minimum_size,
- gint *natural_size);
- void (* get_preferred_height_for_width) (GtkCellArea *area,
- GtkWidget *widget,
- gint width,
- gint *minimum_height,
- gint *natural_height);
- void (* get_preferred_height) (GtkCellArea *area,
- GtkWidget *widget,
- gint *minimum_size,
- gint *natural_size);
- void (* get_preferred_width_for_height) (GtkCellArea *area,
- GtkWidget *widget,
- gint height,
- gint *minimum_width,
- gint *natural_width);
+ GtkSizeRequestMode (* get_request_mode) (GtkCellArea *area);
+ void (* get_preferred_width) (GtkCellArea *area,
+ GtkWidget *widget,
+ gint *minimum_size,
+ gint *natural_size);
+ void (* get_preferred_height_for_width) (GtkCellArea *area,
+ GtkWidget *widget,
+ gint width,
+ gint *minimum_height,
+ gint *natural_height);
+ void (* get_preferred_height) (GtkCellArea *area,
+ GtkWidget *widget,
+ gint *minimum_size,
+ gint *natural_size);
+ void (* get_preferred_width_for_height) (GtkCellArea *area,
+ GtkWidget *widget,
+ gint height,
+ gint *minimum_width,
+ gint *natural_width);
/* Padding for future expansion */
@@ -174,17 +174,17 @@ void gtk_cell_area_render (GtkCellArea
const GdkRectangle *cell_area);
/* Attributes */
-void gtk_cell_area_attribute_connect (GtkCellArea *area,
- GtkCellRenderer *renderer,
- const gchar *attribute,
- gint id);
-void gtk_cell_area_attribute_disconnect (GtkCellArea *area,
- GtkCellRenderer *renderer,
- const gchar *attribute,
- gint id);
-void gtk_cell_area_attribute_apply (GtkCellArea *area,
- gint id,
- GValue *value);
+void gtk_cell_area_attribute_connect (GtkCellArea *area,
+ GtkCellRenderer *renderer,
+ const gchar *attribute,
+ gint id);
+void gtk_cell_area_attribute_disconnect (GtkCellArea *area,
+ GtkCellRenderer *renderer,
+ const gchar *attribute,
+ gint id);
+void gtk_cell_area_attribute_apply (GtkCellArea *area,
+ gint id,
+ GValue *value);
void gtk_cell_area_attribute_forall (GtkCellArea *area,
GtkCellRenderer *renderer,
GtkCellAttributeCallback callback,
diff --git a/gtk/gtkcellareabox.c b/gtk/gtkcellareabox.c
new file mode 100644
index 0000000..5c0bedd
--- /dev/null
+++ b/gtk/gtkcellareabox.c
@@ -0,0 +1,327 @@
+/* gtkcellarea.c
+ *
+ * Copyright (C) 2010 Openismus GmbH
+ *
+ * Authors:
+ * Tristan Van Berkom <tristanvb openismus com>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#include "gtkorientable.h"
+#include "gtkcellareabox.h"
+
+/* GObjectClass */
+static void gtk_cell_area_box_finalize (GObject *object);
+static void gtk_cell_area_box_dispose (GObject *object);
+static void gtk_cell_area_box_set_property (GObject *object,
+ guint prop_id,
+ const GValue *value,
+ GParamSpec *pspec);
+static void gtk_cell_area_box_get_property (GObject *object,
+ guint prop_id,
+ GValue *value,
+ GParamSpec *pspec);
+
+/* GtkCellAreaClass */
+static void gtk_cell_area_box_add (GtkCellArea *area,
+ GtkCellRenderer *renderer);
+static void gtk_cell_area_box_remove (GtkCellArea *area,
+ GtkCellRenderer *renderer);
+static void gtk_cell_area_box_forall (GtkCellArea *area,
+ GtkCellCallback callback,
+ gpointer callback_data);
+static gint gtk_cell_area_box_event (GtkCellArea *area,
+ GtkWidget *widget,
+ GdkEvent *event,
+ const GdkRectangle *cell_area);
+static void gtk_cell_area_box_render (GtkCellArea *area,
+ cairo_t *cr,
+ GtkWidget *widget,
+ const GdkRectangle *cell_area);
+
+static void gtk_cell_area_box_attribute_connect (GtkCellArea *area,
+ GtkCellRenderer *renderer,
+ const gchar *attribute,
+ gint id);
+static void gtk_cell_area_box_attribute_disconnect (GtkCellArea *area,
+ GtkCellRenderer *renderer,
+ const gchar *attribute,
+ gint id);
+static void gtk_cell_area_box_attribute_apply (GtkCellArea *area,
+ gint id,
+ GValue *value);
+static void gtk_cell_area_box_attribute_forall (GtkCellArea *area,
+ GtkCellRenderer *renderer,
+ GtkCellAttributeCallback callback,
+ gpointer user_data);
+
+static GtkSizeRequestMode gtk_cell_area_box_get_request_mode (GtkCellArea *area);
+static void gtk_cell_area_box_get_preferred_width (GtkCellArea *area,
+ GtkWidget *widget,
+ gint *minimum_width,
+ gint *natural_width);
+static void gtk_cell_area_box_get_preferred_height (GtkCellArea *area,
+ GtkWidget *widget,
+ gint *minimum_height,
+ gint *natural_height);
+static void gtk_cell_area_box_get_preferred_height_for_width (GtkCellArea *area,
+ GtkWidget *widget,
+ gint width,
+ gint *minimum_height,
+ gint *natural_height);
+static void gtk_cell_area_box_get_preferred_width_for_height (GtkCellArea *area,
+ GtkWidget *widget,
+ gint height,
+ gint *minimum_width,
+ gint *natural_width);
+
+
+struct _GtkCellAreaBoxPrivate
+{
+ GtkOrientation orientation;
+
+
+};
+
+enum {
+ PROP_0,
+ PROP_ORIENTATION
+};
+
+
+G_DEFINE_TYPE_WITH_CODE (GtkCellAreaBox, gtk_cell_area_box, GTK_TYPE_CELL_AREA,
+ G_IMPLEMENT_INTERFACE (GTK_TYPE_ORIENTABLE, NULL));
+
+
+static void
+gtk_cell_area_box_init (GtkCellAreaBox *box)
+{
+ GtkCellAreaBoxPrivate *priv;
+
+ box->priv = G_TYPE_INSTANCE_GET_PRIVATE (box,
+ GTK_TYPE_CELL_AREA_BOX,
+ GtkCellAreaBoxPrivate);
+ priv = box->priv;
+
+ priv->orientation = GTK_ORIENTATION_HORIZONTAL;
+}
+
+static void
+gtk_cell_area_box_class_init (GtkCellAreaBoxClass *class)
+{
+ GObjectClass *object_class = G_OBJECT_CLASS (class);
+ GtkCellAreaClass *area_class = GTK_CELL_AREA_CLASS (class);
+
+ /* GObjectClass */
+ object_class->finalize = gtk_cell_area_box_finalize;
+ object_class->dispose = gtk_cell_area_box_dispose;
+ object_class->set_property = gtk_cell_area_box_set_property;
+ object_class->get_property = gtk_cell_area_box_get_property;
+
+ /* GtkCellAreaClass */
+ area_class->add = gtk_cell_area_box_add;
+ area_class->remove = gtk_cell_area_box_remove;
+ area_class->forall = gtk_cell_area_box_forall;
+ area_class->event = gtk_cell_area_box_event;
+ area_class->render = gtk_cell_area_box_render;
+
+ area_class->attribute_connect = gtk_cell_area_box_attribute_connect;
+ area_class->attribute_disconnect = gtk_cell_area_box_attribute_disconnect;
+ area_class->attribute_apply = gtk_cell_area_box_attribute_apply;
+ area_class->attribute_forall = gtk_cell_area_box_attribute_forall;
+
+ area_class->get_request_mode = gtk_cell_area_box_get_request_mode;
+ area_class->get_preferred_width = gtk_cell_area_box_get_preferred_width;
+ area_class->get_preferred_height = gtk_cell_area_box_get_preferred_height;
+ area_class->get_preferred_height_for_width = gtk_cell_area_box_get_preferred_height_for_width;
+ area_class->get_preferred_width_for_height = gtk_cell_area_box_get_preferred_width_for_height;
+
+ g_object_class_override_property (object_class, PROP_ORIENTATION, "orientation");
+
+
+ g_type_class_add_private (object_class, sizeof (GtkCellAreaBoxPrivate));
+}
+
+
+/*************************************************************
+ * GObjectClass *
+ *************************************************************/
+static void
+gtk_cell_area_box_finalize (GObject *object)
+{
+ G_OBJECT_CLASS (gtk_cell_area_box_parent_class)->finalize (object);
+}
+
+static void
+gtk_cell_area_box_dispose (GObject *object)
+{
+ G_OBJECT_CLASS (gtk_cell_area_box_parent_class)->dispose (object);
+}
+
+static void
+gtk_cell_area_box_set_property (GObject *object,
+ guint prop_id,
+ const GValue *value,
+ GParamSpec *pspec)
+{
+
+}
+
+static void
+gtk_cell_area_box_get_property (GObject *object,
+ guint prop_id,
+ GValue *value,
+ GParamSpec *pspec)
+{
+
+}
+
+
+/*************************************************************
+ * GtkCellAreaClass *
+ *************************************************************/
+static void
+gtk_cell_area_box_add (GtkCellArea *area,
+ GtkCellRenderer *renderer)
+{
+
+}
+
+static void
+gtk_cell_area_box_remove (GtkCellArea *area,
+ GtkCellRenderer *renderer)
+{
+
+}
+
+static void
+gtk_cell_area_box_forall (GtkCellArea *area,
+ GtkCellCallback callback,
+ gpointer callback_data)
+{
+
+}
+
+static gint
+gtk_cell_area_box_event (GtkCellArea *area,
+ GtkWidget *widget,
+ GdkEvent *event,
+ const GdkRectangle *cell_area)
+{
+
+
+ return 0;
+}
+
+static void
+gtk_cell_area_box_render (GtkCellArea *area,
+ cairo_t *cr,
+ GtkWidget *widget,
+ const GdkRectangle *cell_area)
+{
+
+}
+
+static void
+gtk_cell_area_box_attribute_connect (GtkCellArea *area,
+ GtkCellRenderer *renderer,
+ const gchar *attribute,
+ gint id)
+{
+
+}
+
+static void
+gtk_cell_area_box_attribute_disconnect (GtkCellArea *area,
+ GtkCellRenderer *renderer,
+ const gchar *attribute,
+ gint id)
+{
+
+}
+
+static void
+gtk_cell_area_box_attribute_apply (GtkCellArea *area,
+ gint id,
+ GValue *value)
+{
+
+}
+
+static void
+gtk_cell_area_box_attribute_forall (GtkCellArea *area,
+ GtkCellRenderer *renderer,
+ GtkCellAttributeCallback callback,
+ gpointer user_data)
+{
+
+}
+
+
+static GtkSizeRequestMode
+gtk_cell_area_box_get_request_mode (GtkCellArea *area)
+{
+ GtkCellAreaBox *box = GTK_CELL_AREA_BOX (area);
+ GtkCellAreaBoxPrivate *priv = box->priv;
+
+ return (priv->orientation) == GTK_ORIENTATION_HORIZONTAL ?
+ GTK_SIZE_REQUEST_HEIGHT_FOR_WIDTH :
+ GTK_SIZE_REQUEST_WIDTH_FOR_HEIGHT;
+}
+
+static void
+gtk_cell_area_box_get_preferred_width (GtkCellArea *area,
+ GtkWidget *widget,
+ gint *minimum_width,
+ gint *natural_width)
+{
+
+}
+
+static void
+gtk_cell_area_box_get_preferred_height (GtkCellArea *area,
+ GtkWidget *widget,
+ gint *minimum_height,
+ gint *natural_height)
+{
+
+
+}
+
+static void
+gtk_cell_area_box_get_preferred_height_for_width (GtkCellArea *area,
+ GtkWidget *widget,
+ gint width,
+ gint *minimum_height,
+ gint *natural_height)
+{
+
+}
+
+static void
+gtk_cell_area_box_get_preferred_width_for_height (GtkCellArea *area,
+ GtkWidget *widget,
+ gint height,
+ gint *minimum_width,
+ gint *natural_width)
+{
+
+}
+
+/*************************************************************
+ * API *
+ *************************************************************/
diff --git a/gtk/gtkcellareabox.h b/gtk/gtkcellareabox.h
new file mode 100644
index 0000000..1e188ce
--- /dev/null
+++ b/gtk/gtkcellareabox.h
@@ -0,0 +1,71 @@
+/* gtkcellareabox.h
+ *
+ * Copyright (C) 2010 Openismus GmbH
+ *
+ * Authors:
+ * Tristan Van Berkom <tristanvb openismus com>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
+#error "Only <gtk/gtk.h> can be included directly."
+#endif
+
+#ifndef __GTK_CELL_AREA_BOX_H__
+#define __GTK_CELL_AREA_BOX_H__
+
+#include <gtk/gtkcellarea.h>
+
+G_BEGIN_DECLS
+
+#define GTK_TYPE_CELL_AREA_BOX (gtk_cell_area_box_get_type ())
+#define GTK_CELL_AREA_BOX(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_CELL_AREA_BOX, GtkCellAreaBox))
+#define GTK_CELL_AREA_BOX_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_CELL_AREA_BOX, GtkCellAreaBoxClass))
+#define GTK_IS_CELL_AREA_BOX(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_CELL_AREA_BOX))
+#define GTK_IS_CELL_AREA_BOX_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_CELL_AREA_BOX))
+#define GTK_CELL_AREA_BOX_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_CELL_AREA_BOX, GtkCellAreaBoxClass))
+
+typedef struct _GtkCellAreaBox GtkCellAreaBox;
+typedef struct _GtkCellAreaBoxClass GtkCellAreaBoxClass;
+typedef struct _GtkCellAreaBoxPrivate GtkCellAreaBoxPrivate;
+
+struct _GtkCellAreaBox
+{
+ GtkCellArea parent_instance;
+
+ GtkCellAreaBoxPrivate *priv;
+};
+
+struct _GtkCellAreaBoxClass
+{
+ GtkCellAreaClass parent_class;
+
+
+ /* Padding for future expansion */
+ void (*_gtk_reserved1) (void);
+ void (*_gtk_reserved2) (void);
+ void (*_gtk_reserved3) (void);
+ void (*_gtk_reserved4) (void);
+};
+
+GType gtk_cell_area_box_get_type (void) G_GNUC_CONST;
+
+
+
+G_END_DECLS
+
+#endif /* __GTK_CELL_AREA_BOX_H__ */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]