Request for backport.

Dr Andrew John Hughes ahughes at redhat.com
Mon Dec 20 10:29:30 PST 2010


On 13:22 Mon 20 Dec     , Denis Lila wrote:
> Hi.
> 
> Is this ok?
> 

Yes, changes look good.

> Also, should I backport this to 1.7, 1.8, and 1.9.
> I think it would be worth it.
> 

We shouldn't do this immediately.  We have stable branches for a reason
and fixes should have time to soak in HEAD.

Besides, we'll be releasing 1.10 in January.

> Regards,
> Denis.

> diff -r 12df222ab029 ChangeLog
> --- a/ChangeLog	Fri Dec 17 09:30:47 2010 -0500
> +++ b/ChangeLog	Mon Dec 20 13:22:50 2010 -0500
> @@ -1,3 +1,11 @@
> +2010-12-20  Denis Lila <dlila at redhat.com>
> +
> +	Backport S6800846.
> +	* NEWS: Updated with fixes.
> +	* Makefile.am: Apply patch.
> +	* patches/openjdk/6800846-printing-quality.patch: New file. Backport
> +	of S6795356, and fix for RH662230.
> +
>  2010-12-17  Denis Lila  <dlila at redhat.com>
>  			Pavel Tisnovsky  <ptisnovs at redhat.com>
>  
> diff -r 12df222ab029 Makefile.am
> --- a/Makefile.am	Fri Dec 17 09:30:47 2010 -0500
> +++ b/Makefile.am	Mon Dec 20 13:22:50 2010 -0500
> @@ -313,6 +313,7 @@
>  	patches/openjdk/6795356-proxylazyvalue-leak.patch \
>  	patches/rendering-engine-tests.patch \
>  	patches/jtreg-TestXEmbedServer-fix.patch
> +	patches/openjdk/6800846-printing-quality.patch
>  
>  if WITH_ALT_HSBUILD
>  ICEDTEA_PATCHES += \
> diff -r 12df222ab029 NEWS
> --- a/NEWS	Fri Dec 17 09:30:47 2010 -0500
> +++ b/NEWS	Mon Dec 20 13:22:50 2010 -0500
> @@ -50,6 +50,7 @@
>    - S7002666: Eclipse CDT projects crash with compressed oops
>    - S6979979, RH508185: Rounding error in font sizes selected by the GTK Look and Feel
>    - S6795356: Leak caused by javax.swing.UIDefaults.ProxyLazyValue.acc
> +  - S6800846, RH662230: Printing quality degraded with Java 6 compared to 5.0, index out of bounds exception.
>  
>  * Bug fixes
>    - S7003777, RH647674: JTextPane produces incorrect content after parsing the html text
> diff -r 12df222ab029 patches/openjdk/6800846-printing-quality.patch
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/patches/openjdk/6800846-printing-quality.patch	Mon Dec 20 13:22:50 2010 -0500
> @@ -0,0 +1,144 @@
> +diff -U5 -r --new-file openjdk.old/jdk/src/share/native/sun/awt/image/dither.c openjdk/jdk/src/share/native/sun/awt/image/dither.c
> +--- openjdk.old/jdk/src/share/native/sun/awt/image/dither.c	2010-12-20 13:07:38.305283324 -0500
> ++++ openjdk/jdk/src/share/native/sun/awt/image/dither.c	2010-12-20 13:06:37.348012435 -0500
> +@@ -167,10 +167,11 @@
> +     int i;
> +     CubeStateInfo currentState;
> +     int cubesize = cube_dim * cube_dim * cube_dim;
> +     unsigned char *useFlags;
> +     unsigned char *newILut = (unsigned char*)malloc(cubesize);
> ++    int cmap_mid = (cmap_len >> 1) + (cmap_len & 0x1);
> +     if (newILut) {
> + 
> +       useFlags = (unsigned char *)calloc(cubesize, 1);
> + 
> +       if (useFlags == 0) {
> +@@ -186,44 +187,44 @@
> +         currentState.usedFlags      = useFlags;
> +         currentState.activeEntries  = 0;
> +         currentState.iLUT           = newILut;
> + 
> +         currentState.rgb = (unsigned short *)
> +-                                malloc(256 * sizeof(unsigned short));
> ++                                malloc(cmap_len * sizeof(unsigned short));
> +         if (currentState.rgb == NULL) {
> +             free(newILut);
> +             free(useFlags);
> + #ifdef DEBUG
> +         fprintf(stderr, "Out of memory in color:initCubemap()2\n");
> + #endif
> +             return NULL;
> +         }
> + 
> +         currentState.indices = (unsigned char *)
> +-                                malloc(256 * sizeof(unsigned char));
> ++                                malloc(cmap_len * sizeof(unsigned char));
> +         if (currentState.indices == NULL) {
> +             free(currentState.rgb);
> +             free(newILut);
> +             free(useFlags);
> + #ifdef DEBUG
> +         fprintf(stderr, "Out of memory in color:initCubemap()3\n");
> + #endif
> +             return NULL;
> +         }
> + 
> +-        for (i = 0; i < 128; i++) {
> ++        for (i = 0; i < cmap_mid; i++) {
> +             unsigned short rgb;
> +             int pixel = cmap[i];
> +             rgb = (pixel & 0x00f80000) >> 9;
> +             rgb |= (pixel & 0x0000f800) >> 6;
> +             rgb |=  (pixel & 0xf8) >> 3;
> +             INSERTNEW(currentState, rgb, i);
> +-            pixel = cmap[255-i];
> ++            pixel = cmap[cmap_len - i - 1];
> +             rgb = (pixel & 0x00f80000) >> 9;
> +             rgb |= (pixel & 0x0000f800) >> 6;
> +             rgb |=  (pixel & 0xf8) >> 3;
> +-            INSERTNEW(currentState, rgb, 255-i);
> ++            INSERTNEW(currentState, rgb, cmap_len - i - 1);
> +         }
> + 
> +         if (!recurseLevel(&currentState)) {
> +             free(newILut);
> +             free(useFlags);
> +diff -U5 -r --new-file openjdk.old/jdk/test/sun/awt/image/DrawByteBinary.java openjdk/jdk/test/sun/awt/image/DrawByteBinary.java
> +--- openjdk.old/jdk/test/sun/awt/image/DrawByteBinary.java	1969-12-31 19:00:00.000000000 -0500
> ++++ openjdk/jdk/test/sun/awt/image/DrawByteBinary.java	2010-12-20 13:05:48.338287585 -0500
> +@@ -0,0 +1,75 @@
> ++/*
> ++ * Copyright (c) 2009, Oracle and/or its affiliates. All rights reserved.
> ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
> ++ *
> ++ * This code is free software; you can redistribute it and/or modify it
> ++ * under the terms of the GNU General Public License version 2 only, as
> ++ * published by the Free Software Foundation.
> ++ *
> ++ * This code is distributed in the hope that it will be useful, but WITHOUT
> ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
> ++ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
> ++ * version 2 for more details (a copy is included in the LICENSE file that
> ++ * accompanied this code).
> ++ *
> ++ * You should have received a copy of the GNU General Public License version
> ++ * 2 along with this work; if not, write to the Free Software Foundation,
> ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
> ++ *
> ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
> ++ * or visit www.oracle.com if you need additional information or have any
> ++ * questions.
> ++ */
> ++
> ++/**
> ++ * @test
> ++ * @bug     6800846
> ++ *
> ++ * @summary Test verifes that images with short palette are rendered
> ++ *          withourt artifacts.
> ++ *
> ++ * @run     main DrawByteBinary
> ++ */
> ++
> ++
> ++import java.awt.*;
> ++import java.awt.color.*;
> ++import java.awt.image.*;
> ++import static java.awt.image.BufferedImage.*;
> ++
> ++
> ++public class DrawByteBinary {
> ++
> ++    public static void main(String args[]) {
> ++        int w = 100, h = 30;
> ++        int x = 10;
> ++        byte[] arr = {(byte)0xff, (byte)0x0, (byte)0x00};
> ++
> ++        IndexColorModel newCM = new IndexColorModel(1, 2, arr, arr, arr);
> ++        BufferedImage orig = new BufferedImage(w, h, TYPE_BYTE_BINARY, newCM);
> ++        Graphics2D g2d = orig.createGraphics();
> ++        g2d.setColor(Color.white);
> ++        g2d.fillRect(0, 0, w, h);
> ++        g2d.setColor(Color.black);
> ++        g2d.drawLine(x, 0, x, h);
> ++        g2d.dispose();
> ++
> ++        IndexColorModel origCM = (IndexColorModel)orig.getColorModel();
> ++        BufferedImage test = new BufferedImage(w, h, TYPE_BYTE_BINARY,origCM);
> ++        g2d = test.createGraphics();
> ++        g2d.drawImage(orig, 0, 0, null);
> ++        g2d.dispose();
> ++
> ++        int y = h / 2;
> ++
> ++        // we expect white color outside the line
> ++        if (test.getRGB(x - 1, y) != 0xffffffff) {
> ++            throw new RuntimeException("Invalid color outside the line.");
> ++        }
> ++
> ++        // we expect black color on the line
> ++        if (test.getRGB(x, y) != 0xff000000) {
> ++            throw new RuntimeException("Invalid color on the line.");
> ++        }
> ++    }
> ++}


-- 
Andrew :)

Free Java Software Engineer
Red Hat, Inc. (http://www.redhat.com)

Support Free Java!
Contribute to GNU Classpath and IcedTea
http://www.gnu.org/software/classpath
http://icedtea.classpath.org
PGP Key: 94EFD9D8 (http://subkeys.pgp.net)
Fingerprint = F8EF F1EA 401E 2E60 15FA  7927 142C 2591 94EF D9D8



More information about the distro-pkg-dev mailing list