From: aclement Date: Mon, 12 Jul 2010 19:21:06 +0000 (+0000) Subject: 319431: test+fix: reweavable state names and signatures X-Git-Tag: V1_6_10RC1~120 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=b390592ea35dce3207ea6a4c85a240447284f539;p=aspectj.git 319431: test+fix: reweavable state names and signatures --- diff --git a/org.aspectj.matcher/src/org/aspectj/weaver/WeaverStateInfo.java b/org.aspectj.matcher/src/org/aspectj/weaver/WeaverStateInfo.java index 0ce6c5c46..626927db5 100644 --- a/org.aspectj.matcher/src/org/aspectj/weaver/WeaverStateInfo.java +++ b/org.aspectj.matcher/src/org/aspectj/weaver/WeaverStateInfo.java @@ -27,6 +27,7 @@ import java.util.zip.ZipEntry; import java.util.zip.ZipInputStream; import org.aspectj.bridge.IMessage; +import org.aspectj.weaver.AjAttribute.WeaverVersionInfo; /** * WeaverStateInfo represents how a type was processed. It is used by the weaver to determine how a type was previously treated and @@ -300,9 +301,14 @@ public class WeaverStateInfo { str = s.readSignature(); } else { str = s.readUTF(); - // StringBuilder sb = new StringBuilder(); - // sb.append("L").append(str.replace('.', '/')).append(";"); - // str = sb.toString(); + // Prior to 1.6.9 we were writing out names (com.foo.Bar) rather than signatures (Lcom/foo/Bar;) + // From 1.6.9 onwards we write out signatures (pr319431) + if (s.getMajorVersion() < WeaverVersionInfo.WEAVER_VERSION_AJ169) { + // It is a name, make it a signature + StringBuilder sb = new StringBuilder(); + sb.append("L").append(str.replace('.', '/')).append(";"); + str = sb.toString(); + } } wsi.addAspectAffectingType(str); }