Class RandomObjectTable<T>
java.lang.Object
org.spongepowered.api.util.weighted.RandomObjectTable<T>
- Type Parameters:
T- The type of entry
- All Implemented Interfaces:
Iterable<TableEntry<T>>,Collection<TableEntry<T>>
- Direct Known Subclasses:
ChanceTable,WeightedTable
An abstract table holding weighted objects. Objects may be retrieved from the
table according to weight or chance.
-
Field Summary
Fields -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedRandomObjectTable(int rolls) Creates a newRandomObjectTablewith the provided number of rolls.protectedRandomObjectTable(VariableAmount rolls) Creates a newRandomObjectTablewith the provided number of rolls. -
Method Summary
Modifier and TypeMethodDescriptionbooleanadd(TableEntry<T> entry) booleanAdds the given object to the table with the given weight.booleanaddAll(Collection<? extends @Nullable TableEntry<T>> c) voidclear()booleanbooleancontainsAll(Collection<?> c) booleancontainsAllObjects(Collection<?> c) Gets if this table contains all of the given objects, the objects may either beTableEntrys or the objects contained within the entries.booleancontainsObject(Object obj) Gets if this table contains the given object, the object may either be aTableEntryor the object contained within.List<TableEntry<T>> entries()Gets the entries in the table.get(RandomGenerator rand) Performs a number of rolls according to the number of rolls defined byrolls()and returns items from the table for each roll.booleanisEmpty()iterator()booleanbooleanremoveAll(Collection<?> c) booleanremoveObject(Object object) Removes the first instance of an entry in this table which is aWeightedObjectentry and contains the given object.booleanretainAll(Collection<?> c) rolls()Gets the number of times this table will roll while retrieving items.voidsetRolls(int rolls) Sets the number of times this table will roll while retrieving items.voidsetRolls(VariableAmount rolls) Sets the number of times this table will roll while retrieving items.intsize()Object[]toArray()<R> R[]toArray(R[] a) Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface java.util.Collection
equals, hashCode, parallelStream, removeIf, spliterator, stream, toArray
-
Field Details
-
entries
-
-
Constructor Details
-
RandomObjectTable
protected RandomObjectTable(int rolls) Creates a newRandomObjectTablewith the provided number of rolls.- Parameters:
rolls- the rolls- See Also:
-
RandomObjectTable
Creates a newRandomObjectTablewith the provided number of rolls.- Parameters:
rolls- the rolls- See Also:
-
-
Method Details
-
rolls
Gets the number of times this table will roll while retrieving items. For each roll a complete pass through of the table will occur.- Returns:
- The number of rolls
-
setRolls
Sets the number of times this table will roll while retrieving items.- Parameters:
rolls- The new roll count
-
setRolls
public void setRolls(int rolls) Sets the number of times this table will roll while retrieving items.- Parameters:
rolls- The new roll count
-
add
- Specified by:
addin interfaceCollection<T>
-
add
Adds the given object to the table with the given weight.- Parameters:
object- The new objectweight- The weight of the object- Returns:
- If the object was successfully added
-
addAll
- Specified by:
addAllin interfaceCollection<T>
-
contains
- Specified by:
containsin interfaceCollection<T>
-
containsObject
Gets if this table contains the given object, the object may either be aTableEntryor the object contained within.- Parameters:
obj- The object to check for- Returns:
- If the object is contained within the table
-
containsAll
- Specified by:
containsAllin interfaceCollection<T>
-
containsAllObjects
Gets if this table contains all of the given objects, the objects may either beTableEntrys or the objects contained within the entries.- Parameters:
c- The objects to check for- Returns:
- If all of the objects are contained within the table
-
isEmpty
public boolean isEmpty()- Specified by:
isEmptyin interfaceCollection<T>
-
remove
- Specified by:
removein interfaceCollection<T>
-
removeObject
Removes the first instance of an entry in this table which is aWeightedObjectentry and contains the given object.- Parameters:
object- The object to remove- Returns:
- If the table was changed as a result
-
removeAll
- Specified by:
removeAllin interfaceCollection<T>
-
retainAll
- Specified by:
retainAllin interfaceCollection<T>
-
clear
public void clear()- Specified by:
clearin interfaceCollection<T>
-
size
public int size()- Specified by:
sizein interfaceCollection<T>
-
get
Performs a number of rolls according to the number of rolls defined byrolls()and returns items from the table for each roll.- Parameters:
rand- The random object to use- Returns:
- The returned items, may be empty but not null
-
entries
Gets the entries in the table. Note that the specific sub class of this abstract table will determine the context that the entry weights should be interpreted in (either weights or chances).- Returns:
- The raw entries
-
iterator
-
toArray
- Specified by:
toArrayin interfaceCollection<T>
-
toArray
public <R> R[] toArray(R[] a) - Specified by:
toArrayin interfaceCollection<T>
-