Package org.apache.openjpa.kernel
Interface OpenJPAStateManager
- All Superinterfaces:
- FieldConsumer,- FieldManager,- FieldSupplier,- StateManager
- All Known Implementing Classes:
- DetachedStateManager,- DetachedValueStateManager,- ObjectIdStateManager,- StateManagerImpl
Interface implemented by OpenJPA state managers. Each state manager
 manages the state of a single persistence capable instance. The
 state manager is also responsible for all communications about the
 instance to the 
StoreManager.
  The fetchXXXField and storeXXXField
 methods can be used to get and set fields of the managed persistent object.
 Most back-end code, however, should use the similar
 fetchXXX and storeXXX methods in place of
 the field methods. These methods function just like the field methods, but
 also pass the value through the externalizer and factory the field may have.- Author:
- Abe White
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intThe field is being attached by a detached state manager; the value is from the detached instance.static final intThe remote broker framework is setting the field on the server.static final intA user is setting the field.
- 
Method SummaryModifier and TypeMethodDescriptionbooleanassignObjectId(boolean flush) Ask the store manager to assign a permanent oid to this new instance.booleanbeforeRefresh(boolean refreshAll) Prepare the instance for refreshvoiddirty(int field) Mark the given field as dirty.fetch(int field) Return the externalized value of the field with the given index as an object.booleanfetchBoolean(int field) Return the external value of the given field.bytefetchByte(int field) Return the external value of the given field.charfetchChar(int field) Return the external value of the given field.doublefetchDouble(int field) Return the external value of the given field.fetchField(int field, boolean transitions) Return the value of the field with the given index as an object.floatfetchFloat(int field) Return the external value of the given field.fetchInitialField(int field) Return the value of the field at the specified index as of the beginning of the transaction.intfetchInt(int field) Return the external value of the given field.longfetchLong(int field) Return the external value of the given field.fetchObject(int field) Return the external value of the given field.fetchObjectField(int field) Fetch an object field by index.shortfetchShort(int field) Return the external value of the given field.fetchString(int field) Return the external value of the given field.Return the managing context.getDirty()Return a read-only mask of the indexes of all dirty fields.Return a read-only mask of the indexes of all fields that have been flushed since they were last changed.getId()Return the identifier for this state manager.An object that concrete back ends can associate with each instance.getImplData(int field) Field-level impl data.getIntermediate(int field) Use intermediate field data to store intermediate information that might be available before the field is fully loaded.Return a read-only mask of the indexes of all loaded fields.getLock()The lock object set for this instance.Return the managed instance.Get the metadata for this instance.Return the instance's object id.getOwner()Return the owning state if this is an embedded instance.intReturn the owning value's field indexReturn the state that this object is in.Return thePersistenceCapableinstance that provides access to the instance managed by this state manager.getUnloaded(FetchConfiguration fetch) Return a mutable mask of the unloaded fields that need loading based on the given fetch configuration.Return the current version indicator for this instance.voidinitialize(Class forType, PCState state) Initialize the state manager with a new instance of the given persistence capable type and the proper lifecycle state.booleanisDefaultValue(int field) Return true if the given field has a default value.booleanisDelayed(int field) Some field types (collection proxies) support delayed loading.booleanReturn true if this instance has an owner, meaning it is an embedded value.booleanReturn whether this object has been flushed to the datastore in this transaction.booleanReturn whether this object has been flushed, then dirtied again.booleanWhether the instance-level impl data can be shared among instances in different contexts if L2 caching is enabled.booleanisImplDataCacheable(int field) Whether the field's impl data is loaded and can be shared among instances in different contexts if L2 caching is enabled.booleanReturn whether this object is provisionally persistent.booleanReturns true if this state needs to issue a version check at flush time.booleanReturns true if this state needs to issue a version update, possibly as a result of being locked.voidload(FetchConfiguration fetch) Load fetch group fields.voidloadDelayedField(int field) If a field was marked delayed in a previous load operation this method can be used to load the field.newFieldProxy(int field) Create a new hollow proxy instance for the given field.newProxy(int field) Create a new hollow proxy instance for the given field.voidNotification that an element has been removed from the given field.voidsetDelayed(int field, boolean delay) Some field types (collection proxies) support delayed loading.setImplData(int field, Object data) Field-level impl data.setImplData(Object data, boolean cacheable) An object that concrete back ends can associate with each instance.voidsetIntermediate(int field, Object value) Use intermediate field data to store intermediate information that might be available before the field is fully loaded.voidThe lock object set for this instance.voidsetNextVersion(Object version) Set the next version indicator in the datastore pending a successful flush.voidsetObjectId(Object oid) Set the object id for the managed instance.voidSet the given field to the given value.voidsetVersion(Object version) Set the version indicator for this instance, as loaded from the data store.voidSet the value of the field with the given index as from the external object value.voidstoreBoolean(int field, boolean externalVal) Set the given external value back into the given field.voidstoreByte(int field, byte externalVal) Set the given external value back into the given field.voidstoreChar(int field, char externalVal) Set the given external value back into the given field.voidstoreDouble(int field, double externalVal) Set the given external value back into the given field.voidstoreField(int field, Object value) Set the value of the field with the given index as an object.voidstoreFloat(int field, float externalVal) Set the given external value back into the given field.voidstoreInt(int field, int externalVal) Set the given external value back into the given field.voidstoreLong(int field, long externalVal) Set the given external value back into the given field.voidstoreObject(int field, Object externalVal) Set the given external value back into the given field.voidstoreShort(int field, short externalVal) Set the given external value back into the given field.voidstoreString(int field, String externalVal) Set the given external value back into the given field.Methods inherited from interface org.apache.openjpa.enhance.FieldConsumerstoreBooleanField, storeByteField, storeCharField, storeDoubleField, storeFloatField, storeIntField, storeLongField, storeObjectField, storeShortField, storeStringFieldMethods inherited from interface org.apache.openjpa.enhance.FieldSupplierfetchBooleanField, fetchByteField, fetchCharField, fetchDoubleField, fetchFloatField, fetchIntField, fetchLongField, fetchShortField, fetchStringFieldMethods inherited from interface org.apache.openjpa.enhance.StateManageraccessingField, dirty, fetchObjectId, getGenericContext, getPCPrimaryKey, isDeleted, isDetached, isDirty, isNew, isPersistent, isTransactional, providedBooleanField, providedByteField, providedCharField, providedDoubleField, providedFloatField, providedIntField, providedLongField, providedObjectField, providedShortField, providedStringField, proxyDetachedDeserialized, replaceBooleanField, replaceByteField, replaceCharField, replaceDoubleField, replaceFloatField, replaceIntField, replaceLongField, replaceObjectField, replaceShortField, replaceStateManager, replaceStringField, serializing, settingBooleanField, settingByteField, settingCharField, settingDoubleField, settingFloatField, settingIntField, settingLongField, settingObjectField, settingShortField, settingStringField, writeDetached
- 
Field Details- 
SET_USERstatic final int SET_USERA user is setting the field.- See Also:
 
