Package org.exolab.castor.mapping.loader
Class FieldDescriptorImpl
- java.lang.Object
-
- org.exolab.castor.mapping.loader.FieldDescriptorImpl
-
- All Implemented Interfaces:
NatureExtendable,PropertyHolder,FieldDescriptor
- Direct Known Subclasses:
XMLFieldDescriptorImpl
public class FieldDescriptorImpl extends java.lang.Object implements FieldDescriptor
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedFieldDescriptorImpl()Creates a default instance of a field descriptor.FieldDescriptorImpl(java.lang.String fieldName, TypeInfo typeInfo, FieldHandler handler, boolean isTransitive)Constructs a new field descriptor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddNature(java.lang.String nature)Adds a specified nature.ClassDescriptorgetClassDescriptor()Returns the class descriptor related to the field type.FieldMappingCollectionTypegetCollection()java.lang.StringgetComparator()ClassDescriptorgetContainingClassDescriptor()Get the class descriptor which contains this field.java.lang.StringgetCreateMethod()java.lang.StringgetFieldName()Returns the name of the field.java.lang.Class<?>getFieldType()Returns the Java type of the field.java.lang.StringgetGetMethod()FieldHandlergetHandler()Returns the handler of the field.java.lang.ObjectgetProperty(java.lang.String name)Get a property by its name.java.lang.StringgetSetMethod()booleanhasNature(java.lang.String nature)Checks if a specified nature has been added.booleanisDirect()booleanisIdentity()Is the described field is part of the identity of the class it belongs to?booleanisImmutable()Returns true if the field type is immutable.booleanisLazy()booleanisMultivalued()Returns true if the field is multivalued (a collection).booleanisRequired()Returns true if the field type is required.booleanisTransient()Returns true if the field is transient.voidsetClassDescriptor(ClassDescriptor classDescriptor)Set the ClassDescriptor for the described field.voidsetCollection(FieldMappingCollectionType collection)voidsetComparator(java.lang.String comparator)voidsetContainingClassDescriptor(ClassDescriptor parent)Set the class descriptor which contains this field.voidsetCreateMethod(java.lang.String createMethod)voidsetDirect(boolean direct)voidsetFieldName(java.lang.String fieldName)Set the name of the field.voidsetFieldType(java.lang.Class<?> fieldType)Set the type of the field.voidsetGetMethod(java.lang.String getMethod)voidsetHandler(FieldHandler handler)Set the FieldHandler for the field being described by this FieldDescriptor.voidsetIdentity(boolean identity)Set wether the described field is part of the identity of the class it belongs to.voidsetImmutable(boolean immutable)Set the immutable flag which indicates that changes to this Field result in a new Object to be created, such as java.lang.String.voidsetLazy(boolean lazy)voidsetMultivalued(boolean multivalued)Set wheter the object described by this descriptor is multivalued or not.voidsetProperty(java.lang.String name, java.lang.Object value)Set a property specified by the name to the passed value.voidsetRequired(boolean required)Set whether or not the described field is required.voidsetSetMethod(java.lang.String setMethod)voidsetTransient(boolean isTransient)Sets whether or not the describled field is 'transient'.java.lang.StringtoString()
-
-
-
Constructor Detail
-
FieldDescriptorImpl
protected FieldDescriptorImpl()
Creates a default instance of a field descriptor.
-
FieldDescriptorImpl
public FieldDescriptorImpl(java.lang.String fieldName, TypeInfo typeInfo, FieldHandler handler, boolean isTransitive)Constructs a new field descriptor.- Parameters:
fieldName- The field nametypeInfo- The field type informationhandler- The field handler (may be null)isTransitive- True if the field is transient
-
-
Method Detail
-
setContainingClassDescriptor
public final void setContainingClassDescriptor(ClassDescriptor parent)
Description copied from interface:FieldDescriptorSet the class descriptor which contains this field.- Specified by:
setContainingClassDescriptorin interfaceFieldDescriptor- Parameters:
parent- The class descriptor which contains this field.- See Also:
FieldDescriptor.setContainingClassDescriptor( org.exolab.castor.mapping.ClassDescriptor)
-
getContainingClassDescriptor
public final ClassDescriptor getContainingClassDescriptor()
Description copied from interface:FieldDescriptorGet the class descriptor which contains this field.- Specified by:
getContainingClassDescriptorin interfaceFieldDescriptor- Returns:
- The class descriptor which contains this field.
- See Also:
FieldDescriptor.getContainingClassDescriptor()
-
setFieldName
public final void setFieldName(java.lang.String fieldName)
Set the name of the field.- Parameters:
fieldName- Field name.
-
getFieldName
public final java.lang.String getFieldName()
Description copied from interface:FieldDescriptorReturns the name of the field. The field must have a name, even if set through accessor methods.- Specified by:
getFieldNamein interfaceFieldDescriptor- Returns:
- Field name.
- See Also:
FieldDescriptor.getFieldName()
-
setFieldType
public final void setFieldType(java.lang.Class<?> fieldType)
Set the type of the field.- Parameters:
fieldType- Field type.
-
getFieldType
public final java.lang.Class<?> getFieldType()
Description copied from interface:FieldDescriptorReturns the Java type of the field.- Specified by:
getFieldTypein interfaceFieldDescriptor- Returns:
- Field type.
- See Also:
FieldDescriptor.getFieldType()
-
setClassDescriptor
public final void setClassDescriptor(ClassDescriptor classDescriptor)
Set the ClassDescriptor for the described field.- Parameters:
classDescriptor- The ClassDescriptor for the described field.
-
getClassDescriptor
public final ClassDescriptor getClassDescriptor()
Description copied from interface:FieldDescriptorReturns the class descriptor related to the field type. If the field type is a class for which a descriptor exists, this descriptor is returned. If the field type is a class for which no mapping is provided, null is returned.- Specified by:
getClassDescriptorin interfaceFieldDescriptor- Returns:
- The class descriptor of the field type, or null.
- See Also:
FieldDescriptor.getClassDescriptor()
-
setHandler
public final void setHandler(FieldHandler handler)
Set the FieldHandler for the field being described by this FieldDescriptor.- Parameters:
handler- The FieldHandler for the field being described.
-
getHandler
public final FieldHandler getHandler()
Description copied from interface:FieldDescriptorReturns the handler of the field. In order to persist or marshal a field descriptor will be associated with a handler.- Specified by:
getHandlerin interfaceFieldDescriptor- Returns:
- The field handler.
- See Also:
FieldDescriptor.getHandler()
-
setTransient
public final void setTransient(boolean isTransient)
Sets whether or not the describled field is 'transient'.- Parameters:
isTransient- The flag indicating if the described field is 'transient'.
-
isTransient
public final boolean isTransient()
Description copied from interface:FieldDescriptorReturns true if the field is transient. Transient fields are never persisted or marshalled.- Specified by:
isTransientin interfaceFieldDescriptor- Returns:
- True if transient field.
- See Also:
FieldDescriptor.isTransient()
-
setImmutable
public final void setImmutable(boolean immutable)
Set the immutable flag which indicates that changes to this Field result in a new Object to be created, such as java.lang.String. It serves to identify fields which should not be constructed until all the data is available.- Parameters:
immutable- Flag which if true indicates that the field is immutable.
-
isImmutable
public final boolean isImmutable()
Description copied from interface:FieldDescriptorReturns true if the field type is immutable.- Specified by:
isImmutablein interfaceFieldDescriptor- Returns:
- True if the field type is immutable.
- See Also:
FieldDescriptor.isImmutable()
-
setRequired
public final void setRequired(boolean required)
Set whether or not the described field is required.- Parameters:
required- The flag indicating whether or not the described field is required.
-
isRequired
public final boolean isRequired()
Description copied from interface:FieldDescriptorReturns true if the field type is required.- Specified by:
isRequiredin interfaceFieldDescriptor- Returns:
- True if the field type is required.
- See Also:
FieldDescriptor.isRequired()
-
setMultivalued
public final void setMultivalued(boolean multivalued)
Set wheter the object described by this descriptor is multivalued or not.- Parameters:
multivalued- True if the object described by this descriptor is multivalued.
-
isMultivalued
public final boolean isMultivalued()
Description copied from interface:FieldDescriptorReturns true if the field is multivalued (a collection).- Specified by:
isMultivaluedin interfaceFieldDescriptor- Returns:
- True if the field is multivalued.
- See Also:
FieldDescriptor.isMultivalued()
-
setIdentity
public final void setIdentity(boolean identity)
Set wether the described field is part of the identity of the class it belongs to.- Parameters:
identity-trueif field is part of the classes identity.
-
isIdentity
public final boolean isIdentity()
Is the described field is part of the identity of the class it belongs to?- Returns:
trueif field is part of the classes identity.
-
getProperty
public java.lang.Object getProperty(java.lang.String name)
Description copied from interface:PropertyHolderGet a property by its name.- Specified by:
getPropertyin interfacePropertyHolder- Parameters:
name- of the property- Returns:
- value of the property
-
setProperty
public void setProperty(java.lang.String name, java.lang.Object value)Description copied from interface:PropertyHolderSet a property specified by the name to the passed value.- Specified by:
setPropertyin interfacePropertyHolder- Parameters:
name- of the propertyvalue- of the property
-
addNature
public void addNature(java.lang.String nature)
Description copied from interface:NatureExtendableAdds a specified nature.- Specified by:
addNaturein interfaceNatureExtendable- Parameters:
nature- ID of the Nature
-
hasNature
public boolean hasNature(java.lang.String nature)
Description copied from interface:NatureExtendableChecks if a specified nature has been added.- Specified by:
hasNaturein interfaceNatureExtendable- Parameters:
nature- ID of the Nature- Returns:
- true if the Nature ID was added.
-
getComparator
public java.lang.String getComparator()
-
setComparator
public void setComparator(java.lang.String comparator)
-
getCollection
public FieldMappingCollectionType getCollection()
-
setCollection
public void setCollection(FieldMappingCollectionType collection)
-
isDirect
public boolean isDirect()
-
setDirect
public void setDirect(boolean direct)
-
getGetMethod
public java.lang.String getGetMethod()
-
setGetMethod
public void setGetMethod(java.lang.String getMethod)
-
getSetMethod
public java.lang.String getSetMethod()
-
setSetMethod
public void setSetMethod(java.lang.String setMethod)
-
getCreateMethod
public java.lang.String getCreateMethod()
-
setCreateMethod
public void setCreateMethod(java.lang.String createMethod)
-
isLazy
public boolean isLazy()
-
setLazy
public void setLazy(boolean lazy)
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
-