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
-
Constructor Summary
ModifierConstructorDescriptionprotected
RandomObjectTable
(int rolls) Creates a newRandomObjectTable
with the provided number of rolls.protected
RandomObjectTable
(VariableAmount rolls) Creates a newRandomObjectTable
with the provided number of rolls. -
Method Summary
Modifier and TypeMethodDescriptionboolean
add
(TableEntry<T> entry) boolean
Adds the given object to the table with the given weight.boolean
addAll
(Collection<? extends @Nullable TableEntry<T>> c) void
clear()
boolean
boolean
containsAll
(Collection<?> c) boolean
containsAllObjects
(Collection<?> c) Gets if this table contains all of the given objects, the objects may either beTableEntry
s or the objects contained within the entries.boolean
containsObject
(Object obj) Gets if this table contains the given object, the object may either be aTableEntry
or 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.boolean
isEmpty()
iterator()
boolean
boolean
removeAll
(Collection<?> c) boolean
removeObject
(Object object) Removes the first instance of an entry in this table which is aWeightedObject
entry and contains the given object.boolean
retainAll
(Collection<?> c) rolls()
Gets the number of times this table will roll while retrieving items.void
setRolls
(int rolls) Sets the number of times this table will roll while retrieving items.void
setRolls
(VariableAmount rolls) Sets the number of times this table will roll while retrieving items.int
size()
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, toArray
-
Field Details
-
entries
-
-
Constructor Details
-
RandomObjectTable
protected RandomObjectTable(int rolls) Creates a newRandomObjectTable
with the provided number of rolls.- Parameters:
rolls
- the rolls- See Also:
-
RandomObjectTable
Creates a newRandomObjectTable
with 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:
add
in 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:
addAll
in interfaceCollection<T>
-
contains
- Specified by:
contains
in interfaceCollection<T>
-
containsObject
Gets if this table contains the given object, the object may either be aTableEntry
or the object contained within.- Parameters:
obj
- The object to check for- Returns:
- If the object is contained within the table
-
containsAll
- Specified by:
containsAll
in interfaceCollection<T>
-
containsAllObjects
Gets if this table contains all of the given objects, the objects may either beTableEntry
s 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:
isEmpty
in interfaceCollection<T>
-
remove
- Specified by:
remove
in interfaceCollection<T>
-
removeObject
Removes the first instance of an entry in this table which is aWeightedObject
entry and contains the given object.- Parameters:
object
- The object to remove- Returns:
- If the table was changed as a result
-
removeAll
- Specified by:
removeAll
in interfaceCollection<T>
-
retainAll
- Specified by:
retainAll
in interfaceCollection<T>
-
clear
public void clear()- Specified by:
clear
in interfaceCollection<T>
-
size
public int size()- Specified by:
size
in 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:
toArray
in interfaceCollection<T>
-
toArray
public <R> R[] toArray(R[] a) - Specified by:
toArray
in interfaceCollection<T>
-