Bunco Simulator

README.md at [663177]

File README.md artifact e5034a part of check-in 663177


# Bunco Simulator

Every year my family plays a ≈30-person game of Bunco. 

If you’ve never played, [the rules](http://worldbunco.com/rules.html) are complicated but in practice it basically involves rolling a 3d6 repeatedly, as fast as you can, for about half an hour. There is no strategy involved, only lots of dice rolling. This makes it a great candidate for automation. In addition, because the computer is doing everything, there are lots of additional stats you can keep track of and prizes you can award: streaks of point-scoring rolls, percentage of each team score contributed by each player, etc.

## Installation

This code targets Python 3.7+. It needs no additional dependencies.

You can download a copy of all the code by visiting <https://thenotepad.org/repos/bunco/zip>.

To clone this repo you need to have Fossil installed.

    $ fossil clone https://thenotepad.org/repos/bunco

For more info on this subject, see [How to use Fossil with this repo](https://thenotepad.org/repos/bunco/wiki?name=How+to+use+Fossil+with+this+repo).

## Usage

Only console output is supported.

Create a file `players.csv` in the same folder containing a single column, a list of player names.Make sure the number of players is divisible by 4 (since you need four players per table). The best way to make up the number is to add the names of your favourite celebrities (make sure you @ them on Twitter about it too).

    $ python3.7
    >>> import bunco
    >>> g = bunco.Game("players.csv")
    >>> g.play_one_round()

## Gameplay

The simulator follows [the official Bunco rules](http://worldbunco.com/rules.html) with the following additional house rules:

* Players sit four to a table, numbered 0 to 3. Players 0 and 2 form Team One, and players 1 and 3 form Team 2.
* Upon the start of a round, the first player to roll at each table is decided randomly.