6261502: (reflect) Add the functionality to screen out the "inappropriate" modifier bits

Reviewed-by: alanb
This commit is contained in:
Joe Darcy 2009-08-28 14:11:00 -07:00
parent 575a3613d5
commit d3e91c9151
3 changed files with 115 additions and 16 deletions

View File

@ -82,10 +82,6 @@ public final
// remembering the last Class for which the check succeeded. // remembering the last Class for which the check succeeded.
private volatile Class securityCheckCache; private volatile Class securityCheckCache;
// Modifiers that can be applied to a constructor in source code
private static final int LANGUAGE_MODIFIERS =
Modifier.PUBLIC | Modifier.PROTECTED | Modifier.PRIVATE;
// Generics infrastructure // Generics infrastructure
// Accessor for factory // Accessor for factory
private GenericsFactory getFactory() { private GenericsFactory getFactory() {
@ -359,7 +355,7 @@ public final
public String toString() { public String toString() {
try { try {
StringBuffer sb = new StringBuffer(); StringBuffer sb = new StringBuffer();
int mod = getModifiers() & LANGUAGE_MODIFIERS; int mod = getModifiers() & Modifier.constructorModifiers();
if (mod != 0) { if (mod != 0) {
sb.append(Modifier.toString(mod) + " "); sb.append(Modifier.toString(mod) + " ");
} }
@ -423,7 +419,7 @@ public final
public String toGenericString() { public String toGenericString() {
try { try {
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
int mod = getModifiers() & LANGUAGE_MODIFIERS; int mod = getModifiers() & Modifier.constructorModifiers();
if (mod != 0) { if (mod != 0) {
sb.append(Modifier.toString(mod) + " "); sb.append(Modifier.toString(mod) + " ");
} }

View File

@ -88,12 +88,6 @@ public final
private Class securityCheckCache; private Class securityCheckCache;
private Class securityCheckTargetClassCache; private Class securityCheckTargetClassCache;
// Modifiers that can be applied to a method in source code
private static final int LANGUAGE_MODIFIERS =
Modifier.PUBLIC | Modifier.PROTECTED | Modifier.PRIVATE |
Modifier.ABSTRACT | Modifier.STATIC | Modifier.FINAL |
Modifier.SYNCHRONIZED | Modifier.NATIVE;
// Generics infrastructure // Generics infrastructure
private String getGenericSignature() {return signature;} private String getGenericSignature() {return signature;}
@ -408,12 +402,12 @@ public final
* {@code public}, {@code protected} or {@code private} first, * {@code public}, {@code protected} or {@code private} first,
* and then other modifiers in the following order: * and then other modifiers in the following order:
* {@code abstract}, {@code static}, {@code final}, * {@code abstract}, {@code static}, {@code final},
* {@code synchronized}, {@code native}. * {@code synchronized}, {@code native}, {@code strictfp}.
*/ */
public String toString() { public String toString() {
try { try {
StringBuffer sb = new StringBuffer(); StringBuffer sb = new StringBuffer();
int mod = getModifiers() & LANGUAGE_MODIFIERS; int mod = getModifiers() & Modifier.methodModifiers();
if (mod != 0) { if (mod != 0) {
sb.append(Modifier.toString(mod) + " "); sb.append(Modifier.toString(mod) + " ");
} }
@ -473,7 +467,7 @@ public final
* {@code public}, {@code protected} or {@code private} first, * {@code public}, {@code protected} or {@code private} first,
* and then other modifiers in the following order: * and then other modifiers in the following order:
* {@code abstract}, {@code static}, {@code final}, * {@code abstract}, {@code static}, {@code final},
* {@code synchronized} {@code native}. * {@code synchronized}, {@code native}, {@code strictfp}.
* *
* @return a string describing this {@code Method}, * @return a string describing this {@code Method},
* include type parameters * include type parameters
@ -483,7 +477,7 @@ public final
public String toGenericString() { public String toGenericString() {
try { try {
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
int mod = getModifiers() & LANGUAGE_MODIFIERS; int mod = getModifiers() & Modifier.methodModifiers();
if (mod != 0) { if (mod != 0) {
sb.append(Modifier.toString(mod) + " "); sb.append(Modifier.toString(mod) + " ");
} }

View File

@ -235,6 +235,11 @@ class Modifier {
* possible validity of the combination of modifiers represented * possible validity of the combination of modifiers represented
* by the input. * by the input.
* *
* Note that to perform such checking for a known kind of entity,
* such as a constructor or method, first AND the argument of
* {@code toString} with the appropriate mask from a method like
* {@link #constructorModifiers} or {@link #methodModifiers}.
*
* @param mod a set of modifiers * @param mod a set of modifiers
* @return a string representation of the set of modifiers * @return a string representation of the set of modifiers
* represented by {@code mod} * represented by {@code mod}
@ -353,4 +358,108 @@ class Modifier {
static boolean isSynthetic(int mod) { static boolean isSynthetic(int mod) {
return (mod & SYNTHETIC) != 0; return (mod & SYNTHETIC) != 0;
} }
/**
* See JLSv3 section 8.1.1.
*/
private static final int CLASS_MODIFIERS =
Modifier.PUBLIC | Modifier.PROTECTED | Modifier.PRIVATE |
Modifier.ABSTRACT | Modifier.STATIC | Modifier.FINAL |
Modifier.STRICT;
/**
* See JLSv3 section 9.1.1.
*/
private static final int INTERFACE_MODIFIERS =
Modifier.PUBLIC | Modifier.PROTECTED | Modifier.PRIVATE |
Modifier.ABSTRACT | Modifier.STATIC | Modifier.STRICT;
/**
* See JLSv3 section 8.8.3.
*/
private static final int CONSTRUCTOR_MODIFIERS =
Modifier.PUBLIC | Modifier.PROTECTED | Modifier.PRIVATE;
/**
* See JLSv3 section 8.4.3.
*/
private static final int METHOD_MODIFIERS =
Modifier.PUBLIC | Modifier.PROTECTED | Modifier.PRIVATE |
Modifier.ABSTRACT | Modifier.STATIC | Modifier.FINAL |
Modifier.SYNCHRONIZED | Modifier.NATIVE | Modifier.STRICT;
/**
* See JLSv3 section 8.3.1.
*/
private static final int FIELD_MODIFIERS =
Modifier.PUBLIC | Modifier.PROTECTED | Modifier.PRIVATE |
Modifier.STATIC | Modifier.FINAL | Modifier.TRANSIENT |
Modifier.VOLATILE;
/**
* Return an {@code int} value OR-ing together the source language
* modifiers that can be applied to a class.
* @return an {@code int} value OR-ing together the source language
* modifiers that can be applied to a class.
*
* @jls3 8.1.1 Class Modifiers
* @since 1.7
*/
public static int classModifiers() {
return CLASS_MODIFIERS;
}
/**
* Return an {@code int} value OR-ing together the source language
* modifiers that can be applied to an interface.
* @return an {@code int} value OR-ing together the source language
* modifiers that can be applied to an inteface.
*
* @jls3 9.1.1 Interface Modifiers
* @since 1.7
*/
public static int interfaceModifiers() {
return INTERFACE_MODIFIERS;
}
/**
* Return an {@code int} value OR-ing together the source language
* modifiers that can be applied to a constructor.
* @return an {@code int} value OR-ing together the source language
* modifiers that can be applied to a constructor.
*
* @jls3 8.8.3 Constructor Modifiers
* @since 1.7
*/
public static int constructorModifiers() {
return CONSTRUCTOR_MODIFIERS;
}
/**
* Return an {@code int} value OR-ing together the source language
* modifiers that can be applied to a method.
* @return an {@code int} value OR-ing together the source language
* modifiers that can be applied to a method.
*
* @jls3 8.4.3 Method Modifiers
* @since 1.7
*/
public static int methodModifiers() {
return METHOD_MODIFIERS;
}
/**
* Return an {@code int} value OR-ing together the source language
* modifiers that can be applied to a field.
* @return an {@code int} value OR-ing together the source language
* modifiers that can be applied to a field.
*
* @jls3 8.3.1 Field Modifiers
* @since 1.7
*/
public static int fieldModifiers() {
return FIELD_MODIFIERS;
}
} }