class CacheMemberReader extends Object implements MemberReader, MemberCache
CacheMemberReader implements MemberReader by reading
 from a pre-populated array of Members.
 Note: CacheMemberReader can not handle ragged hierarchies. (HR
 Tests fail if SmartMemberReader is replaced with
 CacheMemberReader).
| Constructor and Description | 
|---|
CacheMemberReader(MemberSource source)  | 
| Modifier and Type | Method and Description | 
|---|---|
int | 
compare(RolapMember m1,
       RolapMember m2,
       boolean siblingsAreEqual)
Compares two members according to their order in a prefix ordered
 traversal. 
 | 
RolapMember | 
desubstitute(RolapMember member)
Returns the member which was substituted. 
 | 
List<RolapMember> | 
getChildrenFromCache(RolapMember member,
                    MemberChildrenConstraint constraint)
Returns the children of  
member if they are currently in the
 cache, otherwise returns null. | 
RolapMember | 
getDefaultMember()  | 
RolapHierarchy | 
getHierarchy()
Returns the hierarchy that this source is reading for. 
 | 
RolapMember | 
getLeadMember(RolapMember member,
             int n)
Returns the member  
n after member in the same
 level (or before, if n is negative). | 
int | 
getLevelMemberCount(RolapLevel level)
Returns the number of members in this level. 
 | 
List<RolapMember> | 
getLevelMembersFromCache(RolapLevel level,
                        TupleConstraint constraint)
Returns the members of  
level if they are currently in the
 cache, otherwise returns null. | 
RolapMember | 
getMember(Object key)
Retrieves the  
RolapMember with a given key. | 
RolapMember | 
getMember(Object key,
         boolean mustCheckCacheStatus)
Retrieves the  
RolapMember with a given key. | 
TupleReader.MemberBuilder | 
getMemberBuilder()  | 
RolapMember | 
getMemberByKey(RolapLevel level,
              List<Comparable> keyValues)
Looks up a member by its key value. 
 | 
void | 
getMemberChildren(List<RolapMember> parentMembers,
                 List<RolapMember> children)
Returns all members which are a child of one of the members in
  
parentMembers, sorted by ordinal. | 
Map<? extends Member,Access> | 
getMemberChildren(List<RolapMember> parentMembers,
                 List<RolapMember> children,
                 MemberChildrenConstraint constraint)
Populates a list of the children of a given set of Members, optionally
 applying a constraint. 
 | 
void | 
getMemberChildren(RolapMember parentMember,
                 List<RolapMember> children)
Writes all children  
parentMember to children. | 
Map<? extends Member,Access> | 
getMemberChildren(RolapMember member,
                 List<RolapMember> children,
                 MemberChildrenConstraint constraint)
Populates a list of the children of a Member, optionally applying a
 constraint. 
 | 
int | 
getMemberCount()
Returns an estimate of number of members in this hierarchy. 
 | 
RolapMember | 
getMemberParent(RolapMember member)  | 
void | 
getMemberRange(RolapLevel level,
              RolapMember startMember,
              RolapMember endMember,
              List<RolapMember> list)
Writes all members between  
startMember and
 endMember into list. | 
List<RolapMember> | 
getMembers()
Returns all members of this hierarchy, sorted by ordinal. 
 | 
List<RolapMember> | 
getMembersInLevel(RolapLevel level)
Returns all of the members in  
level whose ordinal lies
 between startOrdinal and endOrdinal. | 
List<RolapMember> | 
getMembersInLevel(RolapLevel level,
                 TupleConstraint constraint)
Returns the members in the given Level, optionally applying a constraint. 
 | 
List<RolapMember> | 
getRootMembers()
Returns all members of this hierarchy which do not have a parent,
 sorted by ordinal. 
 | 
boolean | 
isMutable()
Returns whether the cache supports removing selected items. 
 | 
RolapMember | 
lookupMember(List<Id.Segment> uniqueNameParts,
            boolean failIfNotFound)
Finds a member based upon its unique name. 
 | 
Object | 
makeKey(RolapMember parent,
       Object key)
Creates a key with which to  
MemberCache.getMember(Object) or
 MemberCache.putMember(Object, RolapMember) the
 RolapMember with a given parent and key. | 
void | 
putChildren(RolapLevel level,
           TupleConstraint constraint,
           List<RolapMember> children)
 | 
