Skip to main content

Python CLI to explore chessboard positions.

Project description

Chessboard

Python CLI to explore chessboard positions.

Stable release: Last release Requirements freshness Software license Popularity

Development: Unit-tests status Coverage Status Code Quality

Motivation

This project is a playground to test some optimization strategies in Python, but is essentially an exemple of a real-life Python package, and serve me as a boilerplate project for future CLI.

Development philosophy

  1. First create something that work (to provide business value).

  2. Then something that’s beautiful (to lower maintenance costs).

  3. Finally works on performance (to avoid wasting time on premature optimizations).

Install

This package is available on PyPi, so you can install the latest stable release and its dependencies with a simple pip call:

$ pip install chessboard

Usage

$ chessboard --help
Usage: chessboard [OPTIONS]

  Python CLI to explore chessboard positions.

Options:
  --version             Show the version and exit.
  -l, --length INTEGER  Length of the board.  [required]
  -h, --height INTEGER  Height of the board.  [required]
  -s, --silent          Do not display result board, only final count.
  -v, --verbose         Print much more debug statements.
  --rook INTEGER        Number of rooks to add to the board.
  --king INTEGER        Number of kings to add to the board.
  --queen INTEGER       Number of queens to add to the board.
  --bishop INTEGER      Number of bishops to add to the board.
  --knight INTEGER      Number of knights to add to the board.
  --help                Show this message and exit.

Exemples

$ chessboard --length=3 --height=3 --king=2 --rook=1
Building up a chessboard...
Solving the chessboard...
┌───┬───┬───┐
        
├───┼───┼───┤
        
├───┼───┼───┤
        
└───┴───┴───┘
┌───┬───┬───┐
        
├───┼───┼───┤
        
├───┼───┼───┤
        
└───┴───┴───┘
┌───┬───┬───┐
       
├───┼───┼───┤
         
├───┼───┼───┤
        
└───┴───┴───┘
┌───┬───┬───┐
        
├───┼───┼───┤
         
├───┼───┼───┤
       
└───┴───┴───┘
4 results found in 0.03 seconds.

Development

Check out latest development branch:

$ git clone git@github.com:kdeldycke/chessboard.git
$ cd ./chessboard
$ python ./setup.py develop

Run unit-tests:

$ python ./setup.py nosetests

Stability policy

Here is a bunch of rules we’re trying to follow regarding stability:

  • Patch releases (0.x.n0.x.(n+1) upgrades) are bug-fix only. These releases must not break anything and keeps backward-compatibility with 0.x.* and 0.(x-1).* series.

  • Minor releases (0.n.*0.(n+1).0 upgrades) includes any non-bugfix changes. These releases must be backward-compatible with any 0.n.* version but are allowed to drop compatibility with the 0.(n-1).* series and below.

  • Major releases (n.*.*(n+1).0.0 upgrades) are not planned yet: we’re still in beta and the final feature set of the 1.0.0 release is not decided yet.

Release process

Start from the develop branch:

$ git clone git@github.com:kdeldycke/chessboard.git
$ git checkout develop

Revision should already be set to the next version, so we just need to set the released date in the changelog:

$ vi ./CHANGES.rst

Create a release commit, tag it and merge it back to master branch:

$ git add ./chessboard/__init__.py ./CHANGES.rst
$ git commit -m "Release vX.Y.Z"
$ git tag "vX.Y.Z"
$ git push
$ git push --tags
$ git checkout master
$ git pull
$ git merge "vX.Y.Z"
$ git push

Push packaging to the test cheeseshop:

$ pip install wheel
$ python ./setup.py register -r testpypi
$ rm -rf ./build ./dist
$ python ./setup.py sdist bdist_egg bdist_wheel upload -r testpypi

Publish packaging to PyPi:

$ python ./setup.py register -r pypi
$ rm -rf ./build ./dist
$ python ./setup.py sdist bdist_egg bdist_wheel upload -r pypi

Bump revision back to its development state:

$ pip install bumpversion
$ git checkout develop
$ bumpversion --verbose patch
$ git add ./chessboard/__init__.py ./CHANGES.rst
$ git commit -m "Post release version bump."
$ git push

Now if the next revision is no longer bug-fix only:

$ bumpversion --verbose minor
$ git add ./chessboard/__init__.py ./CHANGES.rst
$ git commit -m "Next release no longer bug-fix only. Bump revision."
$ git push

