Package net.ontopia.persistence.proxy
Class AbstractLocalCache
- java.lang.Object
-
- net.ontopia.persistence.proxy.AbstractLocalCache
-
- All Implemented Interfaces:
AccessRegistrarIF,StorageCacheIF
- Direct Known Subclasses:
ROLocalCache,RWLocalCache
public abstract class AbstractLocalCache extends Object implements StorageCacheIF, AccessRegistrarIF
INTERNAL: A transactional storage cache implementation. The cache uses the transaction to lookup objects and relies on the fact that PersistentIFs can store their own data.
-
-
Field Summary
Fields Modifier and Type Field Description protected StorageCacheIFpcacheprotected AccessRegistrarIFpregistrarprotected TicketIFticketprotected AbstractTransactiontxn
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidclear(boolean notifyCluster)INTERNAL: Clears the cache.voidclose()INTERNAL: Releases all resources used by the storage cache.IdentityIFcreateIdentity(Class<?> type, long key)INTERNAL: Factory method for creating new identity objects.IdentityIFcreateIdentity(Class<?> type, Object key)INTERNAL: Factory method for creating new identity objects.IdentityIFcreateIdentity(Class<?> type, Object[] keys)INTERNAL: Factory method for creating new identity objects.voidevictField(IdentityIF identity, int field, boolean notifyCluster)INTERNAL: Evict the identity's field value from the cache.voidevictFields(IdentityIF identity, boolean notifyCluster)INTERNAL: Evict all the identity's field values from the cache.voidevictIdentity(IdentityIF identity, boolean notifyCluster)INTERNAL: Evict the identity from the cache.abstract booleanexists(StorageAccessIF access, IdentityIF identity)INTERNAL: Can be called to verify whether the specified identity exists in the cache or in the data repository.AccessRegistrarIFgetRegistrar()INTERNAL: Returns the access registrar instance that is used by the storage cache.TicketIFgetTicket()INTERNAL: Get ticket that should be used as first argument to register methods.abstract ObjectgetValue(StorageAccessIF access, IdentityIF identity, int field)INTERNAL: A call forwarded by the transaction (TransactionIF) from persistent objects (PersistentIF) when the field value needs to be retrieved from storage.booleanisFieldLoaded(IdentityIF identity, int field)INTERNAL: Can be called to check if the specfied field has been registered with the cache.booleanisObjectLoaded(IdentityIF identity)INTERNAL: Can be called to check if the identity has been registered with the cache.intprefetch(StorageAccessIF access, Class<?> type, int field, int nextField, boolean traverse, Collection<IdentityIF> identities)voidregisterEviction()INTERNAL: Tells the cache that eviction is starting.voidregisterField(TicketIF ticket, IdentityIF identity, int field, Object value)INTERNAL: Called by storage accessors (FieldAccessIF) when they read the value of an object field from the database.voidregisterIdentity(TicketIF ticket, IdentityIF identity)INTERNAL: Called by storage accessors (QueryIFs or FieldAccessIF) when they locate the identity of an object in the database.voidreleaseEviction()INTERNAL: Deregister eviction.
-
-
-
Field Detail
-
txn
protected AbstractTransaction txn
-
pcache
protected StorageCacheIF pcache
-
pregistrar
protected AccessRegistrarIF pregistrar
-
ticket
protected TicketIF ticket
-
-
Method Detail
-
getRegistrar
public AccessRegistrarIF getRegistrar()
Description copied from interface:StorageCacheIFINTERNAL: Returns the access registrar instance that is used by the storage cache. If it does not need an access registrar, or it does not have one, null is returned.- Specified by:
getRegistrarin interfaceStorageCacheIF
-
close
public void close()
Description copied from interface:StorageCacheIFINTERNAL: Releases all resources used by the storage cache.- Specified by:
closein interfaceStorageCacheIF
-
exists
public abstract boolean exists(StorageAccessIF access, IdentityIF identity)
Description copied from interface:StorageCacheIFINTERNAL: Can be called to verify whether the specified identity exists in the cache or in the data repository. Whether the data repository is actually asked depends on the policy of the storage cache.- Specified by:
existsin interfaceStorageCacheIF
-
getValue
public abstract Object getValue(StorageAccessIF access, IdentityIF identity, int field)
Description copied from interface:StorageCacheIFINTERNAL: A call forwarded by the transaction (TransactionIF) from persistent objects (PersistentIF) when the field value needs to be retrieved from storage. The field value will be returned.- Specified by:
getValuein interfaceStorageCacheIF
-
isObjectLoaded
public boolean isObjectLoaded(IdentityIF identity)
Description copied from interface:StorageCacheIFINTERNAL: Can be called to check if the identity has been registered with the cache. The data repository will not be asked.- Specified by:
isObjectLoadedin interfaceStorageCacheIF
-
isFieldLoaded
public boolean isFieldLoaded(IdentityIF identity, int field)
Description copied from interface:StorageCacheIFINTERNAL: Can be called to check if the specfied field has been registered with the cache. The data repository will not be asked.- Specified by:
isFieldLoadedin interfaceStorageCacheIF
-
registerEviction
public void registerEviction()
Description copied from interface:StorageCacheIFINTERNAL: Tells the cache that eviction is starting.- Specified by:
registerEvictionin interfaceStorageCacheIF
-
releaseEviction
public void releaseEviction()
Description copied from interface:StorageCacheIFINTERNAL: Deregister eviction.- Specified by:
releaseEvictionin interfaceStorageCacheIF
-
evictIdentity
public void evictIdentity(IdentityIF identity, boolean notifyCluster)
Description copied from interface:StorageCacheIFINTERNAL: Evict the identity from the cache.- Specified by:
evictIdentityin interfaceStorageCacheIF
-
evictFields
public void evictFields(IdentityIF identity, boolean notifyCluster)
Description copied from interface:StorageCacheIFINTERNAL: Evict all the identity's field values from the cache.- Specified by:
evictFieldsin interfaceStorageCacheIF
-
evictField
public void evictField(IdentityIF identity, int field, boolean notifyCluster)
Description copied from interface:StorageCacheIFINTERNAL: Evict the identity's field value from the cache.- Specified by:
evictFieldin interfaceStorageCacheIF
-
clear
public void clear(boolean notifyCluster)
Description copied from interface:StorageCacheIFINTERNAL: Clears the cache.- Specified by:
clearin interfaceStorageCacheIF
-
prefetch
public int prefetch(StorageAccessIF access, Class<?> type, int field, int nextField, boolean traverse, Collection<IdentityIF> identities)
- Specified by:
prefetchin interfaceStorageCacheIF
-
createIdentity
public IdentityIF createIdentity(Class<?> type, long key)
Description copied from interface:AccessRegistrarIFINTERNAL: Factory method for creating new identity objects. Key is guaranteed to have a width of 1 and key value which a Long.- Specified by:
createIdentityin interfaceAccessRegistrarIF
-
createIdentity
public IdentityIF createIdentity(Class<?> type, Object key)
Description copied from interface:AccessRegistrarIFINTERNAL: Factory method for creating new identity objects. Key is guaranteed to have a width of 1.- Specified by:
createIdentityin interfaceAccessRegistrarIF
-
createIdentity
public IdentityIF createIdentity(Class<?> type, Object[] keys)
Description copied from interface:AccessRegistrarIFINTERNAL: Factory method for creating new identity objects. Key can have any width.- Specified by:
createIdentityin interfaceAccessRegistrarIF
-
getTicket
public TicketIF getTicket()
Description copied from interface:AccessRegistrarIFINTERNAL: Get ticket that should be used as first argument to register methods. The ticket is used figure out if value should be registered or not.- Specified by:
getTicketin interfaceAccessRegistrarIF
-
registerIdentity
public void registerIdentity(TicketIF ticket, IdentityIF identity)
Description copied from interface:AccessRegistrarIFINTERNAL: Called by storage accessors (QueryIFs or FieldAccessIF) when they locate the identity of an object in the database.- Specified by:
registerIdentityin interfaceAccessRegistrarIF
-
registerField
public void registerField(TicketIF ticket, IdentityIF identity, int field, Object value)
Description copied from interface:AccessRegistrarIFINTERNAL: Called by storage accessors (FieldAccessIF) when they read the value of an object field from the database.- Specified by:
registerFieldin interfaceAccessRegistrarIF
-
-