From: David Gilbert Date: Tue, 22 Feb 2005 19:07:40 +0000 (+0000) Subject: 2005-02-22 David Gilbert X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=118ca7d014b362b4d3c4417650d8031cde97b508;p=gcc.git 2005-02-22 David Gilbert * java/awt/font/TransformAttribute.java, (TransformAttribute(AffineTransform)): throw IllegalArgumentException for null transform. (getTransform): return a copy of transform. Added doc comments to all. From-SVN: r95408 --- diff --git a/libjava/ChangeLog b/libjava/ChangeLog index d36ba6f38c5..5c99a783417 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,11 @@ +2005-02-22 David Gilbert + + * java/awt/font/TransformAttribute.java, + (TransformAttribute(AffineTransform)): throw + IllegalArgumentException for null transform. + (getTransform): return a copy of transform. + Added doc comments to all. + 2005-02-22 Jeroen Frijters * java/io/Externalizable.java, diff --git a/libjava/java/awt/font/TransformAttribute.java b/libjava/java/awt/font/TransformAttribute.java index b2417041961..3bb3c3cf1c3 100644 --- a/libjava/java/awt/font/TransformAttribute.java +++ b/libjava/java/awt/font/TransformAttribute.java @@ -1,5 +1,5 @@ -/* TransformAttribute.java - Copyright (C) 2003 Free Software Foundation, Inc. +/* TransformAttribute.java -- + Copyright (C) 2003, 2005 Free Software Foundation, Inc. This file is part of GNU Classpath. @@ -42,6 +42,13 @@ import java.awt.geom.AffineTransform; import java.io.Serializable; /** + * This class provides a mechanism for using an {@link AffineTransform} as + * an immutable attribute (for example, in the + * {@link java.text.AttributedString} class). Any transform passed to + * this class is copied before being stored, and any transform handed out + * by this class is a copy of the stored transform. In this way, it is + * not possible to modify the stored transform. + * * @author Michael Koch */ public final class TransformAttribute implements Serializable @@ -50,20 +57,40 @@ public final class TransformAttribute implements Serializable private AffineTransform affineTransform; + /** + * Creates a new attribute that contains a copy of the given transform. + * + * @param transform the transform (null not permitted). + * + * @throws IllegalArgumentException if transform is + * null. + */ public TransformAttribute (AffineTransform transform) { - if (transform != null) + if (transform == null) { - this.affineTransform = new AffineTransform (transform); + throw new IllegalArgumentException("Null 'transform' not permitted."); } + this.affineTransform = new AffineTransform (transform); } + /** + * Returns a copy of the transform contained by this attribute. + * + * @return A copy of the transform. + */ public AffineTransform getTransform () { - return affineTransform; + return (AffineTransform) affineTransform.clone(); } /** + * Returns true if the transform contained by this attribute is + * an identity transform, and false otherwise. + * + * @return true if the transform contained by this attribute is + * an identity transform, and false otherwise. + * * @since 1.4 */ public boolean isIdentity ()