Class AScene
- All Implemented Interfaces:
- Cloneable
AScene (annotated scene) represents the annotations on a set of Java classes and
 packages along with the definitions of some or all of the annotation types used.
 Each client of the annotation library may wish to use its own representation for certain kinds of annotations instead of a simple name-value map; thus, a layer of abstraction in the storage of annotations was introduced.
AScenes and many AElements can contain other AElements. When these
 objects are created, their collections of subelements are empty. In order to associate an
 annotation with a particular Java element in an AScene, one must first ensure that an
 appropriate AElement exists in the AScene. To this end, the maps of subelements
 have a vivify method. Calling vivify to access a particular subelement will
 return the subelement if it already exists; otherwise it will create and then return the
 subelement. (Compare to vivification in Perl.) For example, the following code will obtain an
 AMethod representing Foo.bar in the AScene s, creating it if it
 did not already exist:
 
 AMethod<A> m = s.classes.getVivify("Foo").methods.getVivify("bar");
 
 Then one can add an annotation to the method:
 m.annotationsHere.add(new Annotation(
     new AnnotationDef(taintedDef, RetentionPolicy.RUNTIME, true),
     new Annotation(taintedDef, Collections.emptyMap())
 ));
 - 
Field SummaryFieldsModifier and TypeFieldDescriptionfinal VivifyingMap<String, AClass> This scene's annotated classes; map key is class name.Contains for each annotation type a set of imports to be added to the source if the annotation is inserted with the "abbreviate" option on.
 Key: fully-qualified name of an annotation.final VivifyingMap<String, AElement> This scene's annotated packages; map key is package name.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic voidcheckClone(AScene s0, AScene s1) Checks that the arguments are clones of one another.static <K,V extends AElement> 
 voidcheckCloneMap(VivifyingMap<K, V> m0, VivifyingMap<K, V> m1) Throw exception if m0 == m1 or !m0.equals(m1).clone()booleanReturns true if thisASceneequalso; the commentary and the cautionary remarks onAElement.equals(Object)also apply toequals(Object).booleanReturns true if thisASceneequalso; a slightly faster variant ofequals(Object)for when the argument is statically known to be another nonnullAScene.Fetch the classes in this scene, represented as AClass objects.inthashCode()booleanisEmpty()Returns true if thisASceneis empty.static voidTemporary main for easy testing on JAIFs.voidprune()Removes empty subelements of thisAScenedepth-first.toString()unparse()Returns a string representation.
- 
Field Details- 
packagesThis scene's annotated packages; map key is package name.
- 
importsContains for each annotation type a set of imports to be added to the source if the annotation is inserted with the "abbreviate" option on.
 Key: fully-qualified name of an annotation. e.g. for@com.foo.Bar(x), the fully-qualified name iscom.foo.Bar
 Value: names of packages this annotation needs
- 
classesThis scene's annotated classes; map key is class name.
 
- 
- 
Constructor Details
- 
Method Details- 
clone
- 
equalsReturns true if thisASceneequalso; the commentary and the cautionary remarks onAElement.equals(Object)also apply toequals(Object).
- 
equalsReturns true if thisASceneequalso; a slightly faster variant ofequals(Object)for when the argument is statically known to be another nonnullAScene.
- 
hashCodepublic int hashCode()
- 
getClassesFetch the classes in this scene, represented as AClass objects.- Returns:
- an immutable map from binary names to AClass objects
 
- 
isEmptypublic boolean isEmpty()Returns true if thisASceneis empty.
- 
prunepublic void prune()Removes empty subelements of thisAScenedepth-first.
- 
unparseReturns a string representation.
- 
toString
- 
checkCloneChecks that the arguments are clones of one another.Throws an exception if the arguments 1) are the same reference; 2) are not equal() in both directions; or 3) contain corresponding elements that meet either of the preceding two conditions. - Parameters:
- s0- the first AScene to compare
- s1- the second Ascene to compare
 
- 
checkCloneMappublic static <K,V extends AElement> void checkCloneMap(VivifyingMap<K, V> m0, VivifyingMap<K, V> m1) Throw exception if m0 == m1 or !m0.equals(m1). (SeecheckClone(AScene, AScene)for explanation.)- Type Parameters:
- K- the type of map keys
- V- the type of map values
- Parameters:
- m0- the first map to compare
- m1- the second map to compare
 
- 
mainTemporary main for easy testing on JAIFs.- Parameters:
- args- command-line arguments
 
 
-