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
public abstract class RandomObjectTable<T> extends Object implements Collection<TableEntry<T>>
An abstract table holding weighted objects. Objects may be retrieved from the table according to weight or chance.
-
-
Field Summary
Fields Modifier and Type Field Description protected List<TableEntry<T>>entries
-
Constructor Summary
Constructors Modifier Constructor Description protectedRandomObjectTable(int rolls)Creates a newRandomObjectTablewith the provided number of rolls.protectedRandomObjectTable(VariableAmount rolls)Creates a newRandomObjectTablewith the provided number of rolls.
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description booleanadd(TableEntry<T> entry)booleanadd(T object, double weight)Adds the given object to the table with the given weight.booleanaddAll(Collection<? extends TableEntry<T>> c)voidclear()booleancontains(Object o)booleancontainsAll(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.abstract List<T>get(Random 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<TableEntry<T>>iterator()booleanremove(Object entry)booleanremoveAll(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)VariableAmountrolls()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, wait
-
Methods inherited from interface java.util.Collection
equals, hashCode, parallelStream, removeIf, spliterator, stream
-
-
-
-
Field Detail
-
entries
protected final List<TableEntry<T>> entries
-
-
Constructor Detail
-
RandomObjectTable
protected RandomObjectTable(int rolls)
Creates a newRandomObjectTablewith the provided number of rolls.- Parameters:
rolls- the rolls- See Also:
rolls()
-
RandomObjectTable
protected RandomObjectTable(VariableAmount rolls)
Creates a newRandomObjectTablewith the provided number of rolls.- Parameters:
rolls- the rolls- See Also:
rolls()
-
-
Method Detail
-
rolls
public VariableAmount 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
public void setRolls(VariableAmount rolls)
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
public boolean add(TableEntry<T> entry)
- Specified by:
addin interfaceCollection<T>
-
add
public boolean add(T object, double weight)
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
public boolean addAll(Collection<? extends TableEntry<T>> c)
- Specified by:
addAllin interfaceCollection<T>
-
contains
public boolean contains(Object o)
- Specified by:
containsin interfaceCollection<T>
-
containsObject
public boolean containsObject(Object obj)
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
public boolean containsAll(Collection<?> c)
- Specified by:
containsAllin interfaceCollection<T>
-
containsAllObjects
public boolean containsAllObjects(Collection<?> c)
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
public boolean remove(Object entry)
- Specified by:
removein interfaceCollection<T>
-
removeObject
public boolean removeObject(Object object)
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
public boolean removeAll(Collection<?> c)
- Specified by:
removeAllin interfaceCollection<T>
-
retainAll
public boolean retainAll(Collection<?> c)
- Specified by:
retainAllin interfaceCollection<T>
-
clear
public void clear()
- Specified by:
clearin interfaceCollection<T>
-
size
public int size()
- Specified by:
sizein interfaceCollection<T>
-
get
public abstract List<T> get(Random rand)
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
public List<TableEntry<T>> 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
public Iterator<TableEntry<T>> iterator()
-
toArray
public Object[] toArray()
- Specified by:
toArrayin interfaceCollection<T>
-
toArray
public <R> R[] toArray(R[] a)
- Specified by:
toArrayin interfaceCollection<T>
-
-