Skip to content

A ruby library for creating and comparing texas holdem hands.

License

Notifications You must be signed in to change notification settings

Jberczel/holdem

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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

About

A ruby library for creating and comparing texas holdem hands.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages