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
- Fork it ( https://github.com/[my-github-username]/holdem/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request