aboutsummaryrefslogtreecommitdiffstats
path: root/weaver
diff options
context:
space:
mode:
authoraclement <aclement>2008-09-18 19:41:30 +0000
committeraclement <aclement>2008-09-18 19:41:30 +0000
commit6d6adfc1327fea030f0547737543df96b5447387 (patch)
tree9dd546affbc4a406a591a1fbce904533c5b86964 /weaver
parent5347178d0233e98a74e65cdc1721c19f509c0a18 (diff)
downloadaspectj-6d6adfc1327fea030f0547737543df96b5447387.tar.gz
aspectj-6d6adfc1327fea030f0547737543df96b5447387.zip
copyright added
Diffstat (limited to 'weaver')
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/asm/AsmDetector.java22
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/asm/StackMapAdder.java71
2 files changed, 57 insertions, 36 deletions
diff --git a/weaver/src/org/aspectj/weaver/bcel/asm/AsmDetector.java b/weaver/src/org/aspectj/weaver/bcel/asm/AsmDetector.java
index 415e38efc..a2cc74355 100644
--- a/weaver/src/org/aspectj/weaver/bcel/asm/AsmDetector.java
+++ b/weaver/src/org/aspectj/weaver/bcel/asm/AsmDetector.java
@@ -1,24 +1,34 @@
+/* *******************************************************************
+ * Copyright (c) 2008 Contributors
+ * All rights reserved.
+ * This program and the accompanying materials are made available
+ * under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * Andy Clement
+ * ******************************************************************/
package org.aspectj.weaver.bcel.asm;
import java.lang.reflect.Method;
/**
- * Determines if a version of asm is around that will enable us to add
- * stack map attributes to classes that we produce.
+ * Determines if a version of asm is around that will enable us to add stack map attributes to classes that we produce.
*
* @author Andy Clement
*/
public class AsmDetector {
public static boolean isAsmAround;
-
+
static {
try {
Class reader = Class.forName("org.objectweb.asm.ClassReader");
Class visitor = Class.forName("org.objectweb.asm.ClassVisitor");
- Method m = reader.getMethod("accept",new Class[]{visitor,Integer.TYPE});
- isAsmAround = m!=null;
- } catch (Exception e ) {
+ Method m = reader.getMethod("accept", new Class[] { visitor, Integer.TYPE });
+ isAsmAround = m != null;
+ } catch (Exception e) {
isAsmAround = false;
}
// System.out.println(isAsmAround?"ASM detected":"No ASM found");
diff --git a/weaver/src/org/aspectj/weaver/bcel/asm/StackMapAdder.java b/weaver/src/org/aspectj/weaver/bcel/asm/StackMapAdder.java
index 96d6a8822..7bdc61dd9 100644
--- a/weaver/src/org/aspectj/weaver/bcel/asm/StackMapAdder.java
+++ b/weaver/src/org/aspectj/weaver/bcel/asm/StackMapAdder.java
@@ -1,3 +1,14 @@
+/* *******************************************************************
+ * Copyright (c) 2008 Contributors
+ * All rights reserved.
+ * This program and the accompanying materials are made available
+ * under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * Andy Clement
+ * ******************************************************************/
package org.aspectj.weaver.bcel.asm;
import org.aspectj.weaver.ResolvedType;
@@ -7,9 +18,9 @@ import org.objectweb.asm.ClassReader;
import org.objectweb.asm.ClassWriter;
/**
- * Uses asm to add the stack map attribute to methods in a class. The class is passed in as pure byte data
- * and then a reader/writer process it. The writer is wired into the world so that types can be resolved
- * and getCommonSuperClass() can be implemented without class loading using the context class loader.
+ * Uses asm to add the stack map attribute to methods in a class. The class is passed in as pure byte data and then a reader/writer
+ * process it. The writer is wired into the world so that types can be resolved and getCommonSuperClass() can be implemented without
+ * class loading using the context class loader.
*
* @author Andy Clement
*/
@@ -19,17 +30,17 @@ public class StackMapAdder {
try {
ClassReader cr = new ClassReader(data);
ClassWriter cw = new AspectJConnectClassWriter(world);
- cr.accept(cw,0);
- return cw.toByteArray();
+ cr.accept(cw, 0);
+ return cw.toByteArray();
} catch (Throwable t) {
- System.err.println("AspectJ Internal Error: unable to add stackmap attributes. "+t.getMessage());
- AsmDetector.isAsmAround=false;
+ System.err.println("AspectJ Internal Error: unable to add stackmap attributes. " + t.getMessage());
+ AsmDetector.isAsmAround = false;
return data;
}
}
-
+
private static class AspectJConnectClassWriter extends ClassWriter {
- private World world;
+ private final World world;
public AspectJConnectClassWriter(World w) {
super(ClassWriter.COMPUTE_FRAMES);
@@ -38,26 +49,26 @@ public class StackMapAdder {
// Implementation of getCommonSuperClass() that avoids Class.forName()
protected String getCommonSuperClass(final String type1, final String type2) {
-
- ResolvedType resolvedType1 = world.resolve(UnresolvedType.forName(type1.replace('/','.')));
- ResolvedType resolvedType2 = world.resolve(UnresolvedType.forName(type2.replace('/','.')));
-
- if (resolvedType1.isAssignableFrom(resolvedType2)) {
- return type1;
- }
-
- if (resolvedType2.isAssignableFrom(resolvedType1)) {
- return type2;
- }
-
- if (resolvedType1.isInterface() || resolvedType2.isInterface()) {
- return "java/lang/Object";
- } else {
- do {
- resolvedType1 = resolvedType1.getSuperclass();
- } while (!resolvedType1.isAssignableFrom(resolvedType2));
- return resolvedType1.getName().replace('.','/');
- }
- }
+
+ ResolvedType resolvedType1 = world.resolve(UnresolvedType.forName(type1.replace('/', '.')));
+ ResolvedType resolvedType2 = world.resolve(UnresolvedType.forName(type2.replace('/', '.')));
+
+ if (resolvedType1.isAssignableFrom(resolvedType2)) {
+ return type1;
+ }
+
+ if (resolvedType2.isAssignableFrom(resolvedType1)) {
+ return type2;
+ }
+
+ if (resolvedType1.isInterface() || resolvedType2.isInterface()) {
+ return "java/lang/Object";
+ } else {
+ do {
+ resolvedType1 = resolvedType1.getSuperclass();
+ } while (!resolvedType1.isAssignableFrom(resolvedType2));
+ return resolvedType1.getName().replace('.', '/');
+ }
+ }
}
}