From fdb765da597c1929ffc8d5275e74b78f5624fe60 Mon Sep 17 00:00:00 2001 From: Christopher James Lahey Date: Mon, 5 Feb 2001 21:18:25 +0000 Subject: Fixed a number of small bugs in how we were saving and loading view 2001-02-05 Christopher James Lahey * gal-view-collection.c: Fixed a number of small bugs in how we were saving and loading view collections. * gal-view-etable.c (config_changed): Send the changed signal properly. (gal_view_etable_construct): Duplicate the spec's state here. svn path=/trunk/; revision=7986 --- widgets/menus/gal-view-collection.c | 26 ++++++++++++++++++++++---- 1 file changed, 22 insertions(+), 4 deletions(-) (limited to 'widgets/menus/gal-view-collection.c') diff --git a/widgets/menus/gal-view-collection.c b/widgets/menus/gal-view-collection.c index fb5192f0c7..9b1922b102 100644 --- a/widgets/menus/gal-view-collection.c +++ b/widgets/menus/gal-view-collection.c @@ -196,6 +196,7 @@ view_changed (GalView *view, GalViewCollectionItem *item) { item->changed = TRUE; + item->ever_changed = TRUE; } static GalViewCollectionItem * @@ -269,17 +270,18 @@ load_single_dir (GalViewCollection *collection, } if (!found) { for (i = 0; i < collection->removed_view_count; i++) { - if (!strcmp(id, collection->removed_view_data[i]->id)) + if (!strcmp(id, collection->removed_view_data[i]->id)) { if (!local) collection->removed_view_data[i]->built_in = TRUE; - found = TRUE; - break; + found = TRUE; + break; + } } } if (!found) { GalViewCollectionItem *item = load_single_file (collection, dir, local, child); - if (item->filename) { + if (item->filename && *item->filename) { collection->view_data = g_renew(GalViewCollectionItem *, collection->view_data, collection->view_count + 1); collection->view_data[collection->view_count] = item; collection->view_count ++; @@ -348,6 +350,18 @@ gal_view_collection_save (GalViewCollection *collection) } } } + for (i = 0; i < collection->removed_view_count; i++) { + xmlNode *child; + GalViewCollectionItem *item; + + item = collection->removed_view_data[i]; + + child = xmlNewChild(root, NULL, "GalView", NULL); + e_xml_set_string_prop_by_name(child, "id", item->id); + e_xml_set_string_prop_by_name(child, "title", item->title); + e_xml_set_string_prop_by_name(child, "type", item->type); + + } filename = g_concat_dir_and_file(collection->local_dir, "galview.xml"); xmlSaveFile(filename, doc); xmlFreeDoc(doc); @@ -432,6 +446,10 @@ gal_view_check_string (GalViewCollection *collection, if (!strcmp(string, collection->view_data[i]->id)) return FALSE; } + for (i = 0; i < collection->removed_view_count; i++) { + if (!strcmp(string, collection->removed_view_data[i]->id)) + return FALSE; + } return TRUE; } -- cgit v1.2.3