- 
SET_REMOTEstatic final int SET_REMOTEThe remote broker framework is setting the field on the server.- See Also:
 
- 
SET_ATTACHstatic final int SET_ATTACHThe field is being attached by a detached state manager; the value is from the detached instance.- See Also:
 
 
- 
- 
Method Details- 
initializeInitialize the state manager with a new instance of the given persistence capable type and the proper lifecycle state. Invoking this method may change the object id and metadata for the state manager, as the concrete type specified in the parameter may be a subclass of the expected type.- Parameters:
- forType- the type for which to create a new instance
- state- the initial state to which to set the instance
- Since:
- 0.3.1.2
 
- 
loadLoad fetch group fields.
- 
getManagedInstanceObject getManagedInstance()Return the managed instance.
- 
getPersistenceCapablePersistenceCapable getPersistenceCapable()Return thePersistenceCapableinstance that provides access to the instance managed by this state manager. May be a proxy around the actual managed instance.
- 
getMetaDataClassMetaData getMetaData()Get the metadata for this instance.
- 
getOwnerOpenJPAStateManager getOwner()Return the owning state if this is an embedded instance.
- 
getOwnerIndexint getOwnerIndex()Return the owning value's field index- Since:
- 1.1.0
 
- 
isEmbeddedboolean isEmbedded()Return true if this instance has an owner, meaning it is an embedded value.
- 
isFlushedboolean isFlushed()Return whether this object has been flushed to the datastore in this transaction.
- 
isFlushedDirtyboolean isFlushedDirty()Return whether this object has been flushed, then dirtied again.
- 
isProvisionalboolean isProvisional()Return whether this object is provisionally persistent.
- 
getLoadedBitSet getLoaded()Return a read-only mask of the indexes of all loaded fields.
- 
getDirtyBitSet getDirty()Return a read-only mask of the indexes of all dirty fields.
- 
getFlushedBitSet getFlushed()Return a read-only mask of the indexes of all fields that have been flushed since they were last changed.
- 
getUnloadedReturn a mutable mask of the unloaded fields that need loading based on the given fetch configuration. Pass in null to retrieve all unloaded fields.
- 
newProxyCreate a new hollow proxy instance for the given field. In cases where the field externalizes to an SCO but is declared something else, the returned object may not implementProxy. In all other cases, this method delegates to the systemProxyManagerwith the correct field information. The returned proxy's owner is unset so that modifications to the proxy will not be tracked while its state is initialized. CallingstoreField(int, java.lang.Object)orstore(int, java.lang.Object)will set the proxy's owner automatically.
- 
newFieldProxyCreate a new hollow proxy instance for the given field. This method differs fromnewProxy(int)in that it returns a proxy for the field's declared type, not its externalized type.- See Also:
 
