diff options
author | aclement <aclement> | 2008-07-29 16:55:49 +0000 |
---|---|---|
committer | aclement <aclement> | 2008-07-29 16:55:49 +0000 |
commit | e9823aa074ffa69352ffcab1ef6be2b00d5accf1 (patch) | |
tree | 8ae340bfe41910ef8e13226e9c43936b52a21fa5 | |
parent | 3a79d88b6d101819880ecbc4696b6cd974ae0dba (diff) | |
download | aspectj-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.java | 16 |
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); } |