Added Class.getGenericSuperclass() and improved Member subclasses. Fixed Makefile on OS X

This commit is contained in:
Ilya Mizus 2014-10-09 02:32:56 +04:00
parent 998f99af44
commit 85fec988d5
6 changed files with 49 additions and 17 deletions

View File

@ -712,10 +712,10 @@ public final class Class <T>
throw new UnsupportedOperationException("not yet implemented"); throw new UnsupportedOperationException("not yet implemented");
} }
public Type[] getGenericInterfaces() { /**
if (vmClass.addendum == null || vmClass.addendum.signature == null) { * The first one is the superclass, the others are interfaces
return getInterfaces(); **/
} private String[] getGenericTypeSignatures() {
String signature = Classes.toString((byte[]) vmClass.addendum.signature); String signature = Classes.toString((byte[]) vmClass.addendum.signature);
final char[] signChars = signature.toCharArray(); final char[] signChars = signature.toCharArray();
@ -753,13 +753,39 @@ public final class Class <T>
} }
if (curTypeSign.length() > 0) typeSigns.add(curTypeSign.toString()); if (curTypeSign.length() > 0) typeSigns.add(curTypeSign.toString());
// Parsing types, ignoring the first item in the array String[] res = new String[typeSigns.size()];
// cause it's the base type return typeSigns.toArray(res);
Type[] res = new Type[typeSigns.size() - 1]; }
for (i = 0; i < typeSigns.size() - 1; i++) {
res[i] = SignatureParser.parse(vmClass.loader, typeSigns.get(i + 1), this); public Type[] getGenericInterfaces() {
if (vmClass.addendum == null || vmClass.addendum.signature == null) {
return getInterfaces();
}
String[] typeSigns = getGenericTypeSignatures();
if (typeSigns.length < 1) {
throw new RuntimeException("Class signature doesn't contain any type");
}
// Parsing types
Type[] res = new Type[typeSigns.length - 1];
for (int i = 0; i < typeSigns.length - 1; i++) {
res[i] = SignatureParser.parse(vmClass.loader, typeSigns[i + 1], this);
} }
return res; return res;
} }
public Type getGenericSuperclass() {
if (vmClass.addendum == null || vmClass.addendum.signature == null) {
return getSuperclass();
}
String[] typeSigns = getGenericTypeSignatures();
if (typeSigns.length < 1) {
throw new RuntimeException("Class signature doesn't contain any type");
}
return SignatureParser.parse(vmClass.loader, typeSigns[0], this);
}
} }

View File

@ -15,6 +15,10 @@ import java.lang.annotation.Annotation;
public abstract class AccessibleObject implements AnnotatedElement { public abstract class AccessibleObject implements AnnotatedElement {
protected static final int Accessible = 1 << 0; protected static final int Accessible = 1 << 0;
// Access and property flags for Member descendants
protected static final int ACC_VARARGS = 0x0080;
protected static final int ACC_SYNTHETIC = 0x1000;
public boolean isAnnotationPresent public boolean isAnnotationPresent
(Class<? extends Annotation> class_) (Class<? extends Annotation> class_)
{ {

View File

@ -17,7 +17,7 @@ import avian.Classes;
import java.lang.annotation.Annotation; import java.lang.annotation.Annotation;
public class Field<T> extends AccessibleObject { public class Field<T> extends AccessibleObject implements Member {
private static final int VoidField = 0; private static final int VoidField = 0;
private static final int ByteField = 1; private static final int ByteField = 1;
private static final int CharField = 2; private static final int CharField = 2;
@ -51,6 +51,10 @@ public class Field<T> extends AccessibleObject {
public int getModifiers() { public int getModifiers() {
return vmField.flags; return vmField.flags;
} }
public boolean isSynthetic() {
return (vmField.flags & ACC_SYNTHETIC) != 0;
}
public String getName() { public String getName() {
return getName(vmField); return getName(vmField);

View File

@ -13,8 +13,8 @@ package java.lang.reflect;
public interface Member { public interface Member {
public static final int PUBLIC = 0; public static final int PUBLIC = 0;
public static final int DECLARED = 1; public static final int DECLARED = 1;
public Class getDeclaringClass(); public Class<?> getDeclaringClass();
public int getModifiers(); public int getModifiers();

View File

@ -146,11 +146,11 @@ public class Method<T> extends AccessibleObject implements Member {
} }
public boolean isVarArgs() { public boolean isVarArgs() {
return (getModifiers() & 0x80) != 0; return (getModifiers() & ACC_VARARGS) != 0;
} }
public boolean isSynthetic() { public boolean isSynthetic() {
return (getModifiers() & 0x1000) != 0; return (getModifiers() & ACC_SYNTHETIC) != 0;
} }
public Object getDefaultValue() { public Object getDefaultValue() {

View File

@ -240,9 +240,7 @@ ifneq ($(android),)
-g3 \ -g3 \
-Werror \ -Werror \
-Wno-shift-count-overflow -Wno-shift-count-overflow
ifeq ($(platform),macosx)
android-cflags += -Doff64_t=off_t -Dlseek64=lseek
endif
# on Windows (in MinGW-based build) there are neither __BEGIN_DECLS nor __END_DECLS # on Windows (in MinGW-based build) there are neither __BEGIN_DECLS nor __END_DECLS
# defines; we don't want to patch every file that uses them, so we stub them in # defines; we don't want to patch every file that uses them, so we stub them in
# using CFLAGS mechanism # using CFLAGS mechanism