chess 0.0.9 → 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.gitignore +0 -1
- data/Rakefile +1 -0
- data/doc/apple-touch-icon.png +0 -0
- data/doc/classes/Chess.html +162 -0
- data/doc/classes/Chess/BadNotationError.html +84 -0
- data/doc/classes/Chess/Board.html +795 -0
- data/doc/classes/Chess/CGame.html +1168 -0
- data/doc/classes/Chess/Game.html +775 -0
- data/doc/classes/Chess/Gnuchess.html +206 -0
- data/doc/classes/Chess/IllegalMoveError.html +82 -0
- data/doc/classes/Chess/InvalidFenFormatError.html +82 -0
- data/doc/classes/Chess/InvalidPgnFormatError.html +82 -0
- data/doc/classes/Chess/Pgn.html +332 -0
- data/doc/classes/Chess/UTF8Notation.html +175 -0
- data/doc/created.rid +15 -0
- data/doc/css/github.css +123 -0
- data/doc/css/main.css +323 -0
- data/doc/css/panel.css +384 -0
- data/doc/css/reset.css +48 -0
- data/doc/favicon.ico +0 -0
- data/doc/files/README_rdoc.html +122 -0
- data/doc/files/ext/bitboard_c.html +68 -0
- data/doc/files/ext/board_c.html +68 -0
- data/doc/files/ext/chess_c.html +68 -0
- data/doc/files/ext/common_c.html +68 -0
- data/doc/files/ext/game_c.html +68 -0
- data/doc/files/ext/special_c.html +68 -0
- data/doc/files/lib/chess/exceptions_rb.html +94 -0
- data/doc/files/lib/chess/game_rb.html +84 -0
- data/doc/files/lib/chess/gnuchess_rb.html +84 -0
- data/doc/files/lib/chess/pgn_rb.html +84 -0
- data/doc/files/lib/chess/utf8_notation_rb.html +84 -0
- data/doc/files/lib/chess/version_rb.html +85 -0
- data/doc/files/lib/chess_rb.html +84 -0
- data/doc/i/arrows.png +0 -0
- data/doc/i/results_bg.png +0 -0
- data/doc/i/tree_bg.png +0 -0
- data/doc/index.html +13 -0
- data/doc/js/highlight.pack.js +1 -0
- data/doc/js/jquery-1.3.2.min.js +19 -0
- data/doc/js/jquery-effect.js +593 -0
- data/doc/js/main.js +24 -0
- data/doc/js/navigation.js +142 -0
- data/doc/js/search_index.js +1 -0
- data/doc/js/searchdoc.js +449 -0
- data/doc/js/searcher.js +228 -0
- data/doc/panel/index.html +73 -0
- data/doc/panel/links.html +34 -0
- data/doc/panel/tree.js +1 -0
- data/ext/chess.c +82 -33
- data/ext/chess.h +1 -1
- data/ext/common.c +1 -1
- data/ext/common.h +1 -1
- data/ext/game.c +7 -6
- data/ext/game.h +1 -1
- data/lib/chess/exceptions.rb +2 -1
- data/lib/chess/game.rb +18 -5
- data/lib/chess/gnuchess.rb +1 -1
- data/lib/chess/utf8_notation.rb +1 -0
- data/lib/chess/version.rb +1 -1
- metadata +50 -3
data/doc/css/panel.css
ADDED
@@ -0,0 +1,384 @@
|
|
1
|
+
/* Panel (begin) */
|
2
|
+
.panel
|
3
|
+
{
|
4
|
+
position: absolute;
|
5
|
+
width: 100%;
|
6
|
+
height: 100%;
|
7
|
+
top: 0;
|
8
|
+
left: 0;
|
9
|
+
background: #FFF;
|
10
|
+
z-index: 2;
|
11
|
+
font-family: "Helvetica Neue", "Arial", sans-serif;
|
12
|
+
//zoom: 1;
|
13
|
+
}
|
14
|
+
|
15
|
+
.panel_tree .results,
|
16
|
+
.panel_results .tree
|
17
|
+
{
|
18
|
+
display: none;
|
19
|
+
}
|
20
|
+
|
21
|
+
/* Header with search box (begin) */
|
22
|
+
.panel .header
|
23
|
+
{
|
24
|
+
width: 100%;
|
25
|
+
height: 29px;
|
26
|
+
border-bottom: 1px solid #666;
|
27
|
+
position: relative;
|
28
|
+
left: 0; top: 0;
|
29
|
+
background: #e8e8e8;
|
30
|
+
}
|
31
|
+
|
32
|
+
.panel .header div
|
33
|
+
{
|
34
|
+
margin: 0 7px;
|
35
|
+
}
|
36
|
+
.panel .header table
|
37
|
+
{
|
38
|
+
height: 29px;
|
39
|
+
width: 100%;
|
40
|
+
}
|
41
|
+
|
42
|
+
.panel .header table td
|
43
|
+
{
|
44
|
+
vertical-align: middle;
|
45
|
+
text-align: middle;
|
46
|
+
}
|
47
|
+
|
48
|
+
.panel .header label
|
49
|
+
{
|
50
|
+
position: absolute;
|
51
|
+
font-size: 12px;
|
52
|
+
line-height: 29px;
|
53
|
+
margin-left: 3px;
|
54
|
+
color: #999;
|
55
|
+
cursor: text;
|
56
|
+
}
|
57
|
+
|
58
|
+
.panel .header table input
|
59
|
+
{
|
60
|
+
width: 100%;
|
61
|
+
box-sizing: border-box;
|
62
|
+
-moz-box-sizing: border-box;
|
63
|
+
-webkit-box-sizing: border-box;
|
64
|
+
display: inline-block;
|
65
|
+
-webkit-appearance: searchfield;
|
66
|
+
height: 22px;
|
67
|
+
//height: auto;
|
68
|
+
}
|
69
|
+
|
70
|
+
/* Header with search box (end) */
|
71
|
+
|
72
|
+
|
73
|
+
/* Results (begin) */
|
74
|
+
.panel .result
|
75
|
+
{
|
76
|
+
position: absolute;
|
77
|
+
top: 30px;
|
78
|
+
bottom: 0;
|
79
|
+
left: 0;
|
80
|
+
width: 100%;
|
81
|
+
//height: expression((this.parentNode.offsetHeight - 31));
|
82
|
+
overflow-y: scroll;
|
83
|
+
overflow-x: hidden;
|
84
|
+
-overflow-y: hidden;
|
85
|
+
background: #EDF3FE url(../i/results_bg.png);
|
86
|
+
z-index: 2;
|
87
|
+
//zoom:1;
|
88
|
+
}
|
89
|
+
|
90
|
+
.panel .result ul
|
91
|
+
{
|
92
|
+
font-size: 0.8em;
|
93
|
+
width: 100%;
|
94
|
+
background: #EDF3FE url(../i/results_bg.png);
|
95
|
+
//zoom:1;
|
96
|
+
}
|
97
|
+
|
98
|
+
.panel .result ul li
|
99
|
+
{
|
100
|
+
height: 46px;
|
101
|
+
-height: 50px;
|
102
|
+
//display: inline;
|
103
|
+
//width: 100%;
|
104
|
+
//zoom: 1;
|
105
|
+
overflow: hidden;
|
106
|
+
padding: 4px 10px 0 10px;
|
107
|
+
cursor: pointer;
|
108
|
+
}
|
109
|
+
|
110
|
+
.panel .result ul li h1
|
111
|
+
{
|
112
|
+
font-size: 13px;
|
113
|
+
font-weight: normal;
|
114
|
+
color: #333;
|
115
|
+
margin-bottom: 2px;
|
116
|
+
white-space: nowrap;
|
117
|
+
}
|
118
|
+
|
119
|
+
.panel .result ul li p
|
120
|
+
{
|
121
|
+
font-size: 11px;
|
122
|
+
color: #333;
|
123
|
+
margin-bottom: 2px;
|
124
|
+
white-space: nowrap;
|
125
|
+
}
|
126
|
+
|
127
|
+
.panel .result ul li h1 i,
|
128
|
+
.panel .result ul li p.snippet
|
129
|
+
{
|
130
|
+
color: #999;
|
131
|
+
}
|
132
|
+
|
133
|
+
.panel .result ul li b
|
134
|
+
{
|
135
|
+
color: #000;
|
136
|
+
}
|
137
|
+
|
138
|
+
.panel .result ul li.current
|
139
|
+
{
|
140
|
+
background: #3875D7;
|
141
|
+
}
|
142
|
+
|
143
|
+
.panel .result ul li.current h1,
|
144
|
+
.panel .result ul li.current p
|
145
|
+
{
|
146
|
+
color: #DDD;
|
147
|
+
}
|
148
|
+
|
149
|
+
.panel .result ul li.current h1 i,
|
150
|
+
.panel .result ul li.current p.snippet
|
151
|
+
{
|
152
|
+
color: #AAA;
|
153
|
+
}
|
154
|
+
|
155
|
+
.panel .result ul li.current b
|
156
|
+
{
|
157
|
+
color: #FFF;
|
158
|
+
}
|
159
|
+
|
160
|
+
|
161
|
+
.panel .result ul li:hover,
|
162
|
+
.panel .result ul li.selected
|
163
|
+
{
|
164
|
+
background: #d0d0d0;
|
165
|
+
}
|
166
|
+
|
167
|
+
.panel .result ul li.current:hover
|
168
|
+
{
|
169
|
+
background: #2965C0;
|
170
|
+
}
|
171
|
+
|
172
|
+
.panel .result ul li .badge
|
173
|
+
{
|
174
|
+
margin-right: 0.4em;
|
175
|
+
margin-left: -0.2em;
|
176
|
+
padding: 0 0.2em;
|
177
|
+
color: #000;
|
178
|
+
border-radius: 3px;
|
179
|
+
}
|
180
|
+
|
181
|
+
.panel .result ul li .badge_1
|
182
|
+
{
|
183
|
+
background: #ACDBF4;
|
184
|
+
}
|
185
|
+
|
186
|
+
.panel .result ul li.current .badge_1
|
187
|
+
{
|
188
|
+
background: #97BFD7;
|
189
|
+
}
|
190
|
+
|
191
|
+
.panel .result ul li .badge_2
|
192
|
+
{
|
193
|
+
background: #ACF3C3;
|
194
|
+
}
|
195
|
+
|
196
|
+
.panel .result ul li.current .badge_2
|
197
|
+
{
|
198
|
+
background: #98D7AC;
|
199
|
+
}
|
200
|
+
|
201
|
+
.panel .result ul li .badge_3
|
202
|
+
{
|
203
|
+
background: #E0F3AC;
|
204
|
+
}
|
205
|
+
|
206
|
+
.panel .result ul li.current .badge_3
|
207
|
+
{
|
208
|
+
background: #C4D798;
|
209
|
+
}
|
210
|
+
|
211
|
+
.panel .result ul li .badge_4
|
212
|
+
{
|
213
|
+
background: #D7CA98;
|
214
|
+
}
|
215
|
+
|
216
|
+
.panel .result ul li.current .badge_4
|
217
|
+
{
|
218
|
+
background: #A6B0AC;
|
219
|
+
}
|
220
|
+
|
221
|
+
.panel .result ul li .badge_5
|
222
|
+
{
|
223
|
+
background: #F3C8AC;
|
224
|
+
}
|
225
|
+
|
226
|
+
.panel .result ul li.current .badge_5
|
227
|
+
{
|
228
|
+
background: #D7B198;
|
229
|
+
}
|
230
|
+
|
231
|
+
.panel .result ul li .badge_6
|
232
|
+
{
|
233
|
+
background: #F3ACC3;
|
234
|
+
}
|
235
|
+
|
236
|
+
.panel .result ul li.current .badge_6
|
237
|
+
{
|
238
|
+
background: #D798AB;
|
239
|
+
}
|
240
|
+
|
241
|
+
/* Results (end) */
|
242
|
+
|
243
|
+
/* Tree (begin) */ /**/
|
244
|
+
.panel .tree
|
245
|
+
{
|
246
|
+
position: absolute;
|
247
|
+
top: 30px;
|
248
|
+
bottom: 0;
|
249
|
+
left: 0;
|
250
|
+
width: 100%;
|
251
|
+
//zoom: 1;
|
252
|
+
//height: expression((this.parentNode.offsetHeight - 31));
|
253
|
+
overflow-y: scroll;
|
254
|
+
overflow-x: hidden;
|
255
|
+
-overflow-y: hidden;
|
256
|
+
background: #EDF3FE url(../i/tree_bg.png);
|
257
|
+
z-index: 30;
|
258
|
+
}
|
259
|
+
|
260
|
+
.panel .tree ul
|
261
|
+
{
|
262
|
+
background: #EDF3FE url(../i/tree_bg.png);
|
263
|
+
}
|
264
|
+
|
265
|
+
.panel .tree li
|
266
|
+
{
|
267
|
+
cursor: pointer;
|
268
|
+
overflow: hidden;
|
269
|
+
//height: 23px;
|
270
|
+
//display: inline;
|
271
|
+
//zoom: 1;
|
272
|
+
//width: 100%;
|
273
|
+
}
|
274
|
+
|
275
|
+
|
276
|
+
.panel .tree li .content
|
277
|
+
{
|
278
|
+
padding-left: 18px;
|
279
|
+
padding-top: 5px;
|
280
|
+
height: 18px;
|
281
|
+
overflow: hidden;
|
282
|
+
position: relative;
|
283
|
+
}
|
284
|
+
|
285
|
+
.panel .tree li .icon
|
286
|
+
{
|
287
|
+
width: 10px;
|
288
|
+
height: 9px;
|
289
|
+
background: url(../i/arrows.png);
|
290
|
+
background-position: 0 -9px;
|
291
|
+
position: absolute;
|
292
|
+
left: 1px;
|
293
|
+
top: 8px;
|
294
|
+
cursor: default;
|
295
|
+
}
|
296
|
+
|
297
|
+
.panel .tree li.closed .icon
|
298
|
+
{
|
299
|
+
background-position: 0 0;
|
300
|
+
}
|
301
|
+
|
302
|
+
.panel .tree ul li h1
|
303
|
+
{
|
304
|
+
font-size: 13px;
|
305
|
+
font-weight: normal;
|
306
|
+
color: #000;
|
307
|
+
margin-bottom: 2px;
|
308
|
+
white-space: nowrap;
|
309
|
+
}
|
310
|
+
|
311
|
+
.panel .tree ul li p
|
312
|
+
{
|
313
|
+
font-size: 11px;
|
314
|
+
color: #666;
|
315
|
+
margin-bottom: 2px;
|
316
|
+
white-space: nowrap;
|
317
|
+
}
|
318
|
+
|
319
|
+
.panel .tree ul li h1 i
|
320
|
+
{
|
321
|
+
color: #999;
|
322
|
+
font-style: normal;
|
323
|
+
}
|
324
|
+
|
325
|
+
.panel .tree ul li.empty
|
326
|
+
{
|
327
|
+
cursor: text;
|
328
|
+
}
|
329
|
+
|
330
|
+
.panel .tree ul li.empty h1,
|
331
|
+
.panel .tree ul li.empty p
|
332
|
+
{
|
333
|
+
color: #666;
|
334
|
+
font-style: italic;
|
335
|
+
}
|
336
|
+
|
337
|
+
.panel .tree ul li.current
|
338
|
+
{
|
339
|
+
background: #3875D7;
|
340
|
+
}
|
341
|
+
|
342
|
+
.panel .tree ul li.current .icon
|
343
|
+
{
|
344
|
+
background-position: -10px -9px;
|
345
|
+
}
|
346
|
+
|
347
|
+
.panel .tree ul li.current.closed .icon
|
348
|
+
{
|
349
|
+
background-position: -10px 0;
|
350
|
+
}
|
351
|
+
|
352
|
+
.panel .tree ul li.current h1
|
353
|
+
{
|
354
|
+
color: #FFF;
|
355
|
+
}
|
356
|
+
|
357
|
+
.panel .tree ul li.current p
|
358
|
+
{
|
359
|
+
color: #CCC;
|
360
|
+
}
|
361
|
+
|
362
|
+
.panel .tree ul li.current.empty h1,
|
363
|
+
.panel .tree ul li.current.empty p
|
364
|
+
{
|
365
|
+
color: #999;
|
366
|
+
}
|
367
|
+
|
368
|
+
.panel .tree ul li:hover
|
369
|
+
{
|
370
|
+
background: #d0d0d0;
|
371
|
+
}
|
372
|
+
|
373
|
+
.panel .tree ul li.current:hover
|
374
|
+
{
|
375
|
+
background: #2965C0;
|
376
|
+
}
|
377
|
+
|
378
|
+
.panel .tree .stopper
|
379
|
+
{
|
380
|
+
display: none;
|
381
|
+
}
|
382
|
+
/* Tree (end) */ /**/
|
383
|
+
|
384
|
+
/* Panel (end) */
|
data/doc/css/reset.css
ADDED
@@ -0,0 +1,48 @@
|
|
1
|
+
/* http://meyerweb.com/eric/tools/css/reset/ */
|
2
|
+
/* v1.0 | 20080212 */
|
3
|
+
|
4
|
+
html, body, div, span, applet, object, iframe,
|
5
|
+
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
|
6
|
+
a, abbr, acronym, address, big, cite, code,
|
7
|
+
del, dfn, em, font, img, ins, kbd, q, s, samp,
|
8
|
+
small, strike, strong, sub, sup, tt, var,
|
9
|
+
b, u, i, center,
|
10
|
+
dl, dt, dd, ol, ul, li,
|
11
|
+
fieldset, form, label, legend,
|
12
|
+
table, caption, tbody, tfoot, thead, tr, th, td {
|
13
|
+
margin: 0;
|
14
|
+
padding: 0;
|
15
|
+
border: 0;
|
16
|
+
outline: 0;
|
17
|
+
font-size: 100%;
|
18
|
+
vertical-align: baseline;
|
19
|
+
background: transparent;
|
20
|
+
}
|
21
|
+
body {
|
22
|
+
line-height: 1;
|
23
|
+
}
|
24
|
+
ol, ul {
|
25
|
+
list-style: none;
|
26
|
+
}
|
27
|
+
blockquote, q {
|
28
|
+
quotes: none;
|
29
|
+
}
|
30
|
+
blockquote:before, blockquote:after,
|
31
|
+
q:before, q:after {
|
32
|
+
content: '';
|
33
|
+
content: none;
|
34
|
+
}
|
35
|
+
|
36
|
+
/* remember to highlight inserts somehow! */
|
37
|
+
ins {
|
38
|
+
text-decoration: none;
|
39
|
+
}
|
40
|
+
del {
|
41
|
+
text-decoration: line-through;
|
42
|
+
}
|
43
|
+
|
44
|
+
/* tables still need 'cellspacing="0"' in the markup */
|
45
|
+
table {
|
46
|
+
border-collapse: collapse;
|
47
|
+
border-spacing: 0;
|
48
|
+
}
|
data/doc/favicon.ico
ADDED
Binary file
|
@@ -0,0 +1,122 @@
|
|
1
|
+
<?xml version="1.0" encoding="utf-8"?>
|
2
|
+
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
3
|
+
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
4
|
+
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
5
|
+
<head>
|
6
|
+
<title>README.rdoc</title>
|
7
|
+
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
8
|
+
<link rel="stylesheet" href="../css/reset.css" type="text/css" media="screen" />
|
9
|
+
<link rel="stylesheet" href="../css/main.css" type="text/css" media="screen" />
|
10
|
+
<link rel="stylesheet" href="../css/github.css" type="text/css" media="screen" />
|
11
|
+
<script src="../js/jquery-1.3.2.min.js" type="text/javascript" charset="utf-8"></script>
|
12
|
+
<script src="../js/jquery-effect.js" type="text/javascript" charset="utf-8"></script>
|
13
|
+
<script src="../js/main.js" type="text/javascript" charset="utf-8"></script>
|
14
|
+
<script src="../js/highlight.pack.js" type="text/javascript" charset="utf-8"></script>
|
15
|
+
|
16
|
+
</head>
|
17
|
+
|
18
|
+
<body>
|
19
|
+
<div class="banner">
|
20
|
+
|
21
|
+
<h1>
|
22
|
+
README.rdoc
|
23
|
+
</h1>
|
24
|
+
<ul class="files">
|
25
|
+
<li>README.rdoc</li>
|
26
|
+
<li>Last modified: 2016-03-21 01:23:15 +0100</li>
|
27
|
+
</ul>
|
28
|
+
</div>
|
29
|
+
|
30
|
+
<div id="bodyContent">
|
31
|
+
<div id="content">
|
32
|
+
|
33
|
+
<div class="description">
|
34
|
+
|
35
|
+
<h1 id="label-Chess"><a href="../classes/Chess.html">Chess</a></h1>
|
36
|
+
|
37
|
+
<p>A fast Ruby library to play chess with Ruby. This library is quite fast
|
38
|
+
because rappresent the game situations with bitboards. In addition, the
|
39
|
+
move generator is written in C as a Ruby extension.</p>
|
40
|
+
|
41
|
+
<h2 id="label-Requirements">Requirements</h2>
|
42
|
+
<ul><li>
|
43
|
+
<p>Ruby 1.9 or higher</p>
|
44
|
+
</li></ul>
|
45
|
+
|
46
|
+
<h2 id="label-Installation">Installation</h2>
|
47
|
+
|
48
|
+
<pre><code>gem install chess
|
49
|
+
</code></pre>
|
50
|
+
|
51
|
+
<h2 id="label-Usage">Usage</h2>
|
52
|
+
|
53
|
+
<pre><code>require 'chess'
|
54
|
+
g = Chess::Game.new
|
55
|
+
until g.over?
|
56
|
+
begin
|
57
|
+
print "Give me a #{g.active_player} move: "
|
58
|
+
input = gets.chop
|
59
|
+
break if input == 'quit'
|
60
|
+
g << input
|
61
|
+
puts g
|
62
|
+
puts g.moves.last
|
63
|
+
rescue Chess::IllegalMoveError => e
|
64
|
+
puts 'Illegal move!'
|
65
|
+
end
|
66
|
+
end
|
67
|
+
puts g.status
|
68
|
+
</code></pre>
|
69
|
+
|
70
|
+
<p>Documentation is available <a href="http://pioz.github.com/chess">here</a>.</p>
|
71
|
+
|
72
|
+
<h2 id="label-Questions+or+problems-3F">Questions or problems?</h2>
|
73
|
+
|
74
|
+
<p>If you have any issues please add an <a
|
75
|
+
href="https://github.com/pioz/chess/issues">issue on GitHub</a> or fork the
|
76
|
+
project and send a pull request.</p>
|
77
|
+
|
78
|
+
<h2 id="label-Copyright">Copyright</h2>
|
79
|
+
|
80
|
+
<p>Copyright © 2015 <a href="https://github.com/pioz">Enrico Pilotto
|
81
|
+
(@pioz)</a>. See <a
|
82
|
+
href="https://github.com/pioz/chess/blob/master/LICENSE">LICENSE</a> for
|
83
|
+
details.</p>
|
84
|
+
|
85
|
+
</div>
|
86
|
+
|
87
|
+
|
88
|
+
|
89
|
+
|
90
|
+
|
91
|
+
|
92
|
+
|
93
|
+
|
94
|
+
|
95
|
+
|
96
|
+
|
97
|
+
|
98
|
+
|
99
|
+
|
100
|
+
|
101
|
+
|
102
|
+
|
103
|
+
|
104
|
+
|
105
|
+
|
106
|
+
|
107
|
+
|
108
|
+
|
109
|
+
|
110
|
+
|
111
|
+
|
112
|
+
|
113
|
+
|
114
|
+
|
115
|
+
|
116
|
+
|
117
|
+
<!-- Methods -->
|
118
|
+
</div>
|
119
|
+
|
120
|
+
</div>
|
121
|
+
</body>
|
122
|
+
</html>
|