]> Pileus Git - ~andy/gtk/commitdiff
tests: Make testcellarea use an iconview
authorBenjamin Otte <otte@redhat.com>
Sat, 5 May 2012 03:39:58 +0000 (05:39 +0200)
committerBenjamin Otte <otte@redhat.com>
Sun, 6 May 2012 22:12:26 +0000 (00:12 +0200)
tests/Makefile.am
tests/cellareascaffold.c [deleted file]
tests/cellareascaffold.h [deleted file]
tests/testcellarea.c

index 7a135330ef29ba391ba90f588fc1c14de79bdb53..c3a6ac0476d14de5990409183cfa5a7bcc25702e 100644 (file)
@@ -377,9 +377,7 @@ testscrolledwindow_SOURCES =        \
        testscrolledwindow.c
 
 testcellarea_SOURCES =         \
-       testcellarea.c          \
-       cellareascaffold.c      \
-       cellareascaffold.h
+       testcellarea.c
 
 testtreemenu_SOURCES =         \
        testtreemenu.c
diff --git a/tests/cellareascaffold.c b/tests/cellareascaffold.c
deleted file mode 100644 (file)
index 4c76a04..0000000
+++ /dev/null
@@ -1,1136 +0,0 @@
-/* cellareascaffold.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, see <http://www.gnu.org/licenses/>.
- */
-
-#include <string.h>
-#include "cellareascaffold.h"
-
-/* GObjectClass */
-static void      cell_area_scaffold_finalize                       (GObject              *object);
-static void      cell_area_scaffold_dispose                        (GObject              *object);
-
-/* GtkWidgetClass */
-static void      cell_area_scaffold_realize                        (GtkWidget       *widget);
-static void      cell_area_scaffold_unrealize                      (GtkWidget       *widget);
-static gboolean  cell_area_scaffold_draw                           (GtkWidget       *widget,
-                                                                   cairo_t         *cr);
-static void      cell_area_scaffold_size_allocate                  (GtkWidget       *widget,
-                                                                   GtkAllocation   *allocation);
-static void      cell_area_scaffold_get_preferred_width            (GtkWidget       *widget,
-                                                                   gint            *minimum_size,
-                                                                   gint            *natural_size);
-static void      cell_area_scaffold_get_preferred_height_for_width (GtkWidget       *widget,
-                                                                   gint             for_size,
-                                                                   gint            *minimum_size,
-                                                                   gint            *natural_size);
-static void      cell_area_scaffold_get_preferred_height           (GtkWidget       *widget,
-                                                                   gint            *minimum_size,
-                                                                   gint            *natural_size);
-static void      cell_area_scaffold_get_preferred_width_for_height (GtkWidget       *widget,
-                                                                   gint             for_size,
-                                                                   gint            *minimum_size,
-                                                                   gint            *natural_size);
-static void      cell_area_scaffold_map                            (GtkWidget       *widget);
-static void      cell_area_scaffold_unmap                          (GtkWidget       *widget);
-static gint      cell_area_scaffold_focus                          (GtkWidget       *widget,
-                                                                   GtkDirectionType direction);
-static gboolean  cell_area_scaffold_button_press                   (GtkWidget       *widget,
-                                                                   GdkEventButton  *event);
-
-/* GtkContainerClass */
-static void      cell_area_scaffold_forall                         (GtkContainer    *container,
-                                                                   gboolean         include_internals,
-                                                                   GtkCallback      callback,
-                                                                   gpointer         callback_data);
-static void      cell_area_scaffold_remove                         (GtkContainer    *container,
-                                                                   GtkWidget       *child);
-static void      cell_area_scaffold_put_edit_widget                (CellAreaScaffold *scaffold,
-                                                                   GtkWidget        *edit_widget,
-                                                                   gint              x,
-                                                                   gint              y,
-                                                                   gint              width,
-                                                                   gint              height);
-
-/* CellAreaScaffoldClass */
-static void      cell_area_scaffold_activate                       (CellAreaScaffold *scaffold);
-
-/* CellArea/GtkTreeModel callbacks */
-static void      size_changed_cb                                   (GtkCellAreaContext *context,
-                                                                   GParamSpec       *pspec,
-                                                                   CellAreaScaffold *scaffold);
-static void      focus_changed_cb                                  (GtkCellArea      *area,
-                                                                   GtkCellRenderer  *renderer,
-                                                                   const gchar      *path,
-                                                                   CellAreaScaffold *scaffold);
-static void      add_editable_cb                                   (GtkCellArea      *area,
-                                                                   GtkCellRenderer  *renderer,
-                                                                   GtkCellEditable  *edit_widget,
-                                                                   GdkRectangle     *cell_area,
-                                                                   const gchar      *path,
-                                                                   CellAreaScaffold *scaffold);
-static void      remove_editable_cb                                (GtkCellArea      *area,
-                                                                   GtkCellRenderer  *renderer,
-                                                                   GtkCellEditable  *edit_widget,
-                                                                   CellAreaScaffold *scaffold);
-static void      row_changed_cb                                    (GtkTreeModel     *model,
-                                                                   GtkTreePath      *path,
-                                                                   GtkTreeIter      *iter,
-                                                                   CellAreaScaffold *scaffold);
-static void      row_inserted_cb                                   (GtkTreeModel     *model,
-                                                                   GtkTreePath      *path,
-                                                                   GtkTreeIter      *iter,
-                                                                   CellAreaScaffold *scaffold);
-static void      row_deleted_cb                                    (GtkTreeModel     *model,
-                                                                   GtkTreePath      *path,
-                                                                   CellAreaScaffold *scaffold);
-static void      rows_reordered_cb                                 (GtkTreeModel     *model,
-                                                                   GtkTreePath      *parent,
-                                                                   GtkTreeIter      *iter,
-                                                                   gint             *new_order,
-                                                                   CellAreaScaffold *scaffold);
-
-typedef struct {
-  gint    size; /* The height of rows in the scaffold's */
-} RowData;
-
-struct _CellAreaScaffoldPrivate {
-
-  /* Window for catching events and dispatching them to the cell area */
-  GdkWindow       *event_window;
-
-  /* The model we're showing data for */
-  GtkTreeModel    *model;
-  gulong           row_changed_id;
-  gulong           row_inserted_id;
-  gulong           row_deleted_id;
-  gulong           rows_reordered_id;
-
-  /* The area rendering the data and a global context */
-  GtkCellArea        *area;
-  GtkCellAreaContext *context;
-
-  /* Cache some info about rows (hieghts etc) */
-  GArray          *row_data;
-
-  /* Focus handling */
-  gint             focus_row;
-  gulong           focus_changed_id;
-
-  /* Check when the underlying area changes the size and
-   * we need to queue a redraw */
-  gulong           size_changed_id;
-
-  /* Currently edited widget */
-  GtkWidget       *edit_widget;
-  GdkRectangle     edit_rect;
-  gulong           add_editable_id;
-  gulong           remove_editable_id;
-
-
-  gint             row_spacing;
-  gint             indent;
-};
-
-enum {
-  ACTIVATE,
-  N_SIGNALS
-};
-
-static guint scaffold_signals[N_SIGNALS] = { 0 };
-
-#define DIRECTION_STR(dir)                             \
-  ((dir) == GTK_DIR_TAB_FORWARD  ? "tab forward" :     \
-   (dir) == GTK_DIR_TAB_BACKWARD ? "tab backward" :    \
-   (dir) == GTK_DIR_UP           ? "up" :              \
-   (dir) == GTK_DIR_DOWN         ? "down" :            \
-   (dir) == GTK_DIR_LEFT         ? "left" :            \
-   (dir) == GTK_DIR_RIGHT        ? "right" : "invalid")
-
-G_DEFINE_TYPE_WITH_CODE (CellAreaScaffold, cell_area_scaffold, GTK_TYPE_CONTAINER,
-                        G_IMPLEMENT_INTERFACE (GTK_TYPE_ORIENTABLE, NULL));
-
-
-static void
-cell_area_scaffold_init (CellAreaScaffold *scaffold)
-{
-  CellAreaScaffoldPrivate *priv;
-
-  scaffold->priv = G_TYPE_INSTANCE_GET_PRIVATE (scaffold,
-                                               TYPE_CELL_AREA_SCAFFOLD,
-                                               CellAreaScaffoldPrivate);
-  priv = scaffold->priv;
-
-  priv->area    = gtk_cell_area_box_new ();
-  priv->context = gtk_cell_area_create_context (priv->area);
-
-  priv->row_data = g_array_new (FALSE, FALSE, sizeof (RowData));
-
-  gtk_widget_set_has_window (GTK_WIDGET (scaffold), FALSE);
-  gtk_widget_set_can_focus (GTK_WIDGET (scaffold), TRUE);
-
-  priv->size_changed_id = 
-    g_signal_connect (priv->context, "notify",
-                     G_CALLBACK (size_changed_cb), scaffold);
-
-  priv->focus_changed_id =
-    g_signal_connect (priv->area, "focus-changed",
-                     G_CALLBACK (focus_changed_cb), scaffold);
-
-  priv->add_editable_id =
-    g_signal_connect (priv->area, "add-editable",
-                     G_CALLBACK (add_editable_cb), scaffold);
-
-  priv->remove_editable_id =
-    g_signal_connect (priv->area, "remove-editable",
-                     G_CALLBACK (remove_editable_cb), scaffold);
-}
-
-static void
-cell_area_scaffold_class_init (CellAreaScaffoldClass *class)
-{
-  GObjectClass      *gobject_class;
-  GtkWidgetClass    *widget_class;
-  GtkContainerClass *container_class;
-
-  gobject_class = G_OBJECT_CLASS (class);
-  gobject_class->dispose = cell_area_scaffold_dispose;
-  gobject_class->finalize = cell_area_scaffold_finalize;
-
-  widget_class = GTK_WIDGET_CLASS (class);
-  widget_class->realize = cell_area_scaffold_realize;
-  widget_class->unrealize = cell_area_scaffold_unrealize;
-  widget_class->draw = cell_area_scaffold_draw;
-  widget_class->size_allocate = cell_area_scaffold_size_allocate;
-  widget_class->get_preferred_width = cell_area_scaffold_get_preferred_width;
-  widget_class->get_preferred_height_for_width = cell_area_scaffold_get_preferred_height_for_width;
-  widget_class->get_preferred_height = cell_area_scaffold_get_preferred_height;
-  widget_class->get_preferred_width_for_height = cell_area_scaffold_get_preferred_width_for_height;
-  widget_class->map = cell_area_scaffold_map;
-  widget_class->unmap = cell_area_scaffold_unmap;
-  widget_class->focus = cell_area_scaffold_focus;
-  widget_class->button_press_event = cell_area_scaffold_button_press;
-
-  container_class = GTK_CONTAINER_CLASS (class);
-  container_class->forall = cell_area_scaffold_forall;
-  container_class->remove = cell_area_scaffold_remove;
-
-  class->activate = cell_area_scaffold_activate;
-
-  scaffold_signals[ACTIVATE] =
-    g_signal_new ("activate",
-                 G_OBJECT_CLASS_TYPE (gobject_class),
-                 G_SIGNAL_RUN_FIRST | G_SIGNAL_ACTION,
-                 G_STRUCT_OFFSET (CellAreaScaffoldClass, activate),
-                 NULL, NULL,
-                 g_cclosure_marshal_VOID__VOID,
-                 G_TYPE_NONE, 0);
-  widget_class->activate_signal = scaffold_signals[ACTIVATE];
-
-
-  g_type_class_add_private (gobject_class, sizeof (CellAreaScaffoldPrivate));
-}
-
-/*********************************************************
- *                    GObjectClass                       *
- *********************************************************/
-static void
-cell_area_scaffold_finalize (GObject *object)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (object);
-  CellAreaScaffoldPrivate *priv;
-
-  priv = scaffold->priv;
-
-  g_array_free (priv->row_data, TRUE);
-
-  G_OBJECT_CLASS (cell_area_scaffold_parent_class)->finalize (object);
-}
-
-static void
-cell_area_scaffold_dispose (GObject *object)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (object);
-  CellAreaScaffoldPrivate *priv;
-
-  priv = scaffold->priv;
-
-  cell_area_scaffold_set_model (scaffold, NULL);
-
-  if (priv->context)
-    {
-      /* Disconnect signals */
-      g_signal_handler_disconnect (priv->context, priv->size_changed_id);
-
-      g_object_unref (priv->context);
-      priv->context = NULL;
-      priv->size_changed_id = 0;
-    }
-
-  if (priv->area)
-    {
-      /* Disconnect signals */
-      g_signal_handler_disconnect (priv->area, priv->focus_changed_id);
-      g_signal_handler_disconnect (priv->area, priv->add_editable_id);
-      g_signal_handler_disconnect (priv->area, priv->remove_editable_id);
-
-      g_object_unref (priv->area);
-      priv->area = NULL;
-      priv->focus_changed_id = 0;
-    }
-
-  G_OBJECT_CLASS (cell_area_scaffold_parent_class)->dispose (object);  
-}
-
-/*********************************************************
- *                    GtkWidgetClass                     *
- *********************************************************/
-static void
-cell_area_scaffold_realize (GtkWidget *widget)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-  GtkAllocation            allocation;
-  GdkWindow               *window;
-  GdkWindowAttr            attributes;
-  gint                     attributes_mask;
-
-  gtk_widget_get_allocation (widget, &allocation);
-
-  gtk_widget_set_realized (widget, TRUE);
-
-  attributes.window_type = GDK_WINDOW_CHILD;
-  attributes.x = allocation.x;
-  attributes.y = allocation.y;
-  attributes.width = allocation.width;
-  attributes.height = allocation.height;
-  attributes.wclass = GDK_INPUT_ONLY;
-  attributes.event_mask = gtk_widget_get_events (widget);
-  attributes.event_mask |= (GDK_BUTTON_PRESS_MASK |
-                           GDK_BUTTON_RELEASE_MASK |
-                           GDK_KEY_PRESS_MASK |
-                           GDK_KEY_RELEASE_MASK);
-
-  attributes_mask = GDK_WA_X | GDK_WA_Y;
-
-  window = gtk_widget_get_parent_window (widget);
-  gtk_widget_set_window (widget, window);
-  g_object_ref (window);
-
-  priv->event_window = gdk_window_new (window, &attributes, attributes_mask);
-  gdk_window_set_user_data (priv->event_window, widget);
-}
-
-static void
-cell_area_scaffold_unrealize (GtkWidget *widget)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-
-  if (priv->event_window)
-    {
-      gdk_window_set_user_data (priv->event_window, NULL);
-      gdk_window_destroy (priv->event_window);
-      priv->event_window = NULL;
-    }
-  
-  GTK_WIDGET_CLASS (cell_area_scaffold_parent_class)->unrealize (widget);
-}
-
-static gboolean
-cell_area_scaffold_draw (GtkWidget       *widget,
-                        cairo_t         *cr)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-  GtkTreeIter              iter;
-  gboolean                 valid;
-  GdkRectangle             background_area;
-  GdkRectangle             render_area;
-  GtkAllocation            allocation;
-  gint                     i = 0;
-  gboolean                 have_focus;
-  GtkCellRendererState     flags;
-
-  if (!priv->model)
-    return FALSE;
-
-  have_focus  = gtk_widget_has_focus (widget);
-
-  gtk_widget_get_allocation (widget, &allocation);
-
-  render_area.x      = 0;
-  render_area.y      = 0;
-  render_area.width  = allocation.width;
-  render_area.height = allocation.height;
-
-  background_area = render_area;
-
-  render_area.x      = priv->indent;
-  render_area.width -= priv->indent;
-
-  valid = gtk_tree_model_get_iter_first (priv->model, &iter);
-  while (valid)
-    {
-      RowData *data = &g_array_index (priv->row_data, RowData, i);
-
-      if (have_focus && i == priv->focus_row)
-       flags = GTK_CELL_RENDERER_FOCUSED;
-      else
-       flags = 0;
-
-      render_area.height     = data->size;
-
-      background_area.height = render_area.height;
-      background_area.y      = render_area.y;
-
-      if (i == 0)
-       {
-         background_area.height += priv->row_spacing / 2;
-         background_area.height += priv->row_spacing % 2;
-       }
-      else if (i == priv->row_data->len - 1)
-       {
-         background_area.y      -= priv->row_spacing / 2;
-         background_area.height += priv->row_spacing / 2;
-       }
-      else
-       {
-         background_area.y      -= priv->row_spacing / 2;
-         background_area.height += priv->row_spacing;
-       }
-
-      gtk_cell_area_apply_attributes (priv->area, priv->model, &iter, FALSE, FALSE);
-      gtk_cell_area_render (priv->area, priv->context, widget, cr, 
-                           &background_area, &render_area, flags,
-                           (have_focus && i == priv->focus_row));
-
-      render_area.y += data->size;
-      render_area.y += priv->row_spacing;
-
-      i++;
-      valid = gtk_tree_model_iter_next (priv->model, &iter);
-    }
-
-  /* Draw the edit widget after drawing everything else */
-  GTK_WIDGET_CLASS (cell_area_scaffold_parent_class)->draw (widget, cr);
-
-  return FALSE;
-}
-
-static void 
-request_all_base (CellAreaScaffold *scaffold)
-{
-  CellAreaScaffoldPrivate *priv = scaffold->priv;
-  GtkWidget               *widget = GTK_WIDGET (scaffold);
-  GtkTreeIter              iter;
-  gboolean                 valid;
-
-  if (!priv->model)
-    return;
-
-  g_signal_handler_block (priv->context, priv->size_changed_id);
-
-  valid = gtk_tree_model_get_iter_first (priv->model, &iter);
-  while (valid)
-    {
-      gint min, nat;
-
-      gtk_cell_area_apply_attributes (priv->area, priv->model, &iter, FALSE, FALSE);
-      gtk_cell_area_get_preferred_width (priv->area, priv->context, widget, &min, &nat);
-
-      valid = gtk_tree_model_iter_next (priv->model, &iter);
-    }
-
-  g_signal_handler_unblock (priv->context, priv->size_changed_id);
-}
-
-static void 
-get_row_sizes (CellAreaScaffold *scaffold, 
-              GArray           *array,
-              gint              for_size)
-{
-  CellAreaScaffoldPrivate *priv = scaffold->priv;
-  GtkWidget               *widget = GTK_WIDGET (scaffold);
-  GtkTreeIter              iter;
-  gboolean                 valid;
-  gint                     i = 0;
-
-  if (!priv->model)
-    return;
-
-  valid = gtk_tree_model_get_iter_first (priv->model, &iter);
-  while (valid)
-    {
-      RowData *data = &g_array_index (array, RowData, i);
-
-      gtk_cell_area_apply_attributes (priv->area, priv->model, &iter, FALSE, FALSE);
-      gtk_cell_area_get_preferred_height_for_width (priv->area, priv->context, widget, 
-                                                   for_size, &data->size, NULL);
-
-      i++;
-      valid = gtk_tree_model_iter_next (priv->model, &iter);
-    }
-}
-
-static void
-cell_area_scaffold_size_allocate (GtkWidget           *widget,
-                                 GtkAllocation       *allocation)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-
-  gtk_widget_set_allocation (widget, allocation);
-
-  if (gtk_widget_get_realized (widget))
-    gdk_window_move_resize (priv->event_window,
-                            allocation->x,
-                            allocation->y,
-                            allocation->width,
-                            allocation->height);
-
-  /* Allocate the child GtkCellEditable widget if one is currently editing a row */
-  if (priv->edit_widget)
-    gtk_widget_size_allocate (priv->edit_widget, &priv->edit_rect);
-
-  if (!priv->model)
-    return;
-
-  /* Cache the per-row sizes and allocate the context */
-  gtk_cell_area_context_allocate (priv->context, allocation->width - priv->indent, -1);
-  get_row_sizes (scaffold, priv->row_data, allocation->width - priv->indent);
-}
-
-
-static void
-cell_area_scaffold_get_preferred_width (GtkWidget       *widget,
-                                       gint            *minimum_size,
-                                       gint            *natural_size)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-
-  if (!priv->model)
-    return;
-
-  request_all_base (scaffold);
-  gtk_cell_area_context_get_preferred_width (priv->context, minimum_size, natural_size);
-  
-  *minimum_size += priv->indent;
-  *natural_size += priv->indent;
-}
-
-static void
-cell_area_scaffold_get_preferred_height_for_width (GtkWidget       *widget,
-                                                  gint             for_size,
-                                                  gint            *minimum_size,
-                                                  gint            *natural_size)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-  GArray                  *request_array;
-  gint                     n_rows, i, full_size = 0;
-
-  if (!priv->model)
-    return;
-
-  n_rows = gtk_tree_model_iter_n_children (priv->model, NULL);
-
-  /* Get an array for the contextual request */
-  request_array = g_array_new (FALSE, FALSE, sizeof (RowData));
-  g_array_set_size (request_array, n_rows);
-  memset (request_array->data, 0x0, n_rows * sizeof (RowData));
-
-  /* Gather each contextual size into the request array */
-  get_row_sizes (scaffold, request_array, for_size - priv->indent);
-
-  /* Sum up the size and add some row spacing */
-  for (i = 0; i < n_rows; i++)
-    {
-      RowData *data = &g_array_index (request_array, RowData, i);
-      
-      full_size += data->size;
-    }
-  
-  full_size += MAX (0, n_rows -1) * priv->row_spacing;
-  
-  g_array_free (request_array, TRUE);
-  
-  *minimum_size = full_size;
-  *natural_size = full_size;
-}
-
-static void
-cell_area_scaffold_get_preferred_height (GtkWidget       *widget,
-                                        gint            *minimum_size,
-                                        gint            *natural_size)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-  gint                     min_size, nat_size;
-
-  if (!priv->model)
-    return;
-
-  GTK_WIDGET_GET_CLASS (widget)->get_preferred_width (widget, &min_size, &nat_size);
-  GTK_WIDGET_GET_CLASS (widget)->get_preferred_height_for_width (widget, min_size, 
-                                                                minimum_size, natural_size);
-}
-
-static void
-cell_area_scaffold_get_preferred_width_for_height (GtkWidget       *widget,
-                                                  gint             for_size,
-                                                  gint            *minimum_size,
-                                                  gint            *natural_size)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-
-  if (!priv->model)
-    return;
-
-  GTK_WIDGET_GET_CLASS (widget)->get_preferred_width (widget, minimum_size, natural_size);
-}
-
-static void
-cell_area_scaffold_map (GtkWidget       *widget)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-  
-  GTK_WIDGET_CLASS (cell_area_scaffold_parent_class)->map (widget);
-
-  if (priv->event_window)
-    gdk_window_show (priv->event_window);
-}
-
-static void
-cell_area_scaffold_unmap (GtkWidget       *widget)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-  
-  GTK_WIDGET_CLASS (cell_area_scaffold_parent_class)->unmap (widget);
-
-  if (priv->event_window)
-    gdk_window_hide (priv->event_window);
-}
-
-
-static gint
-cell_area_scaffold_focus (GtkWidget       *widget,
-                         GtkDirectionType direction)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-  GtkTreeIter              iter;
-  gboolean                 valid;
-  gint                     focus_row;
-  gboolean                 changed = FALSE;
-
-  /* Grab focus on ourself if we dont already have focus */
-  if (!gtk_widget_has_focus (widget))
-    gtk_widget_grab_focus (widget);
-
-  /* Move focus from cell to cell and row to row */
-  focus_row = priv->focus_row;
-
-  g_signal_handler_block (priv->area, priv->focus_changed_id);
-  
-  valid = gtk_tree_model_iter_nth_child (priv->model, &iter, NULL, priv->focus_row);
-  while (valid)
-    {
-      gtk_cell_area_apply_attributes (priv->area, priv->model, &iter, FALSE, FALSE);
-      
-      /* If focus stays in the area we dont need to do any more */
-      if (gtk_cell_area_focus (priv->area, direction))
-       {
-         priv->focus_row = focus_row;
-
-         /* XXX A smarter implementation would only invalidate the rectangles where
-          * focus was removed from and new focus was placed */
-         gtk_widget_queue_draw (widget);
-         changed = TRUE;
-         break;
-       }
-      else
-       {
-         if (direction == GTK_DIR_RIGHT ||
-             direction == GTK_DIR_LEFT)
-           break;
-         else if (direction == GTK_DIR_UP ||
-                  direction == GTK_DIR_TAB_BACKWARD)
-           {
-             if (focus_row == 0)
-               break;
-             else
-               {
-                 /* XXX A real implementation should check if the
-                  * previous row can focus with its attributes setup */
-                 focus_row--;
-                 valid = gtk_tree_model_iter_nth_child (priv->model, &iter, NULL, focus_row);
-               }
-           }
-         else /* direction == GTK_DIR_DOWN || GTK_DIR_TAB_FORWARD */
-           {
-             if (focus_row == priv->row_data->len - 1)
-               break;
-             else
-               {
-                 /* XXX A real implementation should check if the
-                  * previous row can focus with its attributes setup */
-                 focus_row++;
-                 valid = gtk_tree_model_iter_next (priv->model, &iter);
-               }
-           }
-       }
-    }
-
-  g_signal_handler_unblock (priv->area, priv->focus_changed_id);
-
-  /* XXX A smarter implementation would only invalidate the rectangles where
-   * focus was removed from and new focus was placed */
-  gtk_widget_queue_draw (widget);
-
-  return changed;
-}
-
-static gboolean
-cell_area_scaffold_button_press (GtkWidget       *widget,
-                                GdkEventButton  *event)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (widget);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-  GtkTreeIter              iter;
-  gboolean                 valid;
-  gint                     i = 0;
-  GdkRectangle             event_area;
-  GtkAllocation            allocation;
-  gboolean                 handled = FALSE;
-
-  gtk_widget_get_allocation (widget, &allocation);
-
-  event_area.x      = 0;
-  event_area.y      = 0;
-  event_area.width  = allocation.width;
-  event_area.height = allocation.height;
-
-  event_area.x      = priv->indent;
-  event_area.width -= priv->indent;
-
-  valid = gtk_tree_model_get_iter_first (priv->model, &iter);
-  while (valid)
-    {
-      RowData *data = &g_array_index (priv->row_data, RowData, i);
-
-      event_area.height = data->size;
-
-      if (event->y >= event_area.y && 
-         event->y <= event_area.y + event_area.height)
-       {
-         /* XXX A real implementation would assemble GtkCellRendererState flags here */
-         gtk_cell_area_apply_attributes (priv->area, priv->model, &iter, FALSE, FALSE);
-         handled = gtk_cell_area_event (priv->area, priv->context, GTK_WIDGET (scaffold),
-                                        (GdkEvent *)event, &event_area, 0);
-         break;
-       }
-      
-      event_area.y += data->size;
-      event_area.y += priv->row_spacing;
-      
-      i++;
-      valid = gtk_tree_model_iter_next (priv->model, &iter);
-    }
-
-  return handled;
-}
-
-
-/*********************************************************
- *                   GtkContainerClass                   *
- *********************************************************/
-static void
-cell_area_scaffold_put_edit_widget (CellAreaScaffold *scaffold,
-                                   GtkWidget        *edit_widget,
-                                   gint              x,
-                                   gint              y,
-                                   gint              width,
-                                   gint              height)
-{
-  CellAreaScaffoldPrivate *priv = scaffold->priv;
-
-  priv->edit_rect.x      = x;
-  priv->edit_rect.y      = y;
-  priv->edit_rect.width  = width;
-  priv->edit_rect.height = height;
-  priv->edit_widget      = edit_widget;
-
-  gtk_widget_set_parent (edit_widget, GTK_WIDGET (scaffold));
-}
-
-static void
-cell_area_scaffold_forall (GtkContainer    *container,
-                          gboolean         include_internals,
-                          GtkCallback      callback,
-                          gpointer         callback_data)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (container);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-
-  if (priv->edit_widget)
-    (* callback) (priv->edit_widget, callback_data);
-}
-
-static void
-cell_area_scaffold_remove (GtkContainer    *container,
-                          GtkWidget       *child)
-{
-  CellAreaScaffold        *scaffold = CELL_AREA_SCAFFOLD (container);
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-
-  g_return_if_fail (child == priv->edit_widget);
-
-  gtk_widget_unparent (priv->edit_widget);
-  priv->edit_widget = NULL;
-}
-
-/*********************************************************
- *                CellAreaScaffoldClass                  *
- *********************************************************/
-static void
-cell_area_scaffold_activate (CellAreaScaffold *scaffold)
-{
-  CellAreaScaffoldPrivate *priv     = scaffold->priv;
-  GtkWidget               *widget   = GTK_WIDGET (scaffold);
-  GtkAllocation            allocation;
-  GdkRectangle             cell_area;
-  GtkTreeIter              iter;
-  gboolean                 valid;
-  gint                     i = 0;
-
-  gtk_widget_get_allocation (widget, &allocation);
-
-  cell_area.x = 0;
-  cell_area.y = 0;
-  cell_area.width  = allocation.width;
-  cell_area.height = allocation.height;
-
-  cell_area.x      = priv->indent;
-  cell_area.width -= priv->indent;
-
-  valid = gtk_tree_model_get_iter_first (priv->model, &iter);
-  while (valid)
-    {
-      RowData *data = &g_array_index (priv->row_data, RowData, i);
-
-      if (i == priv->focus_row)
-       {
-         cell_area.height = data->size;
-
-         gtk_cell_area_apply_attributes (priv->area, priv->model, &iter, FALSE, FALSE);
-         gtk_cell_area_activate (priv->area, priv->context, widget, &cell_area, 
-                                 GTK_CELL_RENDERER_FOCUSED, FALSE);
-
-         break;
-       }
-
-      cell_area.y += data->size + priv->row_spacing;
-
-      i++;
-      valid = gtk_tree_model_iter_next (priv->model, &iter);
-    }
-}
-
-/*********************************************************
- *           CellArea/GtkTreeModel callbacks             *
- *********************************************************/
-static void
-size_changed_cb (GtkCellAreaContext  *context,
-                GParamSpec          *pspec,
-                CellAreaScaffold    *scaffold)
-{
-  if (!strcmp (pspec->name, "minimum-width") ||
-      !strcmp (pspec->name, "natural-width") ||
-      !strcmp (pspec->name, "minimum-height") ||
-      !strcmp (pspec->name, "natural-height"))
-    gtk_widget_queue_resize (GTK_WIDGET (scaffold));
-}
-
-static void
-focus_changed_cb (GtkCellArea      *area,
-                 GtkCellRenderer  *renderer,
-                 const gchar      *path,
-                 CellAreaScaffold *scaffold)
-{
-  CellAreaScaffoldPrivate *priv = scaffold->priv;
-  GtkWidget               *widget = GTK_WIDGET (scaffold);
-  GtkTreePath             *treepath;
-  gint                    *indices;
-
-  if (!priv->model)
-    return;
-
-  /* We can be signaled that a renderer lost focus, here
-   * we dont care */
-  if (!renderer)
-    return;
-  
-  treepath = gtk_tree_path_new_from_string (path);
-  indices = gtk_tree_path_get_indices (treepath);
-
-  priv->focus_row = indices[0];
-
-  gtk_tree_path_free (treepath);
-
-  /* Make sure we have focus now */
-  if (!gtk_widget_has_focus (widget))
-    gtk_widget_grab_focus (widget);
-
-  gtk_widget_queue_draw (widget);
-}
-
-static void
-add_editable_cb (GtkCellArea      *area,
-                GtkCellRenderer  *renderer,
-                GtkCellEditable  *edit_widget,
-                GdkRectangle     *cell_area,
-                const gchar      *path,
-                CellAreaScaffold *scaffold)
-{
-  GtkAllocation allocation;
-
-  gtk_widget_get_allocation (GTK_WIDGET (scaffold), &allocation);
-
-  cell_area_scaffold_put_edit_widget (scaffold, GTK_WIDGET (edit_widget),
-                                     allocation.x + cell_area->x, 
-                                     allocation.y + cell_area->y, 
-                                     cell_area->width, cell_area->height);
-}
-
-static void
-remove_editable_cb (GtkCellArea      *area,
-                   GtkCellRenderer  *renderer,
-                   GtkCellEditable  *edit_widget,
-                   CellAreaScaffold *scaffold)
-{
-  gtk_container_remove (GTK_CONTAINER (scaffold), GTK_WIDGET (edit_widget));
-
-  gtk_widget_grab_focus (GTK_WIDGET (scaffold));
-}
-
-static void 
-rebuild_and_reset_internals (CellAreaScaffold *scaffold)
-{
-  CellAreaScaffoldPrivate *priv = scaffold->priv;
-  gint n_rows;
-
-  if (priv->model)
-    {
-      n_rows = gtk_tree_model_iter_n_children (priv->model, NULL);
-
-      /* Clear/reset the array */
-      g_array_set_size (priv->row_data, n_rows);
-      memset (priv->row_data->data, 0x0, n_rows * sizeof (RowData));
-    }
-  else
-    g_array_set_size (priv->row_data, 0);
-
-  /* Data changed, lets reset the context and consequently queue resize and
-   * start everything over again (note this is definitly far from optimized) */
-  gtk_cell_area_context_reset (priv->context);
-}
-
-static void
-row_changed_cb (GtkTreeModel     *model,
-               GtkTreePath      *path,
-               GtkTreeIter      *iter,
-               CellAreaScaffold *scaffold)
-{
-  rebuild_and_reset_internals (scaffold);
-}
-
-static void
-row_inserted_cb (GtkTreeModel     *model,
-                GtkTreePath      *path,
-                GtkTreeIter      *iter,
-                CellAreaScaffold *scaffold)
-{
-  rebuild_and_reset_internals (scaffold);
-}
-
-static void
-row_deleted_cb (GtkTreeModel     *model,
-               GtkTreePath      *path,
-               CellAreaScaffold *scaffold)
-{
-  rebuild_and_reset_internals (scaffold);
-}
-
-static void
-rows_reordered_cb (GtkTreeModel     *model,
-                  GtkTreePath      *parent,
-                  GtkTreeIter      *iter,
-                  gint             *new_order,
-                  CellAreaScaffold *scaffold)
-{
-  rebuild_and_reset_internals (scaffold);
-}
-
-/*********************************************************
- *                         API                           *
- *********************************************************/
-GtkWidget *
-cell_area_scaffold_new (void)
-{
-  return (GtkWidget *)g_object_new (TYPE_CELL_AREA_SCAFFOLD, NULL);
-}
-
-GtkCellArea  *
-cell_area_scaffold_get_area (CellAreaScaffold *scaffold)
-{
-  CellAreaScaffoldPrivate *priv;
-  
-  g_return_val_if_fail (IS_CELL_AREA_SCAFFOLD (scaffold), NULL);
-
-  priv = scaffold->priv;
-
-  return priv->area;
-}
-
-void
-cell_area_scaffold_set_model (CellAreaScaffold *scaffold,
-                             GtkTreeModel     *model)
-{
-  CellAreaScaffoldPrivate *priv;
-  
-  g_return_if_fail (IS_CELL_AREA_SCAFFOLD (scaffold));
-
-  priv = scaffold->priv;
-
-  if (priv->model != model)
-    {
-      if (priv->model)
-       {
-         g_signal_handler_disconnect (priv->model, priv->row_changed_id);
-         g_signal_handler_disconnect (priv->model, priv->row_inserted_id);
-         g_signal_handler_disconnect (priv->model, priv->row_deleted_id);
-         g_signal_handler_disconnect (priv->model, priv->rows_reordered_id);
-
-         g_object_unref (priv->model);
-       }
-
-      priv->model = model;
-
-      if (priv->model)
-       {
-         g_object_ref (priv->model);
-
-         priv->row_changed_id = 
-           g_signal_connect (priv->model, "row-changed",
-                             G_CALLBACK (row_changed_cb), scaffold);
-
-         priv->row_inserted_id = 
-           g_signal_connect (priv->model, "row-inserted",
-                             G_CALLBACK (row_inserted_cb), scaffold);
-
-         priv->row_deleted_id = 
-           g_signal_connect (priv->model, "row-deleted",
-                             G_CALLBACK (row_deleted_cb), scaffold);
-
-         priv->rows_reordered_id = 
-           g_signal_connect (priv->model, "rows-reordered",
-                             G_CALLBACK (rows_reordered_cb), scaffold);
-       }
-
-      rebuild_and_reset_internals (scaffold);
-    }
-}
-
-GtkTreeModel *
-cell_area_scaffold_get_model (CellAreaScaffold *scaffold)
-{
-  CellAreaScaffoldPrivate *priv;
-  
-  g_return_val_if_fail (IS_CELL_AREA_SCAFFOLD (scaffold), NULL);
-
-  priv = scaffold->priv;
-
-  return priv->model;
-}
-
-
-void
-cell_area_scaffold_set_row_spacing (CellAreaScaffold *scaffold,
-                                   gint              spacing)
-{
-  CellAreaScaffoldPrivate *priv;
-  
-  g_return_if_fail (IS_CELL_AREA_SCAFFOLD (scaffold));
-
-  priv = scaffold->priv;
-
-  if (priv->row_spacing != spacing)
-    {
-      priv->row_spacing = spacing;
-      gtk_widget_queue_resize (GTK_WIDGET (scaffold));
-    }
-}
-
-gint
-cell_area_scaffold_get_row_spacing (CellAreaScaffold *scaffold)
-{
-  CellAreaScaffoldPrivate *priv;
-  
-  g_return_val_if_fail (IS_CELL_AREA_SCAFFOLD (scaffold), 0);
-
-  priv = scaffold->priv;
-
-  return priv->row_spacing;
-}
-
-void
-cell_area_scaffold_set_indentation (CellAreaScaffold *scaffold,
-                                   gint              indent)
-{
-  CellAreaScaffoldPrivate *priv;
-  
-  g_return_if_fail (IS_CELL_AREA_SCAFFOLD (scaffold));
-
-  priv = scaffold->priv;
-
-  if (priv->indent != indent)
-    {
-      priv->indent = indent;
-      gtk_widget_queue_resize (GTK_WIDGET (scaffold));
-    }
-}
-
-gint
-cell_area_scaffold_get_indentation (CellAreaScaffold *scaffold)
-{
-  CellAreaScaffoldPrivate *priv;
-  
-  g_return_val_if_fail (IS_CELL_AREA_SCAFFOLD (scaffold), 0);
-
-  priv = scaffold->priv;
-
-  return priv->indent;
-}
-
-
diff --git a/tests/cellareascaffold.h b/tests/cellareascaffold.h
deleted file mode 100644 (file)
index 9980a1b..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-/* cellareascaffold.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, see <http://www.gnu.org/licenses/>.
- */
-
-#ifndef __CELL_AREA_SCAFFOLD_H__
-#define __CELL_AREA_SCAFFOLD_H__
-
-#include <gtk/gtk.h>
-
-
-G_BEGIN_DECLS
-
-#define TYPE_CELL_AREA_SCAFFOLD            (cell_area_scaffold_get_type ())
-#define CELL_AREA_SCAFFOLD(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_CELL_AREA_SCAFFOLD, CellAreaScaffold))
-#define CELL_AREA_SCAFFOLD_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_CELL_AREA_SCAFFOLD, CellAreaScaffoldClass))
-#define IS_CELL_AREA_SCAFFOLD(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_CELL_AREA_SCAFFOLD))
-#define IS_CELL_AREA_SCAFFOLD_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_CELL_AREA_SCAFFOLD))
-#define CELL_AREA_SCAFFOLD_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_CELL_AREA_SCAFFOLD, CellAreaScaffoldClass))
-
-
-typedef struct _CellAreaScaffold         CellAreaScaffold;
-typedef struct _CellAreaScaffoldClass    CellAreaScaffoldClass;
-typedef struct _CellAreaScaffoldPrivate  CellAreaScaffoldPrivate;
-
-struct _CellAreaScaffold
-{
-  GtkContainer widget;
-
-  CellAreaScaffoldPrivate *priv;
-};
-
-struct _CellAreaScaffoldClass
-{
-  GtkContainerClass parent_class;
-
-  void  (* activate) (CellAreaScaffold *scaffold);
-};
-
-
-GType         cell_area_scaffold_get_type              (void) G_GNUC_CONST;
-GtkWidget    *cell_area_scaffold_new                   (void);
-
-GtkCellArea  *cell_area_scaffold_get_area              (CellAreaScaffold *scaffold);
-void          cell_area_scaffold_set_model             (CellAreaScaffold *scaffold,
-                                                       GtkTreeModel     *model);
-GtkTreeModel *cell_area_scaffold_get_model             (CellAreaScaffold *scaffold);
-
-void          cell_area_scaffold_set_row_spacing       (CellAreaScaffold *scaffold,
-                                                       gint              spacing);
-gint          cell_area_scaffold_get_row_spacing       (CellAreaScaffold *scaffold);
-
-void          cell_area_scaffold_set_indentation       (CellAreaScaffold *scaffold,
-                                                       gint              indent);
-gint          cell_area_scaffold_get_indentation       (CellAreaScaffold *scaffold);
-
-
-
-G_END_DECLS
-
-#endif /* __CELL_AREA_SCAFFOLD_H__ */
index 7064637efcb254b0a93f2cc488c9ddec17792580..f483f5f47d7e93a154e38015f151c73c3243c9eb 100644 (file)
@@ -1,5 +1,4 @@
 #include <gtk/gtk.h>
