aboutsummaryrefslogtreecommitdiffstats
path: root/asm
diff options
context:
space:
mode:
Diffstat (limited to 'asm')
-rw-r--r--asm/src/org/aspectj/asm/IProgramElement.java26
-rw-r--r--asm/src/org/aspectj/asm/internal/ProgramElement.java26
2 files changed, 30 insertions, 22 deletions
diff --git a/asm/src/org/aspectj/asm/IProgramElement.java b/asm/src/org/aspectj/asm/IProgramElement.java
index bc60fdbce..495bef0ba 100644
--- a/asm/src/org/aspectj/asm/IProgramElement.java
+++ b/asm/src/org/aspectj/asm/IProgramElement.java
@@ -151,7 +151,7 @@ public interface IProgramElement extends Serializable {
public void setSourceSignature(String string);
public IProgramElement walk(HierarchyWalker walker);
-
+
/**
* Uses "typesafe enum" pattern.
*/
@@ -159,24 +159,30 @@ public interface IProgramElement extends Serializable {
private static final long serialVersionUID = -8279300899976607927L;
- public static final Modifiers STATIC = new Modifiers("static");
- public static final Modifiers FINAL = new Modifiers("final");
- public static final Modifiers ABSTRACT = new Modifiers("abstract");
- public static final Modifiers SYNCHRONIZED = new Modifiers("synchronized");
- public static final Modifiers VOLATILE = new Modifiers("volatile");
- public static final Modifiers STRICTFP = new Modifiers("strictfp");
- public static final Modifiers TRANSIENT = new Modifiers("transient");
- public static final Modifiers NATIVE = new Modifiers("native");
+ public static final Modifiers STATIC = new Modifiers("static",0x0008);
+ public static final Modifiers FINAL = new Modifiers("final",0x0010);
+ public static final Modifiers ABSTRACT = new Modifiers("abstract",0x0400);
+ public static final Modifiers SYNCHRONIZED = new Modifiers("synchronized",0x0020);
+ public static final Modifiers VOLATILE = new Modifiers("volatile",0x0040);
+ public static final Modifiers STRICTFP = new Modifiers("strictfp",0x0800);
+ public static final Modifiers TRANSIENT = new Modifiers("transient",0x0080);
+ public static final Modifiers NATIVE = new Modifiers("native",0x0100);
public static final Modifiers[] ALL = { STATIC, FINAL, ABSTRACT, SYNCHRONIZED, VOLATILE, STRICTFP, TRANSIENT, NATIVE };
private final String name;
+ private int bit;
- private Modifiers(String name) {
+ private Modifiers(String name, int bit) {
this.name = name;
+ this.bit = bit;
}
public String toString() {
return name;
}
+
+ public int getBit() {
+ return bit;
+ }
// The 4 declarations below are necessary for serialization
private static int nextOrdinal = 0;
diff --git a/asm/src/org/aspectj/asm/internal/ProgramElement.java b/asm/src/org/aspectj/asm/internal/ProgramElement.java
index 189133935..b63f74108 100644
--- a/asm/src/org/aspectj/asm/internal/ProgramElement.java
+++ b/asm/src/org/aspectj/asm/internal/ProgramElement.java
@@ -17,6 +17,7 @@ import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.Iterator;
+import java.util.LinkedList;
import java.util.List;
import java.util.Map;
@@ -49,8 +50,6 @@ public class ProgramElement implements IProgramElement {
private static int AccInterface = 0x0200;
private static int AccAbstract = 0x0400;
private static int AccStrictfp = 0x0800;
-
-
protected String name;
private Kind kind;
@@ -58,7 +57,7 @@ public class ProgramElement implements IProgramElement {
protected List children = Collections.EMPTY_LIST;
private Map kvpairs = Collections.EMPTY_MAP;
protected ISourceLocation sourceLocation = null;
- private int modifiers;
+ private int modifiers;
private String handle = null;
@@ -82,7 +81,6 @@ public class ProgramElement implements IProgramElement {
setFormalComment(comment);
// if (comment!=null && comment.length()>0) formalComment = comment;
this.modifiers = modifiers;
-// this.accessibility = genAccessibility(modifiers);
}
/**
@@ -105,7 +103,6 @@ public class ProgramElement implements IProgramElement {
this.sourceLocation = sourceLocation;
this.kind = kind;
this.modifiers = modifiers;
-// this.accessibility = accessibility;
setDeclaringType(declaringType);//this.declaringType = declaringType;
//this.packageName = packageName;
setFormalComment(comment);
@@ -115,18 +112,13 @@ public class ProgramElement implements IProgramElement {
}
public List getModifiers() {
- return genModifiers(modifiers);
+ return genModifiers(this.modifiers);
}
public Accessibility getAccessibility() {
- return genAccessibility(modifiers); // accessibility
+ return genAccessibility(this.modifiers);
}
-// public void setAccessibility(Accessibility a) {
-//
-// //accessibility=a;
-// }
-
public void setDeclaringType(String t) {
if (t!=null && t.length()>0) {
if (kvpairs==Collections.EMPTY_MAP) kvpairs = new HashMap();
@@ -400,6 +392,16 @@ public class ProgramElement implements IProgramElement {
public void setModifiers(int i) {
this.modifiers = i;
}
+
+ /**
+ * Convenience mechanism for setting new modifiers which do not require
+ * knowledge of the private internal representation
+ *
+ * @param newModifier
+ */
+ public void addModifiers(IProgramElement.Modifiers newModifier) {
+ modifiers |= newModifier.getBit();
+ }
public String toSignatureString() {
return toSignatureString(true);