- 
isDefaultValueboolean isDefaultValue(int field) Return true if the given field has a default value.
- 
getContextStoreContext getContext()Return the managing context.
- 
getPCStatePCState getPCState()Return the state that this object is in.
- 
getIdObject getId()Return the identifier for this state manager. This may return a temporary identifier for new unflushed instances that have not been assigned an object id, or for non-persistent or embedded instances. For all other instances this method is the same asgetObjectId().
- 
getObjectIdObject getObjectId()Return the instance's object id. This method will return null if no oid has been assigned. Oids are assigned to newly-persisted instances when the user first asks for it, or on flush.
- 
setObjectIdSet the object id for the managed instance. Some back ends may not be able to assign a permanent oid until flush. Do not call this method on application identity instances; changing the primary key fields of application identity objects through thestoreXXXFieldmethods will automatically change the oid.
- 
assignObjectIdboolean assignObjectId(boolean flush) Ask the store manager to assign a permanent oid to this new instance.- Parameters:
- flush- if true, flush if necessary to get a permanent oid; if false, the oid may be left unassigned
- Returns:
- true if an oid assigned, false otherwise
 
- 
getLockObject getLock()The lock object set for this instance. This object is generally managed by the system lock manager.
- 
setLockThe lock object set for this instance. This object is generally managed by the system lock manager.
- 
getVersionObject getVersion()Return the current version indicator for this instance.- Specified by:
- getVersionin interface- StateManager
 
- 
setVersionSet the version indicator for this instance, as loaded from the data store. This method is used by theStoreManagerwhen loading instance data. On rollback, the version will be rolled back to this value. Version objects should be serializable and should not require vendor-specific classes, because they are transferred to detached objects.
- 
setNextVersionSet the next version indicator in the datastore pending a successful flush. TheStoreManageruses this method during flush.
- 
isVersionUpdateRequiredboolean isVersionUpdateRequired()Returns true if this state needs to issue a version update, possibly as a result of being locked.
- 
isVersionCheckRequiredboolean isVersionCheckRequired()Returns true if this state needs to issue a version check at flush time.
- 
getImplDataObject getImplData()An object that concrete back ends can associate with each instance. This object is not used or modified in any way by the generic persistence layer.
- 
setImplDataAn object that concrete back ends can associate with each instance. This object is not used or modified in any way by the generic persistence layer.- Parameters:
- cacheable- whether the impl data can be shared among instances in different contexts if L2 caching is enabled
- Returns:
- the previous impl data value, if any
 
- 
isImplDataCacheableboolean isImplDataCacheable()Whether the instance-level impl data can be shared among instances in different contexts if L2 caching is enabled.
- 
getImplDataField-level impl data. Field-level data only applies to loaded fields, and is cleared when the field is cleared.
- 
setImplDataField-level impl data. Field-level data only applies to loaded fields, and is cleared when the field is cleared. Whether the data is cached across instances depends on the corresponding field metadata's response toFieldMetaData.usesImplData().- Returns:
- the previous impl data value, if any
 
