summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoraclement <aclement>2008-07-29 16:55:49 +0000
committeraclement <aclement>2008-07-29 16:55:49 +0000
commite9823aa074ffa69352ffcab1ef6be2b00d5accf1 (patch)
tree8ae340bfe41910ef8e13226e9c43936b52a21fa5
parent3a79d88b6d101819880ecbc4696b6cd974ae0dba (diff)
downloadaspectj-e9823aa074ffa69352ffcab1ef6be2b00d5accf1.tar.gz
aspectj-e9823aa074ffa69352ffcab1ef6be2b00d5accf1.zip
229829: fix for sourceStart() NPE
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseSourceType.java16
1 files changed, 14 insertions, 2 deletions
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseSourceType.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseSourceType.java
index ced21bd9c..7fd1d9ba0 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseSourceType.java
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/EclipseSourceType.java
@@ -253,8 +253,20 @@ public class EclipseSourceType extends AbstractReferenceTypeDelegate {
if (amd.binding == null || !amd.binding.isValidBinding()) continue;
ResolvedMember member = factory.makeResolvedMember(amd.binding);
if (unit != null) {
- member.setSourceContext(new EclipseSourceContext(unit.compilationResult,amd.binding.sourceStart()));
- member.setPosition(amd.binding.sourceStart(),amd.binding.sourceEnd());
+ boolean positionKnown = true;
+ if (amd.binding.sourceMethod() == null) {
+ if (amd.binding.declaringClass instanceof SourceTypeBinding) {
+ SourceTypeBinding stb = ((SourceTypeBinding) amd.binding.declaringClass);
+ if (stb.scope==null || stb.scope.referenceContext==null) positionKnown = false;
+ }
+ }
+ if (positionKnown) { // pr229829
+ member.setSourceContext(new EclipseSourceContext(unit.compilationResult,amd.binding.sourceStart()));
+ member.setPosition(amd.binding.sourceStart(),amd.binding.sourceEnd());
+ } else {
+ member.setSourceContext(new EclipseSourceContext(unit.compilationResult,0));
+ member.setPosition(0,0);
+ }
}
declaredMethods.add(member);
}