Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/backend/ev-jobs.c
diff options
context:
space:
mode:
authorMarco Pesenti Gritti <mpg@redhat.com>2005-06-07 09:20:35 (GMT)
committer Marco Pesenti Gritti <marco@src.gnome.org>2005-06-07 09:20:35 (GMT)
commit421d3d8b0f2f2432ec02f57677da2964d339f2d8 (patch)
treeac1ccd139b4b99b15b8f355e3b8aeca79e439621 /backend/ev-jobs.c
parent2380ada377881c8e6bf00368f713ebd72e355dda (diff)
Add an async renderer interface (method + callback) which is useful for
2005-06-07 Marco Pesenti Gritti <mpg@redhat.com> * backend/Makefile.am: * backend/ev-async-renderer.c: (ev_async_renderer_get_type), (ev_async_renderer_class_init), (ev_async_renderer_render_pixbuf): * backend/ev-async-renderer.h: Add an async renderer interface (method + callback) which is useful for backends like ps. * backend/ev-job-queue.c: (remove_job_from_async_queue), (add_job_to_async_queue), (job_finished_cb), (handle_job), (ev_job_queue_run_next), (ev_job_queue_init), (find_queue), (ev_job_queue_add_job), (move_job_async), (move_job), (ev_job_queue_update_job), (ev_job_queue_remove_job): Add queues for async renderer, these are executed on the main thread. * backend/ev-jobs.c: (ev_job_render_new), (render_finished_cb), (ev_job_render_run): * backend/ev-jobs.h: If the backend support async renderer interface use it. * ps/ps-document.c: (ps_document_init), (push_pixbuf), (setup_pixmap), (ps_document_get_type), (ps_async_renderer_render_pixbuf), (ps_document_document_iface_init), (ps_async_renderer_iface_init): Implement async renderer interface.
Diffstat (limited to 'backend/ev-jobs.c')
-rw-r--r--backend/ev-jobs.c37
1 files changed, 31 insertions, 6 deletions
diff --git a/backend/ev-jobs.c b/backend/ev-jobs.c
index c4556c9..73b0614 100644
--- a/backend/ev-jobs.c
+++ b/backend/ev-jobs.c
@@ -2,6 +2,7 @@
#include "ev-job-queue.h"
#include "ev-document-thumbnails.h"
#include "ev-document-links.h"
+#include "ev-async-renderer.h"
static void ev_job_init (EvJob *job);
static void ev_job_class_init (EvJobClass *class);
@@ -196,9 +197,24 @@ ev_job_render_new (EvDocument *document,
job->target_height = height;
job->include_links = include_links;
+ if (EV_IS_ASYNC_RENDERER (document)) {
+ EV_JOB (job)->async = TRUE;
+ }
+
return EV_JOB (job);
}
+static void
+render_finished_cb (EvDocument *document, GdkPixbuf *pixbuf, EvJobRender *job)
+{
+ g_signal_handlers_disconnect_by_func (EV_JOB (job)->document,
+ render_finished_cb, job);
+
+ EV_JOB (job)->finished = TRUE;
+ job->pixbuf = g_object_ref (pixbuf);
+ ev_job_finished (EV_JOB (job));
+}
+
void
ev_job_render_run (EvJobRender *job)
{
@@ -206,12 +222,21 @@ ev_job_render_run (EvJobRender *job)
ev_document_doc_mutex_lock ();
- job->pixbuf = ev_document_render_pixbuf (EV_JOB (job)->document,
- job->page,
- job->scale);
- if (job->include_links)
- job->link_mapping = ev_document_get_links (EV_JOB (job)->document, job->page);
- EV_JOB (job)->finished = TRUE;
+ if (EV_JOB (job)->async) {
+ EvAsyncRenderer *renderer = EV_ASYNC_RENDERER (EV_JOB (job)->document);
+ ev_async_renderer_render_pixbuf (renderer, job->page, job->scale);
+ g_signal_connect (EV_JOB (job)->document, "render_finished",
+ G_CALLBACK (render_finished_cb), job);
+ } else {
+ job->pixbuf = ev_document_render_pixbuf (EV_JOB (job)->document,
+ job->page,
+ job->scale);
+ if (job->include_links)
+ job->link_mapping = ev_document_get_links (EV_JOB (job)->document, job->page);
+
+ EV_JOB (job)->finished = TRUE;
+ }
+
ev_document_doc_mutex_unlock ();
}