Interface CDORevisionManager
- All Superinterfaces:
- org.eclipse.net4j.util.event.INotifier
- All Known Subinterfaces:
- InternalCDORevisionManager
- All Known Implementing Classes:
- DelegatingCDORevisionManager
revisions in a CDO repository by demand loading
 and caching them.
 Revisions are generally queried by:
 If querying by timestamp it's also possible to ask for multiple revisions (identified by a list of object IDs) in one
 round trip (to the server if this revision manager is contained by a session or to the
 backend store if it is contained by a repository.
- Since:
- 3.0
- Author:
- Eike Stepper
- No Implement
- This interface is not intended to be implemented by clients.
- No Extend
- This interface is not intended to be extended by clients.
- 
Nested Class SummaryNested classes/interfaces inherited from interface org.eclipse.net4j.util.event.INotifierorg.eclipse.net4j.util.event.INotifier.INotifier2
- 
Method SummaryModifier and TypeMethodDescriptionbooleancontainsRevision(CDOID id, CDOBranchPoint branchPoint) Returnstrueif therevision cachecontains arevisionwith the givenIDat the givenbranch point(branch + timestamp),falseotherwise.booleancontainsRevisionByVersion(CDOID id, CDOBranchVersion branchVersion) Returnstrueif therevision cachecontains arevisionwith the givenIDat the givenbranch version(branch + version),falseotherwise.getObjectLifetime(CDOID id, CDOBranchPoint branchPoint) getObjectType(CDOID id) Returns thetypeof an object if a revision for that object is in the revision cache,nullotherwise.getObjectType(CDOID id, CDOBranchManager branchManagerForLoadOnDemand) Returns thetypeof an object.getRevision(CDOID id, CDOBranchPoint branchPoint, int referenceChunk, int prefetchDepth, boolean loadOnDemand) Returns therevisionwith the givenIDat the givenbranch point(branch + timestamp), optionally demand loading it if it is not already in thecache.getRevisionByVersion(CDOID id, CDOBranchVersion branchVersion, int referenceChunk, boolean loadOnDemand) Returns therevisionwith the givenIDat the givenbranch version(branch + version), optionally demand loading it if it is not already in thecache.getRevisions(List<CDOID> ids, CDOBranchPoint branchPoint, int referenceChunk, int prefetchDepth, boolean loadOnDemand) Returns therevisionswith the givenIDsat the givenbranch point(branch + timestamp), optionally demand loading them if they are not already in thecache.getRevisions(List<CDOID> ids, CDOBranchPoint branchPoint, int referenceChunk, int prefetchDepth, boolean loadOnDemand, List<CDORevision> additionalRevisions) Returns therevisionswith the givenIDsat the givenbranch point(branch + timestamp), optionally demand loading them if they are not already in thecache.voidhandleRevisions(EClass eClass, CDOBranch branch, boolean exactBranch, long timeStamp, boolean exactTime, CDORevisionHandler handler) Methods inherited from interface org.eclipse.net4j.util.event.INotifieraddListener, getListeners, hasListeners, removeListener
- 
Method Details- 
getObjectTypeReturns thetypeof an object if a revision for that object is in the revision cache,nullotherwise.Same as calling getObjectType(id, null).
- 
getObjectTypeReturns thetypeof an object.If no revision for that object is found in the revision cache the following is tried: - If branchManagerForLoadOnDemandis notnullthe first revision of the object in the main branch is loaded from the server and its type is returned.
- Otherwise (i.e., if branchManagerForLoadOnDemandisnullor the object does not exist)nullis returned.
 A branch manageris required instead of just a boolean value to specify whether to demand-load or not because this revision manager must be able to access themain branchwhile demand-loading.- Since:
- 4.1
- See Also:
 
- If 
- 
containsRevisionReturnstrueif therevision cachecontains arevisionwith the givenIDat the givenbranch point(branch + timestamp),falseotherwise.
- 
getRevisionCDORevision getRevision(CDOID id, CDOBranchPoint branchPoint, int referenceChunk, int prefetchDepth, boolean loadOnDemand) Returns therevisionwith the givenIDat the givenbranch point(branch + timestamp), optionally demand loading it if it is not already in thecache.- Parameters:
- referenceChunk- The number of target- IDsto load for each many-valued reference in the returned revision, or- CDORevision.UNCHUNKEDfor all such list elements (IDs).
- prefetchDepth- The number of nested containment levels to load revisions for in one round trip. Use the symbolic constants- CDORevision.DEPTH_INFINITEto prefetch all contained revisions or- CDORevision.DEPTH_NONEto not prefetch anything. Only the explicitly requested revision is returned by this method. If additional revisions are prefetched they are placed in the revision cache to speed up subsequent calls to this method.
- loadOnDemand- If the requested revision is not contained in the revision cache it depends on this parameter's value whether the revision is loaded from the server or- nullis returned.
- See Also:
 
- 
getRevisionsList<CDORevision> getRevisions(List<CDOID> ids, CDOBranchPoint branchPoint, int referenceChunk, int prefetchDepth, boolean loadOnDemand) Returns therevisionswith the givenIDsat the givenbranch point(branch + timestamp), optionally demand loading them if they are not already in thecache.- Parameters:
- referenceChunk- The number of target- IDsto load for each many-valued reference in the returned revisions, or- CDORevision.UNCHUNKEDfor all such list elements (IDs).
- prefetchDepth- The number of nested containment levels to load revisions for in one round trip. Use the symbolic constants- CDORevision.DEPTH_INFINITEto prefetch all contained revisions or- CDORevision.DEPTH_NONEto not prefetch anything. Only the explicitly requested revisions are returned by this method. If additional revisions are prefetched they are placed in the revision cache to speed up subsequent calls to this method.
- loadOnDemand- If one or more of the requested revisions is/are not contained in the revision cache it depends on this parameter's value whether the revision(s) is/are loaded from the server or- nullis placed in the list that is returned.
- See Also:
 
- 
getRevisionsList<CDORevision> getRevisions(List<CDOID> ids, CDOBranchPoint branchPoint, int referenceChunk, int prefetchDepth, boolean loadOnDemand, List<CDORevision> additionalRevisions) Returns therevisionswith the givenIDsat the givenbranch point(branch + timestamp), optionally demand loading them if they are not already in thecache.- Parameters:
- referenceChunk- The number of target- IDsto load for each many-valued reference in the returned revisions, or- CDORevision.UNCHUNKEDfor all such list elements (IDs).
- prefetchDepth- The number of nested containment levels to load revisions for in one round trip. Use the symbolic constants- CDORevision.DEPTH_INFINITEto prefetch all contained revisions or- CDORevision.DEPTH_NONEto not prefetch anything. Only the explicitly requested revisions are returned by this method. If additional revisions are prefetched they are placed in the revision cache to speed up subsequent calls to this method.
- loadOnDemand- If one or more of the requested revisions is/are not contained in the revision cache it depends on this parameter's value whether the revision(s) is/are loaded from the server or- nullis placed in the list that is returned.
- additionalRevisions- If non-- null, a list to add additionally prefetched revisions to.
- Since:
- 4.15
- See Also:
 
- 
containsRevisionByVersionReturnstrueif therevision cachecontains arevisionwith the givenIDat the givenbranch version(branch + version),falseotherwise.
- 
getRevisionByVersionCDORevision getRevisionByVersion(CDOID id, CDOBranchVersion branchVersion, int referenceChunk, boolean loadOnDemand) Returns therevisionwith the givenIDat the givenbranch version(branch + version), optionally demand loading it if it is not already in thecache.Prefetching of nested containment levels is not support by this method because the version of a particular revision can not serve as a reasonable baseline criterium for a consistent graph of multiple revisions. - Parameters:
- referenceChunk- The number of target- IDsto load for each many-valued reference in the returned revision, or- CDORevision.UNCHUNKEDfor all such list elements (IDs).
- loadOnDemand- If the requested revision is not contained in the revision cache it depends on this parameter's value whether the revision is loaded from the server or- nullis returned.
- See Also:
 
- 
getObjectLifetime- Since:
- 4.4
 
- 
handleRevisionsvoid handleRevisions(EClass eClass, CDOBranch branch, boolean exactBranch, long timeStamp, boolean exactTime, CDORevisionHandler handler) - Since:
- 4.3
 
 
-