GithubHelp home page GithubHelp logo

pyskat's Introduction

PySkat - A simple CLI and TUI Skat Tournament Management Program

PySkat is a simple tool for managing tournaments of the German national card game Skat. The functionality follows the official tournament rules given by the Deutscher Skatverband e.V. (German Skat Association). Evaluation of games is oriented at the official game sheets for tournaments.

Current Status

This software is currently in alpha state, thus is functionality is not complete and the API may or will change in future.

The following features are already working:

  • TinyDB backend with API methods to create, update, get and list players and game results.
  • Backend function to automatically evaluate game results according to official tournament rules.
  • CLI to interact with the backend database.
  • CLI to shuffle players to tables and evaluate game results.

The following planned features are not working:

  • TUI interface with same feature set as the CLI.
  • HTML printout of players, series, results.

Installation

The software is published on PyPI and can be installed via pip or similar tools:

pip install pyskat

Usage

Once installed, run the CLI using the pyskat command.

To show the help on available commands run:

pyskat --help

You may use all commands directly from your preferred command line. However, it is recommended to open the interactive shell of PySkat, as this saves typing and provides syntax completion without configuring your shell. To open an interactive shell use:

pyskat shell

By default, a file named pyskat_db.json is created in the current working directory holding the persistent data of players and results. You may specify another file by the -f/--database-file option, for example:

pyskat -f my_first_tournament.json shell

Managing Players

Players are managed using the player command and its subcommands. Data for each command can be specified using options, or, if omitted are prompted. To get help on a specific command use the -h/--help option on that command, like:

pyskat player --help

To add a new player:

pyskat player add

To list all players in database:

pyskat player list

To update an existing player:

pyskat player update

To remove a player:

pyskat remove

Generating a Series

To distribute players randomly to tables (generating a series), use the series generate command. This will print out a data sheet indexed by table ID with players placed at the tables, so that the current number of players in the database is efficiently distributed to four- and three-player tables.

pyskat generate series

Entering Results

Results are managed using the result command and its subcommands. Data for each command can be specified using options, or, if omitted are prompted. A result is meant as the result of a specific player in a specific series.

To add a new result:

pyskat result add

To list all results in database:

pyskat result list

To update an existing result:

pyskat result update

Evaluating Results

Results over all games can be evaluated using the evaluate command. For example to generate the high-score list of the tournament, execute:

pyskat evaluate total -s score

License

This software is published under the terms of the MIT License.

Contributing

This project is in early status and does currently not accept code contributions. This may change in future. Feedback and suggestions are welcome via issues.

pyskat's People

Contributors

axtimhaus avatar

Watchers

 avatar

pyskat's Issues

Implement WebUI

  • using flask
  • double all functionality of CLI
  • create plots to analyse results

Remove Players List from Series

Current solution with adding and removing players from/to series is cumbersome.

Better solution:

  • active marker on players
  • shuffling only regards active players
  • shuffling gets additional arguments include (to explicitly add inactive players), include_only (to ignore activity and only use given list), exclude (to explicitly remove active players)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.