Project

holdem

0.01
No commit activity in last 3 years
No release in over 3 years
A ruby module for creating and comparing Texas Holdem poker hands.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

~> 2.1.4
~> 5.14.1
~> 13.0.1
 Project Readme

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