Library that ensures that all the rules of classical chess are followed.
Find a file
Loic Guegan 159d533412 - Add drawing methods to the API
- Improve tests
2022-01-30 10:00:28 +01:00
src - Add drawing methods to the API 2022-01-30 10:00:28 +01:00
tests - Add drawing methods to the API 2022-01-30 10:00:28 +01:00
.gitignore Init project 2022-01-29 11:52:47 +01:00
.gitlab-ci.yml Init project 2022-01-29 11:52:47 +01:00
CMakeLists.txt Init project 2022-01-29 11:52:47 +01:00
LICENSE Add license 2022-01-29 11:55:03 +01:00
Makefile Init project 2022-01-29 11:52:47 +01:00
README.md Update readme 2022-01-29 18:18:16 +01:00

pipeline license

ChessArbiter

ChessArbiter is a library that allow you to play chess games in C++. It ensures that all the rules of classical chess are followed.

Features

  • No external dependencies
  • Simple/Minimal API
  • FEN parsing/serializing
  • Setup a position a play moves
  • Perform various tests on a position:
    • Material
    • Players in check
    • Players captures
    • Castle
    • Attacked squares
    • Checkmate
    • ...
  • More features are coming soon!

How to setup ChessArbiter

ChessArbiter can be used as a shared library in your project. You only need to include ChessArbiter.hpp and linking the .so file to your executable.

Example

Somewhere at the beginning of the file:

#include "ChessArbiter.hpp"

Start playing:

ChessArbiter arbiter;
arbiter.Setup("rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w KQkq - 0 1");
// Now start playing!
if(!arbiter.Play("e2e4")){
    // Handle illegal moves
}
if(arbiter.IsCheckmate()){
    // Game ends
}

See ChessArbiter.hpp for more informations on the API.

CMake Integration

By using the add_subdirectory() directive on this repository, you will be able to use the following cmake calls in your project:

include_directories(${CHESSARBITER_INCLUDE_DIR})
target_link_libraries(<YOUR_TARGET> chessarbiter)