- 
isImplDataCacheableboolean isImplDataCacheable(int field) Whether the field's impl data is loaded and can be shared among instances in different contexts if L2 caching is enabled.
- 
getIntermediateUse intermediate field data to store intermediate information that might be available before the field is fully loaded. The system will automatically clear this data when the field gets loaded. This data should be cacheable; the datastore cache will attempt to cache it if the field value is not available.
- 
setIntermediateUse intermediate field data to store intermediate information that might be available before the field is fully loaded. The system will automatically clear this data when the field gets loaded. This data should be cacheable; the datastore cache will attempt to cache it if the field value is not available.
- 
fetchBooleanboolean fetchBoolean(int field) Return the external value of the given field.
- 
fetchBytebyte fetchByte(int field) Return the external value of the given field.
- 
fetchCharchar fetchChar(int field) Return the external value of the given field.
- 
fetchDoubledouble fetchDouble(int field) Return the external value of the given field.
- 
fetchFloatfloat fetchFloat(int field) Return the external value of the given field.
- 
fetchIntint fetchInt(int field) Return the external value of the given field.
- 
fetchLonglong fetchLong(int field) Return the external value of the given field.
- 
fetchObjectReturn the external value of the given field.
- 
fetchShortshort fetchShort(int field) Return the external value of the given field.
- 
fetchStringReturn the external value of the given field.
- 
fetchReturn the externalized value of the field with the given index as an object. If there is no externalizer, this is equivalent tofetchField(int, boolean).
- 
fetchFieldReturn the value of the field with the given index as an object.- Parameters:
- transitions- if true, this method will cause state transitions to occur as if the field were accessed normally
 
- 
fetchInitialFieldReturn the value of the field at the specified index as of the beginning of the transaction.- Since:
- 0.3.1.1
 
- 
storeBooleanvoid storeBoolean(int field, boolean externalVal) Set the given external value back into the given field.
- 
storeBytevoid storeByte(int field, byte externalVal) Set the given external value back into the given field.
- 
storeCharvoid storeChar(int field, char externalVal) Set the given external value back into the given field.
- 
storeDoublevoid storeDouble(int field, double externalVal) Set the given external value back into the given field.
- 
storeFloatvoid storeFloat(int field, float externalVal) Set the given external value back into the given field.
- 
storeIntvoid storeInt(int field, int externalVal) Set the given external value back into the given field.
- 
storeLongvoid storeLong(int field, long externalVal) Set the given external value back into the given field.
- 
storeObjectSet the given external value back into the given field.
- 
storeShortvoid storeShort(int field, short externalVal) Set the given external value back into the given field.
- 
storeStringSet the given external value back into the given field.
- 
storeSet the value of the field with the given index as from the external object value. If there is no externalizer, this is equivalent tostoreField(int, java.lang.Object).
- 
storeFieldSet the value of the field with the given index as an object.
- 
dirtyvoid dirty(int field) Mark the given field as dirty.
- 
removedNotification that an element has been removed from the given field.
- 
beforeRefreshboolean beforeRefresh(boolean refreshAll) Prepare the instance for refresh- Parameters:
- refreshAll- true if this instance is one of a collection of objects being refreshed
- Returns:
- true if the object needs a refresh, false otherwise
- See Also:
 
- 
setRemoteSet the given field to the given value. Make the field dirty as if user code set it. Do not delete dependent objects in the field's current value. This method is invoked by the remote package to synch a server-side state manager with remote changes. We do not need to delete dependent instances because they will have been deleted when the field changed on the client side, and those client-side deletes will be transmitted independently.- Since:
- 0.3.1
 
- 
isDelayedboolean isDelayed(int field) Some field types (collection proxies) support delayed loading. Delayed loading is a step beyond lazy loading. Delayed load allows an instance of a field to be returned without actually loading it.- Returns:
- true if the field is setup for delayed access
 
- 
setDelayedvoid setDelayed(int field, boolean delay) Some field types (collection proxies) support delayed loading. Delayed loading is a step beyond lazy loading. Delayed load allows an instance of a field to be returned without actually loading it.
- 
loadDelayedFieldvoid loadDelayedField(int field) If a field was marked delayed in a previous load operation this method can be used to load the field.
- 
fetchObjectFieldFetch an object field by index.- Specified by:
- fetchObjectFieldin interface- FieldSupplier
 
 
-