NAME
Chess::Game::MoveListEntry - a read-only class containing move data, used by Chess::Game::MoveList to record a game.
SYNOPSIS
$entry = Chess::Game::MoveListEntry->new(1, $pawn, "e2", "e4", 0); $one = $entry->get_move_num(); $pawn = $entry->get_piece(); $e2 = $entry->get_start_square(); $e4 = $entry->get_dest_square(); $false = $entry->is_capture(); $false = $entry->is_short_castle(); $false = $entry->is_long_castle(); $false = $entry->is_en_passant();
DESCRIPTION
The Chess module provides a framework for writing chess programs with Perl. This class forms part of that framework, containing object data about a single move.
METHODS
Construction
- new()
-
Constructs a new MoveListEntry with the provided parameters. Requires four scalar parameters containing move number, piece, start square and destination square. Optionally takes a fifth parameter containing flags for the entry. The following flags are recognized (but there are no exported constants for them):
MOVE_CAPTURE == 0x01 MOVE_CASTLE_SHORT == 0x02 MOVE_CASTLE_LONG == 0x04 MOVE_EN_PASSANT == 0x08 $entry = Chess::Game::MoveListEntry->new(1, $pawn, "e2", "e4", 0);
Class methods
There are no class methods for this class.
Object methods
- get_move_num()
-
Takes no parameters. Returns the move number this entry was constructed with.
- get_piece()
-
Takes no parameters. Returns the piece reference this entry was constructed with.
- get_start_square()
-
Takes no parameters. Returns the start square this entry was constructed with.
- get_dest_square()
-
Takes no parameters. Returns the destination square this entry was constructed with.
- is_capture()
-
Takes no parameters. Returns true if the entry was recorded as a capture
- is_short_castle()
-
Takes no parameters. Returns true if the entry was recorded as a short (kingside) castle.
- is_long_castle()
-
Takes no parameters. Returns true if the entry was recorded as a long (queenside) castle.
- is_en_passant()
-
Takes no parameters. Returns true if the entry was recorded as an 'en passant' capture. "is_capture()" will also return true in this case.
DIAGNOSTICS
- Invalid Chess::Game::MoveListEntry reference
-
The program uses a reference to a MoveListEntry that was not obtained by calling "new()". Ensure that all MoveListEntries in the program were obtained either in this fashion, or through the container class, Chess::Game::MoveList, and that the reference refers to a defined value.
BUGS
Please report any bugs to the author.
AUTHOR
Brian Richardson <bjr@cpan.org>
COPYRIGHT
Copyright (c) 2002, 2005 Brian Richardson. All rights reserved. This module is Free Software. It may be modified and redistributed under the same terms as Perl itself.
6 POD Errors
The following errors were encountered while parsing the POD:
- Around line 28:
'=item' outside of any '=over'
- Around line 43:
You forgot a '=back' before '=head2'
- Around line 49:
'=item' outside of any '=over'
- Around line 86:
You forgot a '=back' before '=head1'
- Around line 88:
'=item' outside of any '=over'
- Around line 95:
You forgot a '=back' before '=head1'