Class AbstractRelationAdapter
- All Implemented Interfaces:
- EntityList,- Relation,- Iterable<Entity>
- Direct Known Subclasses:
- ToManyRelationAdapter,- ToOneRelationAdapter
Relation interface- 
Nested Class SummaryNested classes/interfaces inherited from class ch.tocco.nice2.persist.core.api.entity.AbstractEntityListAbstractEntityList.SimpleIteratorNested classes/interfaces inherited from interface ch.tocco.nice2.persist.core.api.entity.EntityListEntityList.Filter
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final EntityFacadeListenerManagerprotected final RelationInterceptorprotected final RelationModelprotected final Entity
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedAbstractRelationAdapter(RelationModel relationModel, Entity sourceEntity, EntityFacadeListenerManager entityFacadeListenerManager, EntityInterceptor entityInterceptor) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidAdd an entity to the relation.expect(int amount) Throws if the list does not contain exactly that amount.expectAtLeast(int min) Throws if the list contains fewer than min items.expectAtMost(int max) Throws if the list contains more than max items.protected voidfireRelationChangingEvent(Entity relatedEntity, boolean added, boolean adjusting) @Nullable Entityget()Get the current single target entity of this relation.abstract RelationInterceptorgetKey(int index) Returns the PrimaryKey at the specified position.getKeys()WARNING: this impl may return null entries! This happens when entities of state conception are in the list.Get the entity manager.getModel()Get the model of the entity type contained in this list.intGet the number of pages in this list.intGet the current page size.intindexOf(PrimaryKey key) Get the index within the list of the entity with the specified key.voidRemove an entity from the relation.voidSet the relation's entities to the specified single entity.voidsetPageSize(int pageSize) Set the page size.unwrap()Unwrap to the underlying entity list.protected voidverifyTransactionIsRunning(Context context) Methods inherited from class ch.tocco.nice2.persist.core.api.entity.AbstractEntityListcontains, get, get, get, isEmpty, iterator, toList, toListMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface ch.tocco.nice2.persist.core.api.entity.EntityListcontains, doWithSingleResult, doWithSingleResultOr, expectOr, get, get, getFirstEntity, getOnlyResult, getOptionalOnlyResult, getOptionalOnlyResult, isEmpty, requireFirstEntity, size, spliterator, stream, toList, toListMethods inherited from interface ch.tocco.nice2.persist.core.api.entity.Relationclear, expectAtMostOrThrow, expectOrThrow, get, get, set
- 
Field Details- 
relationModel
- 
sourceEntity
- 
entityFacadeListenerManager
- 
relationInterceptor
 
- 
- 
Constructor Details- 
AbstractRelationAdapterprotected AbstractRelationAdapter(RelationModel relationModel, Entity sourceEntity, EntityFacadeListenerManager entityFacadeListenerManager, EntityInterceptor entityInterceptor) 
 
