]> www.fi.muni.cz Git - evince.git/blobdiff - shell/ev-properties-fonts.c
Updated French translation by Robert-André Mauchin.
[evince.git] / shell / ev-properties-fonts.c
index b50206fa97a0fda60a0c572ab046e92aa5e66f1f..783a5657aa14ad9d28b990257947a0010aaaf40a 100644 (file)
 #include "config.h"
 #endif
 
-#include "ev-properties-fonts.h"
-#include "ev-document-fonts.h"
-#include "ev-jobs.h"
-#include "ev-job-queue.h"
-
 #include <glib/gi18n.h>
-#include <gtk/gtktreeview.h>
+#include <gtk/gtk.h>
 #include <glade/glade.h>
 
+#include "ev-document-fonts.h"
+#include "ev-job-scheduler.h"
+#include "ev-jobs.h"
+#include "ev-properties-fonts.h"
+
 struct _EvPropertiesFonts {
        GtkVBox base_instance;
 
@@ -63,16 +63,16 @@ ev_properties_fonts_dispose (GObject *object)
        }
        
        if (properties->fonts_job) {
-
-               g_signal_handlers_disconnect_by_func
-                               (properties->fonts_job, 
-                                job_fonts_finished_cb, 
-                                properties);
-               ev_job_queue_remove_job (properties->fonts_job);
+               g_signal_handlers_disconnect_by_func (properties->fonts_job, 
+                                                     job_fonts_finished_cb, 
+                                                     properties);
+               ev_job_cancel (properties->fonts_job);
 
                g_object_unref (properties->fonts_job);         
                properties->fonts_job = NULL;
        }
+
+       G_OBJECT_CLASS (ev_properties_fonts_parent_class)->dispose (object);
 }
 
 static void
@@ -159,29 +159,23 @@ update_progress_label (GtkWidget *label, double progress)
 
 static void
 job_fonts_finished_cb (EvJob *job, EvPropertiesFonts *properties)
-{      
-       EvDocumentFonts *document_fonts = EV_DOCUMENT_FONTS (job->document);
-       double progress;
-       
-       progress = ev_document_fonts_get_progress (document_fonts);
-       update_progress_label (properties->fonts_progress_label, progress);
+{
+       g_signal_handlers_disconnect_by_func (job, job_fonts_finished_cb, properties);
+       g_object_unref (properties->fonts_job);
+       properties->fonts_job = NULL;
+}
 
-       if (EV_JOB_FONTS (job)->scan_completed) {
-               g_signal_handlers_disconnect_by_func
-                               (job, job_fonts_finished_cb, properties);
-               g_object_unref (properties->fonts_job);
-               properties->fonts_job = NULL;
-       } else {
-               GtkTreeModel *model;
+static void
+job_fonts_updated_cb (EvJobFonts *job, gdouble progress, EvPropertiesFonts *properties)
+{
+       GtkTreeModel *model;
+       EvDocumentFonts *document_fonts = EV_DOCUMENT_FONTS (properties->document);
 
-               model = gtk_tree_view_get_model
-                               (GTK_TREE_VIEW (properties->fonts_treeview));
-               ev_document_doc_mutex_lock ();
-               ev_document_fonts_fill_model (document_fonts, model);
-               ev_document_doc_mutex_unlock ();
+       update_progress_label (properties->fonts_progress_label, progress);
 
-               ev_job_queue_add_job (job, EV_JOB_PRIORITY_LOW);
-       }
+       model = gtk_tree_view_get_model (GTK_TREE_VIEW (properties->fonts_treeview));
+       /* Documen lock is already held by the jop */
+       ev_document_fonts_fill_model (document_fonts, model);
 }
 
 void
@@ -198,10 +192,13 @@ ev_properties_fonts_set_document (EvPropertiesFonts *properties,
        gtk_tree_view_set_model (tree_view, GTK_TREE_MODEL (list_store));
 
        properties->fonts_job = ev_job_fonts_new (properties->document);
+       g_signal_connect (properties->fonts_job, "updated",
+                         G_CALLBACK (job_fonts_updated_cb),
+                         properties);
        g_signal_connect (properties->fonts_job, "finished",
                          G_CALLBACK (job_fonts_finished_cb),
                          properties);
-       ev_job_queue_add_job (properties->fonts_job, EV_JOB_PRIORITY_LOW);
+       ev_job_scheduler_push_job (properties->fonts_job, EV_JOB_PRIORITY_NONE);
 }
 
 GtkWidget *