Sha256: d9dba090d078b01af8661985896254ff01dd4e08c17d55e4907a67dbcd81023a

Contents?: true

Size: 1.12 KB

Versions: 4

Compression:

Stored size: 1.12 KB

Contents

require 'just_backgammon/common'

module JustBackgammon

  # = Die
  #
  # The die is a cube that be rolled to result in a number from 1 to 6.
  class Die
    extend Common

    # A new instance of Die.
    #
    # @param [Fixnum, NilClass] number
    #   The number of the die. Returns nil if not yet rolled.
    #
    # ==== Example:
    #   # Instantiates a new Die
    #   JustBackgammon::Die.new(number: 1)
    def initialize(number:)
      @number = number
    end

    # @return [Fixnum] the number of the die. Returns nil if not yet rolled
    attr_reader :number

    # Rolls the die, the number will be between 1 and 6.
    #
    # @return [Fixnum]
    def roll
      @number = Random.new.rand(6) + 1
    end

    # Resets the die, the number will be nil.
    #
    # @return [NilClass]
    def reset
      @number = nil
    end

    # Equals operator compares the number to determine if the dice are equal.
    #
    # @return [Boolean]
    def == (other)
      self.number == other.number
    end

    # A hashed serialized representation of the die
    #
    # @return [Hash]
    def as_json
      { number: number }
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
just_backgammon-0.2.0 lib/just_backgammon/die.rb
just_backgammon-0.1.2 lib/just_backgammon/die.rb
just_backgammon-0.1.1 lib/just_backgammon/die.rb
just_backgammon-0.1.0 lib/just_backgammon/die.rb