]> www.fi.muni.cz Git - evince.git/blobdiff - shell/ev-print-job.c
Enable print to a PDF. Fixes bug #332121.
[evince.git] / shell / ev-print-job.c
index 1f215c77c817b4b235c0a55a1e52ce03a529e9fd..59a8130d93da5d0b7be050b822b16b4994ba0a17 100644 (file)
@@ -48,8 +48,8 @@ struct _EvPrintJob {
        double width; /* FIXME unused */
        double height; /* FIXME unused */
        gboolean duplex; /* FIXME unused */
-       int copies; /* FIXME unused */
-       int collate; /* FIXME unsued */
+       int copies;
+       int collate;
 
        /* range printing */
        int first_page;
@@ -60,6 +60,8 @@ struct _EvPrintJob {
        guint idle_id;
        gboolean printing;
        int next_page;
+       int copies_done;
+       int shift;
 };
 
 struct _EvPrintJobClass {
@@ -260,25 +262,49 @@ idle_print_handler (EvPrintJob *job)
                ev_document_doc_mutex_lock ();
                ev_ps_exporter_begin (
                         EV_PS_EXPORTER (job->document),
-                        job->temp_file, job->first_page, job->last_page,
+                        job->temp_file, 
+                       MIN (job->first_page, job->last_page),
+                       MAX (job->first_page, job->last_page),
                         job->width, job->height, job->duplex);
                ev_document_doc_mutex_unlock ();
                job->next_page = job->first_page;
+               job->shift = (job->first_page > job->last_page) ? -1 : 1;
                job->printing = TRUE;
                return TRUE;
        }
-
-       if (job->next_page <= job->last_page) {
+       
+       if ((job->next_page - job->last_page) * job->shift <= 0) {
+               EvRenderContext *rc;
 #if 0
                g_printerr ("Printing page %d\n", job->next_page);
 #endif
+               rc = ev_render_context_new (0, job->next_page, 1.0);
+
                ev_document_doc_mutex_lock ();
-               ev_ps_exporter_do_page (EV_PS_EXPORTER (job->document),
-                                       job->next_page);
+               ev_ps_exporter_do_page (EV_PS_EXPORTER (job->document), rc);
                ev_document_doc_mutex_unlock ();
-               job->next_page++;
+
+               g_object_unref (rc);
+
+               if (job->collate) {
+                       /* collate must repeat the same page */
+                       job->copies_done++;
+                       if(job->copies == job->copies_done) {
+                               job->next_page += job->shift;
+                               job->copies_done = 0;
+                       }
+               } else {
+                       job->next_page += job->shift;
+                       if ((job->next_page - job->last_page) * job->shift > 0){
+                               job->copies_done++;
+                               if(job->copies_done < job->copies) {
+                                       /* more copies to go, restart to the first page */
+                                       job->next_page = job->first_page;
+                               }
+                       }
+               }
                return TRUE;
-       } else { /* no more pages */
+       } else { /* no more pages or copies */
                ev_document_doc_mutex_lock ();
                ev_ps_exporter_end (EV_PS_EXPORTER (job->document));
                ev_document_doc_mutex_unlock ();