You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@pdfbox.apache.org by "Kristian Jörg (JIRA)" <ji...@apache.org> on 2017/11/03 12:26:00 UTC

[jira] [Created] (PDFBOX-3990) Rendering will never complete

Kristian Jörg created PDFBOX-3990:
-------------------------------------

             Summary: Rendering will never complete
                 Key: PDFBOX-3990
                 URL: https://issues.apache.org/jira/browse/PDFBOX-3990
             Project: PDFBox
          Issue Type: Bug
          Components: Rendering
    Affects Versions: 2.0.7
         Environment: Java 1.8
            Reporter: Kristian Jörg
            Priority: Critical
         Attachments: D90296482_20171102.PDF

I have a PDF file that I am attempting to render with:

{code:java}
PDFRenderer renderer = new PDFRenderer(document);
for (int i = 0; i < 2; i++ ) { // the document is two pages, code simplified
    BufferedImage image = renderer.renderImageWithDPI(i, dpi, ImageType.RGB); 
}
{code}
However, the code never returns. When I pause execution (in Eclipse) I see that execution never leaves the decode() method of org.apache.pdfbox.filter.RunLengthDecodeFilter.

The problem is that the inner loop of while (amountToCopy > 0) in bold below is never executed because the stream has come to EOF! That means that the int compressedRead get a negative value and amountToCopy is _*added *_to instead of being subtracted from.
The loop seems to eventually step out of itself, Probably when the integer warps around when reaching it's max (?)
The problem is easy to catch if setting a conditional breakpoint on compressedRead == -1.

I'll include the PDF. The problem arises on page 2.  

{code:java}
    public DecodeResult decode(InputStream encoded, OutputStream decoded,
                                         COSDictionary parameters, int index) throws IOException
    {
        int dupAmount;
        byte[] buffer = new byte[128];
        while ((dupAmount = encoded.read()) != -1 && dupAmount != RUN_LENGTH_EOD)
        {
            if (dupAmount <= 127)
            {
                int amountToCopy = dupAmount + 1;
                int compressedRead;
               * while(amountToCopy > 0)
                {
                    compressedRead = encoded.read(buffer, 0, amountToCopy);
                    decoded.write(buffer, 0, compressedRead);
                    amountToCopy -= compressedRead;
                }*
            }
            else
            {
                int dupByte = encoded.read();
                for (int i = 0; i < 257 - dupAmount; i++)
                {
                    decoded.write(dupByte);
                }
            }
        }
        return new DecodeResult(parameters);
    }
{code}




--
This message was sent by Atlassian JIRA
(v6.4.14#64029)

---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscribe@pdfbox.apache.org
For additional commands, e-mail: dev-help@pdfbox.apache.org