X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;ds=sidebyside;f=shell%2Fev-jobs.c;h=d38ef663c6678b7a957e967e025df959adea73d6;hb=3937a33dfda49381aae84fe3f37f08f2dd9244c0;hp=6ffbb57d0afe2bdcf58a4e537dabc7dfbf7ea8c5;hpb=1af6600934d1f723e5b492b8322e52a1144fb0af;p=evince.git diff --git a/shell/ev-jobs.c b/shell/ev-jobs.c index 6ffbb57d..d38ef663 100644 --- a/shell/ev-jobs.c +++ b/shell/ev-jobs.c @@ -16,9 +16,6 @@ #include #include #include -#include -#include -#include static void ev_job_init (EvJob *job); static void ev_job_class_init (EvJobClass *class); @@ -406,8 +403,8 @@ ev_job_render_run (EvJobRender *job) job->rc->page); if (job->include_images && EV_IS_DOCUMENT_IMAGES (EV_JOB (job)->document)) job->image_mapping = - ev_document_images_get_images (EV_DOCUMENT_IMAGES (EV_JOB (job)->document), - job->rc->page); + ev_document_images_get_image_mapping (EV_DOCUMENT_IMAGES (EV_JOB (job)->document), + job->rc->page); EV_JOB (job)->finished = TRUE; } @@ -925,33 +922,32 @@ ev_job_print_run (EvJobPrint *job) gint n_copies; step = job->reverse ? -1 * job->pages_per_sheet : job->pages_per_sheet; - page = job->reverse ? (n_pages / job->pages_per_sheet) * job->pages_per_sheet : 0; - n_copies = job->collate ? job->copies : 1; + page = job->reverse ? ((n_pages - 1) / job->pages_per_sheet) * job->pages_per_sheet : 0; + n_copies = job->collate ? 1 : job->copies; while ((job->reverse && (page >= 0)) || (!job->reverse && (page < n_pages))) { gint k; - ev_file_exporter_begin_page (EV_FILE_EXPORTER (document)); - - for (j = 0; j < job->pages_per_sheet; j++) { - gint p = page + j; + for (k = 0; k < n_copies; k++) { + ev_file_exporter_begin_page (EV_FILE_EXPORTER (document)); - if (p < 0 || p >= n_pages) - break; + for (j = 0; j < job->pages_per_sheet; j++) { + gint p = page + j; - ev_render_context_set_page (rc, page_list[p]); - - for (k = 0; k < n_copies; k++) { + if (p < 0 || p >= n_pages) + break; + + ev_render_context_set_page (rc, page_list[p]); ev_file_exporter_do_page (EV_FILE_EXPORTER (document), rc); } - } - ev_file_exporter_end_page (EV_FILE_EXPORTER (document)); + ev_file_exporter_end_page (EV_FILE_EXPORTER (document)); + } page += step; } - if (job->collate) + if (!job->collate) break; }