]> www.fi.muni.cz Git - evince.git/commitdiff
Adapted patch from Arjan van de Ven (arjan@linux.intel.com) to avoid the
authorBastien Nocera <hadess@hadess.net>
Tue, 5 Jun 2007 09:23:09 +0000 (09:23 +0000)
committerBastien Nocera <hadess@src.gnome.org>
Tue, 5 Jun 2007 09:23:09 +0000 (09:23 +0000)
2007-06-05  Bastien Nocera  <hadess@hadess.net>

* shell/ev-metadata-manager.c: (ev_metadata_arm_timeout),
(ev_metadata_manager_init), (ev_metadata_manager_shutdown),
(ev_metadata_manager_set_last), (ev_metadata_manager_set),
(ev_metadata_manager_save): Adapted patch from Arjan van de
Ven (arjan@linux.intel.com) to avoid the timeout running all the
time, saves on power (Closes: #443851)

svn path=/trunk/; revision=2484

ChangeLog
shell/ev-metadata-manager.c

index d94e61b4e6b2ff9a71410313ba2459592ce2379f..5d7808e59cd810f9d3e9e57330e003e547d723ee 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,12 @@
+2007-06-05  Bastien Nocera  <hadess@hadess.net>
+
+       * shell/ev-metadata-manager.c: (ev_metadata_arm_timeout),
+       (ev_metadata_manager_init), (ev_metadata_manager_shutdown),
+       (ev_metadata_manager_set_last), (ev_metadata_manager_set),
+       (ev_metadata_manager_save): Adapted patch from Arjan van de
+       Ven (arjan@linux.intel.com) to avoid the timeout running all the
+       time, saves on power (Closes: #443851)
+
 2007-06-02  Carlos Garcia Campos  <carlosgc@gnome.org>
 
        * configure.ac:
index 0dba983e20c238274e9eadabdb658056bb468a19..402beb7096a54203932fe25ad5e47eb3c4a4c36b 100644 (file)
@@ -93,6 +93,24 @@ item_free (gpointer data)
        g_free (item);
 }
 
+/**
+ * ev_metadata_arm_timeout
+ *
+ * Setup a timeout for saving the metadata to disk.
+ */
+static 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);
+}
+
 /**
  * ev_metadata_manager_init:
  *
@@ -116,13 +134,6 @@ ev_metadata_manager_init (void)
                                       g_str_equal, 
                                       g_free,
                                       item_free);
-
-       ev_metadata_manager->timeout_id = 
-               g_timeout_add_full (G_PRIORITY_DEFAULT_IDLE,
-                                   2000, /* 2 sec */
-                                   (GSourceFunc)ev_metadata_manager_save,
-                                   NULL,
-                                   NULL);
 }
 
 /* This function must be called before exiting ev */
@@ -132,7 +143,8 @@ ev_metadata_manager_shutdown (void)
        if (ev_metadata_manager == NULL)
                return;
 
-       g_source_remove (ev_metadata_manager->timeout_id);
+       if (ev_metadata_manager->timeout_id)
+               g_source_remove (ev_metadata_manager->timeout_id);
 
        ev_metadata_manager_save (NULL);
 
@@ -392,6 +404,7 @@ ev_metadata_manager_set_last (const gchar *key,
 
        item->atime = time (NULL);
        ev_metadata_manager->modified = TRUE;
+       ev_metadata_arm_timeout ();
        return;
 }
                                 
@@ -527,6 +540,7 @@ ev_metadata_manager_set (const gchar  *uri,
        item->atime = time (NULL);
 
        ev_metadata_manager->modified = TRUE;
+       ev_metadata_arm_timeout ();
 }
 
 static void
@@ -647,8 +661,10 @@ ev_metadata_manager_save (gpointer data)
        xmlNodePtr root;
        gchar *file_name;
 
+       ev_metadata_manager->timeout_id = 0;
+
        if (!ev_metadata_manager->modified)
-               return TRUE;
+               return FALSE;
 
        resize_items ();
                
@@ -674,9 +690,20 @@ ev_metadata_manager_save (gpointer data)
 
        ev_metadata_manager->modified = FALSE;
 
-       return TRUE;
+       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)
 {