[Poppler-bugs] [Bug 72312] [patch] pdftops: Fixes/improvements for -origpagesizes

bugzilla-daemon at freedesktop.org bugzilla-daemon at freedesktop.org
Fri Dec 6 03:10:29 PST 2013


https://bugs.freedesktop.org/show_bug.cgi?id=72312

--- Comment #6 from Adrian Johnson <ajohnson at redneon.com> ---
Thanks for the patch. Generally it is better if each change is in a separate
patche. It makes it easier to review and easier to git bisect if there are
regressions.

> When printing with CUPS 1.6.x or newer print jobs in PDF format are first
> treated by the pdftopdf filter (of cups-filters). One thing this filter does
> is rotating Landscape-oriented pages by 90 degrees for printers which take
> their paper only short-edge first (portrait orientation). For this rotation
> not the actual file content is rotated, but a rotation field is set (usually
> incremented by 90). You can see it by running "pdfinfo" on the input and on
> the output of pdftopdf. If the first page of the PDF file is
> Landscape-oriented, the "Page rot:" entry will change by 90 degrees.

The filter is rotating landscape pages the wrong way. Landscape pages on a
portrait oriented sheet should be rotated 90 degrees counterclockwise. Your
filter is rotating 90 degrees clockwise.

Have a look at any book that has tables in landscape orientation. It is always
rotated counterclockwise. The reason is if you rotate the book to the read the
landscape page the lower page number should be at the top and you can advance
to the next sheet by turning the page at the bottom.

See also the PS Language Ref Manual 3d ed. page 401: "... rotates the default
user space for landscape orientation 90 degrees counterclockwise with respect
to that for portrait orientation."

> The differences of the new "-origpagesizes" mode are the following:
> 
> 1. The rotation fields of the input PDF pages are taken into account.

Looks ok to me. I tried it with your test cases and it fixes the problem.

> 2. The "%%DocumentMedia: ..." and following "%%+ ..." lines are removed.
> Most PostScript displayers assume all pages being of the size in the
> "%%DocumentMedia: ..." line. Without these lines they have no problems
> displaying each page in the correct size.

This one I disagree with. The bug is in poppler, not the PS viewers. Looking at
the PS output of launch_leaflet-pdftopdf.pdf without your patch:

%%DocumentSuppliedResources: (atend)
%%DocumentMedia: 840x596 840 596 0 () ()
%%BoundingBox: 0 0 840 596

There is only one media size listed even though I can see different page sizes
in evince and acroread:

The first page which according to acroread has a page size of 5.83 x 8.27" has
this:

%%Page: 1 1
%%PageMedia: 840x596
%%PageBoundingBox: 0 0 840 596
%%PageBoundingBox: 0 0 420 596
%%BeginPageSetup
%%PageOrientation: Portrait
<</PageSize [420 596]>> setpagedevice
pdfStartPage
0 0 420 596 re W
%%EndPageSetup

Obviously there should not be two page bounding boxes. Your patch gets rid of
the second one. The setpagedevice operator and one of the page bounding boxes
has the correct size but the %%PageMedia is wrong.

Removing %%DocumentMedia prevents the %%PageMedia from being used so the viewer
falls back to the size set in setpagedevice. This just papers over the bug.

The cause of this bug is that the first page of launch_leaflet-pdftopdf.pdf has
MediaBox set to 840x596 and CropBox set to 420x596. The code that outputs the
DocumentMedia lines is using the media box while the page size on each page is
the crop box. This should be fixed so the sizes in the DocumentMedia/PageMedia
is consistent with the size used by the setpagesize operator.

> 3. The output pages are never centered, "-origpagesizes" activates
> "-nocenter" implicitly. Normally, there should be no difference as the
> output pages get the sizes of the input pages but there are some odd files
> which need this measure.

This one I also disagree with. If cups-filters does not want pages centered it
can easily add the -nocenter option when it runs pdftops. cups-filters is not
the only user of pdftops -origpagesizes. If we make -origpagesizes default to
-nocenter it will not be possible to get centered output when using the
-origpagesizes option since we do not have a -center option. Even if we did
have a -center option it would be a regression to change the default.

-- 
You are receiving this mail because:
You are the assignee for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.freedesktop.org/archives/poppler-bugs/attachments/20131206/6893cb8d/attachment.html>


More information about the Poppler-bugs mailing list