Severity Description Resource In Folder Location Creation Time

The static method setAccessible(AccessibleObject[], boolean) from the type AccessibleObject should be accessed directly 	HashCodeBuilder.java	Apache Jakarta Commons/lang/src/java/org/apache/commons/lang/builder	line 341	July 18, 2003 8:21:31 PM


git-svn-id: https://svn.apache.org/repos/asf/jakarta/commons/proper/lang/trunk@137466 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Gary D. Gregory 2003-07-20 01:12:32 +00:00
parent d27569f61a
commit 42a2549dc0
1 changed files with 9 additions and 8 deletions

View File

@ -53,6 +53,7 @@
*/ */
package org.apache.commons.lang.builder; package org.apache.commons.lang.builder;
import java.lang.reflect.AccessibleObject;
import java.lang.reflect.Field; import java.lang.reflect.Field;
import java.lang.reflect.Modifier; import java.lang.reflect.Modifier;
/** /**
@ -93,7 +94,7 @@ import java.lang.reflect.Modifier;
* *
* <p>Alternatively, there is a method that uses reflection to determine * <p>Alternatively, there is a method that uses reflection to determine
* the fields to test. Because these fields are usually private, the method, * the fields to test. Because these fields are usually private, the method,
* <code>reflectionHashCode</code>, uses <code>Field.setAccessible</code> to * <code>reflectionHashCode</code>, uses <code>AccessibleObject.setAccessible</code> to
* change the visibility of the fields. This will fail under a security manager, * change the visibility of the fields. This will fail under a security manager,
* unless the appropriate permissions are set up correctly. It is also slower * unless the appropriate permissions are set up correctly. It is also slower
* than testing explicitly.</p> * than testing explicitly.</p>
@ -108,7 +109,7 @@ import java.lang.reflect.Modifier;
* @author Stephen Colebourne * @author Stephen Colebourne
* @author Gary Gregory * @author Gary Gregory
* @since 1.0 * @since 1.0
* @version $Id: HashCodeBuilder.java,v 1.13 2003/07/14 22:25:03 bayard Exp $ * @version $Id: HashCodeBuilder.java,v 1.14 2003/07/20 01:12:32 ggregory Exp $
*/ */
public class HashCodeBuilder { public class HashCodeBuilder {
@ -172,7 +173,7 @@ public class HashCodeBuilder {
* <p>This constructor uses two hard coded choices for the constants * <p>This constructor uses two hard coded choices for the constants
* needed to build a hash code.</p> * needed to build a hash code.</p>
* *
* <p>It uses <code>Field.setAccessible</code> to gain access to private * <p>It uses <code>AccessibleObject.setAccessible</code> to gain access to private
* fields. This means that it will throw a security exception if run under * fields. This means that it will throw a security exception if run under
* a security manger, if the permissions are not set up correctly. It is * a security manger, if the permissions are not set up correctly. It is
* also not as efficient as testing explicitly.</p> * also not as efficient as testing explicitly.</p>
@ -196,7 +197,7 @@ public class HashCodeBuilder {
* <p>This constructor uses two hard coded choices for the constants needed * <p>This constructor uses two hard coded choices for the constants needed
* to build a hash code.</p> * to build a hash code.</p>
* *
* <p> It uses <code>Field.setAccessible</code> to gain access to private * <p> It uses <code>AccessibleObject.setAccessible</code> to gain access to private
* fields. This means that it will throw a security exception if run under * fields. This means that it will throw a security exception if run under
* a security manger, if the permissions are not set up correctly. It is * a security manger, if the permissions are not set up correctly. It is
* also not as efficient as testing explicitly.</p> * also not as efficient as testing explicitly.</p>
@ -219,7 +220,7 @@ public class HashCodeBuilder {
/** /**
* <p>This method uses reflection to build a valid hash code.</p> * <p>This method uses reflection to build a valid hash code.</p>
* *
* <p>It uses <code>Field.setAccessible</code> to gain access to private * <p>It uses <code>AccessibleObject.setAccessible</code> to gain access to private
* fields. This means that it will throw a security exception if run under * fields. This means that it will throw a security exception if run under
* a security manger, if the permissions are not set up correctly. It is * a security manger, if the permissions are not set up correctly. It is
* also not as efficient as testing explicitly.</p> * also not as efficient as testing explicitly.</p>
@ -248,7 +249,7 @@ public class HashCodeBuilder {
/** /**
* <p>This method uses reflection to build a valid hash code.</p> * <p>This method uses reflection to build a valid hash code.</p>
* *
* <p>It uses <code>Field.setAccessible</code> to gain access to private * <p>It uses <code>AccessibleObject.setAccessible</code> to gain access to private
* fields. This means that it will throw a security exception if run under * fields. This means that it will throw a security exception if run under
* a security manger, if the permissions are not set up correctly. It is also * a security manger, if the permissions are not set up correctly. It is also
* not as efficient as testing explicitly.</p> * not as efficient as testing explicitly.</p>
@ -280,7 +281,7 @@ public class HashCodeBuilder {
/** /**
* <p>This method uses reflection to build a valid hash code.</p> * <p>This method uses reflection to build a valid hash code.</p>
* *
* <p>It uses <code>Field.setAccessible</code> to gain access to private * <p>It uses <code>AccessibleObject.setAccessible</code> to gain access to private
* fields. This means that it will throw a security exception if run under * fields. This means that it will throw a security exception if run under
* a security manger, if the permissions are not set up correctly. It is also * a security manger, if the permissions are not set up correctly. It is also
* not as efficient as testing explicitly.</p> * not as efficient as testing explicitly.</p>
@ -338,7 +339,7 @@ public class HashCodeBuilder {
*/ */
private static void reflectionAppend(Object object, Class clazz, HashCodeBuilder builder, boolean useTransients) { private static void reflectionAppend(Object object, Class clazz, HashCodeBuilder builder, boolean useTransients) {
Field[] fields = clazz.getDeclaredFields(); Field[] fields = clazz.getDeclaredFields();
Field.setAccessible(fields, true); AccessibleObject.setAccessible(fields, true);
for (int i = 0; i < fields.length; i++) { for (int i = 0; i < fields.length; i++) {
Field f = fields[i]; Field f = fields[i];
if ((f.getName().indexOf('$') == -1) if ((f.getName().indexOf('$') == -1)