From 89fb0653b48f0fb9316ec48edca0308ff60281d0 Mon Sep 17 00:00:00 2001 From: aclement Date: Wed, 20 Aug 2008 20:47:55 +0000 Subject: [PATCH] 145391: take parameterized types into account --- .../ajdt/internal/compiler/ast/SuperFixerVisitor.java | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/SuperFixerVisitor.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/SuperFixerVisitor.java index 3e5256b5f..227b5b4d1 100644 --- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/SuperFixerVisitor.java +++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/SuperFixerVisitor.java @@ -100,7 +100,11 @@ public class SuperFixerVisitor extends ASTVisitor { new String(superBinding.selector)).toCharArray(); } else if (call.receiver.isThis() && call.binding.isProtected() && !call.binding.isStatic()) { //XXX this is a hack that violates some binary compatibility rules - if (superBinding.declaringClass.equals(targetClass)) { + ReferenceBinding superBindingDeclaringClass = superBinding.declaringClass; + if (superBindingDeclaringClass.isParameterizedType()) { + superBindingDeclaringClass = ((ParameterizedTypeBinding)superBindingDeclaringClass).type; + } + if (superBindingDeclaringClass.equals(targetClass)) { accessName = NameMangler.protectedDispatchMethod(factory.fromBinding(targetClass), new String(superBinding.selector)).toCharArray(); -- 2.39.5