changeset in /hg/icedtea: Add OpenJDK7 color patch from Java2D t...

gnu_andrew at member.fsf.org gnu_andrew at member.fsf.org
Thu May 29 14:13:47 PDT 2008


changeset b781c21cad40 in /hg/icedtea
details: http://icedtea.classpath.org/hg/icedtea?cmd=changeset;node=b781c21cad40
description:
	Add OpenJDK7 color patch from Java2D tree.

diffstat:

2 files changed, 15834 insertions(+)
ChangeLog                   |    5 
patches/openjdk-color.patch |15829 +++++++++++++++++++++++++++++++++++++++++++

diffs (truncated from 15845 to 500 lines):

diff -r cfc6ab82a538 -r b781c21cad40 ChangeLog
--- a/ChangeLog	Fri May 23 20:44:43 2008 +0100
+++ b/ChangeLog	Fri May 23 20:45:34 2008 +0100
@@ -1,3 +1,8 @@ 2008-05-23  Andrew John Hughes  <gnu_and
+2008-05-23  Andrew John Hughes  <gnu_andrew at member.fsf.org>
+
+	* patches/openjdk-color.patch: Add
+	OpenJDK color patch from Java2D tree.
+	
 2008-05-23  Andrew John Hughes  <gnu_andrew at member.fsf.org>
 
 	* Makefile.am: Add support for reverting
