From 9e275557271d5b543b5bf48419c565cdec4668ba Mon Sep 17 00:00:00 2001 From: NathanSweet Date: Sun, 16 Jul 2017 02:51:16 +0200 Subject: [PATCH] Use declaring class to access fields. This fixes finding the wrong field when a subclass has the same field name as a super class. --- .../reflectasm/FieldAccess.java | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/src/com/esotericsoftware/reflectasm/FieldAccess.java b/src/com/esotericsoftware/reflectasm/FieldAccess.java index d9f8852..66d33b4 100644 --- a/src/com/esotericsoftware/reflectasm/FieldAccess.java +++ b/src/com/esotericsoftware/reflectasm/FieldAccess.java @@ -260,7 +260,8 @@ static private void insertSetObject (ClassWriter cw, String classNameInternal, A break; } - mv.visitFieldInsn(PUTFIELD, classNameInternal, field.getName(), fieldType.getDescriptor()); + mv.visitFieldInsn(PUTFIELD, field.getDeclaringClass().getName().replace('.', '/'), field.getName(), + fieldType.getDescriptor()); mv.visitInsn(RETURN); } @@ -293,7 +294,8 @@ static private void insertGetObject (ClassWriter cw, String classNameInternal, A mv.visitFrame(F_SAME, 0, null, 0, null); mv.visitVarInsn(ALOAD, 1); mv.visitTypeInsn(CHECKCAST, classNameInternal); - mv.visitFieldInsn(GETFIELD, classNameInternal, field.getName(), Type.getDescriptor(field.getType())); + mv.visitFieldInsn(GETFIELD, field.getDeclaringClass().getName().replace('.', '/'), field.getName(), + Type.getDescriptor(field.getType())); Type fieldType = Type.getType(field.getType()); switch (fieldType.getSort()) { @@ -358,11 +360,13 @@ static private void insertGetString (ClassWriter cw, String classNameInternal, A for (int i = 0, n = labels.length; i < n; i++) { if (!labels[i].equals(labelForInvalidTypes)) { + Field field = fields.get(i); mv.visitLabel(labels[i]); mv.visitFrame(F_SAME, 0, null, 0, null); mv.visitVarInsn(ALOAD, 1); mv.visitTypeInsn(CHECKCAST, classNameInternal); - mv.visitFieldInsn(GETFIELD, classNameInternal, fields.get(i).getName(), "Ljava/lang/String;"); + mv.visitFieldInsn(GETFIELD, field.getDeclaringClass().getName().replace('.', '/'), field.getName(), + "Ljava/lang/String;"); mv.visitInsn(ARETURN); } } @@ -451,12 +455,14 @@ static private void insertSetPrimitive (ClassWriter cw, String classNameInternal for (int i = 0, n = labels.length; i < n; i++) { if (!labels[i].equals(labelForInvalidTypes)) { + Field field = fields.get(i); mv.visitLabel(labels[i]); mv.visitFrame(F_SAME, 0, null, 0, null); mv.visitVarInsn(ALOAD, 1); mv.visitTypeInsn(CHECKCAST, classNameInternal); mv.visitVarInsn(loadValueInstruction, 3); - mv.visitFieldInsn(PUTFIELD, classNameInternal, fields.get(i).getName(), typeNameInternal); + mv.visitFieldInsn(PUTFIELD, field.getDeclaringClass().getName().replace('.', '/'), field.getName(), + typeNameInternal); mv.visitInsn(RETURN); } } @@ -546,7 +552,8 @@ static private void insertGetPrimitive (ClassWriter cw, String classNameInternal mv.visitFrame(F_SAME, 0, null, 0, null); mv.visitVarInsn(ALOAD, 1); mv.visitTypeInsn(CHECKCAST, classNameInternal); - mv.visitFieldInsn(GETFIELD, classNameInternal, field.getName(), typeNameInternal); + mv.visitFieldInsn(GETFIELD, field.getDeclaringClass().getName().replace('.', '/'), field.getName(), + typeNameInternal); mv.visitInsn(returnValueInstruction); } }