-#include "cellareascaffold.h"
 
 /*******************************************************
  *                      Simple Test                    *
@@ -79,21 +78,22 @@ simple_list_model (void)
 }
 
 static GtkWidget *
-simple_scaffold (void)
+simple_iconview (void)
 {
   GtkTreeModel *model;
-  GtkWidget *scaffold;
+  GtkWidget *iconview;
   GtkCellArea *area;
   GtkCellRenderer *renderer;
 
-  scaffold = cell_area_scaffold_new ();
-  gtk_widget_show (scaffold);
+  iconview = gtk_icon_view_new ();
+  gtk_widget_show (iconview);
 
   model = simple_list_model ();
 
-  cell_area_scaffold_set_model (CELL_AREA_SCAFFOLD (scaffold), model);
+  gtk_icon_view_set_model (GTK_ICON_VIEW (iconview), model);
+  gtk_icon_view_set_item_orientation (GTK_ICON_VIEW (iconview), GTK_ORIENTATION_HORIZONTAL);
 
-  area = cell_area_scaffold_get_area (CELL_AREA_SCAFFOLD (scaffold));
+  area = gtk_cell_layout_get_area (GTK_CELL_LAYOUT (iconview));
 
   cell_1 = renderer = gtk_cell_renderer_text_new ();
   gtk_cell_area_box_pack_start (GTK_CELL_AREA_BOX (area), renderer, FALSE, FALSE, FALSE);
@@ -112,24 +112,23 @@ simple_scaffold (void)
   gtk_cell_area_box_pack_start (GTK_CELL_AREA_BOX (area), renderer, FALSE, TRUE, FALSE);
   gtk_cell_area_attribute_connect (area, renderer, "text", SIMPLE_COLUMN_DESCRIPTION);
 
-  return scaffold;
+  return iconview;
 }
 
 static void
 orientation_changed (GtkComboBox      *combo,
-                    CellAreaScaffold *scaffold)
+                    GtkIconView *iconview)
 {
-  GtkCellArea   *area = cell_area_scaffold_get_area (scaffold);
   GtkOrientation orientation = gtk_combo_box_get_active (combo);
 
-  gtk_orientable_set_orientation (GTK_ORIENTABLE (area), orientation);
+  gtk_icon_view_set_item_orientation (iconview, orientation);
 }
 
 static void
 align_cell_2_toggled (GtkToggleButton  *toggle,
-                     CellAreaScaffold *scaffold)
+                     GtkIconView *iconview)
 {
-  GtkCellArea *area = cell_area_scaffold_get_area (scaffold);
+  GtkCellArea *area = gtk_cell_layout_get_area (GTK_CELL_LAYOUT (iconview));
   gboolean     align = gtk_toggle_button_get_active (toggle);
 
   gtk_cell_area_cell_set (area, cell_2, "align", align, NULL);
@@ -137,9 +136,9 @@ align_cell_2_toggled (GtkToggleButton  *toggle,
 
 static void
 align_cell_3_toggled (GtkToggleButton  *toggle,
-                     CellAreaScaffold *scaffold)
+                     GtkIconView *iconview)
 {
-  GtkCellArea *area = cell_area_scaffold_get_area (scaffold);
+  GtkCellArea *area = gtk_cell_layout_get_area (GTK_CELL_LAYOUT (iconview));
   gboolean     align = gtk_toggle_button_get_active (toggle);
 
   gtk_cell_area_cell_set (area, cell_3, "align", align, NULL);
@@ -147,9 +146,9 @@ align_cell_3_toggled (GtkToggleButton  *toggle,
 
 static void
 expand_cell_1_toggled (GtkToggleButton  *toggle,
-                      CellAreaScaffold *scaffold)
+                      GtkIconView *iconview)
 {
-  GtkCellArea *area = cell_area_scaffold_get_area (scaffold);
+  GtkCellArea *area = gtk_cell_layout_get_area (GTK_CELL_LAYOUT (iconview));
   gboolean     expand = gtk_toggle_button_get_active (toggle);
 
   gtk_cell_area_cell_set (area, cell_1, "expand", expand, NULL);
@@ -157,9 +156,9 @@ expand_cell_1_toggled (GtkToggleButton  *toggle,
 
 static void
 expand_cell_2_toggled (GtkToggleButton  *toggle,
-                      CellAreaScaffold *scaffold)
+                      GtkIconView *iconview)
 {
-  GtkCellArea *area = cell_area_scaffold_get_area (scaffold);
+  GtkCellArea *area = gtk_cell_layout_get_area (GTK_CELL_LAYOUT (iconview));
   gboolean     expand = gtk_toggle_button_get_active (toggle);
 
   gtk_cell_area_cell_set (area, cell_2, "expand", expand, NULL);
@@ -167,9 +166,9 @@ expand_cell_2_toggled (GtkToggleButton  *toggle,
 
 static void
 expand_cell_3_toggled (GtkToggleButton  *toggle,
-                      CellAreaScaffold *scaffold)
+                      GtkIconView *iconview)
 {
-  GtkCellArea *area = cell_area_scaffold_get_area (scaffold);
+  GtkCellArea *area = gtk_cell_layout_get_area (GTK_CELL_LAYOUT (iconview));
   gboolean     expand = gtk_toggle_button_get_active (toggle);
 
   gtk_cell_area_cell_set (area, cell_3, "expand", expand, NULL);
@@ -179,13 +178,13 @@ static void
 simple_cell_area (void)
 {
   GtkWidget *window, *widget;
-  GtkWidget *scaffold, *frame, *vbox, *hbox;
+  GtkWidget *iconview, *frame, *vbox, *hbox;
 
   window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
 
   gtk_window_set_title (GTK_WINDOW (window), "CellArea expand and alignments");
 
-  scaffold = simple_scaffold ();
+  iconview = simple_iconview ();
 
   hbox  = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 4);
   frame = gtk_frame_new (NULL);
@@ -195,7 +194,7 @@ simple_cell_area (void)
   gtk_widget_set_valign (frame, GTK_ALIGN_CENTER);
   gtk_widget_set_halign (frame, GTK_ALIGN_FILL);
 
-  gtk_container_add (GTK_CONTAINER (frame), scaffold);
+  gtk_container_add (GTK_CONTAINER (frame), iconview);
 
   gtk_box_pack_end (GTK_BOX (hbox), frame, TRUE, TRUE, 0);
 
@@ -212,7 +211,7 @@ simple_cell_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);
 
   g_signal_connect (G_OBJECT (widget), "changed",
-                    G_CALLBACK (orientation_changed), scaffold);
+                    G_CALLBACK (orientation_changed), iconview);
 
   widget = gtk_check_button_new_with_label ("Align 2nd Cell");
   gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (widget), FALSE);
@@ -220,7 +219,7 @@ simple_cell_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);
   
   g_signal_connect (G_OBJECT (widget), "toggled",
-                    G_CALLBACK (align_cell_2_toggled), scaffold);
+                    G_CALLBACK (align_cell_2_toggled), iconview);
 
   widget = gtk_check_button_new_with_label ("Align 3rd Cell");
   gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (widget), TRUE);
@@ -228,7 +227,7 @@ simple_cell_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);
   
   g_signal_connect (G_OBJECT (widget), "toggled",
-                    G_CALLBACK (align_cell_3_toggled), scaffold);
+                    G_CALLBACK (align_cell_3_toggled), iconview);
 
 
   widget = gtk_check_button_new_with_label ("Expand 1st Cell");
@@ -237,7 +236,7 @@ simple_cell_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);
   
   g_signal_connect (G_OBJECT (widget), "toggled",
-                    G_CALLBACK (expand_cell_1_toggled), scaffold);
+                    G_CALLBACK (expand_cell_1_toggled), iconview);
 
   widget = gtk_check_button_new_with_label ("Expand 2nd Cell");
   gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (widget), TRUE);
@@ -245,7 +244,7 @@ simple_cell_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);
   
   g_signal_connect (G_OBJECT (widget), "toggled",
-                    G_CALLBACK (expand_cell_2_toggled), scaffold);
+                    G_CALLBACK (expand_cell_2_toggled), iconview);
 
   widget = gtk_check_button_new_with_label ("Expand 3rd Cell");
   gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (widget), FALSE);
@@ -253,7 +252,7 @@ simple_cell_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);
   
   g_signal_connect (G_OBJECT (widget), "toggled",
-                    G_CALLBACK (expand_cell_3_toggled), scaffold);
+                    G_CALLBACK (expand_cell_3_toggled), iconview);
 
   gtk_container_add (GTK_CONTAINER (window), hbox);
 
@@ -309,9 +308,9 @@ focus_list_model (void)
 static void
 cell_toggled (GtkCellRendererToggle *cell_renderer,
              const gchar           *path,
-             CellAreaScaffold      *scaffold)
+             GtkIconView      *iconview)
 {
-  GtkTreeModel *model = cell_area_scaffold_get_model (scaffold);
+  GtkTreeModel *model = gtk_icon_view_get_model (iconview);
   GtkTreeIter   iter;
   gboolean      active;
 
@@ -328,9 +327,9 @@ static void
 cell_edited (GtkCellRendererToggle *cell_renderer,
             const gchar           *path,
             const gchar           *new_text,
-            CellAreaScaffold      *scaffold)
+            GtkIconView      *iconview)
 {
-  GtkTreeModel *model = cell_area_scaffold_get_model (scaffold);
+  GtkTreeModel *model = gtk_icon_view_get_model (iconview);
   GtkTreeIter   iter;
 
   g_print ("Cell edited with new text '%s' !\n", new_text);
@@ -342,21 +341,22 @@ cell_edited (GtkCellRendererToggle *cell_renderer,
 }
 
 static GtkWidget *
-focus_scaffold (gboolean color_bg, GtkCellRenderer **focus, GtkCellRenderer **sibling)
+focus_iconview (gboolean color_bg, GtkCellRenderer **focus, GtkCellRenderer **sibling)
 {
   GtkTreeModel *model;
-  GtkWidget *scaffold;
+  GtkWidget *iconview;
   GtkCellArea *area;
   GtkCellRenderer *renderer, *toggle;
 
-  scaffold = cell_area_scaffold_new ();
-  gtk_widget_show (scaffold);
+  iconview = gtk_icon_view_new ();
+  gtk_widget_show (iconview);
 
   model = focus_list_model ();
 
-  cell_area_scaffold_set_model (CELL_AREA_SCAFFOLD (scaffold), model);
+  gtk_icon_view_set_model (GTK_ICON_VIEW (iconview), model);
+  gtk_icon_view_set_item_orientation (GTK_ICON_VIEW (iconview), GTK_ORIENTATION_HORIZONTAL);
 
-  area = cell_area_scaffold_get_area (CELL_AREA_SCAFFOLD (scaffold));
+  area = gtk_cell_layout_get_area (GTK_CELL_LAYOUT (iconview));
 
   renderer = gtk_cell_renderer_text_new ();
   g_object_set (G_OBJECT (renderer), "editable", TRUE, NULL);
@@ -367,7 +367,7 @@ focus_scaffold (gboolean color_bg, GtkCellRenderer **focus, GtkCellRenderer **si
     g_object_set (G_OBJECT (renderer), "cell-background", "red", NULL);
 
   g_signal_connect (G_OBJECT (renderer), "edited",
-                   G_CALLBACK (cell_edited), scaffold);
+                   G_CALLBACK (cell_edited), iconview);
 
   toggle = renderer = gtk_cell_renderer_toggle_new ();
   g_object_set (G_OBJECT (renderer), "xalign", 0.0F, NULL);
@@ -381,7 +381,7 @@ focus_scaffold (gboolean color_bg, GtkCellRenderer **focus, GtkCellRenderer **si
     *focus = renderer;
 
   g_signal_connect (G_OBJECT (renderer), "toggled",
-                   G_CALLBACK (cell_toggled), scaffold);
+                   G_CALLBACK (cell_toggled), iconview);
 
   renderer = gtk_cell_renderer_text_new ();
   g_object_set (G_OBJECT (renderer), 
@@ -400,14 +400,14 @@ focus_scaffold (gboolean color_bg, GtkCellRenderer **focus, GtkCellRenderer **si
 
   gtk_cell_area_add_focus_sibling (area, toggle, renderer);
 
-  return scaffold;
+  return iconview;
 }
 
 static void
 focus_sibling_toggled (GtkToggleButton  *toggle,
-                      CellAreaScaffold *scaffold)
+                      GtkIconView *iconview)
 {
-  GtkCellArea *area = cell_area_scaffold_get_area (scaffold);
+  GtkCellArea *area = gtk_cell_layout_get_area (GTK_CELL_LAYOUT (iconview));
   gboolean     active = gtk_toggle_button_get_active (toggle);
 
   if (active)
@@ -415,7 +415,7 @@ focus_sibling_toggled (GtkToggleButton  *toggle,
   else
     gtk_cell_area_remove_focus_sibling (area, focus_renderer, sibling_renderer);
 
-  gtk_widget_queue_draw (GTK_WIDGET (scaffold));
+  gtk_widget_queue_draw (GTK_WIDGET (iconview));
 }
 
 
@@ -423,7 +423,7 @@ static void
 focus_cell_area (void)
 {
   GtkWidget *window, *widget;
-  GtkWidget *scaffold, *frame, *vbox, *hbox;
+  GtkWidget *iconview, *frame, *vbox, *hbox;
 
   window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
   hbox  = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 4);
@@ -431,7 +431,7 @@ focus_cell_area (void)
 
   gtk_window_set_title (GTK_WINDOW (window), "Focus and editable cells");
 
-  scaffold = focus_scaffold (FALSE, &focus_renderer, &sibling_renderer);
+  iconview = focus_iconview (FALSE, &focus_renderer, &sibling_renderer);
 
   frame = gtk_frame_new (NULL);
   gtk_widget_show (frame);
@@ -439,7 +439,7 @@ focus_cell_area (void)
   gtk_widget_set_valign (frame, GTK_ALIGN_CENTER);
   gtk_widget_set_halign (frame, GTK_ALIGN_FILL);
 
-  gtk_container_add (GTK_CONTAINER (frame), scaffold);
+  gtk_container_add (GTK_CONTAINER (frame), iconview);
 
   gtk_box_pack_end (GTK_BOX (hbox), frame, TRUE, TRUE, 0);
 
@@ -456,7 +456,7 @@ focus_cell_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);
 
   g_signal_connect (G_OBJECT (widget), "changed",
-                    G_CALLBACK (orientation_changed), scaffold);
+                    G_CALLBACK (orientation_changed), iconview);
 
   widget = gtk_check_button_new_with_label ("Focus Sibling");
   gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (widget), TRUE);
@@ -464,7 +464,7 @@ focus_cell_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);
 
   g_signal_connect (G_OBJECT (widget), "toggled",
-                    G_CALLBACK (focus_sibling_toggled), scaffold);
+                    G_CALLBACK (focus_sibling_toggled), iconview);
 
   gtk_container_add (GTK_CONTAINER (window), hbox);
 
@@ -478,9 +478,9 @@ focus_cell_area (void)
  *******************************************************/
 static void
 cell_spacing_changed (GtkSpinButton    *spin_button,
-                     CellAreaScaffold *scaffold)
+                     GtkIconView *iconview)
 {
-  GtkCellArea *area = cell_area_scaffold_get_area (scaffold);
+  GtkCellArea *area = gtk_cell_layout_get_area (GTK_CELL_LAYOUT (iconview));
   gint        value;
 
   value = (gint)gtk_spin_button_get_value (spin_button);
@@ -490,31 +490,31 @@ cell_spacing_changed (GtkSpinButton    *spin_button,
 
 static void
 row_spacing_changed (GtkSpinButton    *spin_button,
-                    CellAreaScaffold *scaffold)
+                    GtkIconView *iconview)
 {
   gint value;
 
   value = (gint)gtk_spin_button_get_value (spin_button);
 
-  cell_area_scaffold_set_row_spacing (scaffold, value);
+  gtk_icon_view_set_row_spacing (iconview, value);
 }
 
 static void
-indentation_changed (GtkSpinButton    *spin_button,
-                    CellAreaScaffold *scaffold)
+item_padding_changed (GtkSpinButton    *spin_button,
+                    GtkIconView *iconview)
 {
   gint value;
 
   value = (gint)gtk_spin_button_get_value (spin_button);
 
-  cell_area_scaffold_set_indentation (scaffold, value);
+  gtk_icon_view_set_item_padding (iconview, value);
 }
 
 static void
 background_area (void)
 {
   GtkWidget *window, *widget, *label, *main_vbox;
-  GtkWidget *scaffold, *frame, *vbox, *hbox;
+  GtkWidget *iconview, *frame, *vbox, *hbox;
 
   window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
   hbox  = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 4);
@@ -526,14 +526,14 @@ background_area (void)
   gtk_window_set_title (GTK_WINDOW (window), "Background Area");
 
   label = gtk_label_new ("In this example, row spacing gets devided into the background area, "
-                        "column spacing is added between each background area, indentation is "
+                        "column spacing is added between each background area, item_padding is "
                         "prepended space distributed to the background area.");
   gtk_label_set_line_wrap  (GTK_LABEL (label), TRUE);
   gtk_label_set_width_chars  (GTK_LABEL (label), 40);
   gtk_widget_show (label);
   gtk_box_pack_start (GTK_BOX (main_vbox), label, FALSE, FALSE, 0);
 
-  scaffold = focus_scaffold (TRUE, NULL, NULL);
+  iconview = focus_iconview (TRUE, NULL, NULL);
 
   frame = gtk_frame_new (NULL);
   gtk_widget_show (frame);
@@ -541,7 +541,7 @@ background_area (void)
   gtk_widget_set_valign (frame, GTK_ALIGN_CENTER);
   gtk_widget_set_halign (frame, GTK_ALIGN_FILL);
 
-  gtk_container_add (GTK_CONTAINER (frame), scaffold);
+  gtk_container_add (GTK_CONTAINER (frame), iconview);
 
   gtk_box_pack_end (GTK_BOX (hbox), frame, TRUE, TRUE, 0);
 
@@ -559,7 +559,7 @@ background_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);
 
   g_signal_connect (G_OBJECT (widget), "changed",
-                    G_CALLBACK (orientation_changed), scaffold);
+                    G_CALLBACK (orientation_changed), iconview);
 
   widget = gtk_spin_button_new_with_range (0, 10, 1);
   label = gtk_label_new ("Cell spacing");
