Package org.apache.cayenne.reflect
Interface ClassDescriptor
- 
- All Known Implementing Classes:
- LazyClassDescriptorDecorator,- PersistentDescriptor
 
 public interface ClassDescriptorA runtime descriptor of an persistent class.- Since:
- 1.2
 
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description ObjectcreateObject()Creates a new instance of a class described by this object.Map<String,DbEntity>getAdditionalDbEntities()Returns information about additional db entities that is used for this ObjEntity (i.e.PropertyDescriptorgetDeclaredProperty(String propertyName)Returns a Java Bean property descriptor matching property name or null if no such property is found.Collection<ObjAttribute>getDiscriminatorColumns()Returns a collection of ObjAttribute for the described class, its superclasses and subclasses, that participate in inheritance qualifier.ObjEntitygetEntity()Returns an ObjEntity associated with this descriptor.EntityInheritanceTreegetEntityInheritanceTree()ExpressiongetEntityQualifier()Returns entity qualifier as a Cayenne expression that includes qualifiers for this entity and all subentities.Collection<AttributeProperty>getIdProperties()Returns a collection of the properties mapped to id columns.Collection<ArcProperty>getMapArcProperties()Returns a collection over the arc properties whose reverse arcs are to-many maps.Class<?>getObjectClass()Returns a class mapped by this descriptor.PropertyDescriptorgetProperty(String propertyName)Returns a property descriptor matching property name, or null if no such property is found.Collection<DbEntity>getRootDbEntities()Returns a collection of DbEntities that are the root tables for this descriptor's ObjEntity.ClassDescriptorgetSubclassDescriptor(Class<?> objectClass)Returns the most "specialized" descriptor for a given class.ClassDescriptorgetSuperclassDescriptor()Returns a descriptor of the mapped superclass or null if the descriptor's entity sits at the top of inheritance hierarchy or no inheritance is mapped.booleanhasSubclasses()Returns whether this class has persistent subclasses.voidinjectValueHolders(Object object)Prepares object properties for access.booleanisFault(Object object)Returns true if an object is not fully resolved.voidshallowMerge(Object from, Object to)Merges object properties from one object to another, avoiding traversal of the ArcProperties.booleanvisitAllProperties(PropertyVisitor visitor)Passes the visitor to the properties "visit" method for a combination of all properties, including properties declared in this descriptor, its super descriptors, and all subdescriptors.booleanvisitDeclaredProperties(PropertyVisitor visitor)Passes the visitor to the properties "visit" method for all properties declared in this descriptor.booleanvisitProperties(PropertyVisitor visitor)Passes the visitor to the properties "visit" method for all properties declared in this descriptor and all its super-decsriptors.
 
- 
- 
- 
Method Detail- 
getEntityObjEntity getEntity() Returns an ObjEntity associated with this descriptor.- Since:
- 3.0
 
 - 
getRootDbEntitiesCollection<DbEntity> getRootDbEntities() Returns a collection of DbEntities that are the root tables for this descriptor's ObjEntity. Usually such collection would contain only one entity, however in cases involving subclass horizontal inheritance, it will be more than one, and in cases of abstract entities with no subclasses, the collection will be empty.- Since:
- 3.0
 
 - 
getAdditionalDbEntitiesMap<String,DbEntity> getAdditionalDbEntities() Returns information about additional db entities that is used for this ObjEntity (i.e. for flattened attributes).Keys are full paths for corresponding flattened attributes. - Returns:
- information about additional db entities
- Since:
- 4.1
 
 - 
getEntityInheritanceTreeEntityInheritanceTree getEntityInheritanceTree() - Since:
- 3.0
 
 - 
hasSubclassesboolean hasSubclasses() Returns whether this class has persistent subclasses.- Since:
- 3.1
 
 - 
getObjectClassClass<?> getObjectClass() Returns a class mapped by this descriptor.
 - 
getSuperclassDescriptorClassDescriptor getSuperclassDescriptor() Returns a descriptor of the mapped superclass or null if the descriptor's entity sits at the top of inheritance hierarchy or no inheritance is mapped.
 - 
getSubclassDescriptorClassDescriptor getSubclassDescriptor(Class<?> objectClass) Returns the most "specialized" descriptor for a given class. This method assumes that the following is true:this.getObjectClass().isAssignableFrom(objectClass) 
 - 
createObjectObject createObject() Creates a new instance of a class described by this object.
 - 
injectValueHoldersvoid injectValueHolders(Object object) throws PropertyException Prepares object properties for access. This may include injection of value holders into the object and such.- Throws:
- PropertyException
 
 - 
shallowMergevoid shallowMerge(Object from, Object to) throws PropertyException Merges object properties from one object to another, avoiding traversal of the ArcProperties.- Throws:
- PropertyException
 
 - 
getPropertyPropertyDescriptor getProperty(String propertyName) Returns a property descriptor matching property name, or null if no such property is found. Lookup includes properties from this descriptor and all its superclass descriptors. Returned property can be any one ofAttributeProperty,ToManyProperty,ToOneProperty.
 - 
getDeclaredPropertyPropertyDescriptor getDeclaredProperty(String propertyName) Returns a Java Bean property descriptor matching property name or null if no such property is found. Lookup DOES NOT including properties from the superclass descriptors. Returned property can be any one ofAttributeProperty,ToManyProperty,ToOneProperty.
 - 
getIdPropertiesCollection<AttributeProperty> getIdProperties() Returns a collection of the properties mapped to id columns.- Since:
- 3.1
 
 - 
getDiscriminatorColumnsCollection<ObjAttribute> getDiscriminatorColumns() Returns a collection of ObjAttribute for the described class, its superclasses and subclasses, that participate in inheritance qualifier. If a discriminator expression specifies a DbAttribute instead of an ObjAttribute, a synthetic ObjAttribute is created and returned.- Since:
- 3.1
 
 - 
getEntityQualifierExpression getEntityQualifier() Returns entity qualifier as a Cayenne expression that includes qualifiers for this entity and all subentities.- Since:
- 3.0
 
 - 
getMapArcPropertiesCollection<ArcProperty> getMapArcProperties() Returns a collection over the arc properties whose reverse arcs are to-many maps. I.e. for each ArcProperty in returned collection, the following is true:arc.getComplimentaryReverseArc() instanceof ToManyMapProperty - Since:
- 3.1
 
 - 
visitPropertiesboolean visitProperties(PropertyVisitor visitor) Passes the visitor to the properties "visit" method for all properties declared in this descriptor and all its super-decsriptors. Properties that are overridden in subdescriptors will include overridden information. Walkthrough is terminated in case one of the properties returns false. Returns true if all visited properties returned true, false - if one property returned false.
 - 
visitDeclaredPropertiesboolean visitDeclaredProperties(PropertyVisitor visitor) Passes the visitor to the properties "visit" method for all properties declared in this descriptor. This property set excludes inherited properties, even those that got overridden in this subclass. Walkthrough is terminated in case one of the properties returns false. Returns true if all visited properties returned true, false - if one property returned false.- Since:
- 3.0
 
 - 
visitAllPropertiesboolean visitAllProperties(PropertyVisitor visitor) Passes the visitor to the properties "visit" method for a combination of all properties, including properties declared in this descriptor, its super descriptors, and all subdescriptors. Walkthrough is terminated in case one of the properties returns false. Returns true if all visited properties returned true, false - if one property returned false.- Since:
- 3.0
 
 - 
isFaultboolean isFault(Object object) Returns true if an object is not fully resolved.
 
- 
 
-