/hg/icedtea6: Added changelog entry for my previous changeset an...

dlila at icedtea.classpath.org dlila at icedtea.classpath.org
Fri Nov 5 13:49:49 PDT 2010


changeset f7334fbff599 in /hg/icedtea6
details: http://icedtea.classpath.org/hg/icedtea6?cmd=changeset;node=f7334fbff599
author: Denis Lila <dlila at redhat.com>
date: Fri Nov 05 16:50:59 2010 -0400

	Added changelog entry for my previous changeset and put the patch
	file in patches/openjdk.


diffstat:

5 files changed, 6089 insertions(+), 6077 deletions(-)
ChangeLog                                            |    8 
Makefile.am                                          |    2 
NEWS                                                 |    4 
patches/icedtea-pisces.patch                         | 6076 ------------------
patches/openjdk/6967436-6976265-6967434-pisces.patch | 6076 ++++++++++++++++++

diffs (truncated from 12201 to 500 lines):

diff -r f935004da674 -r f7334fbff599 ChangeLog
--- a/ChangeLog	Fri Nov 05 18:31:07 2010 +0000
+++ b/ChangeLog	Fri Nov 05 16:50:59 2010 -0400
@@ -1,3 +1,11 @@ 2010-11-05  Andrew John Hughes  <ahughes
+2010-11-05  Denis Lila <dlila at redhat.com>
+
+	* Makefile.am:
+	Apply backported patch.
+	* patches/openjdk/6967436-6976265-6967434-pisces.patch:
+	Backport of the openjdk7 rendering engine, which fixes
+	various bugs and includes performance improvements.
+
 2010-11-05  Andrew John Hughes  <ahughes at redhat.com>
 
 	* hotspot.map:
diff -r f935004da674 -r f7334fbff599 Makefile.am
--- a/Makefile.am	Fri Nov 05 18:31:07 2010 +0000
+++ b/Makefile.am	Fri Nov 05 16:50:59 2010 -0400
@@ -294,7 +294,7 @@ ICEDTEA_PATCHES = \
 	patches/openjdk/6853592-badwindow-warning-fix.patch \
 	patches/6703377-freetypescaler.patch \
 	patches/icedtea-jtreg-international-fonts.patch \
-	patches/icedtea-pisces.patch
+	patches/openjdk/6967436-6976265-6967434-pisces.patch
 
 if WITH_ALT_HSBUILD
 ICEDTEA_PATCHES += \
diff -r f935004da674 -r f7334fbff599 NEWS
--- a/NEWS	Fri Nov 05 18:31:07 2010 +0000
+++ b/NEWS	Fri Nov 05 16:50:59 2010 -0400
@@ -43,6 +43,10 @@ New in release 1.10 (2010-XX-XX):
   - S6638712: Inference with wildcard types causes selection of inapplicable method
   - S6650759: Inference of formal type parameter (unused in formal parameters) is not performed
   - S6991430, PR579: Zero PowerPC fix.
+  - S6967436, RH597227: lines longer than 2^15 can fill window.
+  - S6967433: dashed lines broken when using scaling transforms.
+  - S6976265: No STROKE_CONTROL
+  - S6967434, PR450, RH530642: Round joins/caps of scaled up lines have poor quality.
 * NetX
   - A new man page for javaws.
   - Add a new option -Xclearcache