- 
- 
Method Details- 
getInnerInterceptor
- 
addDescription copied from interface:RelationAdd an entity to the relation.If the entity is in the relation already then the call is ignored; no exception thrown, no events fired. (i'm sure about the exception, but not about the events. -andrej) If this is a to-one relation then you are advised to use the Relation.set(ch.tocco.nice2.persist.core.api.entity.Entity)method. If you still decide to use add() then you also need to call remove() with the old value if there was an entity linked already.Relation.set(ch.tocco.nice2.persist.core.api.entity.Entity)takes care of all this for you.
- 
removeDescription copied from interface:RelationRemove an entity from the relation.TODO document what happens when the entity is not in the relation. 
- 
setDescription copied from interface:RelationSet the relation's entities to the specified single entity. Any other entities will be removed. This method may only be called for relations to a single entity (n-1).NOTE: This calls Relation.remove(ch.tocco.nice2.persist.core.api.entity.Entity)andRelation.add(ch.tocco.nice2.persist.core.api.entity.Entity)internally. That's also why the interceptor does not have this.
- 
getDescription copied from interface:RelationGet the current single target entity of this relation. This method may only be called for relations to a single entity (n-1).- Specified by:
- getin interface- Relation
- Returns:
- The current single target entity potentially in unusable state, ornull.
 
- 
expectDescription copied from interface:EntityListThrows if the list does not contain exactly that amount.Example: EntityList entityList = myQuery.execute(1).expect(1);- Specified by:
- expectin interface- EntityList
- Specified by:
- expectin interface- Relation
- Overrides:
- expectin class- AbstractEntityList
- Parameters:
- amount- The expected amount.
- Returns:
- The list itself.
- See Also:
 
- 
expectAtLeastDescription copied from interface:EntityListThrows if the list contains fewer than min items.Example: EntityList entityList = myQuery.execute().expectAtLeast(3);- Specified by:
- expectAtLeastin interface- EntityList
- Specified by:
- expectAtLeastin interface- Relation
- Overrides:
- expectAtLeastin class- AbstractEntityList
- Parameters:
- min- The expected minimal amount, including.
- Returns:
- The list itself.
- See Also:
 
- 
expectAtMostDescription copied from interface:EntityListThrows if the list contains more than max items.Example: EntityList entityList = myQuery.execute(3).expectAtMost(3);- Specified by:
- expectAtMostin interface- EntityList
- Specified by:
- expectAtMostin interface- Relation
- Overrides:
- expectAtMostin class- AbstractEntityList
- Parameters:
- max- The expected maximal amount, including.
- Returns:
- The list itself.
- See Also:
 
- 
getModelDescription copied from interface:EntityListGet the model of the entity type contained in this list.- Specified by:
- getModelin interface- EntityList
- Returns:
- The model of the entity type contained in this list.
 
- 
getManagerDescription copied from interface:EntityListGet the entity manager.- Specified by:
- getManagerin interface- EntityList
- Returns:
- The entity manager.
 
- 
getSource
- 
getRelationModel- Specified by:
- getRelationModelin interface- Relation
 
- 
unwrapDescription copied from interface:EntityListUnwrap to the underlying entity list. Wrappers of entity lists should delegate this to the list they're wrapping, implementations returnthis. It may be that they cannot, and then return themselves (MultiEntityList).- Specified by:
- unwrapin interface- EntityList
- Specified by:
- unwrapin interface- Relation
- Returns:
- The underlying entity list implementation.
 
- 
setPageSizepublic void setPageSize(int pageSize) Description copied from interface:EntityListSet the page size. The page size determines how many objects will be loaded, once ahollowentity has been accessed.- Specified by:
- setPageSizein interface- EntityList
- Parameters:
- pageSize- The new page size.
 
- 
getPageSizepublic int getPageSize()Description copied from interface:EntityListGet the current page size.- Specified by:
- getPageSizein interface- EntityList
- Returns:
- The current page size.
 
- 
getPageCountpublic int getPageCount()Description copied from interface:EntityListGet the number of pages in this list.- Specified by:
- getPageCountin interface- EntityList
- Returns:
- The number of pages in this list
         (size/pageSize + (size%pageSize>0 ? 1 : 0)).
 
- 
getKeysDescription copied from interface:RelationWARNING: this impl may return null entries! This happens when entities of state conception are in the list. Also, after a commit this data is outdated, see class header.- Specified by:
- getKeysin interface- EntityList
- Specified by:
- getKeysin interface- Relation
- Returns:
- A defensive copy of the array. The size matches the EntityList.size()method.
 
- 
getKeyDescription copied from interface:EntityListReturns the PrimaryKey at the specified position.- Specified by:
- getKeyin interface- EntityList
 
- 
indexOfDescription copied from interface:EntityListGet the index within the list of the entity with the specified key.- Specified by:
- indexOfin interface- EntityList
- Parameters:
- key- The primary key.
- Returns:
- The index or -1, if there's no such entity in the list.
 
- 
fireRelationChangingEvent
- 
verifyTransactionIsRunning
 
-