diff -r cfc6ab82a538 -r b781c21cad40 patches/openjdk-color.patch
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/patches/openjdk-color.patch	Fri May 23 20:45:34 2008 +0100
@@ -0,0 +1,15829 @@
+
+# HG changeset patch
+# User prr
+# Date 1207870125 25200
+# Node ID 91087975bff7219aa8721bca456fd051bf0de7a3
+# Parent bda7549ac1d07d8a5927dabf53e3be4f30ba03fe
+6662775: Move imaging and color classes from closed to open
+Reviewed-by: tdv, campbell
+
+--- a/make/common/internal/BinaryPlugs.gmk	Thu Apr 10 10:32:31 2008 -0700
++++ b/make/common/internal/BinaryPlugs.gmk	Thu Apr 10 16:28:45 2008 -0700
+@@ -126,44 +126,10 @@ com/sun/media/sound/SimpleInputDevicePro
+ com/sun/media/sound/SimpleInputDeviceProvider\$$InputDeviceInfo.class \
+ com/sun/media/sound/SimpleInputDeviceProvider.class
+ 
+-PLUG_AWT_CLASS_NAMES = \
+-java/awt/color/CMMException.class \
+-java/awt/color/ColorSpace.class \
+-java/awt/color/ICC_ColorSpace.class \
+-java/awt/color/ICC_Profile\$$1.class \
+-java/awt/color/ICC_Profile\$$2.class \
+-java/awt/color/ICC_Profile\$$3.class \
+-java/awt/color/ICC_Profile.class \
+-java/awt/color/ICC_ProfileGray.class \
+-java/awt/color/ICC_ProfileRGB.class \
+-java/awt/image/BandedSampleModel.class \
+-java/awt/image/ColorConvertOp.class \
+-java/awt/image/ComponentSampleModel.class \
+-java/awt/image/DataBuffer\$$1.class \
+-java/awt/image/DataBuffer.class \
+-java/awt/image/DataBufferByte.class \
+-java/awt/image/DataBufferInt.class \
+-java/awt/image/DataBufferShort.class \
+-java/awt/image/DataBufferUShort.class \
+-java/awt/image/MultiPixelPackedSampleModel.class \
+-java/awt/image/Raster.class \
+-java/awt/image/RenderedImage.class \
+-java/awt/image/SampleModel.class \
+-java/awt/image/SinglePixelPackedSampleModel.class \
+-java/awt/image/WritableRaster.class \
+-java/awt/image/WritableRenderedImage.class \
+-java/awt/image/renderable/ContextualRenderedImageFactory.class \
+-java/awt/image/renderable/ParameterBlock.class \
+-java/awt/image/renderable/RenderContext.class \
+-java/awt/image/renderable/RenderableImage.class \
+-java/awt/image/renderable/RenderableImageOp.class \
+-java/awt/image/renderable/RenderableImageProducer.class \
+-java/awt/image/renderable/RenderedImageFactory.class
+-
+ # Class list temp files (used by both import and export of plugs)
+ 
+ PLUG_TEMPDIR=$(ABS_TEMPDIR)/plugs
+-PLUG_CLASS_AREAS = jmf sound awt
++PLUG_CLASS_AREAS = jmf sound
+ PLUG_CLISTS = $(PLUG_CLASS_AREAS:%=$(PLUG_TEMPDIR)/%.clist)
+ 
+ # Create jargs file command
+@@ -184,11 +150,6 @@ endef # plug-create-clist-jargs
+ $(PLUG_TEMPDIR)/sound.clist:
+ 	@$(prep-target)
+ 	@for i in $(PLUG_SOUND_CLASS_NAMES) ; do \
+-	  $(ECHO) "$$i" >> $@ ; \
+-	done
+-$(PLUG_TEMPDIR)/awt.clist:
+-	@$(prep-target)
+-	@for i in $(PLUG_AWT_CLASS_NAMES) ; do \
+ 	  $(ECHO) "$$i" >> $@ ; \
+ 	done
+ $(PLUG_TEMPDIR)/all.clist: $(PLUG_CLISTS)
+@@ -198,8 +159,6 @@ endef # plug-create-clist-jargs
+ 	$(plug-create-jargs)
+ $(PLUG_TEMPDIR)/sound.jargs: $(PLUG_TEMPDIR)/sound.clist
+ 	$(plug-create-jargs)
+-$(PLUG_TEMPDIR)/awt.jargs: $(PLUG_TEMPDIR)/awt.clist
+-	$(plug-create-jargs)
+ $(PLUG_TEMPDIR)/all.jargs: $(PLUG_TEMPDIR)/all.clist
+ 	$(plug-create-jargs)
+ 
+@@ -235,15 +194,12 @@ import-binary-plug-jmf-classes: $(PLUG_I
+ 	$(call import-binary-plug-classes,$(PLUG_TEMPDIR)/jmf.clist)
+ import-binary-plug-sound-classes: $(PLUG_IMPORT_JARFILE) $(PLUG_TEMPDIR)/sound.clist
+ 	$(call import-binary-plug-classes,$(PLUG_TEMPDIR)/sound.clist)
+-import-binary-plug-awt-classes: $(PLUG_IMPORT_JARFILE) $(PLUG_TEMPDIR)/awt.clist
+-	$(call import-binary-plug-classes,$(PLUG_TEMPDIR)/awt.clist)
+ 
+ # Import all classes from the jar file
+ 
+ import-binary-plug-jar: \
+ 	     import-binary-plug-jmf-classes \
+-	     import-binary-plug-sound-classes \
+-	     import-binary-plug-awt-classes
++	     import-binary-plug-sound-classes
+ 
+ # Import native libraries
+ 
+@@ -286,7 +242,6 @@ import-binary-plugs: \
+ 	import-binary-plug-jar \
+         import-binary-plug-jmf-classes \
+         import-binary-plug-sound-classes \
+-	import-binary-plug-awt-classes \
+         import-binary-plug-jsound-library
+ 
+ else # !OPENJDK
+--- a/make/java/awt/Makefile	Thu Apr 10 10:32:31 2008 -0700
++++ b/make/java/awt/Makefile	Thu Apr 10 16:28:45 2008 -0700
+@@ -28,23 +28,11 @@ PRODUCT = sun
+ PRODUCT = sun
+ include $(BUILDDIR)/common/Defs.gmk
+ 
+-# WARNING: Make sure the OPENJDK plugs are up-to-date, see make/common/internal/BinaryPlugs.gmk
+ 
+ #
+ # Files
+ #
+ AUTO_FILES_JAVA_DIRS = java/awt sun/awt/geom
+-
+-#
+-# Specific to OPENJDK
+-#
+-ifdef OPENJDK
+-
+-build: import-binary-plug-awt-classes
+-
+-include $(BUILDDIR)/common/internal/BinaryPlugs.gmk
+-
+-endif
+ 
+ build: properties cursors
+ 
+--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
++++ b/src/share/classes/java/awt/color/CMMException.java	Thu Apr 10 16:28:45 2008 -0700
+@@ -0,0 +1,57 @@
++/*
++ * 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.  Sun designates this
++ * particular file as subject to the "Classpath" exception as provided
++ * by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
++ * CA 95054 USA or visit www.sun.com if you need additional information or
++ * have any questions.
++ */
++
++/*
++    Created by gbp, October 25, 1997
++
++ *
++ */
++/**********************************************************************
++ **********************************************************************
++ **********************************************************************
++ *** COPYRIGHT (c) Eastman Kodak Company, 1997                      ***
++ *** As  an unpublished  work pursuant to Title 17 of the United    ***
++ *** States Code.  All rights reserved.                             ***
++ **********************************************************************
++ **********************************************************************
++ **********************************************************************/
++
++
++package java.awt.color;
++
++
++/**
++ * This exception is thrown if the native CMM returns an error.
++ */
++
++public class CMMException extends java.lang.RuntimeException {
++
++    /**
++     *  Constructs a CMMException with the specified detail message.
++     *  @param s the specified detail message
++     */
++    public CMMException (String s) {
++        super (s);
++    }
++}
+--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
++++ b/src/share/classes/java/awt/color/ColorSpace.java	Thu Apr 10 16:28:45 2008 -0700
+@@ -0,0 +1,611 @@
++/*
++ * Portions Copyright 1997-2006 Sun Microsystems, Inc.  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.  Sun designates this
++ * particular file as subject to the "Classpath" exception as provided
++ * by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
++ * CA 95054 USA or visit www.sun.com if you need additional information or
++ * have any questions.
++ */
++
++/**********************************************************************
++ **********************************************************************
++ **********************************************************************
++ *** COPYRIGHT (c) Eastman Kodak Company, 1997                      ***
++ *** As  an unpublished  work pursuant to Title 17 of the United    ***
++ *** States Code.  All rights reserved.                             ***
++ **********************************************************************
++ **********************************************************************
++ **********************************************************************/
++
++package java.awt.color;
++
++import sun.java2d.cmm.PCMM;
++import sun.java2d.cmm.CMSManager;
++
++
++/**
++ * This abstract class is used to serve as a color space tag to identify the
++ * specific color space of a Color object or, via a ColorModel object,
++ * of an Image, a BufferedImage, or a GraphicsDevice.  It contains
++ * methods that transform colors in a specific color space to/from sRGB
++ * and to/from a well-defined CIEXYZ color space.
++ * <p>
++ * For purposes of the methods in this class, colors are represented as
++ * arrays of color components represented as floats in a normalized range
++ * defined by each ColorSpace.  For many ColorSpaces (e.g. sRGB), this
++ * range is 0.0 to 1.0.  However, some ColorSpaces have components whose
++ * values have a different range.  Methods are provided to inquire per
++ * component minimum and maximum normalized values.
++ * <p>
++ * Several variables are defined for purposes of referring to color
++ * space types (e.g. TYPE_RGB, TYPE_XYZ, etc.) and to refer to specific
++ * color spaces (e.g. CS_sRGB and CS_CIEXYZ).
++ * sRGB is a proposed standard RGB color space.  For more information,
++ * see <A href="http://www.w3.org/pub/WWW/Graphics/Color/sRGB.html">
++ * http://www.w3.org/pub/WWW/Graphics/Color/sRGB.html
++ * </A>.
++ * <p>
++ * The purpose of the methods to transform to/from the well-defined
++ * CIEXYZ color space is to support conversions between any two color
++ * spaces at a reasonably high degree of accuracy.  It is expected that
++ * particular implementations of subclasses of ColorSpace (e.g.
++ * ICC_ColorSpace) will support high performance conversion based on
++ * underlying platform color management systems.
++ * <p>
++ * The CS_CIEXYZ space used by the toCIEXYZ/fromCIEXYZ methods can be
++ * described as follows:
++<pre>
++
++&nbsp;     CIEXYZ
++&nbsp;     viewing illuminance: 200 lux
++&nbsp;     viewing white point: CIE D50
++&nbsp;     media white point: "that of a perfectly reflecting diffuser" -- D50
++&nbsp;     media black point: 0 lux or 0 Reflectance
++&nbsp;     flare: 1 percent
++&nbsp;     surround: 20percent of the media white point
++&nbsp;     media description: reflection print (i.e., RLAB, Hunt viewing media)
++&nbsp;     note: For developers creating an ICC profile for this conversion
++&nbsp;           space, the following is applicable.  Use a simple Von Kries
++&nbsp;           white point adaptation folded into the 3X3 matrix parameters
++&nbsp;           and fold the flare and surround effects into the three
++&nbsp;           one-dimensional lookup tables (assuming one uses the minimal
++&nbsp;           model for monitors).
++
++</pre>
++ *
++ * <p>
++ * @see ICC_ColorSpace
++ */
++
++
++
++public abstract class ColorSpace implements java.io.Serializable {
++
++    static final long serialVersionUID = -409452704308689724L;
++
++    private int type;
++    private int numComponents;
++    private transient String [] compName = null;
++
++    // Cache of singletons for the predefined color spaces.
++    private static ColorSpace sRGBspace;
++    private static ColorSpace XYZspace;
++    private static ColorSpace PYCCspace;
++    private static ColorSpace GRAYspace;
++    private static ColorSpace LINEAR_RGBspace;
++
++    /**
++     * Any of the family of XYZ color spaces.
++     */
++    public static final int TYPE_XYZ = 0;
++
++    /**
++     * Any of the family of Lab color spaces.
++     */
++    public static final int TYPE_Lab = 1;
++
++    /**
++     * Any of the family of Luv color spaces.
++     */
++    public static final int TYPE_Luv = 2;
++
++    /**
++     * Any of the family of YCbCr color spaces.
++     */
++    public static final int TYPE_YCbCr = 3;
++
++    /**
++     * Any of the family of Yxy color spaces.
++     */
++    public static final int TYPE_Yxy = 4;
++
++    /**
++     * Any of the family of RGB color spaces.
++     */
++    public static final int TYPE_RGB = 5;
++
++    /**
++     * Any of the family of GRAY color spaces.
++     */
++    public static final int TYPE_GRAY = 6;
++
++    /**
++     * Any of the family of HSV color spaces.
++     */
++    public static final int TYPE_HSV = 7;
++
++    /**
++     * Any of the family of HLS color spaces.
++     */
++    public static final int TYPE_HLS = 8;
++
++    /**
++     * Any of the family of CMYK color spaces.
++     */
++    public static final int TYPE_CMYK = 9;
++
++    /**
++     * Any of the family of CMY color spaces.
++     */
++    public static final int TYPE_CMY = 11;
++
++    /**
++     * Generic 2 component color spaces.
++     */
++    public static final int TYPE_2CLR = 12;
++
++    /**
++     * Generic 3 component color spaces.
++     */
++    public static final int TYPE_3CLR = 13;
++
++    /**
++     * Generic 4 component color spaces.
++     */
++    public static final int TYPE_4CLR = 14;
++
++    /**
++     * Generic 5 component color spaces.
++     */
++    public static final int TYPE_5CLR = 15;
++
++    /**
++     * Generic 6 component color spaces.
++     */
++    public static final int TYPE_6CLR = 16;
++
++    /**
++     * Generic 7 component color spaces.
++     */
++    public static final int TYPE_7CLR = 17;
++
++    /**
++     * Generic 8 component color spaces.
++     */
++    public static final int TYPE_8CLR = 18;
++
++    /**
++     * Generic 9 component color spaces.
++     */
++    public static final int TYPE_9CLR = 19;
++
++    /**
++     * Generic 10 component color spaces.
++     */
++    public static final int TYPE_ACLR = 20;
++
++    /**
++     * Generic 11 component color spaces.
++     */
++    public static final int TYPE_BCLR = 21;
++
++    /**
++     * Generic 12 component color spaces.
++     */
++    public static final int TYPE_CCLR = 22;
++
++    /**
++     * Generic 13 component color spaces.
++     */
++    public static final int TYPE_DCLR = 23;
++
++    /**
++     * Generic 14 component color spaces.
++     */
++    public static final int TYPE_ECLR = 24;
++
++    /**
++     * Generic 15 component color spaces.
++     */
++    public static final int TYPE_FCLR = 25;
++
++    /**
++     * The sRGB color space defined at
++     * <A href="http://www.w3.org/pub/WWW/Graphics/Color/sRGB.html">
++     * http://www.w3.org/pub/WWW/Graphics/Color/sRGB.html
++     * </A>.
++     */
++    public static final int CS_sRGB = 1000;
++
++    /**
++     * A built-in linear RGB color space.  This space is based on the
++     * same RGB primaries as CS_sRGB, but has a linear tone reproduction curve.
++     */
++    public static final int CS_LINEAR_RGB = 1004;
++
++    /**
++     * The CIEXYZ conversion color space defined above.
++     */
++    public static final int CS_CIEXYZ = 1001;
++
++    /**
++     * The Photo YCC conversion color space.
++     */
++    public static final int CS_PYCC = 1002;
++
++    /**
++     * The built-in linear gray scale color space.
++     */
++    public static final int CS_GRAY = 1003;
++
++
++    /**
++     * Constructs a ColorSpace object given a color space type
++     * and the number of components.
++     * @param type one of the <CODE>ColorSpace</CODE> type constants
++     * @param numcomponents the number of components in the color space
++     */
++    protected ColorSpace (int type, int numcomponents) {
++        this.type = type;
++        this.numComponents = numcomponents;
++    }
++
++
++    /**
++     * Returns a ColorSpace representing one of the specific
++     * predefined color spaces.
++     * @param colorspace a specific color space identified by one of
++     *        the predefined class constants (e.g. CS_sRGB, CS_LINEAR_RGB,
++     *        CS_CIEXYZ, CS_GRAY, or CS_PYCC)
++     * @return the requested <CODE>ColorSpace</CODE> object
++     */
++    // NOTE: This method may be called by privileged threads.
++    //       DO NOT INVOKE CLIENT CODE ON THIS THREAD!
++    public static ColorSpace getInstance (int colorspace)
++    {
++    ColorSpace    theColorSpace;



More information about the distro-pkg-dev mailing list