void | 
putChildren(RolapMember member,
           MemberChildrenConstraint constraint,
           List<RolapMember> children)
 | 
Object | 
putMember(Object key,
         RolapMember value)
Replaces the  
RolapMember with a given key and returns the
 previous member if any. | 
RolapMember | 
removeMember(Object key)
Removes the  
RolapMember with a given key from the cache. | 
RolapMember | 
removeMemberAndDescendants(Object key)
Removes the designated  
RolapMember and all its descendants. | 
boolean | 
setCache(MemberCache cache)
Sets the cache which this  
MemberSource will write to. | 
RolapMember | 
substitute(RolapMember member)
Substitutes a given member. 
 | 
CacheMemberReader(MemberSource source)
public RolapHierarchy getHierarchy()
MemberSourcegetHierarchy in interface MemberSourcepublic boolean setCache(MemberCache cache)
MemberSourceMemberSource will write to.
 Cache-writeback is optional (for example, SqlMemberSource
 supports it, and ArrayMemberSource does not), and the return
 value from this method indicates whether this object supports it.
 
If this method returns true, the MemberSource.getMembers(),
 MemberSource.getRootMembers() and MemberSource.getMemberChildren(mondrian.rolap.RolapMember, java.util.List<mondrian.rolap.RolapMember>) methods must
 write to the cache, in addition to returning members as a return value.
setCache in interface MemberSourcecache - The MemberCache which the caller would like
   this MemberSource to write to.MemberSource supports cache-writeback.public RolapMember substitute(RolapMember member)
MemberReaderThis method is called whenever a member is returned from the wrapped member reader and is to be returned to the caller. You could say that it translates 'to caller space'.
substitute in interface MemberReadermember - Memberpublic RolapMember desubstitute(RolapMember member)
MemberReaderThis method is called whenever the caller passes a member into a method and needs to be passed to a method on the wrapped member reader. You could say that it translates 'from caller space'.
desubstitute in interface MemberReadermember - Memberpublic RolapMember getMemberByKey(RolapLevel level, List<Comparable> keyValues)
MemberReadergetMemberByKey in interface MemberReaderlevel - LevelkeyValues - Key valuespublic List<RolapMember> getMembers()
MemberSourceIf this object supports cache-writeaback, also
 writes these members to the cache.
getMembers in interface MemberSourcepublic Object makeKey(RolapMember parent, Object key)
MemberCacheMemberCache.getMember(Object) or
 MemberCache.putMember(Object, RolapMember) the
 RolapMember with a given parent and key.makeKey in interface MemberCacheparent - Parent memberkey - Key of member within parentpublic RolapMember getMember(Object key)
MemberCacheRolapMember with a given key.getMember in interface MemberCachekey - cache key, created by MemberCache.makeKey(mondrian.rolap.RolapMember, java.lang.Object)public RolapMember getMember(Object key, boolean mustCheckCacheStatus)
MemberCacheRolapMember with a given key.getMember in interface MemberCachekey - cache key, created by MemberCache.makeKey(mondrian.rolap.RolapMember, java.lang.Object)mustCheckCacheStatus - If true, do not check cache statuspublic Object putMember(Object key, RolapMember value)
MemberCacheRolapMember with a given key and returns the
 previous member if any.putMember in interface MemberCachekey - cache key, created by MemberCache.makeKey(mondrian.rolap.RolapMember, java.lang.Object)value - new memberpublic void putChildren(RolapMember member, MemberChildrenConstraint constraint, List<RolapMember> children)
MemberCacheputChildren in interface MemberCachemember - the parent memberconstraint - the condition that was used when the members were
   fetched. May be null for all members (no constraint)children - list of childrenpublic void putChildren(RolapLevel level, TupleConstraint constraint, List<RolapMember> children)
MemberCacheputChildren in interface MemberCachelevel - the parent levelconstraint - the condition that was used when the members were
   fetched. May be null for all members (no constraint)children - list of childrenpublic boolean isMutable()
MemberCacheMemberCache.removeMember(Object) and
 MemberCache.removeMemberAndDescendants(Object) methods.
 REVIEW: remove isMutable and move removeMember and removeMemberAndDescendants to new interface MutableMemberCache
isMutable in interface MemberCachepublic RolapMember removeMember(Object key)
MemberCacheRolapMember with a given key from the cache.
 Returns the previous member with that key, or null.
 Optional operation: see MemberCache.isMutable().removeMember in interface MemberCachekey - cache key, created by MemberCache.makeKey(mondrian.rolap.RolapMember, java.lang.Object)public RolapMember removeMemberAndDescendants(Object key)
