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>
++
++ CIEXYZ
++ viewing illuminance: 200 lux
++ viewing white point: CIE D50
++ media white point: "that of a perfectly reflecting diffuser" -- D50
++ media black point: 0 lux or 0 Reflectance
++ flare: 1 percent
++ surround: 20percent of the media white point
++ media description: reflection print (i.e., RLAB, Hunt viewing media)
++ note: For developers creating an ICC profile for this conversion
++ space, the following is applicable. Use a simple Von Kries
++ white point adaptation folded into the 3X3 matrix parameters
++ and fold the flare and surround effects into the three
++ one-dimensional lookup tables (assuming one uses the minimal
++ 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