]> www.fi.muni.cz Git - evince.git/blobdiff - shell/ev-job-queue.c
PageCache and EvJobs are moved from backend to shell. Two new jobs to
[evince.git] / shell / ev-job-queue.c
similarity index 90%
rename from backend/ev-job-queue.c
rename to shell/ev-job-queue.c
index 1b3e496219ec8fe4da5bf35b6c24c83a319f8e0e..877aae81f23cfe89edad49964c370222bdf27c35 100644 (file)
@@ -12,6 +12,8 @@ static GQueue *render_queue_high = NULL;
 static GQueue *render_queue_low = NULL;
 static GQueue *thumbnail_queue_high = NULL;
 static GQueue *thumbnail_queue_low = NULL;
+static GQueue *load_queue = NULL;
+static GQueue *xfer_queue = NULL;
 
 /* Queues used for backends supporting EvAsyncRender interface,
    they are executed on the main thread */
@@ -93,6 +95,10 @@ handle_job (EvJob *job)
                ev_job_thumbnail_run (EV_JOB_THUMBNAIL (job));
        else if (EV_IS_JOB_LINKS (job))
                ev_job_links_run (EV_JOB_LINKS (job));
+       else if (EV_IS_JOB_LOAD (job))
+               ev_job_load_run (EV_JOB_LOAD (job));
+       else if (EV_IS_JOB_XFER (job))
+               ev_job_xfer_run (EV_JOB_XFER (job));
        else if (EV_IS_JOB_RENDER (job))
                ev_job_render_run (EV_JOB_RENDER (job));
 
@@ -126,6 +132,14 @@ search_for_jobs_unlocked (void)
        if (job)
                return job;
 
+       job = (EvJob *) g_queue_pop_head (load_queue);
+       if (job)
+               return job;
+
+       job = (EvJob *) g_queue_pop_head (xfer_queue);
+       if (job)
+               return job;
+
        job = (EvJob *) g_queue_pop_head (thumbnail_queue_low);
        if (job)
                return job;
@@ -139,6 +153,8 @@ no_jobs_available_unlocked (void)
        return g_queue_is_empty (render_queue_high)
                && g_queue_is_empty (render_queue_low)
                && g_queue_is_empty (links_queue)
+               && g_queue_is_empty (load_queue)
+               && g_queue_is_empty (xfer_queue)
                && g_queue_is_empty (thumbnail_queue_high)
                && g_queue_is_empty (thumbnail_queue_low);
 }
@@ -196,6 +212,8 @@ ev_job_queue_init (void)
        ev_queue_mutex = g_mutex_new ();
 
        links_queue = g_queue_new ();
+       load_queue = g_queue_new ();
+       xfer_queue = g_queue_new ();
        render_queue_high = g_queue_new ();
        render_queue_low = g_queue_new ();
        async_render_queue_high = g_queue_new ();
@@ -229,6 +247,12 @@ find_queue (EvJob         *job,
                                return thumbnail_queue_high;
                        else
                                return thumbnail_queue_low;
+               } else if (EV_IS_JOB_LOAD (job)) {
+                       /* the priority doesn't effect load */
+                       return load_queue;
+               } else if (EV_IS_JOB_XFER (job)) {
+                       /* the priority doesn't effect xfer */
+                       return xfer_queue;
                } else if (EV_IS_JOB_LINKS (job)) {
                        /* the priority doesn't effect links */
                        return links_queue;
@@ -367,6 +391,10 @@ ev_job_queue_remove_job (EvJob *job)
                        retval = retval || remove_job_from_queue_locked (render_queue_low, job);
                } else if (EV_IS_JOB_LINKS (job)) {
                        retval = remove_job_from_queue_locked (links_queue, job);
+               } else if (EV_IS_JOB_LOAD (job)) {
+                       retval = remove_job_from_queue_locked (load_queue, job);
+               } else if (EV_IS_JOB_XFER (job)) {
+                       retval = remove_job_from_queue_locked (xfer_queue, job);
                } else {
                        g_assert_not_reached ();
                }