Crate transforms algebraic chess notation into software readable structs and
vice versa. Parsed chess notation for each turn is stored within Turn
struct.
To parse a certain chess turn, such as d2xe3
, send it in form of &str
as
an argument into Turn::try_from()
function.
Turn
is an enum with two elements:
- Castling
- a struct which describes castling turn
- Move
- a struct which describes every other possible turn
Castling
turn0-0
will be translated to:```rust
Turn::Castling(Castling { r#type: CastlingType::Short, flags: Flag::NONE, });
```
Move
turnsd6
will be translated to:```rust
Turn::Move (Move { who: Piece::Pawn, dst: Square::D6, flags: Flag::NONE, src: None, promotion: None, });
```
d7xe8=B+?
will be translated to:```rust
Turn::Move (Move { who: Piece::Pawn, dst: Square::E8, flags: Flag::CHECK | Flag::CAPTURE, src: Some(vec![Square::D7]), promotion: Some(Piece::Bishop), });
```
Nab3#
will be translated to:```rust
Turn::Move (Move { who: Piece::Knight, dst: Square::B3, flags: Flag::CHECKMATE, src: Some(Square::get_file('a').unwrap()), // Vector of 'Ax' squares promotion: None, });
```
Square notation should use lowercase alphabetic characters
a1
, a2
... h7
, h8
.Castling notation can be written with both 0
and O
0-0-0
or O-O
Castling
turn is printed out, it will be printed with 0
notationNotation for pieces:
K
: KingQ
: QueenR
: RookB
: BishopN
: KnightCapture is annotated with a lowercase x
character
Qxd3
Check is annotated with a +
character
Qd3+
Checkmate is annotated with a #
character
Qd3#
Pawn promotion is annoted with =
symbol followed by a piece to which
pawn is promoted to
8
and 1
g8=Q
Comments ??
, !!
, ?
, !
, !?
, ?!
are allowed only at the end of
the turn
a1=B??
??a1=B