Antzy21.Games.Checkerboard 1.1.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package Antzy21.Games.Checkerboard --version 1.1.0
NuGet\Install-Package Antzy21.Games.Checkerboard -Version 1.1.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Antzy21.Games.Checkerboard" Version="1.1.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Antzy21.Games.Checkerboard --version 1.1.0
#r "nuget: Antzy21.Games.Checkerboard, 1.1.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Antzy21.Games.Checkerboard as a Cake Addin
#addin nuget:?package=Antzy21.Games.Checkerboard&version=1.1.0

// Install Antzy21.Games.Checkerboard as a Cake Tool
#tool nuget:?package=Antzy21.Games.Checkerboard&version=1.1.0

Checkerboard

This library is for creating, modifying and accessing a checkboard. A checkboard is a 2D grid of squares, and games that use a checkboard typically have pieces that are placed in the squares available. e.g. Chess and Checkers. Checkerboard is written functionally in F# and does not rely on external packages.

Types and Modules

The Checkerboard library contains 4 types, each with a module to perform functions on the type.

Board

The board type is a 2D array of squares of a generic piece type.

type board<'Piece> = square<'Piece>[,]

The Board module contains submodules for creating a board, getting square(s) and updating a board.

Square

The square type is a record type of an optional generic piece type, and the coordinates it has on a board.

type square<'Piece> = {piece: 'Piece option; coordinates: int * int}

The Square module contains functions for getting its properties, and updating the piece it contains.

Move

The move type is a tuple of two squares.

type move<'Piece> = square<'Piece> * square<'Piece>

It is useful for representing when a piece moves between two squares. The Move module contains functions for getting the pieces on the starting and destination squares, and finding the shift between the two squares.

Coordinates

The coordinates type is a tuple of ints.

type coordinates = int * int

The Coordinates module can parse rank and file naming convention into coordinates.

e.g. "a1" = (0, 0), "c4" = (2, 3)

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
5.0.0 116 1/20/2024
4.0.1 175 11/19/2023
4.0.0 170 5/13/2023
3.0.0 311 1/21/2023
2.0.1 194 3/31/2023
2.0.0 329 11/20/2022
1.2.1 403 10/10/2022
1.2.0 390 10/2/2022
1.1.1 388 9/4/2022
1.1.0 390 9/4/2022
1.0.1 393 9/4/2022
1.0.0 401 9/3/2022