X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=shell%2Fev-metadata-manager.c;h=067ac6ea28712e404f89262744d2ac680ea51e97;hb=084c2e5beb02de1e5ced358e782db12a502ea65b;hp=402beb7096a54203932fe25ad5e47eb3c4a4c36b;hpb=82bb28d04f9ac48818cf556131cc908396d69b26;p=evince.git diff --git a/shell/ev-metadata-manager.c b/shell/ev-metadata-manager.c index 402beb70..067ac6ea 100644 --- a/shell/ev-metadata-manager.c +++ b/shell/ev-metadata-manager.c @@ -59,9 +59,6 @@ struct _EvMetadataManager gboolean values_loaded; /* It is true if the file has been read */ - gboolean modified; /* It is true if the file - has top be written */ - guint timeout_id; GHashTable *items; @@ -103,12 +100,21 @@ ev_metadata_arm_timeout(void) { if (ev_metadata_manager->timeout_id) return; +#if GLIB_CHECK_VERSION (2, 13, 5) + ev_metadata_manager->timeout_id = + g_timeout_add_seconds_full (G_PRIORITY_DEFAULT_IDLE, + 2, + (GSourceFunc)ev_metadata_manager_save, + NULL, + NULL); +#else ev_metadata_manager->timeout_id = g_timeout_add_full (G_PRIORITY_DEFAULT_IDLE, 2000, /* 2 sec */ (GSourceFunc)ev_metadata_manager_save, NULL, NULL); +#endif } /** @@ -117,7 +123,6 @@ ev_metadata_arm_timeout(void) * Creates an EvMetadataManager with default values. * * values_loaded -> %FALSE. - * modified -> %FALSE. * timeout_id -> the id of the event source. * items -> a new full empty #GHashTable. */ @@ -127,7 +132,6 @@ ev_metadata_manager_init (void) ev_metadata_manager = g_new0 (EvMetadataManager, 1); ev_metadata_manager->values_loaded = FALSE; - ev_metadata_manager->modified = FALSE; ev_metadata_manager->items = g_hash_table_new_full (g_str_hash, @@ -143,10 +147,11 @@ ev_metadata_manager_shutdown (void) if (ev_metadata_manager == NULL) return; - if (ev_metadata_manager->timeout_id) + if (ev_metadata_manager->timeout_id) { g_source_remove (ev_metadata_manager->timeout_id); - - ev_metadata_manager_save (NULL); + ev_metadata_manager->timeout_id = 0; + ev_metadata_manager_save (NULL); + } if (ev_metadata_manager->items != NULL) g_hash_table_destroy (ev_metadata_manager->items); @@ -403,7 +408,6 @@ ev_metadata_manager_set_last (const gchar *key, } item->atime = time (NULL); - ev_metadata_manager->modified = TRUE; ev_metadata_arm_timeout (); return; } @@ -539,7 +543,6 @@ ev_metadata_manager_set (const gchar *uri, item->atime = time (NULL); - ev_metadata_manager->modified = TRUE; ev_metadata_arm_timeout (); } @@ -663,9 +666,6 @@ ev_metadata_manager_save (gpointer data) ev_metadata_manager->timeout_id = 0; - if (!ev_metadata_manager->modified) - return FALSE; - resize_items (); xmlIndentTreeOutput = TRUE; @@ -688,22 +688,9 @@ ev_metadata_manager_save (gpointer data) xmlFreeDoc (doc); - ev_metadata_manager->modified = FALSE; - return FALSE; } -void ev_metadata_arm_timeout(void) -{ - if (ev_metadata_manager->timeout_id) - return; - ev_metadata_manager->timeout_id = - g_timeout_add_full (G_PRIORITY_DEFAULT_IDLE, - 2000, /* 2 sec */ - (GSourceFunc)ev_metadata_manager_save, - NULL, - NULL); -} void ev_metadata_manager_set_int (const gchar *uri, const gchar *key, int value) {