Package org.apache.tapestry5.plastic
Interface PlasticField
- 
- All Superinterfaces:
- AnnotationAccess
 
 public interface PlasticField extends AnnotationAccess Represents a field of a class being transformed. No methods of this object should be invoked after the class transformation is completed.
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description PlasticFieldclaim(java.lang.Object tag)Claims the field, used to indicate that the field is "processed".PlasticFieldcreateAccessors(PropertyAccessType accessType)Creates access to the field, using the default property name derived from the name of the field.PlasticFieldcreateAccessors(PropertyAccessType accessType, java.lang.String propertyName)Creates accessors, possibly replacing existing methods (or overriding methods from a super class).java.lang.StringgetGenericSignature()Returns the field's fully qualified generic type, or null if not defined.FieldHandlegetHandle()Returns a handle that can be used to directly access a private field of a transformed class instance.intgetModifiers()Returns the modifiers on the field.java.lang.StringgetName()Returns the name of the field.PlasticClassgetPlasticClass()Returns the class containing this field.java.lang.StringgetTypeName()Returns the fully qualified class name for the field's type or (for a primitive type) the primitive type name ("int", "char", etc.).PlasticFieldinject(java.lang.Object value)Converts the field to be read-only, and provide the indicated value.PlasticFieldinjectComputed(ComputedValue<?> computedValue)Converts the field to be read-only, and provide the value, which is computed indirectly inside the class' constructor.PlasticFieldinjectFromInstanceContext()As withinject(Object), but the value is extracted from theInstanceContext.booleanisClaimed()Returns true if the field has already been claimed.<F> PlasticFieldsetComputedConduit(ComputedValue<FieldConduit<F>> computedConduit)Sets the conduit for the field to a value computed when the class is instantiated<F> PlasticFieldsetConduit(FieldConduit<F> conduit)Intercepts all access to the field, replacing such access with calls on the conduit.- 
Methods inherited from interface org.apache.tapestry5.plastic.AnnotationAccessgetAnnotation, hasAnnotation
 
- 
 
- 
- 
- 
Method Detail- 
getPlasticClassPlasticClass getPlasticClass() Returns the class containing this field.
 - 
getHandleFieldHandle getHandle() Returns a handle that can be used to directly access a private field of a transformed class instance.
 - 
getNamejava.lang.String getName() Returns the name of the field.
 - 
getTypeNamejava.lang.String getTypeName() Returns the fully qualified class name for the field's type or (for a primitive type) the primitive type name ("int", "char", etc.). For array types, the returned name includes a "[]" suffix.
 - 
claimPlasticField claim(java.lang.Object tag) Claims the field, used to indicate that the field is "processed". A field may only be claimed once. Claiming a field is intended as a mechanism to detect or prevent conflicts between different isolated transformations of the field. The tag value used does not matter, and is typically either an annotation (that drove the transformation) or the instance ofPlasticClassTransformerthat performed the transformation. That tag value is only used when generating the error message for the case where a field is claimed for than once.- Returns:
- the field for further manipulation
- Throws:
- java.lang.RuntimeException- if the field is claimed a second time
- java.lang.AssertionError- if tag is null
- See Also:
- PlasticClass.getUnclaimedFields()
 
 - 
isClaimedboolean isClaimed() Returns true if the field has already been claimed.- See Also:
- PlasticClass.getUnclaimedFields()
 
 - 
injectPlasticField inject(java.lang.Object value) Converts the field to be read-only, and provide the indicated value. The field's value will be set inside the class' constructor.- Parameters:
- value- to inject, which must be type compatible with the field (possibly, a wrapper type if the field is a primitive value). The value may not be null.
- Returns:
- the field for further manipulation
- Throws:
- java.lang.IllegalStateException- if the field already has an injection, or the field has a conduit
 
 - 
injectComputedPlasticField injectComputed(ComputedValue<?> computedValue) Converts the field to be read-only, and provide the value, which is computed indirectly inside the class' constructor.- Parameters:
- computedValue- provides the actual value to be injected, and must return a value type compatible with the field (possibly a wrapper type if the field is a primitive value). The computedValue may not be null.
- Returns:
- the field for further manipulation
- Throws:
- java.lang.IllegalStateException- if the field already has an injection, or the field has a conduit
 
 - 
injectFromInstanceContextPlasticField injectFromInstanceContext() As withinject(Object), but the value is extracted from theInstanceContext.- Returns:
- this field for further manipulation
 
 - 
setConduit<F> PlasticField setConduit(FieldConduit<F> conduit) Intercepts all access to the field, replacing such access with calls on the conduit. Even access via the FieldHandle will instead delegate to the conduit. Once a conduit is provided, it is not possible to inject a value into the field. Normally, once a conduit is in place, the field will never be actually read or written. This is problematic for debugging, soTransformationOption.FIELD_WRITEBEHINDis useful when operating in a non-production mode.- Returns:
- the field for further manipulation
- Throws:
- java.lang.IllegalStateException- if the field already has an injection or a conduit
 
 - 
setComputedConduit<F> PlasticField setComputedConduit(ComputedValue<FieldConduit<F>> computedConduit) Sets the conduit for the field to a value computed when the class is instantiated- Parameters:
- computedConduit- object that will compute the actual conduit to be used
- Returns:
- this field for further manipulation
 
 - 
createAccessorsPlasticField createAccessors(PropertyAccessType accessType) Creates access to the field, using the default property name derived from the name of the field. The default property name is the same as the name of the field, but with any leading or trailing underscore characters removed (a common convention among some programmers). Also, strips leading "m_" from the field name (another common convention).- Parameters:
- accessType- which methods to create
- Returns:
- the field for further manipulation
- Throws:
- java.lang.IllegalArgumentException- if an accessor method to be created already exists (possibly inherited from a base class)
 
 - 
createAccessorsPlasticField createAccessors(PropertyAccessType accessType, java.lang.String propertyName) Creates accessors, possibly replacing existing methods (or overriding methods from a super class). The method names consist of the property name, with its first character converted to upper-case, prefixed with "get" or "set". The accessor methods must not already exist.- Parameters:
- accessType- which methods to create
- propertyName- the name of the property (from which the names of the methods are generated)
- Returns:
- the field for further manipulation
- Throws:
- java.lang.IllegalArgumentException- if an accessor method to be created already exists (possibly inherited from a base class)
 
 - 
getGenericSignaturejava.lang.String getGenericSignature() Returns the field's fully qualified generic type, or null if not defined.
 - 
getModifiersint getModifiers() Returns the modifiers on the field.
 
- 
 
-