diff options
author | aclement <aclement> | 2009-04-04 18:42:04 +0000 |
---|---|---|
committer | aclement <aclement> | 2009-04-04 18:42:04 +0000 |
commit | c17d9d32781bdeadd1b30e166c5c88cb0b258fab (patch) | |
tree | 88d32fe4b5fd4058c93e2176d51cf34740aa91da | |
parent | b90b11e6346a98ec268bfc7619e4d8980b939429 (diff) | |
download | aspectj-c17d9d32781bdeadd1b30e166c5c88cb0b258fab.tar.gz aspectj-c17d9d32781bdeadd1b30e166c5c88cb0b258fab.zip |
271169: test and fix: npe in weave call method with 4 longs
-rw-r--r-- | weaver/src/org/aspectj/weaver/bcel/BcelShadow.java | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java b/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java index 086b8f166..3220aecd4 100644 --- a/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java +++ b/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java @@ -2334,24 +2334,24 @@ public class BcelShadow extends Shadow { end = end.getPrev(); } Type[] args = localAdviceMethod.getArgumentTypes(); - int i = 0; - for (int slot = 0; slot < extraParamOffset; i++) { + int argNumber = 0; + for (int slot = 0; slot < extraParamOffset; argNumber++) { // slot will increase by the argument size each time String argumentName = null; - if (i >= args.length || parameterNames.size() == 0 || i >= parameterNames.size()) { + if (argNumber >= args.length || parameterNames.size() == 0 || argNumber >= parameterNames.size()) { // this should be unnecessary as I think all known joinpoints and helper methods // propagate the parameter names around correctly - but just in case let us do this // rather than fail. If a bug is raised reporting unknown as a local variable name // then investigate the joinpoint giving rise to the ResolvedMember and why it has // no parameter names specified - argumentName = new StringBuffer("unknown").append(i).toString(); + argumentName = new StringBuffer("unknown").append(argNumber).toString(); } else { - argumentName = (String) parameterNames.get(i); + argumentName = (String) parameterNames.get(argNumber); } - String argumentSignature = args[i].getSignature(); + String argumentSignature = args[argNumber].getSignature(); LocalVariableTag lvt = new LocalVariableTag(argumentSignature, argumentName, slot, 0); start.addTargeter(lvt); end.addTargeter(lvt); - slot += args[slot].getSize(); + slot += args[argNumber].getSize(); } } |