Class: Dicey::AbstractDie
- Inherits:
-
Object
- Object
- Dicey::AbstractDie
- Defined in:
- lib/dicey/abstract_die.rb
Overview
Asbtract die which may have an arbitrary list of sides, not even neccessarily numbers but strings or other objects.
As the base class for all dice, defines their API.
Dice can be created through several methods:
-
basic
.new(#initialize), creating one die from an appropriate definition; -
AbstractDie.from_list, creating an array of dice from a list of definitions;
-
AbstractDie.from_count, creating a number of equal dice from one definition.
Rolling a die is done through #roll. #current returns the current side of the die.
AbstractDie.srand can be used to (re)set the internal randomizer’s state for all dice, allowing to reproduce the same sequence of rolls (if it was done with a known state).
Direct Known Subclasses
Constant Summary collapse
- @@random =
Random.new
Instance Attribute Summary collapse
-
#sides_list ⇒ Array<Any>
readonly
Die’s list of sides.
-
#sides_num ⇒ Integer
readonly
Number of sides of the die.
Class Method Summary collapse
-
.describe(dice) ⇒ String
Get a text representation of a list of dice.
-
.from_count(count, definition) ⇒ Array<AbstractDie>
Create a number of equal dice from one definition.
-
.from_list(*definitions) ⇒ Array<AbstractDie>
Create a bunch of different dice at once from a list of definitions.
-
.rand ⇒ Object
private
Get a random value using a private instance of Random.
-
.srand ⇒ Object
Reset internal randomizer using a new seed.
Instance Method Summary collapse
-
#==(other) ⇒ Boolean
Determine if this die and the other one have the same list of sides.
-
#current ⇒ Any
Get current side of the die.
-
#eql?(other) ⇒ Boolean
Determine if this die and the other one are of the same class and have the same list of sides.
-
#hash ⇒ Integer
Generates an Integer hash value for this object.
-
#initialize(sides_list) ⇒ AbstractDie
constructor
A new instance of AbstractDie.
-
#next ⇒ Any
Get next side of the die, advancing internal state.
-
#roll ⇒ Any
Move internal state to a random side.
-
#to_s ⇒ String
Return a string representing the die.
Constructor Details
#initialize(sides_list) ⇒ AbstractDie
Returns a new instance of AbstractDie.
86 87 88 89 90 91 92 93 94 |
# File 'lib/dicey/abstract_die.rb', line 86 def initialize(sides_list) @sides_list = sides_list.to_a @sides_list = @sides_list.dup if @sides_list.equal?(sides_list) raise DiceyError, "dice must have at least one side!" if @sides_list.empty? @sides_list.freeze @sides_num = @sides_list.size @current_side_index = 0 end |
Instance Attribute Details
#sides_list ⇒ Array<Any> (readonly)
Die’s list of sides.
77 78 79 |
# File 'lib/dicey/abstract_die.rb', line 77 def sides_list @sides_list end |
#sides_num ⇒ Integer (readonly)
Number of sides of the die.
82 83 84 |
# File 'lib/dicey/abstract_die.rb', line 82 def sides_num @sides_num end |
Class Method Details
.describe(dice) ⇒ String
Get a text representation of a list of dice.
49 50 51 52 53 |
# File 'lib/dicey/abstract_die.rb', line 49 def self.describe(dice) return dice.to_s if AbstractDie === dice dice.to_a.join("+") end |
.from_count(count, definition) ⇒ Array<AbstractDie>
Create a number of equal dice from one definition.
70 71 72 |
# File 'lib/dicey/abstract_die.rb', line 70 def self.from_count(count, definition) Array.new(count) { new(definition) } end |
.from_list(*definitions) ⇒ Array<AbstractDie>
Create a bunch of different dice at once from a list of definitions.
60 61 62 |
# File 'lib/dicey/abstract_die.rb', line 60 def self.from_list(*definitions) definitions.map { new(_1) } end |
.rand ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Get a random value using a private instance of Random.
Do not use this method directly. Reproducible rolls depend on it being called only internally.
30 31 32 |
# File 'lib/dicey/abstract_die.rb', line 30 def self.rand(...) @@random.rand(...) end |
.srand ⇒ Object
Reset internal randomizer using a new seed.
36 37 38 |
# File 'lib/dicey/abstract_die.rb', line 36 def self.srand(...) @@random = Random.new(...) end |
Instance Method Details
#==(other) ⇒ Boolean
Determine if this die and the other one have the same list of sides. Be aware that differently ordered sides are not considered equal.
137 138 139 |
# File 'lib/dicey/abstract_die.rb', line 137 def ==(other) AbstractDie === other && same_sides?(other) end |
#current ⇒ Any
Get current side of the die.
99 100 101 |
# File 'lib/dicey/abstract_die.rb', line 99 def current @sides_list[@current_side_index] end |
#eql?(other) ⇒ Boolean
Determine if this die and the other one are of the same class and have the same list of sides. Be aware that differently ordered sides are not considered equal.
die_1.eql?(die_2) implies die_1.hash == die_2.hash.
151 152 153 |
# File 'lib/dicey/abstract_die.rb', line 151 def eql?(other) self.class === other && same_sides?(other) end |
#hash ⇒ Integer
Generates an Integer hash value for this object.
158 159 160 |
# File 'lib/dicey/abstract_die.rb', line 158 def hash [self.class, @sides_list].hash end |
#next ⇒ Any
Get next side of the die, advancing internal state. Starts from first side, wraps from last to first side.
107 108 109 110 111 |
# File 'lib/dicey/abstract_die.rb', line 107 def next ret = current @current_side_index = (@current_side_index + 1) % @sides_num ret end |
#roll ⇒ Any
Move internal state to a random side.
116 117 118 119 |
# File 'lib/dicey/abstract_die.rb', line 116 def roll @current_side_index = self.class.rand(@sides_num) current end |
#to_s ⇒ String
Return a string representing the die.
Default representation is a list of sides in round brackets.
126 127 128 |
# File 'lib/dicey/abstract_die.rb', line 126 def to_s (@sides_list.size > 1) ? "(#{@sides_list.join(",")})" : "(#{@sides_list.first},)" end |