blob: 53b790bd18acda6d6eaf0a19a612af6d3e9c2f1d (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
import sys
from . import DealFormat
from .bri import BRIFormat
from .dge import DGEFormat
from .. import dto
class DUPFormat(DealFormat):
@property
def suffix(self):
return '.dup'
def __init__(self):
self.bri = BRIFormat()
self.dge = DGEFormat()
def parse_content(self, content):
boards = []
while True:
boards.append(content.read(156))
if len(boards[-1]) < 156:
if len(boards[-1]) > 0:
print 'WARNING: truncated .dup content: %s' % (boards[-1])
boards = boards[0:-1]
break
boards = [(board[0:78], board[78:146], board[146:]) for board in boards]
if boards[0][2][0] == chr(0):
print 'ERROR: .dup file header not found'
sys.exit()
start_board = int(boards[0][2][2:4].strip())
board_count = int(boards[0][2][7:9].strip())
board_numbers = range(start_board, start_board+board_count)
if boards[0][2][1].upper() != 'N':
print 'WARNING: .dup file header has "reverse" flag set, nobody knows what to do with it, so it\'s time to panic'
dealset = []
for idx, board in enumerate(boards):
deal = dto.Deal()
deal.number = board_numbers[idx]
deal.dealer = deal.get_dealer(deal.number)
deal.vulnerable = deal.get_vulnerability(deal.number)
deal.hands = self.bri.parse_hands(board[0])
dealset.append(deal)
return dealset
def output_content(self, out_file, dealset):
board_numbers = [deal.number for deal in dealset]
first_board = min(board_numbers)
board_count = len(dealset)
for board in range(first_board, first_board+board_count):
if board not in board_numbers:
print 'ERROR: .dup format requires consequent board numbers'
sys.exit()
header = 'YN%s 0 %02d ' % (str(first_board).ljust(2, ' '), board_count)
for deal in dealset:
out_file.write(self.bri.single_deal_output(deal))
out_file.write(self.dge.single_deal_output(deal))
if deal.number == first_board:
out_file.write(header)
else:
out_file.write(chr(0) * 10)
|