MemberCacheRolapMember and all its descendants.
 Returns the previous member with that key, or null.
 Optional operation: see MemberCache.isMutable().removeMemberAndDescendants in interface MemberCachekey - cache key, created by MemberCache.makeKey(mondrian.rolap.RolapMember, java.lang.Object)public List<RolapMember> getChildrenFromCache(RolapMember member, MemberChildrenConstraint constraint)
MemberCachemember if they are currently in the
 cache, otherwise returns null.
 The children may be garbage collected as soon as the returned list may be garbage collected.
getChildrenFromCache in interface MemberCachemember - the parent memberconstraint - the condition that was used when the members were
    fetched. May be null for all members (no constraint)public List<RolapMember> getLevelMembersFromCache(RolapLevel level, TupleConstraint constraint)
MemberCachelevel if they are currently in the
 cache, otherwise returns null.
 The members may be garbage collected as soon as the returned list may be garbage collected.
getLevelMembersFromCache in interface MemberCachelevel - the level whose members should be fetchedconstraint - the condition that was used when the members were
   fetched. May be null for all members (no constraint)public RolapMember lookupMember(List<Id.Segment> uniqueNameParts, boolean failIfNotFound)
MemberSourcelookupMember in interface MemberSourcepublic List<RolapMember> getRootMembers()
MemberSourceIf this object supports cache-writeback, also
 writes these members to the cache.
getRootMembers in interface MemberSourceList of RolapMemberspublic List<RolapMember> getMembersInLevel(RolapLevel level)
MemberReaderlevel whose ordinal lies
 between startOrdinal and endOrdinal.
 If this object
 supports cache-writeback, also
 writes these members to the cache.
getMembersInLevel in interface MemberReaderList of RolapMemberpublic List<RolapMember> getMembersInLevel(RolapLevel level, TupleConstraint constraint)
MemberReadergetMembersInLevel in interface MemberReaderlevel - Levelconstraint - Constraintpublic int getLevelMemberCount(RolapLevel level)
MemberReadergetLevelMemberCount in interface MemberReaderlevel - Levelpublic void getMemberChildren(RolapMember parentMember, List<RolapMember> children)
MemberSourceparentMember to children.
 If this object supports cache-writeback, also
 writes these members to the cache.
getMemberChildren in interface MemberSourcepublic Map<? extends Member,Access> getMemberChildren(RolapMember member, List<RolapMember> children, MemberChildrenConstraint constraint)
MemberReadergetMemberChildren in interface MemberReadermember - Members whose children to findchildren - List to populate with membersconstraint - Constraintnull values.public void getMemberChildren(List<RolapMember> parentMembers, List<RolapMember> children)
MemberSourceparentMembers, sorted by ordinal.
 If this object supports cache-writeaback, also
 writes these members to the cache.
getMemberChildren in interface MemberSourcepublic Map<? extends Member,Access> getMemberChildren(List<RolapMember> parentMembers, List<RolapMember> children, MemberChildrenConstraint constraint)
MemberReadergetMemberChildren in interface MemberReaderparentMembers - List of members whose children to findchildren - List to populate with membersconstraint - Constraintnull values.public RolapMember getLeadMember(RolapMember member, int n)
MemberReadern after member in the same
 level (or before, if n is negative).
 Returns Hierarchy.getNullMember() if we run off the beginning or
 end of the level.getLeadMember in interface MemberReaderpublic void getMemberRange(RolapLevel level, RolapMember startMember, RolapMember endMember, List<RolapMember> list)
MemberReaderstartMember and
 endMember into list.getMemberRange in interface MemberReaderpublic int getMemberCount()
MemberSourcegetMemberCount in interface MemberSourcepublic int compare(RolapMember m1, RolapMember m2, boolean siblingsAreEqual)
MemberReadersiblingsAreEqual, then two members with the
 same parent will compare equal.compare in interface MemberReadersiblingsAreEqual and
         m1 and m2 have the same parentpublic TupleReader.MemberBuilder getMemberBuilder()
getMemberBuilder in interface MemberReaderpublic RolapMember getDefaultMember()
getDefaultMember in interface MemberReaderpublic RolapMember getMemberParent(RolapMember member)
getMemberParent in interface MemberReader