summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjhugunin <jhugunin>2003-05-27 18:30:16 +0000
committerjhugunin <jhugunin>2003-05-27 18:30:16 +0000
commit6f69422b5b935c1fbaf73dc8768e41c85991d1ae (patch)
tree1d6f3e74a2347d14dd96b71bc0d0acb15fe11243
parentb8f6c48800b7dfb6b2da0fb61a9f6b721b20fe64 (diff)
downloadaspectj-6f69422b5b935c1fbaf73dc8768e41c85991d1ae.tar.gz
aspectj-6f69422b5b935c1fbaf73dc8768e41c85991d1ae.zip
slightly better error messages for Bugzilla Bug 38168
insertion of lots of advice code can make branch offset for if too large
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/LazyMethodGen.java15
1 files changed, 13 insertions, 2 deletions
diff --git a/weaver/src/org/aspectj/weaver/bcel/LazyMethodGen.java b/weaver/src/org/aspectj/weaver/bcel/LazyMethodGen.java
index 9c7f3dc42..f5d87a3e7 100644
--- a/weaver/src/org/aspectj/weaver/bcel/LazyMethodGen.java
+++ b/weaver/src/org/aspectj/weaver/bcel/LazyMethodGen.java
@@ -33,6 +33,7 @@ import org.apache.bcel.classfile.Method;
import org.apache.bcel.generic.BranchHandle;
import org.apache.bcel.generic.BranchInstruction;
import org.apache.bcel.generic.CPInstruction;
+import org.apache.bcel.generic.ClassGenException;
import org.apache.bcel.generic.CodeExceptionGen;
import org.apache.bcel.generic.Instruction;
import org.apache.bcel.generic.InstructionHandle;
@@ -45,6 +46,7 @@ import org.apache.bcel.generic.MethodGen;
import org.apache.bcel.generic.ObjectType;
import org.apache.bcel.generic.Select;
import org.apache.bcel.generic.Type;
+import org.aspectj.bridge.IMessage;
import org.aspectj.weaver.AjAttribute;
import org.aspectj.weaver.BCException;
import org.aspectj.weaver.ISourceContext;
@@ -278,8 +280,17 @@ public final class LazyMethodGen {
}
public Method getMethod() {
- MethodGen gen = pack();
- return gen.getMethod();
+ try {
+ MethodGen gen = pack();
+ return gen.getMethod();
+ } catch (ClassGenException e) {
+ enclosingClass.getBcelObjectType().getResolvedTypeX().getWorld().showMessage(
+ IMessage.ERROR, "problem generating method " +
+ this.getClassName() + "." + this.getName() + ": " + e.getMessage(),
+ this.getMemberView() == null ? null : this.getMemberView().getSourceLocation(), null);
+ throw e;
+ }
+
}
// =============================