/holdem

A ruby library for creating and comparing texas holdem hands.

Primary LanguageRubyMIT LicenseMIT

Holdem

A ruby module for creating and comparing Texas Holdem poker hands.

Installation

Add this line to your application's Gemfile:

gem 'holdem'

And then execute:

$ bundle

Or install it yourself as:

$ gem install holdem

Example

require 'holdem'

deck = Holdem::Deck.new
deck.shuffle!

hand1 = Holdem::PokerHand.new(deck.deal(7))
hand2 = Holdem::PokerHand.new(deck.deal(7))
hand3 = Holdem::PokerHand.new("4c Kc 4h 5d 6s Kd Qs")

puts hand1                     # => 5♦ K♣ T♠ J♥ 8♥ 8♠ 2♥ -> Pair of 8s
puts hand2                     # => Q♦ 6♦ 2♦ 6♣ 5♥ 6♠ T♦ -> Three of a Kind (trip 6s)
puts hand3                     # => 4♣ K♣ 4♥ 5♦ 6♠ K♦ Q♠ -> Two Pairs (Ks and 4s)

puts hand1 > hand2             # => false
puts hand2 < hand3             # => false
puts [hand1, hand2, hand3].max # => Q♦ 6♦ 2♦ 6♣ 5♥ 6♠ T♦ -> Three of a Kind (trip 6s)

Usage

Cards can be passed to the PokerHand constructor as a string of card representations or as an array of card objects.

Face cards (ten, jack, queen, king, and ace) are represented by (T, J, Q, K, A).

Suits (club, diamond, spade, heart) are represented by (c, d, s, h).

puts Holdem::PokerHand.new('Ac 7d 4c Td Qc Qh Ks')             # => A♣ 7♦ 4♣ T♦ Q♣ Q♥ K♠ -> Pair of Qs

card1, card2 = Holdem::Card.new('Ad'), Holdem::Card.new('Ah')     
puts Holdem::PokerHand.new([card1, card2])                     # => A♦ A♥ -> Pair of As

There is also a Deck class to facilitate random poker hands:

deck  = Holdem::Deck.new.shuffle!
cards = deck.deal(7)
hand  = Holdem::PokerHand.new(cards)
puts hand    # => K♦ 5♣ 4♣ 8♣ J♠ 3♣ 7♦ -> K high

A number of ranks can be asked about a hand:

hand.straight_flush?
hand.quads?           # or hand.four_of_a_kind?
hand.boat?            # or hand.full_house?
hand.flush?
hand.straight?
hand.trips?           # or hand.three_of_a_kind? 
hand.two_pairs?
hand.pair?

TODO

Build Simulations, players, table, chips, and game objects.

Add methods to PokerRank for:

hand.four_to_flush?
hand.gutshot?

Contributing

  1. Fork it ( https://github.com/[my-github-username]/holdem/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request