From e9f8e15bf4f624f566eb0ea66e47be67098d5dc2 Mon Sep 17 00:00:00 2001 From: Christian Persch Date: Sun, 27 Jul 2003 12:26:10 +0000 Subject: Fix mem leak. 2003-07-27 Christian Persch * lib/widgets/ephy-node-view.c: (ephy_node_view_remove): Fix mem leak. * lib/widgets/ephy-node-view.c: (ephy_node_view_remove): * src/pdm-dialog.c: (pdm_cmd_delete_selection): If we've just deleted every row in the tree view, the row ref contains an empty path. Check for that; possibly fixing bug #118398. --- lib/widgets/ephy-node-view.c | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) (limited to 'lib') diff --git a/lib/widgets/ephy-node-view.c b/lib/widgets/ephy-node-view.c index 839947101..86eb48f49 100644 --- a/lib/widgets/ephy-node-view.c +++ b/lib/widgets/ephy-node-view.c @@ -949,7 +949,7 @@ ephy_node_view_get_selection (EphyNodeView *view) void ephy_node_view_remove (EphyNodeView *view) { - GList *list; + GList *list, *l; EphyNode *node; GtkTreeIter iter, iter2; GtkTreePath *path; @@ -986,9 +986,9 @@ ephy_node_view_remove (EphyNodeView *view) } gtk_tree_path_free (path); - for (; list != NULL; list = list->next) + for (l = list; l != NULL; l = l->next) { - ephy_node_unref (list->data); + ephy_node_unref (l->data); } g_list_free (list); @@ -998,9 +998,14 @@ ephy_node_view_remove (EphyNodeView *view) if (row_ref != NULL) { path = gtk_tree_row_reference_get_path (row_ref); - gtk_tree_view_set_cursor (GTK_TREE_VIEW (view), path, NULL, FALSE); + + if (path != NULL) + { + gtk_tree_view_set_cursor (GTK_TREE_VIEW (view), path, NULL, FALSE); + gtk_tree_path_free (path); + } + gtk_tree_row_reference_free (row_ref); - gtk_tree_path_free (path); } } -- cgit v1.2.3