summaryrefslogtreecommitdiff
path: root/gtk/gtkliststore.c
diff options
context:
space:
mode:
authorBenjamin Otte <otte@gnome.org>2009-06-30 13:22:51 +0200
committerBenjamin Otte <otte@gnome.org>2009-07-01 10:57:11 +0200
commit3c97f037a9fc5ef0f9438e41882eff8c703c88a6 (patch)
tree3af66f79ab1e1a01e85d26decf1bff8eea6aa083 /gtk/gtkliststore.c
parent89e3a9bc08935aaa897ee180ef09486b0f08dadd (diff)
downloadgtk+-3c97f037a9fc5ef0f9438e41882eff8c703c88a6.tar.gz
clean up code in gtk_list_store_set_n_columns()
Previous code's messiness noted by Francisco Javier Taboada Aguado in http://mail.gnome.org/archives/gtk-devel-list/2009-June/msg00001.html
Diffstat (limited to 'gtk/gtkliststore.c')
-rw-r--r--gtk/gtkliststore.c20
1 files changed, 5 insertions, 15 deletions
diff --git a/gtk/gtkliststore.c b/gtk/gtkliststore.c
index 3f2f7c4fc3..470c9f82b1 100644
--- a/gtk/gtkliststore.c
+++ b/gtk/gtkliststore.c
@@ -338,29 +338,19 @@ gtk_list_store_set_n_columns (GtkListStore *list_store,
gint n_columns)
{
GType *new_columns;
+ int i;
if (list_store->n_columns == n_columns)
return;
- new_columns = g_new0 (GType, n_columns);
- if (list_store->column_headers)
- {
- /* copy the old header orders over */
- if (n_columns >= list_store->n_columns)
- memcpy (new_columns, list_store->column_headers, list_store->n_columns * sizeof (gchar *));
- else
- memcpy (new_columns, list_store->column_headers, n_columns * sizeof (GType));
-
- g_free (list_store->column_headers);
- }
+ list_store->column_headers = g_renew (GType, list_store->column_headers, n_columns);
+ for (i = list_store->n_columns; i < n_columns; i++)
+ list_store->column_headers[i] = G_TYPE_INVALID;
+ list_store->n_columns = n_columns;
if (list_store->sort_list)
_gtk_tree_data_list_header_free (list_store->sort_list);
-
list_store->sort_list = _gtk_tree_data_list_header_new (n_columns, list_store->column_headers);
-
- list_store->column_headers = new_columns;
- list_store->n_columns = n_columns;
}
static void