aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoraclement <aclement>2006-09-28 10:51:13 +0000
committeraclement <aclement>2006-09-28 10:51:13 +0000
commitc50a557d3c5de6868dee87e187bf1ae33636cae4 (patch)
tree317c1dce183f0e828d09b621f523b94136a97190
parentbbc4284b46b7f276239f059e96fe11852ca6f87b (diff)
downloadaspectj-c50a557d3c5de6868dee87e187bf1ae33636cae4.tar.gz
aspectj-c50a557d3c5de6868dee87e187bf1ae33636cae4.zip
test and fixes for 145442 - line number info for stack traces.
-rw-r--r--tests/bugs153/pr145442/helloworld.jarbin0 -> 1089 bytes
-rw-r--r--tests/features152/synchronization/transformed/expected/C.ma.txt4
-rw-r--r--tests/src/org/aspectj/systemtest/ajc153/Ajc153Tests.java7
-rw-r--r--tests/src/org/aspectj/systemtest/ajc153/ajc153.xml19
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/BcelAdvice.java20
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/BcelMethod.java9
-rw-r--r--weaver/testdata/AroundAllAndOthersFancyHelloWorld.txt8
-rw-r--r--weaver/testdata/AroundAllAndOthersHelloWorld.txt4
-rw-r--r--weaver/testdata/BeforeFancyHelloWorld.txt8
-rw-r--r--weaver/testdata/BeforeHelloWorld.txt4
-rw-r--r--weaver/testdata/CflowStateResidueDynamicHelloWorld.txt4
-rw-r--r--weaver/testdata/FieldSet.txt4
-rw-r--r--weaver/testdata/StaticEnclosingTjpBeforeHelloWorld.txt4
-rw-r--r--weaver/testdata/StaticTjpBeforeHelloWorld.txt4
-rw-r--r--weaver/testdata/TjpBeforeHelloWorld.txt4
-rw-r--r--weaver/testdata/TraceJarHello.txt2
16 files changed, 71 insertions, 34 deletions
diff --git a/tests/bugs153/pr145442/helloworld.jar b/tests/bugs153/pr145442/helloworld.jar
new file mode 100644
index 000000000..17666f197
--- /dev/null
+++ b/tests/bugs153/pr145442/helloworld.jar
Binary files differ
diff --git a/tests/features152/synchronization/transformed/expected/C.ma.txt b/tests/features152/synchronization/transformed/expected/C.ma.txt
index 0a6b97849..4d76af4e4 100644
--- a/tests/features152/synchronization/transformed/expected/C.ma.txt
+++ b/tests/features152/synchronization/transformed/expected/C.ma.txt
@@ -1,13 +1,13 @@
public void ma() org.aspectj.weaver.MethodDeclarationLineNumber: 14:307
:
- INVOKESTATIC Two.aspectOf ()LTwo;
+ INVOKESTATIC Two.aspectOf ()LTwo; (line 15)
INVOKEVIRTUAL Two.ajc$before$Two$1$8d8821ee ()V
ALOAD_0
DUP
ASTORE_1
MONITORENTER
finally -> E1
- | GETSTATIC java.lang.System.err Ljava/io/PrintStream; (line 15)
+ | GETSTATIC java.lang.System.err Ljava/io/PrintStream;
| LDC "hello"
| INVOKEVIRTUAL java.io.PrintStream.println (Ljava/lang/String;)V
| ALOAD_1
diff --git a/tests/src/org/aspectj/systemtest/ajc153/Ajc153Tests.java b/tests/src/org/aspectj/systemtest/ajc153/Ajc153Tests.java
index bbe34a79f..9e3da6829 100644
--- a/tests/src/org/aspectj/systemtest/ajc153/Ajc153Tests.java
+++ b/tests/src/org/aspectj/systemtest/ajc153/Ajc153Tests.java
@@ -24,14 +24,15 @@ import org.aspectj.weaver.bcel.Utility;
public class Ajc153Tests extends org.aspectj.testing.XMLBasedAjcTestCase {
//public void testGenericsProblem_pr151978() { runTest("generics problem");}
- //public void testMissingLineNumbersInStacktraceBefore_pr145442() { runTest("missing line numbers in stacktrace before");}
- //public void testMissingLineNumbersInStacktraceAfter_pr145442() { runTest("missing line numbers in stacktrace after");}
- //public void testMissingLineNumbersInStacktraceAround_pr145442() { runTest("missing line numbers in stacktrace around");}
+// public void testMissingLineNumbersInStacktraceAfter_pr145442() { runTest("missing line numbers in stacktrace after");}
+// public void testMissingLineNumbersInStacktraceAround_pr145442() { runTest("missing line numbers in stacktrace around");}
// public void testArgnamesAndJavac_pr148381() { runTest("argNames and javac");}
// public void testCFlowXMLAspectLTW_pr149096() { runTest("cflow xml concrete aspect"); }
// public void testAmbiguousBinding_pr121805() { runTest("ambiguous binding");}
// public void testNoIllegalStateExceptionWithGenericInnerAspect_pr156058() { runTest("no IllegalStateException with generic inner aspect"); }
// public void testNegatedAnnotationMatchingProblem_pr153464() { runTest("negated annotation matching problem");}
+ public void testMissingLineNumbersInStacktraceBefore_pr145442() { runTest("missing line numbers in stacktrace before");}
+ public void testMissingLineNumbersInStacktraceBefore_pr145442_Binary() { runTest("missing line numbers in stacktrace before - binary");}
public void testAnnotationStylePointcutNPE_pr158412() { runTest("annotation style pointcut npe"); }
public void testAnnotationStylePointcutNPE_pr158412_2() { runTest("annotation style pointcut npe - 2"); }
public void testAnnotationsCallConstructors_pr158126() { runTest("annotations, call and constructors problem");}
diff --git a/tests/src/org/aspectj/systemtest/ajc153/ajc153.xml b/tests/src/org/aspectj/systemtest/ajc153/ajc153.xml
index 38654042b..f65a256a3 100644
--- a/tests/src/org/aspectj/systemtest/ajc153/ajc153.xml
+++ b/tests/src/org/aspectj/systemtest/ajc153/ajc153.xml
@@ -222,8 +222,18 @@
<compile files="hello/HelloWorld.java hello/ThrowExceptionBefore.aj"/>
<run class="hello.HelloWorld">
<stderr>
- <line text="hello.HelloWorld.println(HelloWorld.java:13)"/>
- <!--line text="hello.HelloWorld.println(HelloWorld.java)"/-->
+ <line text="hello.HelloWorld.println(HelloWorld.java:14)"/>
+ <line text="hello.HelloWorld.testStackTrace(HelloWorld.java:19)"/>
+ <line text="hello.HelloWorld.main(HelloWorld.java:41)"/>
+ </stderr>
+ </run>
+ </ajc-test>
+
+ <ajc-test dir="bugs153/pr145442" title="missing line numbers in stacktrace before - binary">
+ <compile inpath="helloworld.jar" files="hello/ThrowExceptionBefore.aj"/>
+ <run class="hello.HelloWorld">
+ <stderr>
+ <line text="hello.HelloWorld.println(HelloWorld.java:14)"/>
<line text="hello.HelloWorld.testStackTrace(HelloWorld.java:19)"/>
<line text="hello.HelloWorld.main(HelloWorld.java:41)"/>
</stderr>
@@ -234,7 +244,7 @@
<compile files="hello/HelloWorld.java hello/ThrowExceptionAfter.aj"/>
<run class="hello.HelloWorld">
<stderr>
- <line text="hello.HelloWorld.println(HelloWorld.java:15)"/>
+ <line text="hello.HelloWorld.println(HelloWorld.java:14)"/>
<line text="hello.HelloWorld.testStackTrace(HelloWorld.java:19)"/>
<line text="hello.HelloWorld.main(HelloWorld.java:41)"/>
</stderr>
@@ -245,8 +255,7 @@
<compile files="hello/HelloWorld.java hello/ThrowExceptionAround.aj" options="-XnoInline"/>
<run class="hello.HelloWorld">
<stderr>
- <line text="hello.HelloWorld.println(HelloWorld.java:13)"/>
- <!--line text="hello.HelloWorld.println(HelloWorld.java:1)"/-->
+ <line text="hello.HelloWorld.println(HelloWorld.java:14)"/>
<line text="hello.HelloWorld.testStackTrace(HelloWorld.java:19)"/>
<line text="hello.HelloWorld.main(HelloWorld.java:41)"/>
</stderr>
diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelAdvice.java b/weaver/src/org/aspectj/weaver/bcel/BcelAdvice.java
index ab61031f6..2fcd25e6d 100644
--- a/weaver/src/org/aspectj/weaver/bcel/BcelAdvice.java
+++ b/weaver/src/org/aspectj/weaver/bcel/BcelAdvice.java
@@ -24,6 +24,7 @@ import org.aspectj.apache.bcel.generic.InstructionConstants;
import org.aspectj.apache.bcel.generic.InstructionFactory;
import org.aspectj.apache.bcel.generic.InstructionHandle;
import org.aspectj.apache.bcel.generic.InstructionList;
+import org.aspectj.apache.bcel.generic.LineNumberTag;
import org.aspectj.bridge.ISourceLocation;
import org.aspectj.bridge.Message;
import org.aspectj.weaver.Advice;
@@ -424,7 +425,24 @@ public class BcelAdvice extends Advice {
il.append(getNonTestAdviceInstructions(shadow));
InstructionHandle ifYesAdvice = il.getStart();
- il.insert(getTestInstructions(shadow, ifYesAdvice, ifNoAdvice, ifYesAdvice));
+ il.insert(getTestInstructions(shadow, ifYesAdvice, ifNoAdvice, ifYesAdvice));
+
+ // If inserting instructions at the start of a method, we need a nice line number for this entry
+ // in the stack trace
+ if (shadow.getKind()==Shadow.MethodExecution && getKind()==AdviceKind.Before) {
+ int lineNumber=0;
+ // Uncomment this code if you think we should use the method decl line number when it exists...
+// // If the advised join point is in a class built by AspectJ, we can use the declaration line number
+// boolean b = shadow.getEnclosingMethod().getMemberView().hasDeclarationLineNumberInfo();
+// if (b) {
+// lineNumber = shadow.getEnclosingMethod().getMemberView().getDeclarationLineNumber();
+// } else { // If it wasn't, the best we can do is the line number of the first instruction in the method
+ lineNumber = shadow.getEnclosingMethod().getMemberView().getLineNumberOfFirstInstruction();
+// }
+ if (lineNumber>0) il.getStart().addTargeter(new LineNumberTag(lineNumber));
+ }
+
+
return il;
}
diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelMethod.java b/weaver/src/org/aspectj/weaver/bcel/BcelMethod.java
index 2bc6e9734..13839f41a 100644
--- a/weaver/src/org/aspectj/weaver/bcel/BcelMethod.java
+++ b/weaver/src/org/aspectj/weaver/bcel/BcelMethod.java
@@ -23,6 +23,8 @@ import org.aspectj.apache.bcel.classfile.Attribute;
import org.aspectj.apache.bcel.classfile.ExceptionTable;
import org.aspectj.apache.bcel.classfile.GenericSignatureParser;
import org.aspectj.apache.bcel.classfile.JavaClass;
+import org.aspectj.apache.bcel.classfile.LineNumber;
+import org.aspectj.apache.bcel.classfile.LineNumberTable;
import org.aspectj.apache.bcel.classfile.LocalVariable;
import org.aspectj.apache.bcel.classfile.LocalVariableTable;
import org.aspectj.apache.bcel.classfile.Method;
@@ -102,6 +104,13 @@ public final class BcelMethod extends ResolvedMemberImpl {
return super.getParameterNames();
}
+ public int getLineNumberOfFirstInstruction() {
+ LineNumberTable lnt = method.getLineNumberTable();
+ if (lnt==null) return -1;
+ LineNumber[] lns = lnt.getLineNumberTable();
+ if (lns==null || lns.length==0) return -1;
+ return lns[0].getLineNumber();
+ }
public void determineParameterNames() {
if (parameterNamesInitialized) return;
diff --git a/weaver/testdata/AroundAllAndOthersFancyHelloWorld.txt b/weaver/testdata/AroundAllAndOthersFancyHelloWorld.txt
index 789b9d37e..dea1d2c63 100644
--- a/weaver/testdata/AroundAllAndOthersFancyHelloWorld.txt
+++ b/weaver/testdata/AroundAllAndOthersFancyHelloWorld.txt
@@ -25,7 +25,7 @@ public abstract class FancyHelloWorld extends java.lang.Object:
ALOAD_0
ASTORE 19
method-execution(void FancyHelloWorld.main(java.lang.String[]))
- | INVOKESTATIC Aspect.ajc_before_method_execution ()V
+ | INVOKESTATIC Aspect.ajc_before_method_execution ()V (line 9)
| BIPUSH 1
| ANEWARRAY java.lang.Object
| ASTORE 21
@@ -45,7 +45,7 @@ public abstract class FancyHelloWorld extends java.lang.Object:
public static String getName():
method-execution(java.lang.String FancyHelloWorld.getName())
- | INVOKESTATIC Aspect.ajc_before_method_execution ()V
+ | INVOKESTATIC Aspect.ajc_before_method_execution ()V (line 20)
| BIPUSH 0
| ANEWARRAY java.lang.Object
| ASTORE 15
@@ -292,7 +292,7 @@ public abstract class FancyHelloWorld extends java.lang.Object:
end static final void main_aroundBody20(String[])
static final void main_aroundBody22(String[]):
- INVOKESTATIC Aspect.ajc_before_method_execution ()V
+ INVOKESTATIC Aspect.ajc_before_method_execution ()V (line 9)
BIPUSH 1
ANEWARRAY java.lang.Object
ASTORE_1
@@ -500,7 +500,7 @@ public abstract class FancyHelloWorld extends java.lang.Object:
end static final String getName_aroundBody40()
static final String getName_aroundBody42():
- INVOKESTATIC Aspect.ajc_before_method_execution ()V
+ INVOKESTATIC Aspect.ajc_before_method_execution ()V (line 20)
BIPUSH 0
ANEWARRAY java.lang.Object
ASTORE_0
diff --git a/weaver/testdata/AroundAllAndOthersHelloWorld.txt b/weaver/testdata/AroundAllAndOthersHelloWorld.txt
index 2175e03c6..b3d0b28fb 100644
--- a/weaver/testdata/AroundAllAndOthersHelloWorld.txt
+++ b/weaver/testdata/AroundAllAndOthersHelloWorld.txt
@@ -25,7 +25,7 @@ public class HelloWorld extends java.lang.Object:
ALOAD_0
ASTORE 7
method-execution(void HelloWorld.main(java.lang.String[]))
- | INVOKESTATIC Aspect.ajc_before_method_execution ()V
+ | INVOKESTATIC Aspect.ajc_before_method_execution ()V (line 8)
| BIPUSH 1
| ANEWARRAY java.lang.Object
| ASTORE 9
@@ -153,7 +153,7 @@ public class HelloWorld extends java.lang.Object:
end static final void main_aroundBody12(String[])
static final void main_aroundBody14(String[]):
- INVOKESTATIC Aspect.ajc_before_method_execution ()V
+ INVOKESTATIC Aspect.ajc_before_method_execution ()V (line 8)
BIPUSH 1
ANEWARRAY java.lang.Object
ASTORE_1
diff --git a/weaver/testdata/BeforeFancyHelloWorld.txt b/weaver/testdata/BeforeFancyHelloWorld.txt
index bc2ef49ba..69ee446b2 100644
--- a/weaver/testdata/BeforeFancyHelloWorld.txt
+++ b/weaver/testdata/BeforeFancyHelloWorld.txt
@@ -10,10 +10,10 @@ public abstract class FancyHelloWorld extends java.lang.Object:
public static void main(String[]):
method-execution(void FancyHelloWorld.main(java.lang.String[]))
- | INVOKESTATIC Aspect.ajc_before_method_execution ()V
+ | INVOKESTATIC Aspect.ajc_before_method_execution ()V (line 9)
| field-get(java.io.PrintStream java.lang.System.out)
| | INVOKESTATIC Aspect.ajc_before_field_get ()V
- | | GETSTATIC java.lang.System.out Ljava/io/PrintStream; (line 9)
+ | | GETSTATIC java.lang.System.out Ljava/io/PrintStream;
| field-get(java.io.PrintStream java.lang.System.out)
| ASTORE_1
| finally -> E1
@@ -55,8 +55,8 @@ public abstract class FancyHelloWorld extends java.lang.Object:
public static String getName():
method-execution(java.lang.String FancyHelloWorld.getName())
- | INVOKESTATIC Aspect.ajc_before_method_execution ()V
- | ICONST_0 (line 20)
+ | INVOKESTATIC Aspect.ajc_before_method_execution ()V (line 20)
+ | ICONST_0
| ISTORE_0
| ILOAD_0 // int x (line 21)
| LDC "name"
diff --git a/weaver/testdata/BeforeHelloWorld.txt b/weaver/testdata/BeforeHelloWorld.txt
index d89b5acd9..13dab828c 100644
--- a/weaver/testdata/BeforeHelloWorld.txt
+++ b/weaver/testdata/BeforeHelloWorld.txt
@@ -10,10 +10,10 @@ public class HelloWorld extends java.lang.Object:
public static void main(String[]):
method-execution(void HelloWorld.main(java.lang.String[]))
- | INVOKESTATIC Aspect.ajc_before_method_execution ()V
+ | INVOKESTATIC Aspect.ajc_before_method_execution ()V (line 8)
| field-get(java.io.PrintStream java.lang.System.out)
| | INVOKESTATIC Aspect.ajc_before_field_get ()V
- | | GETSTATIC java.lang.System.out Ljava/io/PrintStream; (line 8)
+ | | GETSTATIC java.lang.System.out Ljava/io/PrintStream;
| field-get(java.io.PrintStream java.lang.System.out)
| LDC "hello world" (line 9)
| method-call(void java.io.PrintStream.println(java.lang.String))
diff --git a/weaver/testdata/CflowStateResidueDynamicHelloWorld.txt b/weaver/testdata/CflowStateResidueDynamicHelloWorld.txt
index 4745c2af0..4d3b2775d 100644
--- a/weaver/testdata/CflowStateResidueDynamicHelloWorld.txt
+++ b/weaver/testdata/CflowStateResidueDynamicHelloWorld.txt
@@ -9,7 +9,7 @@ public class DynamicHelloWorld extends java.lang.Object implements java.io.Seria
public static void main(String[]):
method-execution(void DynamicHelloWorld.main(java.lang.String[]))
- | GETSTATIC Aspect.ajc$cflowStack$0 Lorg/aspectj/runtime/internal/CFlowStack;
+ | GETSTATIC Aspect.ajc$cflowStack$0 Lorg/aspectj/runtime/internal/CFlowStack; (line 12)
| INVOKEVIRTUAL org.aspectj.runtime.internal.CFlowStack.isValid ()Z
| IFEQ L0
| GETSTATIC Aspect.ajc$cflowStack$0 Lorg/aspectj/runtime/internal/CFlowStack;
@@ -18,7 +18,7 @@ public class DynamicHelloWorld extends java.lang.Object implements java.io.Seria
| CHECKCAST java.util.ArrayList
| INVOKESTATIC Aspect.ajc_before_0 (Ljava/util/ArrayList;)V
| catch java.lang.UnsupportedOperationException -> E0
- | | L0: NEW DynamicHelloWorld (line 12)
+ | | L0: NEW DynamicHelloWorld
| | DUP
| | INVOKESPECIAL DynamicHelloWorld.<init> ()V
| | LDC "hello"
diff --git a/weaver/testdata/FieldSet.txt b/weaver/testdata/FieldSet.txt
index a32fad0f7..f5704a576 100644
--- a/weaver/testdata/FieldSet.txt
+++ b/weaver/testdata/FieldSet.txt
@@ -19,10 +19,10 @@ public class FieldyHelloWorld extends java.lang.Object:
public static void main(String[]):
method-execution(void FieldyHelloWorld.main(java.lang.String[]))
- | INVOKESTATIC Aspect.ajc_before_method_execution ()V
+ | INVOKESTATIC Aspect.ajc_before_method_execution ()V (line 6)
| field-get(java.lang.String FieldyHelloWorld.str)
| | INVOKESTATIC Aspect.ajc_before_field_get ()V
- | | GETSTATIC FieldyHelloWorld.str Ljava/lang/String; (line 6)
+ | | GETSTATIC FieldyHelloWorld.str Ljava/lang/String;
| field-get(java.lang.String FieldyHelloWorld.str)
| method-call(java.lang.String java.lang.String.valueOf(java.lang.Object))
| | INVOKESTATIC Aspect.ajc_before_method_call ()V
diff --git a/weaver/testdata/StaticEnclosingTjpBeforeHelloWorld.txt b/weaver/testdata/StaticEnclosingTjpBeforeHelloWorld.txt
index fc806f810..fed62e3c7 100644
--- a/weaver/testdata/StaticEnclosingTjpBeforeHelloWorld.txt
+++ b/weaver/testdata/StaticEnclosingTjpBeforeHelloWorld.txt
@@ -13,12 +13,12 @@ public class HelloWorld extends java.lang.Object:
public static void main(String[]):
method-execution(void HelloWorld.main(java.lang.String[]))
- | GETSTATIC HelloWorld.ajc$tjp_1 Lorg/aspectj/lang/JoinPoint$EnclosingStaticPart;
+ | GETSTATIC HelloWorld.ajc$tjp_1 Lorg/aspectj/lang/JoinPoint$EnclosingStaticPart; (line 8)
| INVOKESTATIC Aspect.ajc_before (Lorg/aspectj/lang/JoinPoint$StaticPart;)V
| field-get(java.io.PrintStream java.lang.System.out)
| | GETSTATIC HelloWorld.ajc$tjp_1 Lorg/aspectj/lang/JoinPoint$EnclosingStaticPart;
| | INVOKESTATIC Aspect.ajc_before (Lorg/aspectj/lang/JoinPoint$StaticPart;)V
- | | GETSTATIC java.lang.System.out Ljava/io/PrintStream; (line 8)
+ | | GETSTATIC java.lang.System.out Ljava/io/PrintStream;
| field-get(java.io.PrintStream java.lang.System.out)
| LDC "hello world" (line 9)
| method-call(void java.io.PrintStream.println(java.lang.String))
diff --git a/weaver/testdata/StaticTjpBeforeHelloWorld.txt b/weaver/testdata/StaticTjpBeforeHelloWorld.txt
index 6bc961dab..dcb25de15 100644
--- a/weaver/testdata/StaticTjpBeforeHelloWorld.txt
+++ b/weaver/testdata/StaticTjpBeforeHelloWorld.txt
@@ -15,12 +15,12 @@ public class HelloWorld extends java.lang.Object:
public static void main(String[]):
method-execution(void HelloWorld.main(java.lang.String[]))
- | GETSTATIC HelloWorld.ajc$tjp_3 Lorg/aspectj/lang/JoinPoint$StaticPart;
+ | GETSTATIC HelloWorld.ajc$tjp_3 Lorg/aspectj/lang/JoinPoint$StaticPart; (line 8)
| INVOKESTATIC Aspect.ajc_before (Lorg/aspectj/lang/JoinPoint$StaticPart;)V
| field-get(java.io.PrintStream java.lang.System.out)
| | GETSTATIC HelloWorld.ajc$tjp_1 Lorg/aspectj/lang/JoinPoint$StaticPart;
| | INVOKESTATIC Aspect.ajc_before (Lorg/aspectj/lang/JoinPoint$StaticPart;)V
- | | GETSTATIC java.lang.System.out Ljava/io/PrintStream; (line 8)
+ | | GETSTATIC java.lang.System.out Ljava/io/PrintStream;
| field-get(java.io.PrintStream java.lang.System.out)
| LDC "hello world" (line 9)
| method-call(void java.io.PrintStream.println(java.lang.String))
diff --git a/weaver/testdata/TjpBeforeHelloWorld.txt b/weaver/testdata/TjpBeforeHelloWorld.txt
index 910465ee1..cf1eb20f8 100644
--- a/weaver/testdata/TjpBeforeHelloWorld.txt
+++ b/weaver/testdata/TjpBeforeHelloWorld.txt
@@ -28,7 +28,7 @@ public class HelloWorld extends java.lang.Object:
INVOKESTATIC org.aspectj.runtime.reflect.Factory.makeJP (Lorg/aspectj/lang/JoinPoint$StaticPart;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Lorg/aspectj/lang/JoinPoint;
ASTORE 5
method-execution(void HelloWorld.main(java.lang.String[]))
- | ALOAD 5
+ | ALOAD 5 (line 8)
| INVOKESTATIC Aspect.ajc_before (Lorg/aspectj/lang/JoinPoint;)V
| GETSTATIC HelloWorld.ajc$tjp_1 Lorg/aspectj/lang/JoinPoint$StaticPart;
| ACONST_NULL
@@ -38,7 +38,7 @@ public class HelloWorld extends java.lang.Object:
| field-get(java.io.PrintStream java.lang.System.out)
| | ALOAD_1
| | INVOKESTATIC Aspect.ajc_before (Lorg/aspectj/lang/JoinPoint;)V
- | | GETSTATIC java.lang.System.out Ljava/io/PrintStream; (line 8)
+ | | GETSTATIC java.lang.System.out Ljava/io/PrintStream;
| field-get(java.io.PrintStream java.lang.System.out)
| LDC "hello world" (line 9)
| ASTORE_3
diff --git a/weaver/testdata/TraceJarHello.txt b/weaver/testdata/TraceJarHello.txt
index 95a629d12..7e313b911 100644
--- a/weaver/testdata/TraceJarHello.txt
+++ b/weaver/testdata/TraceJarHello.txt
@@ -42,7 +42,7 @@ public class DynamicHelloWorld extends java.lang.Object implements java.io.Seria
ALOAD_2
ASTORE 4
method-execution(java.lang.String DynamicHelloWorld.doit(java.lang.String, java.util.List))
- | INVOKESTATIC MyTrace.aspectOf ()LMyTrace;
+ | INVOKESTATIC MyTrace.aspectOf ()LMyTrace; (line 21)
| ALOAD_0
| INVOKEVIRTUAL Trace.ajc$before$Trace$1$26352be2 (Ljava/lang/Object;)V
| INVOKESTATIC MyTrace.aspectOf ()LMyTrace;