@@ -572,10 +572,11 @@ background_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
 
   g_signal_connect (G_OBJECT (widget), "value-changed",
-                    G_CALLBACK (cell_spacing_changed), scaffold);
+                    G_CALLBACK (cell_spacing_changed), iconview);
 
 
   widget = gtk_spin_button_new_with_range (0, 10, 1);
+  gtk_spin_button_set_value (GTK_SPIN_BUTTON (widget), gtk_icon_view_get_row_spacing (GTK_ICON_VIEW (iconview)));
   label = gtk_label_new ("Row spacing");
   hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 4);
   gtk_widget_show (hbox);
@@ -586,10 +587,11 @@ background_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
 
   g_signal_connect (G_OBJECT (widget), "value-changed",
-                    G_CALLBACK (row_spacing_changed), scaffold);
+                    G_CALLBACK (row_spacing_changed), iconview);
 
   widget = gtk_spin_button_new_with_range (0, 30, 1);
-  label = gtk_label_new ("Intentation");
+  label = gtk_label_new ("Item padding");
+  gtk_spin_button_set_value (GTK_SPIN_BUTTON (widget), gtk_icon_view_get_item_padding (GTK_ICON_VIEW (iconview)));
   hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 4);
   gtk_widget_show (hbox);
   gtk_widget_show (label);
@@ -599,7 +601,7 @@ background_area (void)
   gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
 
   g_signal_connect (G_OBJECT (widget), "value-changed",
-                    G_CALLBACK (indentation_changed), scaffold);
+                    G_CALLBACK (item_padding_changed), iconview);
 
   gtk_widget_show (window);
 }