summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorehilsdal <ehilsdal>2003-08-21 16:02:53 +0000
committerehilsdal <ehilsdal>2003-08-21 16:02:53 +0000
commitd90acdcedd63f04b906b0efc5e249e93245f5618 (patch)
tree87c6c99f574df73f33666f2ac7b4bb8e586451b5
parent1c2077ea4994f8d268f89a1c85d482d82f97f876 (diff)
downloadaspectj-d90acdcedd63f04b906b0efc5e249e93245f5618.tar.gz
aspectj-d90acdcedd63f04b906b0efc5e249e93245f5618.zip
Using correct patch for bug 39436 instead of vague one from email
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/LazyMethodGen.java53
1 files changed, 32 insertions, 21 deletions
diff --git a/weaver/src/org/aspectj/weaver/bcel/LazyMethodGen.java b/weaver/src/org/aspectj/weaver/bcel/LazyMethodGen.java
index 0d9db5bdf..a9ffd06db 100644
--- a/weaver/src/org/aspectj/weaver/bcel/LazyMethodGen.java
+++ b/weaver/src/org/aspectj/weaver/bcel/LazyMethodGen.java
@@ -256,10 +256,8 @@ public final class LazyMethodGen {
LocalVariableGen lng = (LocalVariableGen) targeter;
LocalVariableTag lr = new LocalVariableTag(BcelWorld.fromBcel(lng.getType()), lng.getName(), lng.getIndex());
if (lng.getStart() == ih) {
- lng.setStart(null);
locals.add(lr);
} else {
- lng.setEnd(null);
ends.add(lr);
}
}
@@ -835,15 +833,10 @@ public final class LazyMethodGen {
}
} else if (targeter instanceof LocalVariableTag) {
LocalVariableTag lvt = (LocalVariableTag) targeter;
- if (i instanceof LocalVariableInstruction) {
- int index = ((LocalVariableInstruction)i).getIndex();
- if (lvt.getSlot() == index) {
- if (localVariableStarts.get(lvt) == null) {
- localVariableStarts.put(lvt, jh);
- }
- localVariableEnds.put(lvt, jh);
- }
- }
+ if (localVariableStarts.get(lvt) == null) {
+ localVariableStarts.put(lvt, jh);
+ }
+ localVariableEnds.put(lvt, jh);
}
}
}
@@ -852,7 +845,7 @@ public final class LazyMethodGen {
jh = jh.getNext();
}
}
-
+
// now add exception handlers
for (Iterator iter = exnList.iterator(); iter.hasNext();) {
ExceptionRange r = (ExceptionRange) iter.next();
@@ -872,16 +865,34 @@ public final class LazyMethodGen {
// remove them and add back to the gen.
Map duplicatedLocalMap = new HashMap();
-
+ // Reverse sort these keys
List keys = new ArrayList();
- keys.addAll(localVariableStarts.keySet());
- Collections.sort(keys,new Comparator() {
- public int compare(Object a,Object b) {
- LocalVariableTag taga = (LocalVariableTag)a;
- LocalVariableTag tagb = (LocalVariableTag)b;
- return taga.getName().compareTo(tagb.getName());
- }});
- for (Iterator iter = keys.iterator(); iter.hasNext(); ) {
+ keys.addAll(localVariableStarts.keySet());
+// System.err.println("Keys for local variable tags");
+// for (int i = 0;i <keys.size();i++) {
+// System.err.println("Before sort: #"+i+"="+keys.get(i));
+// }
+ Collections.sort(keys, new Comparator() {
+ public int compare(Object a, Object b) {
+ LocalVariableTag taga = (LocalVariableTag) a;
+ LocalVariableTag tagb = (LocalVariableTag) b;
+ if (taga.getName().startsWith("arg")) {
+ if (tagb.getName().startsWith("arg")) {
+ return -taga.getName().compareTo(tagb.getName());
+ } else {
+ return 1; // Whatever tagb is, it must come out before 'arg'
+ }
+ } else if (tagb.getName().startsWith("arg")) {
+ return -1; // Whatever taga is, it must come out before 'arg'
+ } else {
+ return -taga.getName().compareTo(tagb.getName());
+ }
+ }
+ });
+// for (int i = 0;i <keys.size();i++) {
+// System.err.println("After sort: #"+i+"="+keys.get(i));
+// }
+ for (Iterator iter = keys.iterator(); iter.hasNext(); ) {
LocalVariableTag tag = (LocalVariableTag) iter.next();
// have we already added one with the same slot number and start location?
// if so, just continue.