Compare commits
No commits in common. "6421842c0c28e9d169a17731eb7078fa5f35d60a" and "cb06fc10c8d7109eb61c942ec61f41aae96e967e" have entirely different histories.
6421842c0c
...
cb06fc10c8
1 changed files with 14 additions and 63 deletions
|
|
@ -4,17 +4,6 @@ import gdb
|
|||
import gdb.printing
|
||||
|
||||
|
||||
def optional(constructor, val):
|
||||
try:
|
||||
return constructor(val["Some"]["__0"])
|
||||
except gdb.error:
|
||||
return None
|
||||
|
||||
|
||||
def print_opt(val):
|
||||
return "(None)" if val is None else str(val)
|
||||
|
||||
|
||||
class Square(object):
|
||||
"""
|
||||
Python representation of a 'seer::board::square::Square' raw value.
|
||||
|
|
@ -24,14 +13,8 @@ class Square(object):
|
|||
RANKS = list(map(lambda n: str(n + 1), range(8)))
|
||||
|
||||
def __init__(self, val):
|
||||
if isinstance(val, Square):
|
||||
val = val._val
|
||||
self._val = val
|
||||
|
||||
@classmethod
|
||||
def from_gdb(cls, val):
|
||||
return cls(int(val))
|
||||
|
||||
@classmethod
|
||||
def from_file_rank(cls, file, rank):
|
||||
return cls(file * 8 + rank)
|
||||
|
|
@ -54,14 +37,8 @@ class Bitboard(object):
|
|||
"""
|
||||
|
||||
def __init__(self, val):
|
||||
if isinstance(val, Bitboard):
|
||||
val = val._val
|
||||
self._val = val
|
||||
|
||||
@classmethod
|
||||
def from_gdb(cls, val):
|
||||
return cls(int(val["__0"]))
|
||||
|
||||
def __str__(self):
|
||||
return "[" + ", ".join(map(str, self.squares)) + "]"
|
||||
|
||||
|
|
@ -88,10 +65,6 @@ class CastleRights(enum.IntEnum):
|
|||
QUEEN_SIDE = 2
|
||||
BOTH_SIDES = 3
|
||||
|
||||
@classmethod
|
||||
def from_gdb(cls, val):
|
||||
return cls(int(val))
|
||||
|
||||
def __str__(self):
|
||||
return self.name.title().replace("_", "")
|
||||
|
||||
|
|
@ -105,10 +78,6 @@ class Color(enum.IntEnum):
|
|||
WHITE = 0
|
||||
BLACK = 1
|
||||
|
||||
@classmethod
|
||||
def from_gdb(cls, val):
|
||||
return cls(int(val))
|
||||
|
||||
def __str__(self):
|
||||
return self.name.title()
|
||||
|
||||
|
|
@ -128,10 +97,6 @@ class File(enum.IntEnum):
|
|||
G = 6
|
||||
H = 7
|
||||
|
||||
@classmethod
|
||||
def from_gdb(cls, val):
|
||||
return cls(int(val))
|
||||
|
||||
def __str__(self):
|
||||
return self.name.title()
|
||||
|
||||
|
|
@ -151,10 +116,6 @@ class Rank(enum.IntEnum):
|
|||
Seventh = 6
|
||||
Eighth = 7
|
||||
|
||||
@classmethod
|
||||
def from_gdb(cls, val):
|
||||
return cls(int(val))
|
||||
|
||||
def __str__(self):
|
||||
return self.name.title()
|
||||
|
||||
|
|
@ -172,10 +133,6 @@ class Piece(enum.IntEnum):
|
|||
KNIGHT = 4
|
||||
PAWN = 5
|
||||
|
||||
@classmethod
|
||||
def from_gdb(cls, val):
|
||||
return cls(int(val))
|
||||
|
||||
def __str__(self):
|
||||
return self.name.title()
|
||||
|
||||
|
|
@ -207,10 +164,6 @@ class Move(object):
|
|||
def __init__(self, val):
|
||||
self._val = val
|
||||
|
||||
@classmethod
|
||||
def from_gdb(cls, val):
|
||||
return cls(int(val))
|
||||
|
||||
@property
|
||||
def piece(self):
|
||||
return Piece(self._val >> self.PIECE_SHIFT & self.PIECE_MASK)
|
||||
|
|
@ -260,6 +213,7 @@ class Move(object):
|
|||
"double_step",
|
||||
"castling",
|
||||
]
|
||||
print_opt = lambda val: "(None)" if val is None else str(val)
|
||||
indent = lambda s: " " + s
|
||||
|
||||
values = [key + ": " + print_opt(getattr(self, key)) + ",\n" for key in KEYS]
|
||||
|
|
@ -280,7 +234,6 @@ class ChessBoard(object):
|
|||
half_move_clock,
|
||||
total_plies,
|
||||
side,
|
||||
en_passant,
|
||||
):
|
||||
self._piece_occupancy = list(map(Bitboard, piece_occupancy))
|
||||
self._color_occupancy = list(map(Bitboard, color_occupancy))
|
||||
|
|
@ -288,18 +241,17 @@ class ChessBoard(object):
|
|||
self._half_move_clock = int(half_move_clock)
|
||||
self._total_plies = int(total_plies)
|
||||
self._side = Color(side)
|
||||
self._en_passant = None if en_passant is None else Square(en_passant)
|
||||
|
||||
@classmethod
|
||||
def from_gdb(cls, val):
|
||||
return cls(
|
||||
[Bitboard.from_gdb(val["piece_occupancy"][p]) for p in Piece],
|
||||
[Bitboard.from_gdb(val["color_occupancy"][c]) for c in Color],
|
||||
[CastleRights.from_gdb(val["castle_rights"][c]) for c in Color],
|
||||
[int(val["piece_occupancy"][p]["__0"]) for p in Piece],
|
||||
[int(val["color_occupancy"][c]["__0"]) for c in Color],
|
||||
[int(val["castle_rights"][c]) for c in Color],
|
||||
# FIXME: find out how to check for Some/None in val["en_passant"],
|
||||
int(val["half_move_clock"]),
|
||||
int(val["total_plies"]),
|
||||
Color.from_gdb(val["side"]),
|
||||
optional(Square.from_gdb, val["en_passant"]),
|
||||
Color(int(val["side"])),
|
||||
)
|
||||
|
||||
def at(self, square):
|
||||
|
|
@ -340,7 +292,6 @@ class ChessBoard(object):
|
|||
"Half-move clock: " + str(self._half_move_clock),
|
||||
"Total plies: " + str(self._total_plies),
|
||||
"Side to play: " + str(self._side),
|
||||
"En passant: " + print_opt(self._en_passant),
|
||||
]
|
||||
return "\n".join(res)
|
||||
|
||||
|
|
@ -349,7 +300,7 @@ class SquarePrinter(object):
|
|||
"Print a seer::board::square::Square"
|
||||
|
||||
def __init__(self, val):
|
||||
self._val = Square.from_gdb(val)
|
||||
self._val = Square(val)
|
||||
|
||||
def to_string(self):
|
||||
return str(self._val)
|
||||
|
|
@ -359,7 +310,7 @@ class BitboardPrinter(object):
|
|||
"Print a seer::board::bitboard::Bitboard"
|
||||
|
||||
def __init__(self, val):
|
||||
self._val = Bitboard.from_gdb(val)
|
||||
self._val = Bitboard(int(val["__0"]))
|
||||
|
||||
def to_string(self):
|
||||
return "Bitboard{" + str(self._val)[1:-1] + "}"
|
||||
|
|
@ -369,7 +320,7 @@ class CastleRightsPrinter(object):
|
|||
"Print a seer::board::castle_rights::CastleRights"
|
||||
|
||||
def __init__(self, val):
|
||||
self._val = CastleRights.from_gdb(val)
|
||||
self._val = CastleRights(int(val))
|
||||
|
||||
def to_string(self):
|
||||
return str(self._val)
|
||||
|
|
@ -379,7 +330,7 @@ class ColorPrinter(object):
|
|||
"Print a seer::board::color::Color"
|
||||
|
||||
def __init__(self, val):
|
||||
self._val = Color.from_gdb(val)
|
||||
self._val = Color(int(val))
|
||||
|
||||
def to_string(self):
|
||||
return str(self._val)
|
||||
|
|
@ -389,7 +340,7 @@ class FilePrinter(object):
|
|||
"Print a seer::board::file::File"
|
||||
|
||||
def __init__(self, val):
|
||||
self._val = File.from_gdb(val)
|
||||
self._val = File(int(val))
|
||||
|
||||
def to_string(self):
|
||||
return str(self._val)
|
||||
|
|
@ -399,7 +350,7 @@ class RankPrinter(object):
|
|||
"Print a seer::board::rank::Rank"
|
||||
|
||||
def __init__(self, val):
|
||||
self._val = Rank.from_gdb(val)
|
||||
self._val = Rank(int(val))
|
||||
|
||||
def to_string(self):
|
||||
return str(self._val)
|
||||
|
|
@ -409,7 +360,7 @@ class PiecePrinter(object):
|
|||
"Print a seer::board::piece::Piece"
|
||||
|
||||
def __init__(self, val):
|
||||
self._val = Piece.from_gdb(val)
|
||||
self._val = Piece(int(val))
|
||||
|
||||
def to_string(self):
|
||||
return str(self._val)
|
||||
|
|
@ -419,7 +370,7 @@ class MovePrinter(object):
|
|||
"Print a seer::board::move::Move"
|
||||
|
||||
def __init__(self, val):
|
||||
self._val = Move.from_gdb(val)
|
||||
self._val = Move(int(val["__0"]))
|
||||
|
||||
def to_string(self):
|
||||
return str(self._val)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue