Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/shell/ev-jobs.c
diff options
context:
space:
mode:
authorCarlos Garcia Campos <carlosgc@gnome.org>2006-07-23 19:59:43 (GMT)
committer Carlos Garcia Campos <carlosgc@src.gnome.org>2006-07-23 19:59:43 (GMT)
commit1bc11bf9ca800edd4469d5e8c8aeb605d3037bc7 (patch)
tree2230a6065f7b0ff89fde7282fcae97b9630a1821 /shell/ev-jobs.c
parentee62be520b68ca0ff33fd7ed9b5f67c8ecf69e1e (diff)
Use GtkPrint instead of GnomePrint when it's available. Fixes bug #348422
2006-07-23 Carlos Garcia Campos <carlosgc@gnome.org> * configure.ac: * shell/Makefile.am: * shell/ev-job-queue.c: * shell/ev-jobs.[ch]: * shell/ev-sidebar-links.c: * shell/ev-window.[ch]: Use GtkPrint instead of GnomePrint when it's available. Fixes bug #348422
Diffstat (limited to 'shell/ev-jobs.c')
-rw-r--r--shell/ev-jobs.c113
1 files changed, 113 insertions, 0 deletions
diff --git a/shell/ev-jobs.c b/shell/ev-jobs.c
index bc0a15a..a2f5403 100644
--- a/shell/ev-jobs.c
+++ b/shell/ev-jobs.c
@@ -7,7 +7,10 @@
#include "ev-document-fonts.h"
#include "ev-selection.h"
#include "ev-async-renderer.h"
+#include "ev-ps-exporter.h"
+#include <glib/gstdio.h>
+#include <unistd.h>
#include <libgnomevfs/gnome-vfs-uri.h>
#include <libgnomevfs/gnome-vfs-utils.h>
#include <libgnomevfs/gnome-vfs-ops.h>
@@ -23,6 +26,8 @@ static void ev_job_thumbnail_init (EvJobThumbnail *job);
static void ev_job_thumbnail_class_init (EvJobThumbnailClass *class);
static void ev_job_xfer_init (EvJobXfer *job);
static void ev_job_xfer_class_init (EvJobXferClass *class);
+static void ev_job_print_init (EvJobPrint *job);
+static void ev_job_print_class_init (EvJobPrintClass *class);
enum
{
@@ -38,6 +43,7 @@ G_DEFINE_TYPE (EvJobRender, ev_job_render, EV_TYPE_JOB)
G_DEFINE_TYPE (EvJobThumbnail, ev_job_thumbnail, EV_TYPE_JOB)
G_DEFINE_TYPE (EvJobFonts, ev_job_fonts, EV_TYPE_JOB)
G_DEFINE_TYPE (EvJobXfer, ev_job_xfer, EV_TYPE_JOB)
+G_DEFINE_TYPE (EvJobPrint, ev_job_print, EV_TYPE_JOB)
static void ev_job_init (EvJob *job) { /* Do Nothing */ }
@@ -173,6 +179,39 @@ ev_job_thumbnail_class_init (EvJobThumbnailClass *class)
oclass->dispose = ev_job_thumbnail_dispose;
}
+static void ev_job_print_init (EvJobPrint *job) { /* Do Nothing */ }
+
+static void
+ev_job_print_dispose (GObject *object)
+{
+ EvJobPrint *job;
+
+ job = EV_JOB_PRINT (object);
+
+ if (job->temp_file) {
+ g_unlink (job->temp_file);
+ g_free (job->temp_file);
+ job->temp_file = NULL;
+ }
+
+ if (job->error) {
+ g_error_free (job->error);
+ job->error = NULL;
+ }
+
+ (* G_OBJECT_CLASS (ev_job_print_parent_class)->dispose) (object);
+}
+
+static void
+ev_job_print_class_init (EvJobPrintClass *class)
+{
+ GObjectClass *oclass;
+
+ oclass = G_OBJECT_CLASS (class);
+
+ oclass->dispose = ev_job_print_dispose;
+}
+
/* Public functions */
void
ev_job_finished (EvJob *job)
@@ -480,3 +519,77 @@ ev_job_xfer_run (EvJobXfer *job)
return;
}
+EvJob *
+ev_job_print_new (EvDocument *document,
+ gdouble width,
+ gdouble height)
+{
+ EvJobPrint *job;
+
+ job = g_object_new (EV_TYPE_JOB_PRINT, NULL);
+
+ EV_JOB (job)->document = g_object_ref (document);
+
+ job->temp_file = NULL;
+ job->error = NULL;
+
+ job->width = width;
+ job->height = height;
+
+ return EV_JOB (job);
+}
+
+void
+ev_job_print_run (EvJobPrint *job)
+{
+ EvDocument *document = EV_JOB (job)->document;
+ gint fd;
+ gint last_page;
+ gint i;
+
+ g_return_if_fail (EV_IS_JOB_PRINT (job));
+
+ if (job->temp_file)
+ g_free (job->temp_file);
+ job->temp_file = NULL;
+
+ if (job->error)
+ g_error_free (job->error);
+ job->error = NULL;
+
+ fd = g_file_open_tmp ("evince_print.ps.XXXXXX", &job->temp_file, &job->error);
+ if (fd <= -1) {
+ EV_JOB (job)->finished = TRUE;
+ return;
+ }
+
+ last_page = ev_document_get_n_pages (document) - 1;
+
+ ev_document_doc_mutex_lock ();
+ ev_ps_exporter_begin (EV_PS_EXPORTER (document),
+ job->temp_file,
+ MIN (0, last_page),
+ MAX (0, last_page),
+ job->width, job->height, FALSE);
+ ev_document_doc_mutex_unlock ();
+
+ for (i = 0; i <= last_page; i++) {
+ EvRenderContext *rc;
+
+ rc = ev_render_context_new (0, i, 1.0);
+
+ ev_document_doc_mutex_lock ();
+ ev_ps_exporter_do_page (EV_PS_EXPORTER (document), rc);
+ ev_document_doc_mutex_unlock ();
+
+ g_object_unref (rc);
+ }
+
+ ev_document_doc_mutex_lock ();
+ ev_ps_exporter_end (EV_PS_EXPORTER (document));
+ ev_document_doc_mutex_unlock ();
+
+ close (fd);
+
+ EV_JOB (job)->finished = TRUE;
+}