diff -r f935004da674 -r f7334fbff599 patches/icedtea-pisces.patch
--- a/patches/icedtea-pisces.patch	Fri Nov 05 18:31:07 2010 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,6076 +0,0 @@
-diff -Nru openjdk.orig/jdk/src/share/classes/sun/java2d/pisces/Curve.java openjdk/jdk/src/share/classes/sun/java2d/pisces/Curve.java
---- openjdk.orig/jdk/src/share/classes/sun/java2d/pisces/Curve.java	1969-12-31 19:00:00.000000000 -0500
-+++ openjdk/jdk/src/share/classes/sun/java2d/pisces/Curve.java	2010-11-04 09:55:16.830085236 -0400
-@@ -0,0 +1,294 @@
-+/*
-+ * Copyright (c) 2007, 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.  Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package sun.java2d.pisces;
-+
-+import java.util.Iterator;
-+
-+class Curve {
-+
-+    float ax, ay, bx, by, cx, cy, dx, dy;
-+    float dax, day, dbx, dby;
-+
-+    Curve() {
-+    }
-+
-+    void set(float[] points, int type) {
-+        switch(type) {
-+        case 8:
-+            set(points[0], points[1],
-+                points[2], points[3],
-+                points[4], points[5],
-+                points[6], points[7]);
-+            break;
-+        case 6:
-+            set(points[0], points[1],
-+                points[2], points[3],
-+                points[4], points[5]);
-+            break;
-+        default:
-+            throw new InternalError("Curves can only be cubic or quadratic");
-+        }
-+    }
-+
-+    void set(float x1, float y1,
-+             float x2, float y2,
-+             float x3, float y3,
-+             float x4, float y4)
-+    {
-+        ax = 3 * (x2 - x3) + x4 - x1;
-+        ay = 3 * (y2 - y3) + y4 - y1;
-+        bx = 3 * (x1 - 2 * x2 + x3);
-+        by = 3 * (y1 - 2 * y2 + y3);
-+        cx = 3 * (x2 - x1);
-+        cy = 3 * (y2 - y1);
-+        dx = x1;
-+        dy = y1;
-+        dax = 3 * ax; day = 3 * ay;
-+        dbx = 2 * bx; dby = 2 * by;
-+    }
-+
-+    void set(float x1, float y1,
-+             float x2, float y2,
-+             float x3, float y3)
-+    {
-+        ax = ay = 0f;
-+
-+        bx = x1 - 2 * x2 + x3;
-+        by = y1 - 2 * y2 + y3;
-+        cx = 2 * (x2 - x1);
-+        cy = 2 * (y2 - y1);
-+        dx = x1;
-+        dy = y1;
-+        dax = 0; day = 0;
-+        dbx = 2 * bx; dby = 2 * by;
-+    }
-+
-+    float xat(float t) {
-+        return t * (t * (t * ax + bx) + cx) + dx;
-+    }
-+    float yat(float t) {
-+        return t * (t * (t * ay + by) + cy) + dy;
-+    }
-+
-+    float dxat(float t) {
-+        return t * (t * dax + dbx) + cx;
-+    }
-+
-+    float dyat(float t) {
-+        return t * (t * day + dby) + cy;
-+    }
-+
-+    private float ddxat(float t) {
-+        return 2 * dax * t + dbx;
-+    }
-+
-+    private float ddyat(float t) {
-+        return 2 * day * t + dby;
-+    }
-+
-+    int dxRoots(float[] roots, int off) {
-+        return Helpers.quadraticRoots(dax, dbx, cx, roots, off);
-+    }
-+
-+    int dyRoots(float[] roots, int off) {
-+        return Helpers.quadraticRoots(day, dby, cy, roots, off);
-+    }
-+
-+    int infPoints(float[] pts, int off) {
-+        // inflection point at t if -f'(t)x*f''(t)y + f'(t)y*f''(t)x == 0
-+        // Fortunately, this turns out to be quadratic, so there are at
-+        // most 2 inflection points.
-+        final float a = dax * dby - dbx * day;
-+        final float b = 2 * (cy * dax - day * cx);
-+        final float c = cy * dbx - cx * dby;
-+
-+        return Helpers.quadraticRoots(a, b, c, pts, off);
-+    }
-+
-+    // finds points where the first and second derivative are
-+    // perpendicular. This happens when g(t) = f'(t)*f''(t) == 0 (where
-+    // * is a dot product). Unfortunately, we have to solve a cubic.
-+    private int perpendiculardfddf(float[] pts, int off, final float err) {
-+        assert pts.length >= off + 4;
-+
-+        // these are the coefficients of g(t):
-+        final float a = 2*(dax*dax + day*day);
-+        final float b = 3*(dax*dbx + day*dby);
-+        final float c = 2*(dax*cx + day*cy) + dbx*dbx + dby*dby;
-+        final float d = dbx*cx + dby*cy;
-+        // TODO: We might want to divide the polynomial by a to make the
-+        // coefficients smaller. This won't change the roots.
-+        return Helpers.cubicRootsInAB(a, b, c, d, pts, off, err, 0f, 1f);
-+    }
-+
-+    // Tries to find the roots of the function ROC(t)-w in [0, 1). It uses
-+    // a variant of the false position algorithm to find the roots. False
-+    // position requires that 2 initial values x0,x1 be given, and that the
-+    // function must have opposite signs at those values. To find such
-+    // values, we need the local extrema of the ROC function, for which we
-+    // need the roots of its derivative; however, it's harder to find the
-+    // roots of the derivative in this case than it is to find the roots
-+    // of the original function. So, we find all points where this curve's
-+    // first and second derivative are perpendicular, and we pretend these
-+    // are our local extrema. There are at most 3 of these, so we will check
-+    // at most 4 sub-intervals of (0,1). ROC has asymptotes at inflection
-+    // points, so roc-w can have at least 6 roots. This shouldn't be a
-+    // problem for what we're trying to do (draw a nice looking curve).
-+    int rootsOfROCMinusW(float[] roots, int off, final float w, final float err) {
-+        // no OOB exception, because by now off<=6, and roots.length >= 10
-+        assert off <= 6 && roots.length >= 10;
-+        int ret = off;
-+        int numPerpdfddf = perpendiculardfddf(roots, off, err);
-+        float t0 = 0, ft0 = ROCsq(t0) - w*w;
-+        roots[off + numPerpdfddf] = 1f; // always check interval end points
-+        numPerpdfddf++;
-+        for (int i = off; i < off + numPerpdfddf; i++) {
-+            float t1 = roots[i], ft1 = ROCsq(t1) - w*w;
-+            if (ft0 == 0f) {
-+                roots[ret++] = t0;
-+            } else if (ft1 * ft0 < 0f) { // have opposite signs
-+                // (ROC(t)^2 == w^2) == (ROC(t) == w) is true because
-+                // ROC(t) >= 0 for all t.
-+                roots[ret++] = falsePositionROCsqMinusX(t0, t1, w*w, err);
-+            }
-+            t0 = t1;
-+            ft0 = ft1;
-+        }
-+
-+        return ret - off;
-+    }
-+
-+    private static float eliminateInf(float x) {
-+        return (x == Float.POSITIVE_INFINITY ? Float.MAX_VALUE :
-+            (x == Float.NEGATIVE_INFINITY ? Float.MIN_VALUE : x));
-+    }
-+
-+    // A slight modification of the false position algorithm on wikipedia.
-+    // This only works for the ROCsq-x functions. It might be nice to have
-+    // the function as an argument, but that would be awkward in java6.
-+    // It is something to consider for java7, depending on how closures
-+    // and function objects turn out. Same goes for the newton's method
-+    // algorithm in Helpers.java
-+    private float falsePositionROCsqMinusX(float x0, float x1,
-+                                           final float x, final float err)
-+    {
-+        final int iterLimit = 100;
-+        int side = 0;
-+        float t = x1, ft = eliminateInf(ROCsq(t) - x);
-+        float s = x0, fs = eliminateInf(ROCsq(s) - x);
-+        float r = s, fr;
-+        for (int i = 0; i < iterLimit && Math.abs(t - s) > err * Math.abs(t + s); i++) {
-+            r = (fs * t - ft * s) / (fs - ft);
-+            fr = ROCsq(r) - x;
-+            if (fr * ft > 0) {// have the same sign
-+                ft = fr; t = r;
-+                if (side < 0) {
-+                    fs /= (1 << (-side));
-+                    side--;
-+                } else {
-+                    side = -1;
-+                }
-+            } else if (fr * fs > 0) {
-+                fs = fr; s = r;
-+                if (side > 0) {
-+                    ft /= (1 << side);
-+                    side++;
-+                } else {
-+                    side = 1;
-+                }
-+            } else {
-+                break;
-+            }
-+        }
-+        return r;
-+    }
-+
-+    // returns the radius of curvature squared at t of this curve
-+    // see http://en.wikipedia.org/wiki/Radius_of_curvature_(applications)
-+    private float ROCsq(final float t) {
-+        final float dx = dxat(t);
-+        final float dy = dyat(t);
-+        final float ddx = ddxat(t);
-+        final float ddy = ddyat(t);
-+        final float dx2dy2 = dx*dx + dy*dy;
-+        final float ddx2ddy2 = ddx*ddx + ddy*ddy;
-+        final float ddxdxddydy = ddx*dx + ddy*dy;
-+        float ret = ((dx2dy2*dx2dy2) / (dx2dy2 * ddx2ddy2 - ddxdxddydy*ddxdxddydy))*dx2dy2;
-+        return ret;
-+    }
-+
-+    // curve to be broken should be in pts[0]
-+    // this will change the contents of both pts and Ts
-+    // TODO: There's no reason for Ts to be an array. All we need is a sequence
-+    // of t values at which to subdivide. An array statisfies this condition,
-+    // but is unnecessarily restrictive. Ts should be an Iterator<Float> instead.
-+    // Doing this will also make dashing easier, since we could easily make
-+    // LengthIterator an Iterator<Float> and feed it to this function to simplify
-+    // the loop in Dasher.somethingTo.
-+    static Iterator<float[]> breakPtsAtTs(final float[][] pts, final int type,
-+                                          final float[] Ts, final int numTs)
-+    {
-+        assert pts.length >= 2 && pts[0].length >= 8 && numTs <= Ts.length;
-+        return new Iterator<float[]>() {
-+            int nextIdx = 0;
-+            int nextCurveIdx = 0;
-+            float prevT = 0;
-+
-+            public boolean hasNext() {
-+                return nextCurveIdx < numTs + 1;
-+            }
-+
-+            public float[] next() {
-+                float[] ret;
-+                if (nextCurveIdx < numTs) {
-+                    float curT = Ts[nextCurveIdx];
-+                    float splitT = (curT - prevT) / (1 - prevT);
-+                    Helpers.subdivideAt(splitT,
-+                                        pts[nextIdx], 0,
-+                                        pts[nextIdx], 0,
-+                                        pts[1-nextIdx], 0, type);
-+                    updateTs(Ts, Ts[nextCurveIdx], nextCurveIdx + 1, numTs - nextCurveIdx - 1);
-+                    ret = pts[nextIdx];
-+                    nextIdx = 1 - nextIdx;
-+                } else {
-+                    ret = pts[nextIdx];
-+                }
-+                nextCurveIdx++;
-+                return ret;
-+            }
-+
-+            public void remove() {}
-+        };
-+    }
-+
-+    // precondition: ts[off]...ts[off+len-1] must all be greater than t.
-+    private static void updateTs(float[] ts, final float t, final int off, final int len) {
-+        for (int i = off; i < off + len; i++) {
-+            ts[i] = (ts[i] - t) / (1 - t);
-+        }
-+    }
-+}
-+
-diff -Nru openjdk.orig/jdk/src/share/classes/sun/java2d/pisces/Dasher.java openjdk/jdk/src/share/classes/sun/java2d/pisces/Dasher.java
---- openjdk.orig/jdk/src/share/classes/sun/java2d/pisces/Dasher.java	2010-11-04 09:55:54.074209905 -0400
-+++ openjdk/jdk/src/share/classes/sun/java2d/pisces/Dasher.java	2010-11-04 09:55:16.830085236 -0400
-@@ -25,6 +25,8 @@
- 
- package sun.java2d.pisces;
- 
-+import sun.awt.geom.PathConsumer2D;
-+
- /**
-  * The <code>Dasher</code> class takes a series of linear commands
-  * (<code>moveTo</code>, <code>lineTo</code>, <code>close</code> and
-@@ -36,118 +38,68 @@
-  * semantics are unclear.
-  *
-  */
--public class Dasher extends LineSink {
--
--    LineSink output;
--    int[] dash;
--    int startPhase;
--    boolean startDashOn;
--    int startIdx;
--
--    int idx;
--    boolean dashOn;
--    int phase;
--
--    int sx, sy;
--    int x0, y0;
--
--    int m00, m01;
--    int m10, m11;
--
--    Transform4 transform;
-+public class Dasher implements sun.awt.geom.PathConsumer2D {
- 
--    boolean symmetric;
--    long ldet;
-+    private final PathConsumer2D out;
-+    private final float[] dash;
-+    private final float startPhase;
-+    private final boolean startDashOn;
-+    private final int startIdx;
-+
-+    private boolean starting;
-+    private boolean needsMoveTo;
-+
-+    private int idx;
-+    private boolean dashOn;
-+    private float phase;
- 
--    boolean firstDashOn;
--    boolean starting;
--    int sx1, sy1;
-+    private float sx, sy;
-+    private float x0, y0;
- 
--    /**
--     * Empty constructor.  <code>setOutput</code> and
--     * <code>setParameters</code> must be called prior to calling any
--     * other methods.
--     */
--    public Dasher() {}
-+    // temporary storage for the current curve
-+    private float[] curCurvepts;
- 
-     /**
-      * Constructs a <code>Dasher</code>.
-      *
--     * @param output an output <code>LineSink</code>.
--     * @param dash an array of <code>int</code>s containing the dash
--     * pattern in S15.16 format.
--     * @param phase an <code>int</code> containing the dash phase in
--     * S15.16 format.
--     * @param transform a <code>Transform4</code> object indicating
--     * the transform that has been previously applied to all incoming
--     * coordinates.  This is required in order to compute dash lengths
--     * properly.
-+     * @param out an output <code>PathConsumer2D</code>.
-+     * @param dash an array of <code>float</code>s containing the dash pattern
-+     * @param phase a <code>float</code> containing the dash phase
-      */
--    public Dasher(LineSink output,
--                  int[] dash, int phase,
--                  Transform4 transform) {
--        setOutput(output);
--        setParameters(dash, phase, transform);
--    }
--
--    /**
--     * Sets the output <code>LineSink</code> of this
--     * <code>Dasher</code>.
--     *
--     * @param output an output <code>LineSink</code>.
--     */
--    public void setOutput(LineSink output) {
--        this.output = output;
--    }
--
--    /**
--     * Sets the parameters of this <code>Dasher</code>.
--     *
--     * @param dash an array of <code>int</code>s containing the dash
--     * pattern in S15.16 format.
--     * @param phase an <code>int</code> containing the dash phase in
--     * S15.16 format.
--     * @param transform a <code>Transform4</code> object indicating
--     * the transform that has been previously applied to all incoming
--     * coordinates.  This is required in order to compute dash lengths
--     * properly.
--     */
--    public void setParameters(int[] dash, int phase,
--                              Transform4 transform) {
-+    public Dasher(PathConsumer2D out, float[] dash, float phase) {
-         if (phase < 0) {
-             throw new IllegalArgumentException("phase < 0 !");
-         }
- 
-+        this.out = out;
-+
-         // Normalize so 0 <= phase < dash[0]
-         int idx = 0;
-         dashOn = true;
--        int d;
-+        float d;
-         while (phase >= (d = dash[idx])) {
-             phase -= d;
-             idx = (idx + 1) % dash.length;
-             dashOn = !dashOn;
-         }
- 
--        this.dash = new int[dash.length];
--        for (int i = 0; i < dash.length; i++) {
--            this.dash[i] = dash[i];
--        }
-+        this.dash = dash;
-         this.startPhase = this.phase = phase;
-         this.startDashOn = dashOn;
-         this.startIdx = idx;
-+        this.starting = true;
- 
--        this.transform = transform;
--
--        this.m00 = transform.m00;
--        this.m01 = transform.m01;
--        this.m10 = transform.m10;
--        this.m11 = transform.m11;
--        this.ldet = ((long)m00*m11 - (long)m01*m10) >> 16;
--        this.symmetric = (m00 == m11 && m10 == -m01);
-+        // we need curCurvepts to be able to contain 2 curves because when
-+        // dashing curves, we need to subdivide it
-+        curCurvepts = new float[8 * 2];
-     }
- 
--    public void moveTo(int x0, int y0) {
--        output.moveTo(x0, y0);



More information about the distro-pkg-dev mailing list