Third-party

This project package’s boilerplate is sourced from the code I wrote for Scaleway’s postal-address module, which is published under a GPLv2+ License.

The CLI code is based on the one I wrote for the kdenlive-tools module, published under a BSD license.

License

This software is licensed under the GNU General Public License v2 or later (GPLv2+).

ChangeLog

1.0.0 (2015-08-27)

  • Do not spend time converting back and forth linear position to 2D position. Provides a 1.16x speed-up.

  • Proceed permutation exploration with pieces of biggest territory coverage first. Adds 16x speed-up. Closes #5.

  • Add support for bumpversion.

  • Add new --profile option to produce an execution profile of the solver.

0.9.1 (2015-08-25)

  • Fix rendering of unicode string in terminal.

  • Document stability policy and release process.

  • Add PyPi-based badges.

0.9.0 (2015-08-25)

  • Validate CLI user inputs and provides hints.

  • Abandon branches of the search space as soon as possible. Closes #3.

  • Deduplicate per-kind piece group permutations early. Closes #7.

  • Add --silent option to skip displaying of all board results in ASCII art.

0.8.0 (2015-08-15)

  • Refactor solver to deduplicate positions by kind (combination) before iterating the search space by brute force (cartesian product).

0.7.0 (2015-08-14)

  • Display results in unicode-art.

0.6.0 (2015-08-14)

  • Add Knight model.

0.5.0 (2015-08-13)

  • Add Rook and Bishop models.

  • Allow overlapping but non-threatening territory of pieces to co-exists.

0.4.0 (2015-08-13)

  • Add project status badges.

  • Enable continuous integration metrics: build status, coverage and code quality.

  • Fix index to position computation in non-square boards.

  • Remove restriction on board dimensions.

  • Unit-tests result sets produced by the solver.

0.3.0 (2015-08-12)

  • Add Queen piece.

  • Fix displaying of piece representation.

  • Fix persistence of square occupancy between each piece addition.

0.2.1 (2015-08-11)

  • Fix King displacement map.

0.2.0 (2015-08-11)

  • Allow initialization of board pieces.

  • Implement brute-force solver.

0.1.1 (2015-08-08)

  • Package re-release to fix bad version number.

0.1.0 (2015-08-08)

  • First public release.

  • Implements a CLI to inititalize the chessboard.

0.0.0 (2015-08-08)

  • First commit.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

chessboard-1.0.0.tar.gz (26.6 kB view details)

Uploaded Source

Built Distributions

chessboard-1.0.0-py2.7.egg (20.9 kB view details)

Uploaded Source

chessboard-1.0.0-py2-none-any.whl (25.4 kB view details)

Uploaded Python 2

File details

Details for the file chessboard-1.0.0.tar.gz.

File metadata

  • Download URL: chessboard-1.0.0.tar.gz
  • Upload date:
  • Size: 26.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for chessboard-1.0.0.tar.gz
Algorithm Hash digest
SHA256 0d76076d484853704b8e668e77caed9b75e00d8d460c08cab146387853ee0d14
MD5 e04d249d66d605959ee0d869818f82b5
BLAKE2b-256 30088a60ab71f7aa8217595decddbe80994bfe754485d886bbfe1478a85a2c66

See more details on using hashes here.

File details

Details for the file chessboard-1.0.0-py2.7.egg.

File metadata

File hashes

Hashes for chessboard-1.0.0-py2.7.egg
Algorithm Hash digest
SHA256 50e82c75167b758fff23bb6b1a3d6c12f98074711211856d0dc88d4da09d2ccc
MD5 bf38dd0c093b48a95aa3685562e31c7c
BLAKE2b-256 c41c26298348cd735be7d1f8ef6ce9294c40c60a8c7769d14fb7b3dc10798394

See more details on using hashes here.

File details

Details for the file chessboard-1.0.0-py2-none-any.whl.

File metadata

File hashes

Hashes for chessboard-1.0.0-py2-none-any.whl
Algorithm Hash digest
SHA256 18dc2f7a772b99840eb98c0397e3fe2d4fda143934f50509678001d8016659af
MD5 29e5a1833cd1202f7928ddca627234cb
BLAKE2b-256 38a6b6c79255465f979a72561b07cc485667464f18e904981746e3230c0f0ce5

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page