Let mentioning completed tourney file add one cycle
[xboard.git] / ChangeLog
1 ChangeLog for XBoard/WinBoard
2 -----------------------------
3
4 (latest entries created by git log --no-merges --pretty="%ai %an <%ae>:%n%s%n%n%b" vlast.. )
5
6 2011-05-07 18:44:24 -0700 Arun Persaud <arun@nubati.net>:
7 added translations generated via lng2po from all winboard languages
8
9 2011-05-07 18:40:23 -0700 Arun Persaud <arun@nubati.net>:
10 lng2po.sh: added command line options, GPL header
11
12 also use a temporary file generated with mktemp instead of a hard coded one
13
14 2011-05-07 17:53:10 -0700 Arun Persaud <arun@nubati.net>:
15 fixed access rights to winboard language files (644 instead of 655)
16
17 2011-05-07 14:55:55 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
18 Import WinBoard language files into git
19
20 2011-05-06 23:14:02 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
21 Let Shift+RightClick on PV actually play the PV moves
22
23 2011-05-06 18:06:48 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
24 Make book-edit function WB
25
26 The tags dialog is used to display the GUI book moves from the current
27 position, and will be updated when you step or move to another one.
28 The edited move list (with weights) can be written back to the book.
29
30 2011-05-07 16:21:25 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
31 Fix resetting engine options
32
33 Not all options were reset, and -needsNonCompliantFEN was 'reset'
34 to a completely wrong value, so that bad FENs would be sent.
35
36 2011-05-06 18:51:20 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
37 Add -first/secondPgnName option
38
39 This option replaces the tidy name of the engine in the PGN player tags
40 of engine-engine games. In WinBoard engines can be installed with this
41 option through a checkbox in the Load Engine dialog.
42
43 2011-05-06 23:31:36 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
44 Let XB generic popup define default file extensions
45
46
47 2011-05-06 18:25:38 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
48 Save time-control settings in tourney file
49
50 Because parsing the options and storing them in appData is not enough,
51 the time-control code setting the internally used parameters from the
52 appData info in InitBackend was made into a subroutine, and also caled
53 after parsing the tourney file.
54
55 2011-05-06 20:40:34 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
56 Put saveGameFile in tournament dialog
57
58
59 2011-05-06 19:17:56 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
60 Plug memory leak, filenames relative to installDir
61
62 String options are consistently freed now, before assigning a new value
63 to them through strdup. The init code now even does use strdup when
64 setting defaults. This is important for optionslike -lgf, which are not
65 saved in the settings file, and thus are usually left with their
66 default. When a dialog to set them then uses free, this causes a crash.
67 When setting the defaults uses strdup, ParseArgs can already free them.
68 This plugs an important memory leak, as ParseArgs in now called to parse
69 the tourney file before every tourney game (twice!), and the lists of
70 participants and results in it can be quite long.  Macros are defined in
71 common.h to make the code look simpler.
72   Filenames entered through the generic popup are now interpreted
73 relative to the WinBoard installation folder, just as the saveGameFile
74 already was. The code handling the atter was made into a subroutine for
75 this.
76
77 2011-05-06 22:02:53 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
78 Add WB new popup prototypes
79
80
81 2011-05-06 18:58:08 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
82 Add partcipants at bottom in tourney dialog (WB)
83
84
85 2011-05-06 18:56:53 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
86 Fix range of tourneyType spin WB
87
88
89 2011-05-06 18:15:23 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
90 Fix exit popup in tourney mode
91
92 Only the instance finishing the last tourney game will cause a popup
93 with final standings. As long as there are still busy games, it exits or
94 switches back to idle mode silently.
95
96 2011-05-06 18:11:47 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
97 Fix stopping of match in tourney mode
98
99
100 2011-05-06 18:59:26 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
101 Add default extension in file browser
102
103
104 2011-05-06 22:37:14 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
105 Improve sizing of comment and tags dialogs
106
107 There seems to be a bug in Xaw for the sizing of buttons; they get
108 unpredicatble and weird sizes when the size is not explicitly set,
109 possibly stretching the initial width of a dialog to rediculous values.
110 Sizing back to a remembered value from the settings file then makes
111 buttons overlapand text edits shrink to almost nothing. To prevent that
112 we now define exlicit sizes for the buttons in tags and comment popups.
113
114 2011-05-06 21:00:25 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
115 Fix generic combobox bug
116
117 The patch placing gettext markers was done wrong, setting the
118 translated menu text outside the loop, so all entries became the same.
119
120 2011-05-07 14:23:12 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
121 Fix PV walking in analysis mode
122
123 ParsePV assumed that the PV would always have been produced by an engin
124 thinking about the final position of the game (or the one before it). In
125 analysismode, however, the engine can be analysing positions internal to
126 the game, and the PV would be considered invalid. This is fixed by
127 cutting of the tail off the game (shelving it in variation fashion)
128 before starting the PV walk, and reverting afterwards.
129   For this the PushTail and PopTail routines had to be split into an
130 'inner' part, doing the pushing and popping, and an outer part, handling
131 menu graying and popdowns (which is undesirable in in this application).
132
133 2011-05-03 00:24:10 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
134 Lift length-limit on text-edits in WB generic popup
135
136
137 2011-05-04 13:53:05 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
138 Lift limitation of text length in generic dialog XB
139
140 All string options should now point to allocated memory, as strdup /
141 free is consistently used on them. This is OK for values received from
142 ParseArgs, but for non-arg intermediate variables that must receive strg
143 values, such as in the comment and tags popups, strdup has to be used to
144 initialize those.
145
146 2011-05-04 14:53:02 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
147 Implement Tournament Options dialog WinBoard
148
149 The file browser now can select on extension WB generic dialogs,
150 with a default based on the option.max value of the option for which it
151 browses. A textBox can be forced to be multiline by putting the number
152 of extra lines in option.min.
153
154 2011-05-04 15:30:00 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
155 Make option to draw second engine from first list
156
157
158 2011-05-03 00:17:47 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
159 Fix error message on engine load
160
161
162 2011-05-04 15:09:33 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
163 Implement Load Engine dialog in WinBoard
164
165 The Load Engine dialog is implemented for WinBoard, and is invoked by
166 the menu item Engine->Load, which formerly was Install 2nd. Install 1st
167 is renamed 'Edit Engine List'. Unlike in XBoard, the dialog has separate
168 fields for the engine executale and its parameters.
169   The dialog is implemented by converting the Engine Settings popup into
170 a generic dialog generator.
171
172 2011-05-04 13:43:06 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
173 Load new logo on engine change WinBoard
174
175 Picking the logo for the first engine is made into a subroutine. The
176 code for picking the logo of the first engine was made into a subrroutne
177 for this. We use the kludge to recognize the engine by its command line
178 when starting a new engine process.
179
180 2011-05-04 13:36:27 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
181 Allow switching off match mode through menu
182
183 The Machine Match menu item is now checkmarked, and no longer grayed
184 during a match, and clicking it while a match is running will terminate
185 the match after the current game. To not be left with hanging
186 checkmarks, the checkmark is already removed duringthe last match game
187 (which is logically equivalent to ordinary Two Machines mode anyway).
188
189 2011-05-03 00:14:22 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
190 Calculate and display tourney result
191
192
193 2011-05-04 18:42:13 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
194 Implement Tournament Manager
195
196 New command-line options are added to specify the tourney: -tourneyType
197 (-tt), -tourneyCycles (-cy), -participants, -syncAfterRound,
198 -syncAfterCycle, -results, to be saved on a -tourneyFile (-tf), but
199 otherwise volatile. When a tourneyFile is specified during a match,
200 a new routine NextTourneyGame is called from NextMatchGame before every
201 game, to decide the pairing, and unload and redefine the engines, when
202 needed. The XBoard Match Options dialog can be used to set the options
203 and create the tournament file.
204   Actual loading of new engines is done by TwoMachinesEvent, which is
205 now modified to also wait for the feature timeout of the first engine.
206 Waiting for the matchPause is now also implemented there, after waiting
207 for the engines (so they can be started during the pause).
208   Pairings and color assignment is now all done in an absolute
209 (non-incremental) way, based on a new global game-number variable
210 nextGame, which takes over the function of matchGame in a tourney. The
211 latter is now used to count games between the same players, so it can be
212 still used to derive the load-file indexes (again in absolute fashion).
213   The next game to play is already picked in GameEnd, so it can be
214 decided if there is a game to be scheduled, or if we can terminate.
215
216 2011-05-04 15:42:26 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
217 Display note in stead of empty engine-settings dialog XB
218
219
220 2011-04-24 18:02:20 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
221 Fix crash on empty Engine Settings dialog
222
223 The generic popup was not foolproof against this.
224
225 2011-04-22 12:47:24 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
226 Refactor code for loading games and positions in match
227
228 The code in NextMatchGame and MatchEvent was nearly the same,
229 (MatchEvent did a little more error checking, but that is never
230 harmful), and could be combined. In stead of determining the load index
231 incrementally, it is now calculated in an absolute way from the game
232 number, so it can be used more easily in tournament mode.
233
234 2011-04-21 22:37:56 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
235 Add callback possibility to combobox selection
236
237
238 2011-04-24 17:15:23 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
239 Lock game an position file during writing
240
241 The use of flock() on the file desctiptor of the opened stream should
242 guarantee multiple XBoard instances, saving on the same file, will not
243 interleave their PGN games or FEN positions.
244
245 2011-04-27 17:05:06 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
246 Remove building rule for parser.c from WB makefiles
247
248
249 2011-04-29 16:58:49 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
250 Fix Engine Settings buttons in WinBoard
251
252 This was broken by a leftover statement from debugging the -file/-path
253 patch.
254
255 2011-05-02 13:38:14 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
256 Implement flock in WinBoard
257
258 This system function seems unknown in a MinGW compile, so it is
259 implemented with the aid of file byte-range locking, using a lock on the
260 first 1024 bytes of the file as a semaphore.
261
262 2011-04-29 23:06:43 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
263 Fix grayout XB Match Options in ICS mode
264
265
266 2011-05-03 00:22:40 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
267 Delay loading of second engine until it is used
268
269
270 2011-05-02 15:00:03 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
271 Fix zippy bughouse partner bug
272
273 The patchs to subject Zippy messages to coloriation was faulty, because
274 there were messages recognized by zippy that were not colorized, and
275 such messages would then not be 'read away' after zippy recognition
276 (except for the first character). As a result the messages were
277 processed over and over again.
278
279 2011-05-04 10:59:43 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
280 Silence more rpm warnings
281
282
283 2011-05-01 20:33:50 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
284 Fix warnings XBoard file browser
285
286 All the prototypes have been moved to selfile.h, to force uniformity.
287 The order of the #include files xstat.h and selfile.h had to be
288 swapped, to make sure 'struct stat' is a nown type atthe time of
289 prototype declaration. The event handler SFmotionList is considered
290 wrong type because of its third argument (XMotionEvent in stead of
291 XEvent), and had to be casted to (XtEventHandler) when passed to
292 XtAddEventHandler.
293
294 2011-05-04 10:56:05 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
295 Fix some warnings and header-file improvement
296
297 Ther were lot of 'extern' declarations in the x-files, so called
298 'imports from xboard.c', (sometimes backend.c) which logically belonged
299 in xboard.h (backend.h) to ensure their uniform definition. These have
300 now been moved there. Some prototypes have been added in xboard.h as
301 well, for functions that needed calling from xoptions.c.
302
303 2011-05-04 10:50:12 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
304 Create conversion tools for language files
305
306 A shell script "lng2po.sh" is provided, to apply the translation given
307 in a WinBoard .lng file to "xboard.pot", in order to generate a
308 "language.po" file containing translations for all strings for which
309 the .lng file had a translation. It makes use of a file "metascript",
310 which is the ed script used to turn the .lng file in an ed script to
311 turn the .pot into .po. For example, the command "./lng2po.sh
312 espa?ol.lng" will create a file "language.po", which can be renamed to
313 "es.po".
314 ****************************** WARNING ********************************
315   Note that the lng2po script does a "recode" that assumes the given
316 .lng file is encoded in latin-1. This means it canot be used without
317 modification for the Vietnamese and Chinese translation; you would have
318 to replace latin-1 by the applicable encoding first (CP1258 / BG2312 /
319 BIG5).
320
321 2011-04-27 22:04:38 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
322 Put gettext markers in generic dialog creator
323
324 This is done by adding extra XtNstring argumentsto the widget gcreaton,
325 so the displayed name can be different fromthe widget name.
326
327 2011-05-01 19:56:38 -0700 Tim Mann <tim@tim-mann.org>:
328 Use getaddrinfo instead of gethostbyname.  Hopefully this makes us compatible with IPv6 and with hosts that have more than one IP address.  However, I don't know of any chess servers that have either of those properties, so I couldn't test that.  I did test that xboard still works with freechess.org and chessclub.com and that it gives an error message for invalid host names.
329
330
331 2011-04-24 11:18:28 -0700 Arun Persaud <arun@nubati.net>:
332 updated German translation
333
334
335 2011-04-24 11:17:43 -0700 Arun Persaud <arun@nubati.net>:
336 replaced hardcoded email address with generic PACKAGE_BUGREPORT
337
338
339 2011-04-23 10:51:57 -0700 Arun Persaud <arun@nubati.net>:
340 updated po-files; updated german translation
341
342
343 2011-04-23 10:51:02 -0700 Arun Persaud <arun@nubati.net>:
344 updated list of files that include translation strings; updated pot-file
345
346
347 2011-04-22 21:50:58 -0700 Arun Persaud <arun@nubati.net>:
348 marked more strings for gettext that were only marked with N_()
349
350 they need to be marked again with _() when they are used to get the translated string
351
352 2011-04-22 21:39:22 -0700 Arun Persaud <arun@nubati.net>:
353 updated translation files
354
355
356 2011-04-22 21:37:22 -0700 Arun Persaud <arun@nubati.net>:
357 added/fixed i18n support via gettext to xboard
358
359 this was already added a long time ago, but now it's added again to
360 autoconf. Also fixed some compile errors that showed up.
361
362 2011-04-20 10:27:20 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
363 Make engine startup error non-fatal
364
365 When engine startup fails, do not generate a fatal error, but swicth
366 back to -ncp mode. Write on broken pipe errors had to be suppressed for
367 this.
368
369 2011-04-20 14:35:50 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
370 Make engine loadable during session
371
372 A "Load Engine ..." menu item is added to the Engine menu, which pops
373 up a dialog where one can replace the first or second engine by a new
374 one, without destroying the game state. Switching from -ncp to engine
375 mode needed activation of some menu items in SetGNUMode, and
376 re-enabling clockMode. It was also important that noChessProgram is
377 cleared before re-initializing the ChessProgramState.
378   The Load-Engine dialog can select from the list of installed
379 engines, and also add a newly specified engine to this list. In this
380 case it saves the directory, hasBook, and isUCI info with the engine,
381 and optionally the current variant. When loading an engine with a
382 specified variant, it resets the game and switches to the new variant.
383
384 2011-04-18 15:56:47 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
385 Generalize WaitForSecond to WaitForEngine
386
387
388 2011-04-18 15:46:12 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
389 Add UnloadEngine routine
390
391
392 2011-04-20 13:45:51 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
393 Put engine initialization code in per-engine function
394
395 Initializing of the ChessProgramStates first and second from the
396 option settings in appData is now done by separate calls to the same
397 routine. Clearing of options is added to the initialization. This is
398 needed when reloading an engine. This is done in a separate routine,
399 which could also be called on -reset options.
400
401 2011-04-18 13:21:44 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
402 Bring structure in appData engine options
403
404 All options in appData that came in pairs for both engines are replaced
405 by arrays of ENGINES (=2, for now) elements. The use of the named
406 appData field that are replaced in the source is replaced by use of the
407 corresponding array element, by #define directives in common.h, awaiting
408 their replacement.
409
410 2011-04-19 15:15:48 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
411 Fix gettext macros in option dialogs
412
413 The strings in the tables were using _() in stead of N_().
414
415 2011-04-18 20:58:01 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
416 Fix crash on using Engine #1 Settings in ICS non-zippy mode
417
418 If XBoard is compiled with zippy the Engine #1 Settings menu was not
419 grayed out even when you don't run in zippy mode, and using it would
420 then crash XBoard.
421
422 2011-04-19 15:07:31 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
423 Fix shogipixmaps
424
425 Some pixmaps forptomoted pieces had wrong background color, others had a
426 wrong name (so the one with the correct name was missing).
427
428 2011-04-17 19:12:00 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
429 Change texture-install directory to pixmaps/textures
430
431
432 2011-04-17 17:36:32 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
433 Limit install of sound files to those in menu
434
435 The sounds directory is set to .../xboard/sounds, and only ten
436 sounds are kept (all non-spoken).
437
438 2011-04-17 17:27:57 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
439 Remove some bitmaps from install
440
441 Some files in the bitmaps source directory need not be installed,
442 because they are there only to be linked to the binary in a build
443 without LIBXPM, are README files or conversion programs. I left only the
444 stuff that is in a Debian binary package in .../xboard/bitmaps.xchess.
445
446 2011-04-17 16:34:03 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
447 Configure some default sounds
448
449 The move sound is set to Wood Thunk; the sounds for tell and challenge
450 events to Phone and Gong, respectively.
451
452 2011-04-17 16:17:30 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
453 Change default sounds in Xboard menu
454
455 All spoken sounds are removed now. Thud, Click and Ching are replaced by
456 Wood Thunk, Slap and Cymbal; Car Horn and Pop are added.
457
458 2011-04-17 12:46:47 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
459 Make user wav file available for try-out in sound dialog
460
461 The GenericReadout was adapted to be able to read a single selected
462 value, so that the callback to the 'play' button in the sounds dialog
463 could get the name of the 'user WAV file' without accepting all settings
464 for the other sounds (which should only happen on 'OK', and might still
465 be cancelled in stead).
466
467 2011-04-16 10:36:31 -0700 Arun Persaud <apersaud@lbl.gov>:
468 configure: enable silent rules by default
469
470
471 2011-04-16 10:28:16 -0700 Arun Persaud <apersaud@lbl.gov>:
472 configure: added install directory for bitmaps files: .../games/xboard/bitmaps/default/
473
474
475 2011-04-16 10:25:33 -0700 Arun Persaud <apersaud@lbl.gov>:
476 configure: added install of sounds in .../games/xboard/sounds/default
477
478
479 2011-04-16 09:54:26 -0700 Arun Persaud <apersaud@lbl.gov>:
480 configure: renamed bitmapdir to pixmapsdir, since it installed only pixmaps. also changed name of default dir
481
482 pixmaps will now be installed under .../games/xboard/pixmaps/default/
483
484 2011-04-16 13:40:16 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
485 Fix gamelist highlight
486
487 Reopening the gamelist should highlight the current game.
488
489 2011-04-16 10:25:53 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
490 Fix size limit on 'save as diagram'
491
492 In stead of a fixed-size buffer the diagram-save code now uses an
493 allocated buffer with size calculated from the bitmap parameters to
494 retreive the bitmap data, so it should work for all sizes.
495
496 2011-04-15 22:04:03 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
497 Fix chaining of bottom-row dialog buttons
498
499 The OK & cancel buttons are chained to the bottom. This patch makes sure
500 that other buttons appearing in the same row (as in the tags and
501 comment dialogs) will be chained that way too, so that they will behave
502 the same on vertical sizing. The bottom of a full-width text-edit above
503 it will be chained to bottom too. To make this work in the tags dialog,
504 the (optional) cmail-message field had to be put above the tags memo.
505
506 2011-04-15 19:18:46 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
507 Fix switching between pixmap and bitmap pieces
508
509 There were still several flags that had to be reset when redoing the
510 graphics initialization. The Debian patch to use a default bitmap
511 directory when none is given but monoMode is selected or forced, is
512 moved to a more sensible place, so that it does not disturb matters when
513 compiled without LIBXPM (when we do have built-in bitmaps).
514
515 2011-04-15 15:47:09 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
516 Remove outline-pieces option from board-options dialog
517
518 This option does not exist in XBoard (yet).
519
520 2011-04-15 15:41:38 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
521 Fix running of clock during hash allocation engine
522
523 In TwoMachinesEvent we now wait for the second engine to acknowledge the
524 'ping' after 'new', to make sure it is done allocating hash in reaction
525 to the preceding 'memory' command, before the clock for the game is
526 started.
527
528 2011-04-14 21:42:50 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
529 Describe move type-in in texi file
530
531
532 2011-04-14 20:34:42 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
533 Describe Copy Game List menu item in texi file
534
535
536 2011-04-14 20:30:16 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
537 Describe -sweepPromotions in texi file
538
539 The new method for selection promotion piece, and the -sweepPromotions
540 option are described in the texi file.
541
542 2011-04-14 20:14:44 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
543 Describe -pieceMenu option in texi file
544
545 The sweep method for selecting a piece in Edit-Position mode is
546 explained, as well as the -pieceMenu option.
547
548 2011-04-14 15:59:57 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
549 Update texi file
550
551 Descriptions of the new XBoard menu dialogs are included in the docs.
552
553 2011-04-14 21:06:49 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
554 Reorganize texi description
555
556
557 2011-04-14 12:31:15 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
558 Fix sweep-promotions patch
559
560 Setting of the from square was moved to before OKtoStartUserMove in the
561 LeftClick handler, to make sure we could test the promotion possiblity
562 when OnlyMove() would have altered (x,y) to be no longer the from
563 square. But this setting of fromX, fromY hung on also if the move was
564 not OK, so you could effectively select opponent pieces and empty
565 squares. The from-square is now set back to undefined when it is not OK
566 to move the piece you clicked.
567
568 2011-04-14 11:56:59 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
569 Alter treatment of moves with empty squares
570
571 In Edit Position mode one can move empty squares, and use them to
572 'capture' pieces as a means to clear their square. But this often leads
573 to unintended disappearence of pieces one wants to grab for dragging, if
574 a previous click had inadvertantly left an empty square selected: the
575 click on the piece is then seen as the to-click of a click-click move.
576   This patch treats to-clicks of moves with an empty-square differently
577 from other to-clicks: Rather than performing the move (in this case
578 clearing of the to-square) on the down-click, it defers that to the
579 up-click, and only does it if that up-click is in the same square. This
580 allows the user to grab the piece on the down-click, and drag it to
581 another square, if that is what he wanted to do, without being disturbed
582 by sudden implosion of the piece he tried to grab.
583   If the to-square is in the holdings, grabbing the piece is the only
584 action, as moves of empty squares into the holdings are forbidden anyway.
585
586 2011-04-13 13:14:00 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
587 Block selection of a directory when file is needed
588
589 When we are not browsing merely to obtain a name to put in a text edit,
590 but really must return an open file pointer, selection of a directory
591 (ending in '/') can no longer be OK'ed in the file browser. (XBoard
592 tends to segfault when offered garbage for game or position file...)
593
594 2011-04-13 12:23:00 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
595 Let double-click select file in file browser
596
597 A second click on the already selected entry now has the same effect as
598 pressing the OK button.
599
600 2011-04-12 17:06:28 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
601 Couple mouse wheel to v-scrolls in file browser
602
603 A newly added mouse-wheel event handler was made to call the v-scroll
604 callback routines with parameters to step one entry. The button-press
605 handler for the lists themselves was also made to intercept the wheel
606 events (buttons 4 and 5), to prevent they would select an entry, and
607 make them scroll in stead as well.
608
609 2011-04-13 11:41:54 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
610 Fix crash copying game list when there is none
611
612
613 2011-04-13 11:15:14 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
614 Fix changing of float setting by generic popup
615
616 Changing a float setting (so far the only one is in the Load Options
617 dalog) did not always work, because the old value was clipped to (int),
618 so that changing it back to an integer value might erroneously conclude
619 there was no change.
620
621 2011-04-13 16:15:22 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
622 Fix crash on closing dialogs in wrong order
623
624 When a menu dialog was closed when it still had an open file-browse
625 daughter, which could be done through the system menu X on the title
626 bar, later closing of the file browser caused a crash. This is solved by
627 keeping track of the fact that there is such a daughter through a global
628 flag, and ignoring the pop-down command if there is one.
629
630 2011-04-13 16:33:16 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
631 Fix startup focus of board window
632
633 When there were open auxiliary windows, these would have focus on
634 starting up XBoard. The XtSetKeyboardFocus call added in XBoard main()
635 was ineffective in curing that. It has now been replaced by a call to
636 XSetInputFocus, which does do the job. By giving input focus to the form
637 widget, rather than the board widget, XBoard will be immediately
638 sensitive to all key bindings.
639
640 2011-04-13 15:48:35 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
641 Fix game-list highight error when filtered (WB)
642
643 When the gamelist was filtered, the game that was highlingted was the
644 n-th game in the list rather than the n-th game in the file, when the
645 latter was loaded (and n did not exceed the number of filtered games).
646 This is fixed now by searching for the line in the listbox that starts
647 with the game number n, rather than taking the n-th line.
648
649 2011-04-12 19:20:46 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
650 Refactor move type-in code
651
652 Common code between XBoard and WinBoard was moved to the back-end
653 creating TypeInEvent() and TypeInDoneEvent() routines.
654
655 2011-04-12 10:13:40 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
656 Fix saving of XBoard fonts with spaces in name
657
658 SaveFontArg now prints quotes around the saved font string, so that the
659 general option-argument parser doesnot stop at the first space it sees.
660
661 2011-04-11 20:48:24 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
662 Implement move type-in for XBoard
663
664 By adding an event handler to the main window for key presses, users can
665 now type moves when the board has focus, like in WinBoard. The typed
666 character appears as first character in the type-in box that willpop up.
667 Enter and Escape close the box; finishing the typing of the move enters
668 it. Like in WinBoard it is also possible to type a move number (to go
669 there) or (in Edit Position mode) a FEN.
670
671 2011-04-11 20:59:44 -0700 Arun Persaud <apersaud@lbl.gov>:
672 new developer release
673
674 tried to keep the v4.5.x branch developed already separated in the NEWS file, as well as DIFFSTAT and SHORTLOG.
675 The Changelog is just the one from master.
676
677 2011-04-10 22:47:59 -0700 Arun Persaud <apersaud@lbl.gov>:
678 updated Changelog, NEWS, etc.
679
680 2011-04-10 20:32:57 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
681 Fix use of game/position file in first match game
682
683 When a match was started from the menu, it was not paying attention to
684 game and position files. (Later games were.) The code that handled this
685 in the initialization when a match is started through the command line
686 was made into a routine MatchEvent, which can be called from the menu
687 proc too.
688
689 2011-04-09 20:55:47 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
690 Fix crash on opening ICS Text Menu
691
692 The patch for the color defaults had broken the ICS Text Menu.
693
694 2011-04-09 19:22:00 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
695 Implement Copy Game List menu item for XBoard
696
697 Some WinBoard code was cloned for this.
698
699 2011-04-09 11:42:21 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
700 Third method of sweep selection
701
702 This method sweeps through the possible promotion choices for the piece
703 that is being dragged, as long as you drag a 7th-rank Pawn backwards. On
704 draggin such a Pawn forwards, it immediately shows it as the piece you
705 are going to promote to.
706
707 2011-04-08 23:39:10 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
708 Alternative sweep promotions
709
710 The sweep takes place on the from-square here.
711
712 2011-04-07 23:21:02 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
713 Make sweep-select promotions work in WinBoard
714
715 The mouse-move handler had to be connected to the PromoScroll back-end
716 routine.
717
718 2011-04-07 23:19:10 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
719 Fix path browsing in WinBoard
720
721 The routine BrowseForFolder was still declared as static in woptions.c,
722 while it was used from wsettings.c.
723
724 2011-04-07 11:14:45 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
725 Fixes to sweep selection
726
727
728 2011-04-06 23:47:58 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
729 Implement sweep selection of promotion piece
730
731 When the option -sweepPromotions is true, a click-click promotion move
732 will first display the default choice (usually Queen) on the promotion
733 square. While you have the mouse button still down, you can change the
734 piece by moving the mouse vertically.
735
736 2011-04-06 21:20:30 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
737 Implement sweep selection as alternative for the piece menu
738
739 When the option -pieceMenu is off, the piece menu will no longer appear
740 on right-clicks in Edit Position mode. In stead a Pawn of the chosen
741 color will appear immediately in the clicked square, and vertical
742 movement of the mouse with the right button down will cycle through
743 all other pieces defined in the pieceToCharTable of the current variant.
744   Setting the side to move is acheived by clicking the correspondig
745 clock. Clear board can be effected by clicking the clock of the side
746 that already has the move.
747
748 2011-03-30 18:17:58 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
749 Remember Tags and Comment dialog coordinates
750
751 The save-settings code now uses the shell and shellUp arrays from the
752 GenericPopUp to read out the window coordinates for Tags and Comment
753 window. Pointers used by GenericPopUp are set topoint to the
754 corresponding WindowPlacement structs.
755
756 2011-03-10 19:21:59 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
757 Redo Tags dialog
758
759 The generic popup is used for generating the Tags / EditTags popups.
760 The tags popup use a 'label' field to display the cmail message
761
762 2011-04-01 13:43:52 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
763 Implement Edit-Comment window through generic popup
764
765 The Edit Comment and Comment popups are combined into one, that can
766 always be edited (similar to WinBoard). It uses shell number 1.
767 (Number 0 is for all transient dialogs.) A save-changes button is added.
768 The positioning is not implemented yet.
769
770 2011-04-06 10:56:57 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
771 Refinements to generic popup and color picker
772
773 *) The text part of a checkbox can now be clicked to toggle the option.
774 *) Typing <Enter> in single-line text edits is ignored
775 *) Using a spin button now sets focus to the affected text edit, with
776 the insert position at the end.
777 *) Using the sample field or an RGB button sets focus to the
778 corresponding text edit, with the insert position at the end.
779 *) The adjust buttons now work in reverse, with a D button for "darker".
780 *) Editing a color field causes the sample field to update to the new
781 color when you type <Enter>.
782 *) The color pickers now define a default color, which can be instated
783 by clicking on the sample field.
784 *) Fix some 64-bit pointer warnings
785
786 2011-04-05 17:05:39 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
787 Let file browser filter on extension
788
789 A new text field is added in the file-browse dialog, to hold (space-
790 separated) extensions, on which the filenames are then filtered. This
791 field is initialized by the caller, depending on what we need the file
792 for, but can be changed by the user. (Directories are always displayed!)
793   Changes in the extension field  become effective after typing a return
794 in it. Escape typed in the extension field gives focus to the filename
795 field, and restores the contents. Escape in the filename field cancels
796 the dialog, return ther OKs it. The extension filter of the browser is
797 initialized to the extension (if any) of the file currently in the text
798 edit you are browsing for.
799   When re-opening the file browser from the XBoard File menu, and there
800 is no suggested filename, it will now start with the last succesfully
801 opened name as suggestion. Calling the browser with a NULL argument
802 for the suggested filename requests that (unlike calling with an empty
803 string, which will start it in the current directory). To make this
804 work smoothly, the filebrowser saves the last used name on entry, so it
805 can be restored on cancel, so that a cancelled browse session really
806 erases all memory of it.
807
808 2011-04-04 19:26:53 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
809 Fix animation masks on changing piece pixmaps
810
811 The animation masks were not remade when new pieces were loaded
812 interactively through the board-options dialog.
813
814 2011-04-04 19:09:21 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
815 Fix linegap option in board dialog
816
817 The lineGC was not recalculated, so the grid lines stayed the same
818 thickness. In addition, setting the line-gap override to -1 now
819 retrieves the original line gap that belongs to the current board size.
820
821 2011-03-05 23:27:48 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
822 Make a kind of ICS text menu in XBoard as a dialog
823
824 The dialog with buttons can be opened from the View menu. It is
825 configured by the option -icsMenu; a default setting for this is
826 included in the master settings file.
827   The commands specified by the -icsMenu can now contain $name and $input
828 keywords, which will be replaced by the current primary selection, or
829 text the user types, respectively. Commands that contain $name will not
830 be sent when the current selection is empty. Commands that do not
831 contain $input will be sent to the ICS immediately; otherwise they will
832 be placed in the ICS Input Box, with the cursor at the point of the
833 $input, and input focus given to the Input Box, so the user can start
834 typing. When a command is prefixed by "$add " it will be appended to the
835 existing ICS Input Box contents, rather than replace it.
836   The items now have to be separated by ";\n", and button text from
837 command by ';' (with optional linefeed). This allows configuring of
838 multi-line commands, as a single linefeed no longer has special
839 sigificance.
840
841 2011-03-31 13:36:05 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
842 Redo ICS input box with generic popup
843
844 This box is just a single text edit, but the complexity is in the added
845 callbacks. These callbacks remain in xboard.c, and were altered to
846 access the edit through the option.handle field.
847
848 2011-04-03 12:54:51 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
849 Activate -path and -file options
850
851 In XBoard the generic popup was prepared for this. In WinBoard, for
852 -path options the BrowseFolder routine is used, and had to be made
853 global (prototype in winboard.h).
854
855 2011-04-02 18:40:33 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
856 Let generic popup generate Engine Settings dialog
857
858
859 2011-04-02 18:36:09 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
860 Merge SettingsPopUp into GenericPopUp
861
862 Based on currentCps the values read from the dialog are sent to the
863 engine, or stored into the option.target in the callback, and fetched
864 from the option.target in the PopUp. The currentCps is cleared in the
865 generic popdown of a transient dialog.
866
867 2011-03-06 10:11:06 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
868 Make generic dialog popup reentrant
869
870 To allow persistent dialogs to be implemented through the generic popup,
871 it must be possible to have several dialogs open at the same time, and
872 thus make sure the popdowns under the cacel or close-window button know
873 which one to pop down. To this end an array shells[] is created that
874 takes over the function of settingsShell, and GenericPopUp gets an extra
875 parameter telling it which element to use for storing the dialog shell.
876 This number is then also passed to the callbacks that trigger popdown.
877 This was a bit nasty for the CatchDeleteWindow stuff, which passes user
878 data to the callback as text strings.
879 Keep a separate up/down indicator, so that shell widgets can be kept
880 for persistent dialogs. Also keep a currentOption per dialog type.
881   The coordinates and size of the window is read out and stored in a
882 WindowPlacement structure, (if one is specified for that dialog), when
883 the dialog is popped down. When initialized the structure is also used
884 to set the window parameters when the dialog is created. (The idea being
885 that the structure was saved in the settings file.)
886   The routine MarkMenu checkmarks a given menu item, and logs it for the
887 given dialog type, so that a later popdown automatically unchecks is.
888
889 2011-02-25 12:14:25 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
890 Implement Machine Match menu item and options dialog
891
892 An item to start a match from the menu is added, similar to what
893 WinBoard has. (The code is duplicated, so I guess it should be moved to
894 the back-end now, as MachineMatchEvent(), but it was tiny.) A dialog in
895 the Options menu was added with the aid of the generic popup, and allows
896 the user to set the load Game / Position File and Index.
897
898 2011-04-01 14:54:26 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
899 Create General-Options dialog
900
901 The generic popup is used to implement a General-Options dialog, which
902 contains all Boolaen options that used to be set directly from the main
903 Options menu, plus a spin option for the flash count and flash rate.
904 The corresponing options are removed from the main Options menu, but the
905 whole thing is made conditional on a compiler switch OPTIONSDIALOG.
906 The dialog needs an OK callback for sending an altered ponder-state to
907 the engine. (Why isn't this option disabled in -ncp mode, btw?)
908 A spin control is added to adjust -animateSpeed between 5 and 100.
909 Add dropMenu and showTargetSquares item as well.
910
911 2011-04-01 18:16:47 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
912 Redo new-variant dialog with generic popup
913
914 Some special code was added in GenericPopUp() to force buttons of the
915 type needed in the New Variant dialog (wide, colored, greyed-out on
916 variant type). The dialog was implemented with these, and callbacks for
917 the buttons directly exit the dialog, without the need for OK. New spin
918 controls are added to the dialog for adjusting the board format.
919
920 2011-04-01 14:48:48 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
921 Redo common-engine dialog with generic popup
922
923 The ponder option was removed, as it is already in the main Options
924 menu, and would require nastiness in the OK callback. Added book options
925 in common-engine dialog.
926
927 2011-02-24 13:32:01 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
928 Redo adjudications dialog through generic popup
929
930 We dropped the periodic-updates option, as it is already in the main
931 Option menu.
932
933 2011-04-01 21:56:07 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
934 Make sounds dialog for XBoard
935
936 This uses the combo boxes. A 'play' button isimplemented for a test
937 sound. A sound directory is introduced, and can be set through the
938 dialog. A default setting for -soundDirectory is added to xboard.conf.
939
940 2011-04-01 23:11:29 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
941 Add ICS options dialog
942
943
944 2011-04-01 21:52:48 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
945 Add board dialog XBoard
946
947 The GenericPopUp() is used to implement a dialog for board options. The
948 board dialog needs to trigger redraw and redefinition of the
949 colors, through an OK callback. Color-pickers are used for the 6 basic
950 color settings.
951   To allow changing board settings during the session (i.e. from a menu
952 dialog), the routines to allocate resources have to free the resources
953 for the previous settings first. This patch take care of XtCreateGCs(),
954 preventing re-creation of resources that are unchangeable (such as the
955 grid color), and calling XtReleastGC() on GCs that can be changed.
956 To prevent resource leaks the old pixmaps are deleted before making new
957 ones on second or later calls of CreateXPMPieces().
958
959 2011-04-03 11:39:26 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
960 Add browse button to generic popup
961
962 Options of type FileName and PathName cause a browse button to be added
963 behind the text field. The SpinCallback is used to handle the
964 button presses, and invokes the file browser dialog to obtain a
965 filename, which is then copied to the text field.
966
967 2011-04-01 21:49:26 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
968 Make generic XBoard popup, and implement 2 dialogs
969
970 The Engine-Settings dialog of XBoard was cloned to work on predefined
971 lists of (XBoard) options, rather than engine options. An extra field
972 was added to the Option struct, to hold a pointer to the XBoard variable
973 that should hold the option setting, so on OK'ing the dialog the altered
974 values can be copied there. Not usable for options which should trigger
975 an action (like redraw, or sending something to the engine).
976 A Load Game, Save Game and ICS Options dialog were then defined by
977 tables fed to GenericPopUp(). Options set from these dialogs were removed
978 from the main Option menu, which removes a lot of code from xboard.c
979 (for checkmarking, disabling the menu items).
980   A button defined in the GenericPopUp can attain the color indicated
981 by a previous text field, and add a callback to change the color in a
982 spin-like manner (but using R G B W in stead of + - butons).
983 The EndMark option can specify a callback, to be used on OK.
984 A non-zero max field in the Option descriptor will be used to set the
985 width of ComboBox, TextBox and Button optons.
986 The elements are chained such that extra space goes fully into the input
987 fields. A label type is added for clarifying texts that would not fit in
988 the option names. A break-type (pseudo-)option is added. Make OK and
989 cancel button suppressable in generic popup (by 2 bit of the option.min
990 field).
991
992 2011-04-03 11:34:21 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
993 Add file-browser option to just return name
994
995 By passing mode "f" the file browser dialog will not open the selected
996 file at all, so it can be used to retreive the name for the benefit of a
997 file-browser button to a -file option. A mode "p" will limit the
998 selection to directories only, to browse for a path.
999
1000 2011-04-03 13:15:17 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
1001 Put insertion point at end of text on SetFocus
1002
1003
1004 2011-04-05 23:47:34 -0700 Arun Persaud <apersaud@lbl.gov>:
1005 fixed 64 bit warnings by casting integers to intptr_t before casting to int
1006
1007
1008 2011-04-05 23:24:24 -0700 Arun Persaud <apersaud@lbl.gov>:
1009 removed check and #includes for malloc.h, since it's not needed
1010
1011 hopefully this doesn't break things on non-linux systems. OS X seems to be ok, not sure about others ;)
1012
1013 2011-04-03 20:23:49 -0700 Arun Persaud <apersaud@lbl.gov>:
1014 check if malloc.h is present before including it
1015
1016 OS X 10.6 doesn't have malloc.h, so it complained.
1017
1018 2011-04-03 20:01:36 -0700 Arun Persaud <apersaud@lbl.gov>:
1019 Fix bug introduced in commit 89b4744: removed a "/" and forgot to add it in the config file
1020
1021 removed a "/" to make OS X happy, but forgot to add the "/" again in the xboard.conf.in file
1022
1023 2011-03-12 14:08:50 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1024 Fix display of promotion piece in ICS superchess
1025
1026 In Great Shatranj and Superchess promoted Pawns were displayed as shadow
1027 piece because these variants had holdings, while captured pieces should
1028 go back into the holdings unchanged, rather than reverted to Pawns.
1029
1030 2011-03-13 14:09:14 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1031 Fix o-o castling in new parser
1032
1033 The non-compliant notation of castling with lower-case 'o' should be
1034 preferred over the non-compliant interpretation of moving a Pawn along
1035 the o-file. Not doing so breaks ICS play, as ICS use o-o and o-o-o for
1036 castling! So an exception is now made for the o-file in the 'fxg'
1037 case.
1038
1039 2011-03-10 19:27:41 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1040 Implement yynewstr entry point in new parser
1041
1042 This entry point, used for parsing an ICS move list, was forgotten, and
1043 was still an empty routine. This made XBoard crash when observing an ICS
1044 game.
1045
1046 2011-03-07 23:11:00 -0800 Arun Persaud <apersaud@lbl.gov>:
1047 fixed wrong default for polyglotDir mentioned in docs.
1048
1049 Thanks to Hans Aberg for reporting it.
1050
1051 2011-03-05 12:39:01 -0800 Arun Persaud <apersaud@lbl.gov>:
1052 Fix "make install" on Os X10.6.6 (removed a "/")
1053
1054 seems like an extra "/" made "make install" unhappy
1055
1056 2011-03-03 21:19:05 -0800 Arun Persaud <apersaud@lbl.gov>:
1057 removed parser.l from build process, also removed flex dependency from configure
1058
1059
1060 2011-03-02 22:14:57 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1061 New parser, written in C
1062
1063 A new parser was written to replace the flex-generated one. Immediate
1064 improvements are that it understand double-digit rank numbers, and Shogi
1065 coordinates. No changes were made in the Makefile yet to reflect the
1066 new, flexless building procedure.
1067
1068 2011-03-02 22:23:21 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1069 Fix bugs in FRC castling rights
1070
1071 When parsing a castling move in FRC when no rights existed, the parser
1072 returned 0 (= EndOfFile) rather than ImpossibleMove. The recognition of
1073 the absence of rights was not adapted to the new encoding NoRights in
1074 stead of -1.
1075
1076 2011-03-01 23:42:34 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1077 Fix parsing bug of FRC castling
1078
1079 The code that was supposed to intercept castling when no rights existed
1080 in FRC was not adapted to the new encoding for this by NoRights, rather
1081 than -1, and furthermore returned 0 (= EndOfFile) rather than
1082 ImpossibleMove. Not sure if the former would manifest itself in any
1083 way, but the latter seems bad.
1084
1085 2011-03-01 23:32:25 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1086 Fix two bugs in reading position diagram
1087
1088 When reading a game without FEN tag, a position diagram is used to set
1089 the initial position. This calls CharToPiece() with a '.' as argument,
1090 because that is the position-diagram way to indicate empty squares.
1091 altered CharToPiece() over time this would be recognized as the first
1092 undefined piece or, more recently, the first piece without nickName,
1093 which is a white Pawn. Now it returns EmptySquare again in that case.
1094 A second problem was that for position diagrams in braces the brace was
1095 not in the list of ignored characters, and would cause the reading to
1096 get out of phase, so that the side to move was not recognized.
1097
1098 2011-02-26 21:12:08 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1099 Fix flipBlack option XBoard with board texture
1100
1101 In XBoard -flipBlack is implemented by swapping white and black pieces,
1102 because the Shogi bitmaps from XShogi are made that way. But the mask
1103 used to cut out the whole in the board texture to fit the piece was not
1104 swapped, both when drawing static pieces, as well as during animation.
1105
1106 2011-02-25 14:38:21 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1107 Improve repairing damage of arrow highlight XBoard
1108
1109 With line gap the highlight arrow necessitated redrawing of the entire
1110 board, to repair damage on the grid. This interfered with flashing of
1111 pieces, which was only done on selective redraws. In stead of forcing a
1112 total repaint we now just redraw the grid lines.
1113
1114 2011-02-23 16:41:36 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1115 Fix unintended translation in debug file
1116
1117 The words "first" and "second" (cps->which) were sometimes used in
1118 context that should definitely not be translated. (e.g. the indicator
1119 for which engine printed/got the line in the debug file.) So translation
1120 is now deferred to all uses in popups.
1121
1122 2011-02-23 16:29:12 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1123 Fix nps bug
1124
1125 The nps settingwas tested for being > 0 in stead of >=0, so that the
1126 case of CPU time was not properly handled.
1127
1128 2011-02-24 19:06:27 +0100 Kamil Blank <caceel@gmail.com>:
1129 Added missing fclose()
1130
1131 (tiny change)
1132 Signed-off-by: Arun Persaud <apersaud@lbl.gov>
1133
1134 2011-02-20 16:12:19 -0800 Arun Persaud <apersaud@lbl.gov>:
1135 release of version 4.5.1
1136
1137 2011-02-20 16:10:16 -0800 Arun Persaud <apersaud@lbl.gov>:
1138 updated Changelog, NEWS, etc.
1139
1140 2011-02-20 20:36:28 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1141 Fix two typos in option names in texi file
1142
1143 Polyglot was capitalyzed
1144
1145 2011-02-20 00:03:19 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1146 Fix some resource leaks
1147
1148 Some files were opened not closed in XBoard, when loading XIM images
1149 (which I doubt anyone ever does) but also when copying the clipboard
1150 (which has the potential of being done very often). There was also some
1151 code that would not work if conditional code which is permanently
1152 disabled would be enabled.
1153
1154 2011-02-17 20:17:04 -0800 Arun Persaud <apersaud@lbl.gov>:
1155 new developer release
1156
1157 2011-02-17 20:14:38 -0800 Arun Persaud <apersaud@lbl.gov>:
1158 updated Changelog, NEWS, etc.
1159
1160 2011-02-17 15:40:02 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1161 Fix MSVC snprintf problem
1162
1163 In MSVC snprintf has to be redefined as _snprintf, and this happens
1164 conditionally in config.c. But the latter was not #included in help.c.
1165
1166 2011-02-16 19:41:27 -0800 Arun Persaud <apersaud@lbl.gov>:
1167 updated configure.ac to check for Xaw header files
1168
1169 check for Xaw header files when --without-Xaw3d was given. Before the test was
1170 only done when Xaw3d was specified, but could not be found.
1171
1172 If Xaw3d or Xaw can't be found, print a hopefully useful error message and exit the configure script.
1173
1174 2011-02-16 12:03:22 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1175 Fix ICS channel 0
1176
1177 Channel 0 messages were not displayed in the console, because the test
1178 for channel number considered every non-numeric or non-existent handle
1179 in a chatbox to be zero. So the messages were diverted to a non-exsting
1180 chatbox. Now it test first for the handle to start with a digit.
1181
1182 2011-02-15 19:13:33 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1183 Make language choice from menu persistent
1184
1185 Set appData.language to the chosen language file, or empty if English is
1186 chosen, so that the choice is saved with the settings. Increase the
1187 number of possible language choices from 5 to 20. (After all, we already
1188 have 7 now!)
1189
1190 2011-02-14 11:09:24 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1191 Fix showing of user move after adjudication
1192
1193 The correction of the fishy patch (removing ShowMove() from Adjudicate())
1194 had broken the adjudication of user moves (that actually did work before
1195 the fishy patch, because there the gobal fromX/Y and toX/Y do contain
1196 the correct values for the move to be shown). An entered move that led
1197 to adjudication (like a checkmate) now was not displayed at all. Adding
1198 an extra ShowMove() after (successful) return of Adudicate() solves it.
1199
1200 2011-02-13 23:49:44 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1201 Fix Xiangqi King facing
1202
1203 The Spartan patch had broken the CheckTest for Xiangqi, because cl.check
1204 was cleared after the King-facing test, rather than before it.
1205
1206 2011-02-13 22:30:59 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1207 Fix variant janus size prefix
1208
1209 The default board size of Janus Chess was not consistently taken to be
1210 10x8, which resulted the name to be sent as 10x8+0_janus to the engine.
1211
1212 2011-02-13 12:18:52 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1213 Fix Alfil bug
1214
1215 The test for Alfil (suppressing single steps on the Elephant) contained
1216 a wrong logical operator, so that it could never be active. It also
1217 failed to include Xiangqi as variant with traditional Alfil. This led to
1218 one-step moves of the Elephant in these variants, and false check or
1219 unreliable mate detections.
1220
1221 Fix move of Xiangqi Elephant
1222
1223 2011-02-09 23:19:09 -0800 Arun Persaud <apersaud@lbl.gov>:
1224 fixed configure script to correctly detect Xaw3d library
1225
1226
1227 2011-02-06 22:07:17 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1228 Fix unmarked translation
1229
1230 The file-browser wndowtitle in WB was not marked for translation.
1231
1232 2011-02-04 10:27:49 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1233 Put warning in HTML help
1234
1235 A warning is added that the help file is not yet updated for the new
1236 menu organzation.
1237
1238 2011-02-04 10:22:29 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1239 Fix 64-bit Windows compilability
1240
1241 The API interface for Set/GetWindowLong has been changed for 64-bit
1242 Windows, both in the name of the call as in the arguments.
1243
1244 2011-02-04 10:21:06 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1245 Fix MSVC compilability
1246
1247 Both the makefile and the project file had to be adapted for the new
1248 source file history.c, and the new location of parser.c.
1249
1250 2011-02-05 10:11:58 -0800 Arun Persaud <apersaud@lbl.gov>:
1251 added missing #includes and missing prototypes to filebrowser
1252
1253 thanks to Max Funk for reporting. Now using HAVE_DIRENT_H.
1254
1255 Also cleaned up missing prototypes and some casts.
1256
1257 2011-02-05 09:21:48 -0800 Arun Persaud <apersaud@lbl.gov>:
1258 added missing header file for sprintf
1259
1260
1261 2011-02-03 08:50:50 -0800 Arun Persaud <apersaud@lbl.gov>:
1262 added history.c to the tar-ball. Needed for Winboard
1263
1264
1265 2011-01-31 23:03:05 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1266 Fix deselection of greyed-out variant button (WB)
1267
1268 In Windows a disabled radiobutton refuses to deselect when you select
1269 another (enabled) button from the group. There are then 2 buttons
1270 checked, and the code to readout the buttons took the first one. Now it
1271 is changed to take the first enabled one.
1272
1273 2011-02-03 08:28:15 -0800 Arun Persaud <apersaud@lbl.gov>:
1274 Revert "Implement -reset option feature in WinBoard"
1275
1276 This reverts commit efecf86cd9b54072c6a2f38d62f1d775e69c545b.
1277
1278 picked the wrong commit from HGM's git tree.
1279
1280 2011-02-01 22:01:12 -0800 Arun Persaud <apersaud@lbl.gov>:
1281 add DIFFSTAT and SHORTLOG to tar-ball
1282
1283 was only in the v4.4.x branch and not in master
1284
1285 2011-01-30 09:52:15 -0800 Arun Persaud <arun@nubati.net>:
1286 release of version 4.5.0
1287
1288 2011-02-01 07:41:04 -0800 Arun Persaud <apersaud@lbl.gov>:
1289 changed size of borders around squares from 0 to 1 as a default
1290
1291 this way highlights show up again.
1292
1293 2011-01-29 20:11:30 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1294 Implement -reset option feature in WinBoard
1295
1296 2011-01-30 10:12:08 -0800 Arun Persaud <arun@nubati.net>:
1297 updated Changelog, NEWS, etc.
1298
1299 2011-01-30 09:56:39 -0800 Arun Persaud <arun@nubati.net>:
1300 updated parser.c form parser.l
1301
1302 2011-01-29 19:59:11 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1303 Clean up fishy patch
1304
1305 None of the ShowMove() calls in Adjudicate() was working, because when
1306 this code was taken out of HandleMachineMove() it was taken outside the
1307 scope of the local fromX, fromY etc. there, so that it started using the
1308 global variables from the mouse driver. As these usually contain -1,
1309 this suppressed move animation and highlighting. All these calls have
1310 now been removed, and ShowMove() is called after a positive return (from
1311 HandleMachineMove(), so within the correct scope).
1312 This improves the previous fix, which led to some flicker, because the
1313 erroneous ShowMove() calls did draw the new board (instantly), wich in
1314 the fishy patch was then immediately overwritten by the old position, to
1315 start animation. This drawing of the old position is now no longer
1316 needed either.
1317
1318 2011-01-29 13:36:30 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1319 Update RTF file
1320
1321 The RTF file is adapted to the new menu organization.
1322
1323 2011-01-29 13:31:48 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1324 Update texi file
1325
1326 The highlight-with-arrow and one-click-move menu items are described.
1327 The highlightMoveWithArrow and variations option are described.
1328 Load Next /Previous Position descriptions are moved to File menu.
1329 The description for entering variations is updated (using Shift key).
1330 The remark that editing holdings is impossible is removed.
1331 Spartan Chess is added to the list of supported variants.
1332
1333 2011-01-28 18:35:48 -0800 Arun Persaud <arun@nubati.net>:
1334 Updated copyright notice to 2011
1335
1336
1337 2011-01-24 15:01:25 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1338 Greyout unavailable variants in New Variant dialog
1339
1340 The WB radio-button code is refactored to be driven from a list (which
1341 must be kept in phase with the variant definitions in common.h!). It now
1342 also checks if the first engine supports the variant, and greys out the
1343 item if it isn't. XB now also makes this check. Slight re-ordering of
1344 10x8 variants there, to have the more common on top.
1345 If no radio button is selected, keep old variant even on OK.
1346
1347 2011-01-19 11:10:59 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1348 Move clock-click code to back-end
1349
1350 Some duplicated (or should-be-duplicated) code for handling clicks on
1351 the clocks from the XBoard and WinBoard front-ends was merged and
1352 relocated to the back-end, so it can be shared. Noticeable was that
1353 XBoard allowed turn change in ICS examine mode by clock clicking,
1354 while WinBoard did not. WB, on the other hand, allowed clock adjustment.
1355
1356 2011-01-16 23:15:17 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1357 Fix legality testing of drop moves
1358
1359 Drops of noexistent pieces (i.e. with a piece indicator letter that is
1360 not corresponding to any defined piece) are now parsed as
1361 ImpossibleMove, rather than IllegalMove, so they are also rejected with
1362 legality testing off.
1363
1364 2011-01-17 00:28:32 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1365 Fix WB Sound Options greyout and remove some grossness
1366
1367 The sound and ICS Options menu items in WB were accessed 'by position',
1368 with fixed defined positions (always messing up any reorganization of
1369 the menus when you forgot to redefine the position constants in
1370 winboard.h). And not only that, but for completely mysterious reasons,
1371 the greying of the sound item greyed out the game-list options (above
1372 it) in stead when it was defined as 9, and the ICS options (below it)
1373 when it was 10 !!!. Now they are addressed 'by command' (and the
1374 position definitions are removed), which fixes things.
1375
1376 2011-01-25 21:35:10 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1377 Re-instate load next/prev position menu items
1378
1379 As positions do not use something similar to the game list, these are
1380 still useful. For some reason I could not get Alt+Shift+PgUp/Dn to work,
1381 so I settled for Shift+PgUp/Dn.
1382
1383 2011-01-16 21:56:14 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1384 Remove superfluous copying of machine move
1385
1386 There was explicit code in HandleMachineMove() and FinishMove() to put
1387 the move in the moveList, while MakeMove() already does this later in a
1388 more reliable way by calling CoordsToComputerAlgebraic(). This
1389 superfluous code is removed now.
1390
1391 2011-01-16 21:44:26 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1392 Fix spurious mate test in Edit Game mode
1393
1394 When entering a game, it was terminated by the mate test even when
1395 legality checking was switched off (so that mates might not be reliably
1396 recognized). The mate test is now made dependent on legality testing.
1397
1398 2011-01-16 21:37:16 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1399 Fix type-in of drop moves
1400
1401 Drop moves entered through the move type-in already come in the (piece,
1402 DROP_RANK, x, y) format, rather than having a holdings from square. This
1403 caused UserMoveEvent to consider them illegal when testing if the
1404 piecewas of the side to move, and when this was fixed, to recognize
1405 Knight drops as coming from between board and holdings (and thus
1406 illegal).
1407
1408 2011-01-16 21:31:42 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1409 Fix move type-in truncating game
1410
1411 Starting a new variation by keeping Shift pressed did not work when
1412 OK'ing the move type-in, because there was some code ther that truncated
1413 the game. While this could be safely left to UserMoveEvent, which it
1414 calls, as the situation is not different from entering moves through the
1415 mouse.
1416
1417 2011-01-11 16:12:02 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1418 Fix legality testing for promotions
1419
1420 Turns out WB has never tested for the legality of the chosen promotion
1421 piece, and would allow promotion to King innorml chess even with
1422 legality testing on (when entered through the keyboard)! Now strict
1423 testing is done, outlawing Pawns and Kings (or Unicorns in
1424 Knightmate). Only in suicide / giveaway Kings are stillallowed, and in
1425 spartan a black King if you do not have two yet.(And promotion
1426 toLnce,representing Hoplite Pawn,is forbidden there.)
1427
1428 2011-01-11 11:34:07 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1429 Reset 50-move counter on all pawn-like Lance moves
1430
1431 Now the Lance represents a Pawn-like piece not only in variant fairy,
1432 but anywhere outside Shogi / Superchess, its moves should also reset the
1433 50-move counter in those cases. Especially important for Spartan Chess,
1434 where the Lance actually participates.
1435
1436 2011-01-11 11:18:15 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1437 Fix logo repainting
1438
1439 The logos were not repainted when the main window was moved out of the
1440 display area, and then back into view. The reason for this is
1441 unknown, as the PaintProc calls HDCDrawPosition, which was calling
1442 DrawLogoOnDC. But the logos were not drawn, (or on an expose event
1443 sometimes half drawn!) despite the fact that the rest of the board was.
1444 The drawing of logos now has been decoupled from drawing the board,
1445 and has been moved to a separate routine DisplayLogos() (in analogy to
1446 DisplayBothClocks()). This is cleaner anyway, as the logos usually do
1447 not change when the board does. So apart from in PaintProc, it has only
1448 to be called when the mode changes (ModeHighlight()) or on swap clocks.
1449 This seems to fix the problem.
1450
1451 2011-01-10 20:36:48 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1452 Fix time in PGN info
1453
1454 Saving of the thinking time in the PGN was broken by the patch that
1455 removed the race condition in the clock switching, because that moved
1456 the incrementing of forwardMostMove to behind the code that used fmm to
1457 index pvInfoList. As a result the time was stored in the slot for the
1458 opponent's previous move. The value is corrected now.
1459
1460 2011-01-09 00:24:17 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1461 Fishy fix
1462
1463 The move that delivers checkmate in two-machines mode is not animated
1464 when adjudication is on. There then also is no highlighting of this move
1465 Redrawing the board and calling ShowMove fixes it. Which is rather
1466 strange, because ShowMove was already called in Adjudicate (when it
1467 adjudicates), before GameEnds. For reasons that are not understood this
1468 call to ShowMove() (which calls AnimateMove()) is not effective.
1469
1470 2011-01-09 00:21:41 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1471 Reset machine colors after match
1472
1473 The colors each engine playse are set to the originals after the last
1474 match game, so that a new match or two-machines game will not have
1475 swapped colors.
1476
1477 2011-01-09 00:15:18 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1478 Reset win/loss counters before match
1479
1480 The win/loss counters were not reset, because the code counted on them
1481 being initialized to zero. But with matches startable from the menu,
1482 this is no longer true after the first match.
1483
1484 2011-01-09 00:08:52 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1485 Show move that causes false illegal-move claim
1486
1487 Without claim testing XBoard takes back moves that an engine objects to.
1488 But when the engine is forfeited for a false claim, the move should of
1489 course stay. So the claim test is moved to before the take-back.
1490
1491 2011-01-09 00:05:38 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1492 Fix Spartan promotion to King
1493
1494 Promotions toKing were refused when in check, because XBoard thought
1495 they would not resolve the check. Now the promotion is actually
1496 performed before doing the check test.
1497
1498 2011-01-05 17:31:37 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1499 Fix WB font-based piece rendering on variant switch
1500
1501 The piece bitmaps were only created from the font characters when the
1502 number of ranks or files changed, because it was done in
1503 InitDrawingSizes(). This caused missing pieces when changing to a
1504 variant on the same board that used other pieces. Now InitDrawingSizes()
1505 is called for any variant switch.
1506
1507 2011-01-05 17:25:11 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1508 Fix right-alignment pproblem in WB ICS window
1509
1510 Use of Ctrl-R to summon the context menu still trickled through to the
1511 default text-edit window routine, and caused right-alignment. This was
1512 because the text-edit reacts on keyDown rather than the character event.
1513 KeyDown of R with Ctrl pressed is now also intercepted and ignored.
1514
1515 2011-01-03 13:04:56 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1516 Fix chat window title
1517
1518 The title was using the engine name, rather than the ICS handle, which
1519 did not work outside zippy mode. Now it only uses the engine name when
1520 no ICS handle is known. The titleis now also subjected to translation.
1521
1522 2011-01-03 12:50:54 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1523 Fix spurious reading of old game title by JAWS
1524
1525 Because focus was switched to the board window before loading the
1526 selected game from the game list, the titlebar still contained the
1527 name of the previously loaded game, which would spontaneously be read by
1528 JAWS. Now the focus switch is done after loading the new game (which
1529 updates the window title.)
1530
1531 2011-01-03 12:37:17 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1532 Add variant Spartan Chess
1533
1534 In the WB menu it takes the place of the defunct Twilight Chess item.
1535 The setup routine needed patching for setting up Lances in stead of
1536 Pawns for black, the check test had to be adapted to handle duple check,
1537 Alfil and Dragon moves were fine tuned in this variant to make the exact
1538 moves, and the promotion popup was adapted to show King and interpret
1539 Rook and Bishop as Dragon and Alfil for black. The Alfil now always
1540 moves as Modern Elephant except in Shatranj and Courier.
1541
1542 2011-01-03 12:23:39 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1543 Fix mate test
1544
1545 Due to a bug in logical operators drops were tried for mate evasions
1546 even in non-drop games, which broke it in Superchess and Great Shatranj,
1547 and wasted CPU time in other variants.
1548
1549 2011-01-05 17:19:35 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1550 Fix promotion suffixon disambiguated piece moves
1551
1552 The promotion suffixon piecemoves that needed disambiguation was not
1553 passedon to the back-end in most variants. Now it is passed on in any
1554 variant.
1555
1556 2011-01-03 12:08:19 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1557 Fix promotion of Pawn-like Lance
1558
1559 In variants where the Lance is used to represent an unorthodox Pawn, it
1560 must promote when it reaches last rank. With legality testing on,
1561 however, the promoChar was ignored in ApplyMove in this case. The
1562 promotion suffix also was not appended in SAN moves.
1563
1564 2011-01-03 11:57:23 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1565 Fix WB promotion popup
1566
1567 The promotion popup did not work properly in variants where black did
1568 not use the pieces that white wanted to promote to. Now the character
1569 for the selected piece is taken from the piece encodings of the side to
1570 move. In addition, selection of undefined pieces is ignored.
1571
1572 2011-01-02 14:17:32 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1573 Fix bug in parsing variations
1574
1575 The moves parsed from a variation were stored in the moveList without
1576 appended linefeed. This caused errors if the variation extended to
1577 beyond the end of the main line,into a hitherto unused part of the move
1578 list, as the linefeed was then not there from the overwritten move. As a
1579 result moves sent to the engine were concatenated, triggering
1580 illegal-move messages and bringing the engine out of phase.
1581
1582 2011-01-02 14:11:45 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1583 Define Ctrl-R as right-click in WB Comment dialog
1584
1585 To allow JAWS users to load a variation through the keyboard, Ctrl-R is
1586 equated to a right click at the position of the caret or selection.
1587
1588 2011-01-02 14:10:02 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1589 Allow starting a variation from keyboard entry in WB-JAWS
1590
1591 The status of the shift key is remembered when space is pressed to
1592 select a board square.
1593
1594 2011-01-02 14:06:14 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1595 Disable some accelerators in JAWS version
1596
1597 Single-key accelerators that could result in irreversible data loss are
1598 undesirable, because the risk of accidentally pushing them is too large.
1599 So the non-Alt duplicates of next/previous game/position are disabled,
1600 as are Home and End for Revert and Truncate Game. JAWS users will have
1601 to rely on the menus for those functions.
1602
1603 2011-01-02 13:59:01 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1604 Group engine-output memos with engine names
1605
1606 The engine names are now defined just before the text edits, so that
1607 JAWS 11 will read the engine name when the memo for the output of that
1608 engine is selected. (JAWS 10 will still read the NPS, as it reads in
1609 geometrical order.)
1610
1611 2011-01-02 13:55:19 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1612 Put nr CPU earlier in tab cycle of WB Common Engine dialog
1613
1614 By defining the max CPU control after hash size, the tabbing steps
1615 through the controls in geometrical (and logical) order, rather than
1616 having the max CPU in between the book controls.
1617
1618 2010-12-29 23:47:14 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1619 Update WB language template file
1620
1621
1622 2010-12-29 23:41:27 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1623 Subject JAWS menu and spoken strings to translation
1624
1625
1626 2010-12-29 23:37:39 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1627 Let JAWS SayString buffer full sentence
1628
1629 The meaning of the flag parameter of SayString was changed to indicate
1630 buffering of flushing. On flushing a message of a single space is used
1631 as a kludge to indicate interruptability. Calls to force flushing where
1632 added everywhere.
1633
1634 2010-12-29 23:32:54 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1635 Adapt JAWS menu to new menu organization
1636
1637 The menus did not correspondto the texts after translation of the main
1638 menu bar.
1639
1640 2010-12-29 23:18:30 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1641 Translate menus after creation of JAWS menu
1642
1643
1644 2010-12-29 23:07:05 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1645 Fix ICS context menu for JAWS
1646
1647 The Ctrl+R key did select text at the mouse pointer in stead of at the
1648 curser, now that up and down-click were combined.
1649
1650 2010-12-29 23:04:08 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1651 Reorganize order of WB New Variant dialog controls
1652
1653 The definitions are re-ordered so that at least JAWS 11 will speak the
1654 board-size elements properly.
1655
1656 2010-12-29 22:57:55 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1657 Fix order of elements in WB time-control dialog
1658
1659 Someleading texts were defined after the text edit they referred to,so
1660 that JAWS 11 associated them to the wrong one. A tab stop was added to
1661 the time-odds label, to make JAWS speak it.
1662
1663 2010-12-29 22:51:17 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1664 Change tabbing order in WB sounds dialog
1665
1666 The 'Play' button now gets focus immediately after the controls for
1667 selecting the sound, rather than at the end of the dialog (after OK).
1668
1669 2010-12-29 22:47:26 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1670 Remove tab stops on first radio button of WB dialogs
1671
1672 The New Variant and Board dialogs had a tab stop on the first radio
1673 button,so that tabbing toit would automatically select variant
1674 normal or size tiny. Now it tabs straight to the current size, without
1675 changing anything. (Important for JAWS users.)
1676
1677 2010-12-29 22:45:23 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1678 Put OK/Cancel last in tab cycle of some WB dialogs
1679
1680
1681 2010-12-29 22:29:37 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1682 Fix duplicate menu character for Edit Comment
1683
1684 Edit Comment did have the same shortcut character as Copy Game. Changed
1685 to m now.
1686
1687 2010-12-11 11:18:56 -0800 Arun Persaud <arun@nubati.net>:
1688 fixed automake process: xboard.conf couldn't be generated if $srcdir was not the current directory
1689
1690
1691 2010-12-11 09:50:48 -0800 Arun Persaud <arun@nubati.net>:
1692 new developer release
1693
1694
1695 2010-12-05 18:01:21 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1696 Subject WB context menus to translation
1697
1698 The innerloopof the menu translation has been made into a separate
1699 routine. This now uses GetMenuItemInfo() in stead of ModifyMenu() to
1700 better preserve menu breaks. Menu #10 is used for context menus (from
1701 the routine that pops them up), and for this number the orignal texts
1702 are not saved in menuText. (This is not needed, because the menu is
1703 created everytime anew from the resource data.)
1704
1705 2010-12-05 15:00:28 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1706 Update translation template
1707
1708 Add the new menu items; add some notes.
1709
1710 2010-12-05 14:04:46 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1711 Resize buttons in WB engine-settings dialog
1712
1713 The OK and cancel buttons were to narrow for most translations, and were
1714 a non-standard order as well.
1715
1716 2010-12-05 13:56:52 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1717 Add one-click move control to WB general-options dialog
1718
1719 This is a duplicate of the one in the ICS options dialog, but the latter
1720 is inaccessible in non-ICS modes, and one-click move is now
1721 alsoavailable in engine mode.
1722
1723 2010-12-05 13:51:20 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1724 Create space in dialogs for translation
1725
1726 The translated texts often did not fit, because controls were defined
1727 needlessly small (when there was empty space between them). In these
1728 cases they have been enlarged to consume all available space. Some
1729 dialogs are made wider.
1730
1731 2010-12-05 13:47:26 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1732 Add handle for translator acknowledgement
1733
1734 An empty string is printed in the about box, which can be 'translated'
1735 to a message acknowledging the translator.
1736
1737 2010-12-05 13:43:26 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1738 Use default logo for user
1739
1740 When no logo with the name of the current user is found, use dummy.bmp.
1741
1742 2010-12-05 15:46:34 -0800 Arun Persaud <arun@nubati.net>:
1743 added rlwrap tip to FAQ
1744
1745
1746 2010-12-03 23:24:06 -0800 Arun Persaud <arun@nubati.net>:
1747 replace hard coded paths with path from configure script
1748
1749 use $datadir and subdirectories to store some data files. Also make files in xboard.conf use correct path.
1750
1751 2010-12-03 23:02:09 -0800 Arun Persaud <arun@nubati.net>:
1752 fixed a typo in the configure script output
1753
1754
1755 2010-12-03 21:46:00 -0800 Arun Persaud <arun@nubati.net>:
1756 added a desktop file
1757
1758 taken from the openSUSE project
1759
1760 2010-12-03 22:44:02 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1761 Fix Edit Game/Position checkmarking in WinBoard
1762
1763 Because the entries in Edit and Mode menu were pure duplicats, the
1764 entries in the wrong menu (Edit) were checkmarked while active. By
1765 defining different IDs for those in the Edit menu, those in the Mode
1766 menu are checkmarked again.
1767
1768 2010-12-03 10:07:34 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1769 Add XBoard menu items for arrow highlight and one-click move
1770
1771 These items are put in the options menu; the 'Old Save Style' item is
1772 removed.
1773
1774 2010-12-03 09:27:58 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1775 Provide menus for editing WinBoard engine and server lists
1776
1777 The Edit Tags dialog in the WB front-end is adapted to act as a general
1778 edit for string variables, by giving it an extra parameter to indicate
1779 where to store the edited result. Menu items are added to invoke this
1780 dialog for editing the /first, /secondChessProgramNames and /icsNames
1781 options. This solves the problem that people would have to edit an ini
1782 file that they can no longer locate (because the %APPDATA% folder has
1783 different names and locations in the various Windows versions, and is
1784 often a hidden folder on top of that).
1785 There is a slight memory leak here, as the memory for the previous
1786 value of the altered string option is not freed.
1787
1788 2010-12-02 16:18:53 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1789 Configure arrow highlighting as default in XBoard
1790
1791 Set -highlightMoveWithArrow true in the xboard.conf file, and specify a
1792 lineGap of 0 to make that efficient (and the wood theme even nicer).
1793
1794 2010-12-02 15:56:46 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1795 Port highlighting with arrow to XBoard
1796
1797 Unfortuntely this duplicates a fair amount of code in the front end.
1798 Removing the arrow is done by a total repaint if there is a non-zero
1799 lineGap, because the clever algorithm for selective redrawing (based
1800 on damage) that XBoard uses does not repair damage to the grid lines.
1801 For lineGap=0, however, (for which the arrow is mainly intended) the
1802 damage mechanism is used, and the damaged squares are determined by
1803 tracing out the arrow in 64 steps, and marking all squares in the
1804 neighborhood as damaged.
1805
1806 2010-12-02 15:55:25 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1807 Strip CR from xboard.c
1808
1809
1810 2010-12-02 14:21:24 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1811 Let user decide if he wants highlights in blindfold mode
1812
1813 Remove the automaticsuppression ofhighlighting.
1814
1815 2010-12-02 00:24:43 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1816 Fix fag-fell marker with logos on
1817
1818 The flag-fell marker "(!)" that is displayed in the clock in WinBoard in
1819 two-machines mode was printed twice when the clock was split over two
1820 lines (as with logos on).
1821
1822 2010-12-01 18:57:57 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1823 Also exempt variant seirawan from eval-scale doubling
1824
1825 It is not really a drop game, so a scale from -7 to 7 in the eval graph
1826 is good enough (like variants great and super).
1827
1828 2010-12-01 10:33:13 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1829 Configure EGTB cache size in adapterCommand
1830
1831 The hash size, nr of CPUs and EGTB path are transferred through the WB
1832 protocol interface commands memory, cores and egtpath. But there is no
1833 WB command for detailing the EGTB cache size. So the value of the
1834 command-line option -defaultCacheSizeEGTB has to be sent to Polyglot
1835 through its startup command to make it known to UCI engines.
1836
1837 2010-11-30 22:46:16 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1838 Move Hint and Book items to Engine menu in XBoard
1839
1840
1841 2010-11-30 22:17:24 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1842 Correct the key bindings fo view menu in texi file
1843
1844 The mentioned bindings for Game List and Eval Graph were wrong.
1845
1846 2010-11-30 21:25:07 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1847 Fix sub-variation display with negative score
1848
1849 The test if the displayed score was the pvInfo score failed for negative
1850 scores, because floats are truncated towards zero. So the previous fix
1851 of spurious score/depth info was not working when the score was
1852 negative.
1853
1854 2010-11-30 18:27:52 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1855 Peel PV out of comment
1856
1857 Arena stores engine PVs not in variation format, but within both braces
1858 and parentheses, before the score/depth info. This caused XBoard to
1859 overlook the score/depth info, (frustrating, e.g., the eval graph),
1860 while the PV would not be accessible for walking it as a variation.
1861 The routine that extracts the score/depth from a comment now has
1862 been made more clever, to recognize a leadin PV in the comment, and then
1863 place it in front of the comment as variation (by moving the opening
1864 brace to behind it). For some reason it does not work if the PV and
1865 score/depth were separated by a newline, but this happens quite rarely.
1866
1867 2010-11-30 18:23:12 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1868 Allow line-straddling result comments
1869
1870 Some GUIs (in particular Arena) do not have the decency to keep the
1871 result comment on a single line. In this case the parser rules would not
1872 recognize it, and treat it as a normal comment, plus an undetailed PGN
1873 result. The rules are now fixed to allow linefeeds in the comment, and
1874 between comment and PGN result. To correctly process the comment further
1875 (e.g. in game-list lines) the linefeeds are replaced by spaces in the
1876 back-end routines that do use the result comment.
1877
1878 2010-11-30 12:22:32 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1879 Write key bindings in XBoard menus
1880
1881 Unfortunately tabs are not understood in menu texts, so fine-tuning
1882 through spaces is necessary to get some sort of ragged alignment.
1883
1884 2010-11-29 18:01:38 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1885 Configure XBoard to use wood board texture by default
1886
1887 The texture pixmaps are sought in /usr/share/games/xboard, with names
1888 wood_l.pm and wood_d.xpm. I guess the " make install" should be adapted
1889 to put them there. XBoard is resitent to non-existence of the files,
1890 btw. It simply ignores the arguments in that case.
1891
1892 2010-11-29 17:48:48 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1893 Configure -inc as volatile option in XBoard
1894
1895 XBoard users are not used to options being persistent, and thus have
1896 many scripts assuming the timeIncrement is -1 when they don't specify it
1897 on the command line, and want to specify -mps. But a persistent -inc of
1898 0 fom a preious session would then force their -mps to zero, causing
1899 big-time confusion.
1900
1901 2010-11-29 17:36:33 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1902 Make WinBoard clocks translation-proof
1903
1904 With logos on, the splitting of the clock over two lines assumed the
1905 lengths of the words "white" and "black" would always be 5. Used strlen.
1906
1907 2010-11-29 14:57:00 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1908 Improve drawing of highlight arrow
1909
1910 A diagonal arrow sometimes had a notch in the shaft because of
1911 independent rounding of the starting and ending point coordinates.
1912 Furthermore the width of the shaft was unnecessary variable(as a
1913 function of direction) because half the width was rounded and then used
1914 twice. Now rounding of end-points is always done towards a fixed grid
1915 of square centers, which keeps diagonals purely diagonal, and one side
1916 of the shaft is drawn relative to the other side, after the
1917 position of the latter has been rounded, so any rounding error affects
1918 the shaft width only once.
1919
1920 2010-11-29 10:25:50 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1921 Alter descriptionof Analyze File menu item
1922
1923 This menu item has been given a new function, so a new description was
1924 needed.
1925
1926 2010-11-29 10:15:39 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1927 Add description of Game List Options in texi file
1928
1929
1930 2010-11-29 09:58:00 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1931 Update texi file for new menu organization
1932
1933 The descriptions are shuffled around and organized into sections
1934 corresponding to the new main menus. Where necessary the name of the
1935 items was changed to their new names. The items removed from the File
1936 menu (the next/previous/same stuff) are nowmoved to the section "other
1937 shortcut keys", as the key bindings for some of them are still active.
1938
1939 2010-11-29 09:06:14 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1940 Update info on key bindings in texi file
1941
1942 The texi file was still listing the old XBoard key bindings. Where
1943 necessary this is now changed to the new (WinBoard) bindings, and all
1944 the new bindings were added.
1945
1946 2010-11-29 09:04:53 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1947 Add XBoard key bindings for Revert and Truncate
1948
1949 Use Home key as accelerator for Revert, End for Truncate, as in WinBoard.
1950
1951 2010-11-28 23:12:14 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1952 Divorce the Edit and Show Tags/Comment menu items
1953
1954 In WinBoard the items in the Edit and View menu for Tags and Comment now
1955 have different IDs, so they can be independently controlled. Only the
1956 items in the View menu are check-marked. The items still do the same.
1957
1958 2010-11-28 23:08:26 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1959 Alter WinBoard menu text
1960
1961 The texts are slightly adapted, mostly by choosing more convenient
1962 tabbing characters for the new menu organization. The translation
1963 template is updated accordingly.
1964
1965 2010-11-28 20:24:46 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1966 Let move-history window scroll to bottom after adding move
1967
1968 By activating the scrollbar of the viewport through XtCallActionProc
1969 the move-history window is scrolled to the bottom.
1970
1971 2010-11-27 14:38:14 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1972 Fix Shogi promotion popup
1973
1974 The texts were adapted to shogi by printing new text items over the
1975 Queen and Knight buttons, but these did not alwys cover it. Now the text
1976 on the buttons is changed as it should be. Also the window title is
1977 adapted.
1978
1979 2010-11-26 11:22:06 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1980 Apply gettext macros to menu texts
1981
1982 Now texts and references are separated, the texts in the tables can be
1983 decorated with the N_() macro, so that the _() macro no longer has to be
1984 applied when they are used. (This makes the texts appear in the .po
1985 files.)
1986
1987 2010-11-26 11:12:58 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1988 Adapt some XBoard menu texts
1989
1990 The "Show" prefix is removed from the "View" menu items, as this seems
1991 implied. An ellipsis is added to the Engine #N Settings items, which
1992 could not be there before, because periods in a menu name would break
1993 any reference to it. For some other names the ellipsis was deleted.
1994 (These were not refered to, but who knows what we will do in the future.)
1995
1996 2010-11-26 11:03:35 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
1997 Separate menu text from menu name in XBoard
1998
1999 The text string in the menu-definition tables was used both for the menu
2000 text, as well as for referencing the items from the code (for enabing or
2001 checkmarking). Now these can be defined separately, so that altering the
2002 menu texts is possible without breaing any references to the item.
2003 (Moving them to another menu would still break XBoard, though!)
2004 Currently the texts and names are still the same.
2005
2006 2010-11-26 10:48:54 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2007 Bugfix XBoard menu translation
2008
2009 The gettext macro N_() was applied to the menu definition tables, but
2010 this would break any translation, as these items are both used as menu
2011 texts as well as reference for enabling and checkmarking. The routines
2012 that create the menus already apply _() dynamically to these items when
2013 they are used as menu texts.
2014
2015 2010-11-26 10:10:55 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2016 Restrict drops in variant seirawan to back rank
2017
2018 Drops aren't really llowed at all in Seirawan Ches, but there exists an
2019 engine that supports a variant where drops on the back-rank are allowed.
2020
2021 2010-11-25 19:44:37 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2022 Let Analyze File annotate the loaded game
2023
2024 By not suppressing the auto-play loop in AnalyzeFle mode, we step
2025 through the game while the engine is analyzing, and store the PV info
2026 that the engine produces, as well as the full PV (as variation comment)
2027 with each move.
2028
2029 2010-11-25 19:41:05 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2030 Revive Analyze File menu item in WB
2031
2032 We will keep this menu after all, becase it can be given a new meaning.
2033
2034 2010-11-25 19:31:52 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2035 Fix spurious scores in comments
2036
2037 The comment popup is also used to display engine PV info, but when the
2038 contents of the window is written back when we select a variation,
2039 it was treated as a real comment. This is fixed now by checing in
2040 ReplaceComment() if the comment starts with the PV info, and if so,
2041 ignore the latter. This solves the problem, but I guess the real bug is
2042 that selecting a variation tries to write the comment even if it did not
2043 change.
2044
2045 2010-11-25 19:26:34 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2046 Display error for wrong use of Machine Match
2047
2048
2049 2010-11-24 13:30:08 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2050 Reorganize XBoard menus
2051
2052
2053 2010-11-24 11:02:19 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2054 Reorganize WinBoard menus
2055
2056 New main menus Edit, View and Engine are added; the step menu
2057 disappears. The menu items are redistributed over the new menus.
2058 Sometimes duplicates are created. No adaptation of short-cut characters
2059 as made yet (as this affects translation).
2060
2061 2010-11-20 20:20:27 -0800 Arun Persaud <arun@nubati.net>:
2062 removed trailing whitespaces from NEWS
2063
2064
2065 2010-11-20 20:19:30 -0800 Arun Persaud <arun@nubati.net>:
2066 merged readme_HGM.txt into the NEWS file
2067
2068 seems like a better place for the release notes, although those releases where not officially part of GNU, but the NEWS file already covers similar releases, so it might as well cover all of them.
2069
2070 2010-11-20 18:24:19 -0800 Arun Persaud <arun@nubati.net>:
2071 typo in date of developer release
2072
2073 but will leave the tagged version as it is, since it's still a unique version number
2074
2075 2010-11-20 18:11:01 -0800 Arun Persaud <arun@nubati.net>:
2076 new developer release
2077
2078
2079 2010-11-20 18:12:41 -0800 Arun Persaud <arun@nubati.net>:
2080 added latest version of parser.c
2081
2082
2083 2010-11-20 18:05:56 -0800 Arun Persaud <arun@nubati.net>:
2084 updated Changelog, etc for developer release
2085
2086
2087 2010-11-20 16:22:00 -0800 Arun Persaud <arun@nubati.net>:
2088 Revert "adding gnu-readline support"
2089
2090 This reverts commit c95ef32a700132a134f335f857ca6f1b6f3c169f.
2091
2092 Conflicts:
2093         backend.c
2094
2095 better to use the (relatively) new ICS input box then add readline support.
2096
2097 2010-11-20 16:19:32 -0800 Arun Persaud <arun@nubati.net>:
2098 Revert "bugfix: fixed readline support with icslogon option"
2099
2100 This reverts commit b9cdd7422ad1037d7376bce4f8f2db2669396e83.
2101
2102 Conflicts:
2103         backend.c
2104
2105 better to use the (relatively) new ICS input box then add readline support.
2106
2107 2010-11-19 23:10:35 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2108 Make Hoplite moves irreversible in Spartan Chess
2109
2110 Consider Lance moves in variant Fairy (where the Lance represents the
2111 Spartan Hoplite Pawn) as Pawn moves, so they reset the 50-move counter.
2112
2113 2010-11-19 21:09:24 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2114 Give Lance moves of Amazon in variant super
2115
2116 Now that Lance is no longer a wild-card piece the moves of Amazon must
2117 be programmed explicitly, to keep the possibbilty to play Superchess
2118 with legality testing on.
2119
2120 2010-11-19 18:32:16 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2121 Change representation of Bede in variant fairy initial position
2122
2123 This used to be Lance, but the promoted Bishop (Dragon Horse)
2124 is more applicable. Especially now that Lance is supposed to move like a
2125 Berolina Pawn.
2126
2127 2010-11-19 18:28:19 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2128 Make yyskipmoves also suppress examining of drop moves
2129
2130 Not sure if this does any good, but it seemed illogical that this would
2131 happen in all other moves, but not drops.
2132
2133 2010-11-19 18:23:05 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2134 Define moves for Dragon Horse outside Shogi
2135
2136 Let it move like Bishop + Wazir + Dababba.
2137
2138 2010-11-17 13:40:20 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2139 Fix safety crash when appending comments
2140
2141 The length limit imposed on safeStrCpy was one too short when copying
2142 an existing comment to the space allocated for the longer (concatenated)
2143 one. It allowed no space for the terminating '\0'.
2144
2145 2010-11-17 13:38:00 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2146 Fix safeStrCpy
2147
2148 The test for when to terminate a non-fiting string was one off, and the
2149 debug message was written stdoutin stead of debugFP.
2150
2151 2010-11-16 12:40:31 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2152 Fix default holdings size for variant seirawan
2153
2154 The holdings for 7 pieces werealways considered an overrule, so that the
2155 variant name was prefixed with "8x8+7_".
2156
2157 2010-11-15 11:36:21 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2158 Fix home-dir crash
2159
2160 When confronted with a path name starting with ~ and not containing a /
2161 XBoard would segfault.
2162
2163 2010-11-14 21:45:55 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2164 Fix one-click moving on up-click
2165
2166 (First) up-clicks were not always ignored: in Edit-Game mode with
2167 one-click moving enabled this could lead to a capture being made on
2168 the down-click, and the recapture on the correspoding up-click.
2169 This has now been corrected, and only the down-click of a first click
2170 can lead to selecting a piece or a one-click move.
2171
2172 2010-11-15 18:15:40 -0800 Arun Persaud <arun@nubati.net>:
2173 fixed buffer size for snprintf
2174
2175
2176 2010-11-13 23:04:14 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2177 Accept Seirawan-style gating suffixes
2178
2179 The parser rules were extended to accept / as an equivalent of = in
2180 promotion-suffix notation (e.g. Nf3/H in stead of Nf3=H).
2181
2182 2010-11-13 22:55:32 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2183 Use Falcon and Alfil as built-ins for Seirawan chess
2184
2185 Where available (size 49 and 72) we use Falcon for Archbishop and Alfil
2186 for Chancelor, to better conform to the Seirawan names Hawk and Elephant.
2187
2188 2010-11-13 20:02:31 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2189 Implement entering gating moves with mouse
2190
2191 A move with a back-rank piece that starts when a piece in the holdings
2192 is selected will be interpreted as a gating move in variant seirawan.
2193 The front-end uses a 'gatingPiece' selected this way todisplay it on the
2194 from square during animate dragging.
2195
2196 2010-11-13 18:56:15 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2197 Implement variant seirawan
2198
2199 Set upthe position, including Hawk and Elephant in holdings, in
2200 InitPostion(). Suppress putting captured pieces in holding. Let
2201 promoChar indicate gating in ApplyMove(). Remove gated pieces from
2202 the holdings there. Let GenLegal() generate RxK-type castlings to act as
2203 base for gating on Rook square. Gatings are tested for legality
2204 based on the holdings content and whether they occur on the back
2205 rank. Disambiguate() also tests this. Make sure the gated pieces are
2206 printed as move suffixes in CoordsToAlgebraic().
2207
2208 2010-11-13 18:42:27 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2209 Add -variant seirawan to menu
2210
2211
2212 2010-11-13 22:52:09 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2213 Fix acceptance of null-move with legality testing off
2214
2215 A second click on the same piece was interpreted as a to-square rather
2216 than deselection of the piece.
2217
2218 2010-11-13 22:49:43 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2219 Fix one-click bug
2220
2221 Disambiguate was imagining captures, so an only capture by double
2222 clicking your own piece did not always work.
2223
2224 2010-11-13 20:08:32 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2225 Fix mouse-driver buglet
2226
2227 The highlights were not cleared on moves that went vertically off board.
2228
2229 2010-11-12 17:17:41 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2230 List some undocumented commands as compliant
2231
2232 The engine->GUI commands setboard and setup are now always printed in
2233 the debug file as well.
2234
2235 2010-11-12 17:05:22 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2236 List Hint with compliant commands
2237
2238 This command was omitted, so that in some -engineDebugOutput modes it
2239 would not appear in the debug file.
2240
2241 2010-11-12 17:02:53 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2242 Restrict use of escape expansion
2243
2244 Only expand escape sequences like \n and \t in telluser(error) comamnds
2245 that ask for it by preficing the messages by double backslash. Otherwise
2246 backward copatiblity is too severely broken for messages that display
2247 DOS-style filenames.
2248
2249 2010-11-12 13:56:33 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2250 Make safeStrCpy safe
2251
2252 SafeStrCpy was causing a lot of out-of-bound write accesses, as it was
2253 always writing the character at the length limit of the destination.
2254 Now no memory is accessed that is is not needed to hold the copy.
2255
2256 2010-11-07 21:37:10 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2257 Allow clicked name internal to the icsMenu command string
2258
2259 A command in the /icsMenu that was specified to contain the selected
2260 text or clicked word always appended this word at the end. Now the user
2261 can also configure it to appear in the middle, by putting a %s in the
2262 command string where he wants it to appear.
2263
2264 2010-11-07 21:33:19 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2265 Let Engine #2 Settings start second engine
2266
2267 If the second engine is not yet running, it would be impossible to use
2268 the settings dialog for it, as the features have not been received and
2269 the dialog will be empty. So the user could not adjust the engine
2270 parameters before starting a match. Using this menu now automatically
2271 starts the engine, and delays the appearence of the popup untill the
2272 features are received, using a similar mechanism as in
2273 TwoMachinesEventIfReady().
2274
2275 2010-11-01 19:40:26 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2276 Newly lexed parser.c
2277
2278
2279 2010-11-06 19:55:31 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2280 Fix bug in parsing illegal Pawn captures
2281
2282 When a pawn move of type exf5 was illegal, the parser made an attempt to
2283 interpret it as e.p. capture of f5. This, however, messed up the move,
2284 so that it was now permanently mistaken for e5xf6. Even in cases with
2285 legality testing off, where you would want the original move to be
2286 accepted despite the fact that it was illegal.
2287
2288 2010-11-06 19:49:45 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2289 Keep last PV while clearing engine-output display
2290
2291 When ponder is on, the display is cleared immediately when the last line
2292 of thinking output appears by the appearing ponder output. So you would
2293 never get the chance to see it. This line is now re-written after
2294 clearing, so it appears at the bottom of the output for the next search.
2295
2296 2010-11-06 19:45:18 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2297 Give Lance moves of Berolina Pawn
2298
2299 In stead of using it as a wildcard piece, the Lance gets the moves of
2300 the Berolina Pawn (straight capture, diagonal move). The initial double
2301 osh can be a ump, though. (So it is really a Hoplite Pawn from Spartan
2302 Chess.)
2303
2304 2010-11-06 19:42:16 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2305 Use SAN even on illegal moves
2306
2307 If there is only one piece of type T, moves like Ta1 or Txa1 are never
2308 ambiguous, so adding the from square is just cumbersome.
2309
2310 2010-11-06 19:34:53 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2311 Use normal SAN for wildcard pieces
2312
2313 SAN often can also be used with pieces we don't know the moves of, e.g.
2314 if there is only one of that type. We just always get rank or file
2315 disambiguators if there are more (even when they might be unnecessary).
2316
2317 2010-11-06 14:52:12 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2318 Fix some warnings
2319
2320 Unused variables were removed from parser.l
2321
2322 2010-11-06 14:43:54 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2323 Allow arbitrary nesting of sub-variations in PGN input
2324
2325 The parsing of subvariations is moved out of the state-machine parsing,
2326 to allow arbitrary nesting. In stead of the entire sub-variation being
2327 parsed by lex as Comment, it now returns Open and Close for the
2328 corresponding parentheses, which are then handled in a wrapper routine
2329 for yylex(): Myylex(). Problem was that yy_text is supposed to return
2330 the entire parsed text of the returned symbol, which thus has to be
2331 collected. To make this possible, yylex has to return everything that it
2332 parses, (even white space!), and a symbol "Nothing" was added to return
2333 in parsing rules that before just ate away irrelevant text without
2334 returning anything.
2335
2336 2010-11-06 21:48:47 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2337 Implement setup (engine-GUI) command
2338
2339 This allows the frst engine (when legality testing is off) to overrule
2340 the default opening position, in reply to the variant command. Syntax is
2341 "setup (PIECE_TO_CHAR_TABLE) FEN_STRING"
2342 where the FEN string is interpreted in the context of the given
2343 pieceToCharTable (which is optional, and only delimeted by parethesis if
2344 it is present).
2345 Sendng the position to the second engine is delayed until the first
2346 engine has responded to the ping after the new-game sequence, to make
2347 sure it gets the chance to alter the position before it is sent to the
2348 second engine. This feature is useful for playing variants that WinBoard
2349 does not even know the opening positon for, and can be used even if they
2350 are shuffle variants.
2351
2352 2010-11-06 14:19:56 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2353 Restrict use of a2a3 kludge
2354
2355 The kudge to send "a2a3" in stead of "black" to get black to move is
2356 fatally flawed in varants that have no Pawn on a2. So in that case we
2357 revert to use of the deprecated "black" command.
2358
2359 2010-11-02 13:06:58 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2360 Remember values set by -firstOptions, -secondOptions
2361
2362 When an engine announces its option features, and the option name
2363 matches that of a setting given in -first/secondOptions, the engine is
2364 sent hte specified value, but this value was not remembered as current
2365 value (but the latter  was left at the engine-announced default),
2366 leading to inconsistent behavior in the Engine #N Settings dialog.
2367
2368 2010-11-01 19:26:19 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2369 Make test for valid promotion piece color-dependent
2370
2371 This is needed to make it work in variants where white and black have
2372 different armies; quite likely white will promote to pieces that do not
2373 exist in the black army, so we really have to make sure we test if the
2374 white (upper-case) piece exists in this case.
2375
2376 2010-11-01 19:23:43 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2377 Remove validity test on promochar from parser
2378
2379 The backend routines Disambiguate() and LegalityTest() will catch
2380 invalid promotions, so no need to do it here.
2381
2382 2010-10-31 23:37:06 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2383 Add the actual size-33 Shogi bitmaps
2384
2385 These were forgotten in the original commit that fixed the .rc file.
2386
2387 2010-10-31 13:20:08 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2388 Delete some stale promotion code
2389
2390 The correction of the promotion piece to Ferz in Shatran-like variants
2391 in ApplyMove() was no longer needed, as the new promotion code already
2392 does this in the move parser.
2393
2394 2010-10-31 13:08:52 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2395 Augment moves of some fairy pieces
2396
2397 To get better disambiguation in variants that have to be played with
2398 legality testing off, the Elephant is given also one-step moves (making
2399 it a so-called Modern Elephant) in -variant fairy and great. The Dragon
2400 King (Crowned Rook), which had no moves defined for it outside Shogi at
2401 all, has been given Rook moves plus an orthogonal 2-jump, so that it
2402 can get SAN moves when used as Dababba or Short Rook. (Illegal moves
2403 currently aways force long algebraic notation...)
2404
2405 2010-11-08 22:57:56 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2406 Bugfix safeStrCpy patch, WinBoard
2407
2408 The use of sizeof on pointers was detected through the same method as
2409 the previous patches, this time while compiling WinBoard. A typo in
2410 jaws.c was fixed as well.
2411
2412 2010-11-08 23:03:13 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2413 Bugfix for safeStrCpy patch for XBoard
2414
2415 By a trick (temporarily redefining safeStrCpy in common.h as
2416 ((char*) (a=1/(4-3rdArgument))) ) a compile-time warning (division by 0)
2417 could be generated for every occurrence where the size argument was equal
2418 to 4, i.e. where the 1st argument was likely a pointer rather than an
2419 array. These cases are now fixed. The file xoptions.c, which is the
2420 only ne that does not #include common.h had to be fixed by making
2421 the #define in the file itself.
2422
2423 2010-10-31 13:16:01 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
2424 Fix spurious promotions with legality testing off
2425
2426 The recent promotion patch had broken playing without legality testing
2427 completely: without legality testing one always gets the piece that was
2428 asked for, but a NULLCHAR should not be taken as a request for a piece!
2429 But it was, and this resulted in any moved piece turning into a white
2430 Pawn! For true promotions the piece was always black, which was also not
2431 very useful.
2432
2433 Also revert to the use of '+' as internal Shogi promoChar, because
2434 pre-processing turns out not to be possible when reading a game file.
2435 In stead parse any trailing '+' on moves as promoChar. Downside: '++'
2436 can no longer be recognized as checkmate symbol.
2437
2438 2010-10-29 22:54:18 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2439 Make deferral default in Shogi promotions
2440
2441 Because '+' is intercepted by the parser as check indicator, Shogi moves
2442 are pre-processed to change a trailing '+' into an internally used
2443 alternative '^'. The testing if a promotion character is OK is now done
2444 in LegalityTest() and Disambiguate(), which return ImpossibleMove when
2445 the character does not correspond to any piece, and IllegalMove when in
2446 Shogi anything other than '^' or '=' is used. (Except for the ICS
2447 notations.) On output, in CoordsToComputerAlgebraic() and
2448 CoordsToAlgebraic(), the '^' is translated back to '+'.
2449
2450 2010-10-28 17:51:34 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2451 Animate piece explosions in drag-drop moves and in XB
2452
2453 This required some code restructuring: the decision if an explosion is
2454 needed is now taken in a new routine Explode() in the backend. This then
2455 calls the front-end driver, and it returns the info if there was an
2456 explosion or not, so the caller (AnimateMove() or the mouse driver) can
2457 take action to repair the damage to the board caused by the blast wave.
2458 A front-end driver for XBoard is provided as well, so that both
2459 click-click (and replay, which is the same) and drag-drop atomic
2460 captures are animated in XB as well as WB.
2461 Explosions on rejected moves are suppressed.
2462
2463 2010-10-28 13:53:51 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2464 Suppress promotion popup if piece will explode
2465
2466 In atomic, a Pawn capture to last rank is not really a promotion.
2467 Fix choice to Queen.
2468
2469 2010-10-28 18:42:25 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2470 Make Knight hop first straight, then diagonal
2471
2472 It used to be the other way around, which looked pretty illogical in
2473 Xiangqi: to see Horses, which are blockable pieces there, move over an
2474 occupied square.
2475
2476 2010-10-27 20:04:01 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2477 Let -oneClickMove also work in EditGame mode
2478
2479 There is really no reason why people that lke one-clcik moves enough to
2480 switch them on would not want to use them too when editing a game.
2481 This solves a nast inconsistency, as before it used to work in -ncp mode
2482 on the _first_ move, as the mode is then BeginningOfGame, and not yet
2483 EditGame, and we do want it to work for BeginningOfGame, as this is
2484 also the game mode when you start playing as white.
2485
2486 2010-10-27 19:40:22 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2487 Make -flipBlack and -allWhite option volatile
2488
2489 As these options are very Shogi specific, and the variant is volatile,
2490 it seems logical to make them also volatile. Not completely sure about
2491 -allWhite, though. It cold be useful if you want, for example, to play
2492 wth dark-brown pieces for black, as any color but black looks much
2493 better with outline pieces than with solid pieces.
2494
2495 2010-10-27 19:33:44 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2496 Provide some sample board-texture pixmaps
2497
2498 Wood and marble themes are provided as textures for light and dark
2499 squares, plus two complete Xiangqi boards (wood and evenly colored).
2500 These should probably not goint the distro tar ball.
2501
2502 2010-10-27 19:25:56 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2503 The -overrideLineGap option is made to work in XBoard
2504
2505 Although XBoard already allowed this in the -boardSize specification,
2506 it is still seful to globally disable grid lines, e.g. for an
2507 oriental Xiangqi board. And it converges XB and WB.
2508
2509 2010-10-27 19:18:41 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2510 Implement board textures in XBoard
2511
2512 The -darkBackTextureFile and -liteBackTextureFile options now wrk in
2513 XBoard too, for loading a pixmap that will be used to cut out the dark
2514 and light square backgrounds. The cutting algorithm is such that the
2515 pixmap image is completely restored if the size was that of the total
2516 board (e.g. a drawing of a Xiangqi board).
2517
2518 2010-10-27 12:11:02 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2519 Complete WB (western) bitmaps for Shogi at size 33
2520
2521 The Lance was not replacing Queen in some sizes where the bitmaps were
2522 already available, and new bitmaps for the promotion Golds were added.
2523
2524 2010-10-22 20:30:06 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2525 Make starting new variation dependent on shift key
2526
2527 The shift key is read during mouse events, and posted in a global
2528 variable, which can then be used by the back-end. The decision to start
2529 a new variation (pushing the game tail rather than clipping it off) when
2530 entring a move in Edit Game or Analyze mode is made dependent on this.
2531 The move-typein also records the shift-key state.
2532
2533 2010-10-22 20:25:06 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2534 Fix merging bug
2535
2536 A %g format was used to print an int in sending the level command,
2537 because decimal points were dropped when merging patches. Also an unused
2538 variable was removed to suppress a warning.
2539
2540 2010-10-18 19:50:09 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2541 Add set of shogi pixmaps for XBoard
2542
2543 The -size 64 pieces from gShogi (and originally XShogi) are made
2544 suitable for loading by XBoard, through redefining the transparent
2545 background color as either light or dark square color. These bitmaps are
2546 not included in the XBoard build, and perhaps should not even be
2547 included in the source distribution, but made available in a separate
2548 distribution?
2549
2550 2010-10-18 19:46:33 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2551 Implement -flipBlack in XBoard
2552
2553 When -flipBlack is true, the white and back piece pixmaps are swapped in
2554 flipView. The idea is that the black pieces are upside-down versions of
2555 the white (Shogi) pieces, so that swapping white and black in effect
2556 turns all pieces upside down, which is what should happen in flipView.
2557
2558 2010-10-11 21:06:41 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2559 Disable some very verbose debug printing
2560
2561 The internationalization seems debugged enough to do without them.
2562
2563 2010-10-11 20:52:10 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2564 Add option -variations to control variation-tree walking
2565
2566 Just so that users can switch it off if the find it annoying.
2567
2568 2010-10-11 21:01:00 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2569 Allow full promotion suffixes on SAN piece moves
2570
2571 This facilitates the parsing of (non-standard) Shogi moves in ICS
2572 protocol. It can also be useful for Seirawan Chess, where a future
2573 implementation of it can use promotion suffixes to indicate gating.
2574
2575 2010-10-11 14:07:02 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2576 Allow lower-case piece indicator in drop-move notation
2577
2578 As it seems that XBoard also sends such moves in zippy play, it seems
2579 more fair to recognize them from the engine as well.
2580
2581 2010-10-10 21:26:11 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2582 Fix bug in ICS variant switch for Shogi
2583
2584 Because a test for 8x8 variants was done by <= VariantShogi,
2585 rather than <, spurious move-list fetching occurred in Shogi.
2586
2587 2010-10-10 21:23:09 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2588 Fix WinBoard Lance bug
2589
2590 The choice between Lance and Queen was made on appData.variant, in stead
2591 of gameInfo.variant. Because of this it was not always up-to-date in ICS
2592 games.
2593
2594 2010-10-10 21:15:06 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2595 Adapt WinBoard to Shogi implementation on Variant ICS
2596
2597 The Variant ICS does not use the '+P' notation for promoted pieces,
2598 neither in the board, nor in SAN, but simply indicates any Gold by 'G',
2599 and uses 'H' and 'D' for +B  and +R. The Shogi promotion code in
2600 LegalityTest() and Disambiguate(), which are used in move Parsing, are
2601 adapted to handle this. Deferred promotions sent to the ICS now use an
2602 == suffix.
2603
2604 2010-10-10 21:07:18 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2605 Inherit promoted-info that ICS does not give from previous board
2606
2607 The ICS does not tell us in Crazyhouse (or Shogi) if a piece is
2608 primordial or a promoted pawn (or a promoted other piece). We now derive
2609 this info from the previous board. The option -disguisePromotedPieces
2610 controls this feature.
2611
2612 2010-10-10 21:03:29 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2613 Limit multi-session clock handling to non-ICS games
2614
2615 In ICS games a time forfeit crashed XBoard, apparently because the
2616 fullTimeControl string is not properly set when we try to use it to see
2617 if a sudden-death session is indeed the last session.
2618
2619 2010-10-08 11:47:34 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2620 Change evalgraph scale in drop games
2621
2622 Score swings tend to be much larger in Crazyhouse and Shogi, so the
2623 vertical rangee in those games is doubled to (-14, 14).
2624
2625 2010-10-13 23:05:05 -0700 Arun Persaud <arun@nubati.net>:
2626 bugfix: fixed readline support with icslogon option
2627
2628 The icslogon option sends the login and password, so we don't need to handle
2629 special cases for the readline buffer.
2630
2631 2010-10-07 20:35:26 -0700 Arun Persaud <arun@nubati.net>:
2632 fixed some typos that were introduced during the sprintf->snprintf changes
2633
2634
2635 2010-10-07 11:59:33 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2636 Fix uninitialized variable in book code
2637
2638 The variable ' power' was used uninitialized in case -bookVariation was
2639 set to 0, which can be an error even if it was only multiplied by zero.
2640
2641 2010-10-06 14:20:03 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2642 Fix menu translation bug
2643
2644 The menuText array was declared too small, so that the last entry of the
2645 File menu got out of bounds and was overwritten by the first of the Mode
2646 menu.
2647
2648 2010-10-05 21:14:08 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2649 Allow -timeIncrement to be a float
2650
2651 The increment can now be fractional seconds. The printing in
2652 ParseTimeControl() and SendTimeControl() is done with %g format, so that
2653 for integer increment there is backward compatibility with the old level
2654 command.
2655
2656 2010-03-30 20:24:49 -0700 Arun Persaud <arun@nubati.net>:
2657 adding gnu-readline support
2658
2659 should make the user interface for xboard a bit nicer. In the end we want to have a separate input window, but this probably will have to wait until the GTK version.
2660
2661 2010-09-24 21:17:50 -0700 Arun Persaud <arun@nubati.net>:
2662 added warning if icsLogon file couldn't be opened
2663
2664
2665 2010-09-24 21:10:28 -0700 Arun Persaud <arun@nubati.net>:
2666 security fix: replaced some strcat with strncat
2667
2668 there is still more to do
2669
2670 2010-09-19 20:55:01 -0700 Arun Persaud <arun@nubati.net>:
2671 add option for silent builds
2672
2673 this can be enabled for automake versions >1.11 by calling ./configure --enable-silent-rules.
2674 It should still work for older automake versions too
2675
2676 2010-09-19 13:16:40 -0700 Arun Persaud <arun@nubati.net>:
2677 bugfix: missing array index
2678
2679
2680 2010-09-19 12:19:44 -0700 Arun Persaud <arun@nubati.net>:
2681 added new case for (Chessmove) 0 in common.h
2682
2683 this cleans up a few more -Wall messages
2684
2685 2010-09-17 21:47:22 -0700 Arun Persaud <arun@nubati.net>:
2686 cleaned up -Wall warnings (apart from settings some parentheses)
2687
2688 removed unsused variables, etc mostly everything from -Wall -Wno-parenthesis
2689
2690 2010-09-17 20:36:54 -0700 Arun Persaud <arun@nubati.net>:
2691 sizedefaults has 9 members, the last line of the array (NULL) only set 7.
2692
2693
2694 2010-09-12 20:04:03 -0700 Arun Persaud <arun@nubati.net>:
2695 security fix: replaced sprintf with snprintf
2696
2697 replaced most sprintf with snprintf. There are still some left where for example a pointer is used and is allocated in the line before, which should be fine... and some others.
2698
2699 2010-09-10 23:36:23 -0700 Arun Persaud <arun@nubati.net>:
2700 security fix: replaced strcpy with safeStrCpy from backend.c
2701
2702 see comment in backend.c on how to use safeStrCpy. This was already added by AS, but only used in 3 places.
2703
2704 2010-10-04 11:50:38 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2705 Enhance multi-session TC clock handling
2706
2707 Some new TC types are introduced: Bronstein and free sessions. The
2708 former is implemented by letting an exclamation point '!' in front of an
2709 increment (in the -tc string) indicate that the increment is limited to
2710 the time actually used on the previous move. The latter is an interval
2711 of given duraton in which you can do any number of moves (even zero),
2712 before the next session starts. This is needed for implementing Shogi
2713 byoyomi-type TC, as a first session, followed by a session of fixed-time
2714 per move. The latter can now be specified with the -tc argument as a
2715 degenerate case of Bronstein, where the time on the clock is <= the
2716 increment (so that it is never possible to think longer than the
2717 increment). A TC of 5 min + 10 sec byoyomi can then be indicated as
2718 300:10+!10.
2719
2720 The sessions are now separated by ':' in stead of '+', and all times in
2721 the TC string are converted to seconds first (in ParseTimeControl), so
2722 the fullTCstring can now be directly used in a PGN tag.
2723
2724 Note that this patch only addresses clock handling; the engine will not
2725 be informed yet if the TC type or parameters change at the start of new
2726 session!
2727
2728 2010-10-04 09:32:18 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2729 Remove promotion-piece encoding from ChessMove type
2730
2731 The shizophrenic way to indcate promotion pieces in the XBoard code
2732 (sometimes using a promoChar, at other times relying on moveType) was
2733 cured by combining all promotion move types (such as WhitePromotionRook)
2734 into a single one (WhitePromotion), and relying on promoChar to specify
2735 the piece. This solves the problem of promoting to new piece types in
2736 variants, which formerly also required addition of new move types.
2737
2738 In Shogi the '+' character is now consistently used to indicate
2739 promotions (and recognized in ApplyMove), rather than 'q' or
2740 PieeToChar(BlackQueen), as the latter did not work in minivariants where
2741 the Queen (representng the Lance) did not partcipate.
2742
2743 2010-10-03 20:50:01 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2744 Pass promoChar to SendMoveToICS
2745
2746 SendMoveToICS was the only place where the promotion piece was derived
2747 from moveType, rather than an explicity passed promoChar.
2748
2749 2010-10-04 09:41:11 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2750 Suppress spurious use of SAN castling in mini variants
2751
2752 King moves from a central file to the king-side-castled position (1
2753 square away from the right corner) were intercepted and printed as O-O
2754 in CoordsToAlgebraic. But on a 5x5 board (mini-Shogi!) this caught the
2755 normal King move Kc1-d1 as well. The castling notation is now reserved
2756 for King moves larger than one step.
2757
2758 2010-10-04 08:21:19 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2759 Make Shogi promotion zone board-size dependent
2760
2761 In stead of using a fixed size of 3 ranks, we use BOARD_HEIGHT/3, which
2762 would translate to 1 rank for mini-Shogi (5x5) and 2 ranks for Judgkin's
2763 Shogi (6x6), which are indeed what these variants need.
2764
2765 2010-10-03 19:58:00 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2766 Make board-size overrule options volatile
2767
2768 The options -boardWidth, -boardHeight and -holdingSize were legacies
2769 from the day choosing a variant would not automatically set a board
2770 size. As a result they are seldomly used anymore. The first real
2771 application is mini-Shogi (on 5x5 board), and it turned out very
2772 annoying if the 5x5 settings persisted to the next session, where you
2773 almost certainly want to play another variant.
2774
2775 2010-10-04 09:16:47 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2776 Strip DOS line endings from parser.l
2777
2778
2779 2010-09-16 18:58:37 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2780 Extend mate test to drop games
2781
2782 MateTest() in case of no legal moves now also looks if there are legal
2783 drops that can resolve the check. This provides reliable mate testing in
2784 Crazyhouse and Shogi, so these are now made subject to adjudications too.
2785
2786 2010-09-16 18:48:29 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2787 Extend legality testing to drop moves
2788
2789 LegalityTest() can nowbe called with (internal-format) drop moves, and
2790 delegates their testing to a new routine LegalDrop(). This routine
2791 performs the 'no-pawn-on-back-rank' test that used to be in
2792 UserMoveTest (which now calls LegalityTest also for drop moves).
2793 The more complex Shogi case is also handled (except for Pawn mate
2794 drops) in LegalDrop().
2795
2796 2010-09-16 18:25:21 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2797 Revert splitting of UserMoveEvent
2798
2799 This splitting into UserMoveTest and FinishMove was no longer needed,
2800 now that the new mouse driver no longer calls UserMoveTest to figure out
2801 if a move is a promotion, and XBoard and WinBoard are unified in this
2802 respect. It was counter-productive, because UserMoveTest was not able to
2803 change the fromX, fromY (call-by-value) parameters for passing them to
2804 FinishMove, so it had to defer the conversion of drop moves to internal
2805 format to the latter, while it did not belong there. (Because
2806 DropMenuEvent already delivers the moves in internal format.) This
2807 whole kludgy construction was therefore abandoned, by going back
2808 to the original 4.2.7 calling scheme, where UserMoveEvent completely
2809 pre-processes the move, and when it is valid, calls FinishMove directly.
2810
2811 2010-09-16 18:02:40 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2812 Fix silent bug in drop moves
2813
2814 In ApplyMove() the piece on the from square was accessed and used before
2815 we tested for drop moves. As drop moves have off-board from-squares this
2816 led to out-of-bound array access, which apparently was usually harmless.
2817
2818 2010-09-16 17:43:59 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2819 Allow parsing of upper-case machine moves
2820
2821 Dubious patch, as it caters to non-compliancy. Some variant engines are
2822 very non-compliant, though.
2823
2824 2010-09-16 17:38:35 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2825 Prevent transmission of spurious promo char to other engine
2826
2827 The parser now strps off spurious promotion characters.
2828 New move types "White/BlackNonPromotion" had to be introduced for this,
2829 to indicate NormalMoves that could have been a promotion, to make sure
2830 the '=' suffix of Shogi deferred promotions survives.
2831
2832 2010-09-16 20:44:37 -0700 Arun Persaud <arun@nubati.net>:
2833 fixed internationalization for winboard
2834
2835 in the original commit some files were forgotten. This should fix it.
2836
2837 2010-08-29 21:07:12 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2838 Fix JAWS bug saying side to move in ICS play
2839
2840 This was done the wrong way around.
2841
2842 2010-08-27 14:08:39 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2843 Make WB run-time language switch possible from menu
2844
2845 This is a rather involved patch that might not be worth it. It is
2846 difficult, because translation of things that live forever is not easy
2847 to invert (menus, the auxiliary windows). We hae to remember all
2848 original, English texts there to be able to put them back,or
2849 re-translate. Still does not fully work, although the menus and
2850 temporary dialogs now are all OK.
2851
2852 2010-08-27 14:35:46 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2853 Update WB translation template
2854
2855 The language.txt file now also contains all translatable strings from
2856 the C source files, rather than jsut the resource.
2857
2858 2010-08-27 14:14:51 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2859 Update docs
2860
2861 Add descriptions for machine-match menu support and enhanced book
2862 control, nick-name options and language.
2863
2864 2010-08-27 13:59:09 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2865 Add some forgotten translation hooks
2866
2867 The general-options, file-browse dialogs and the about box did not call
2868 Translate() yet. Also translate contents of combo boxes. Some small bug
2869 fixes.
2870
2871 2010-08-27 13:28:33 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2872 Do not translate game-end messages in PGN
2873
2874 The messages themselves are not subjected to _(), but in stead their
2875 displaying in DisplayMove is subjected to T_().
2876
2877 2010-08-23 13:23:22 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2878 Internationalization for WinBoard
2879
2880 A function Translate() was added, which uses a list of item dialogs,
2881 reads their value, and replaces it by a translation (if available). It
2882 also reads the window title and sets a translation. Calls to this
2883 routine are added in the initialization code of every dialog callback.
2884 In addition all translatable strings in the WnBoard front end are marked
2885 by the gettext macro _(). Because WB is not gettexted yet, a hard
2886 re-definition of this macro is added in each file using it, to the
2887 string-translation routine T_() supplied in winboard.c.
2888 Code to read the translation file, and translate the menu texts is added
2889 in winboard.c. In backend.c the meaning of the gettet macros is
2890 redefined for the WIN32 case.
2891
2892 2010-08-23 13:07:40 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2893 Make the ID of all WB dialog items unique
2894
2895 Mnany static dialog texts did share the ID -1 (IDC_STATIC). But to
2896 replace tet at run-time for translation purposes, they need to be
2897 addressed individually. So they were given new IDs, with symbols defined
2898 for those.
2899
2900 2010-08-23 12:48:07 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2901 Mark XBoard result messages for internationalization
2902
2903 The GNU gettext macro _() is used with the game-end messages. This might
2904 be controversial, as they will appear in the PGN as well. But only as a
2905 comment. We can always decide not to supply a translation.
2906
2907 2010-08-23 12:43:27 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2908 Do not exit after match when match started from menu
2909
2910 The codelooks weird, but matchMode == 2 in this case. We then use
2911 DisplayNote() to report the match result.
2912
2913 2010-08-23 12:39:07 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2914 Trivial-draws recognition improved in Xiangqi
2915
2916 Now based on a routine "SufficientDefence". If both have it, it is draw.
2917
2918 2010-08-20 17:46:45 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2919 Update .dev files
2920
2921 The relocation of parser.c and the addition of history.c was not yet
2922 incorporated in the devcpp proect files.
2923
2924 2010-08-19 13:45:04 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2925 Fix some MSVC compile errors
2926
2927 Some statements has moved up stream of declaratons, which is an error
2928 that gcc is forgiving about, but where MSVC is strict.
2929
2930 2010-08-14 14:01:44 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2931 Improved patch for expansion of WB settings-file name
2932
2933 The expansion of environment variables now allows multiple environment
2934 variables in the path name. Tested on %HOMEDRIVE%%HOMEPATH%\winboard.ini
2935 and %APPDATA%\winboard.ini.
2936
2937 2010-08-07 16:53:50 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2938 Add -colorNickNames option
2939
2940 This option allows non-standard designation of side to move in FENs.
2941 (Useful for Xiangqi, where white is indicated often as r(ed), and Shogi,
2942 where white is s(ente) or b(lack), and black is g(ote) or w(hite).)
2943 Can also be used for FENs in a local language. A match of theinput
2944 character with the nick name translates it to the standard; this means
2945 the standard will continue to be recognized, unless it was defined as a
2946 nick name.
2947
2948 2010-08-07 16:39:16 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2949 Tricked by the grossnes
2950
2951 Some WB menu items were referenced by a hard number. As items had been
2952 added over the years, the wrong menu items were grayed. In particular
2953 the Options -> Adjudication menu was grayed out, in -ncp mode, where
2954 this was intended for the Sounds dialog. This accidentally proved
2955 useful, until we started to apply adjudictions also to the Human moves.
2956 Then it was suddenly undesirable, and a small mystery why it happened at
2957 all, when I tried to change it. The numbers are now corrected to the new
2958 locatons of the items in the menus.
2959
2960 2010-08-07 16:35:23 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2961 Allow match to be started from WB menu
2962
2963 A menu item Machine Match was added in the Mode menu to switch to
2964 matchMode. A persistent option /defaultMatchGames determines the number
2965 of games. A control was added to the Options -> Common Engine dialog to
2966 set this option.
2967
2968 2010-08-07 16:26:35 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2969 Add some book-control options
2970
2971 Options /bookDepth and /bookVariation have been added to control the use
2972 of the GUI book. In WinBoard the Optons -> Common Engine dialog now
2973 contains fields to set them.
2974
2975 2010-08-07 00:15:57 -0700 Arun Persaud <arun@nubati.net>:
2976 new developer release
2977
2978
2979 2010-08-06 11:18:34 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2980 Repair exit-popup deadlock patch
2981
2982 Relocating the exit popup call had made it lose access to the message it
2983 should print, because it was declared only in an inner code block, by
2984 the same name: buf[]. Deleting the inner declaration fixes it.
2985
2986 2010-08-04 11:00:28 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2987 Fix erors when compiling with --disable-zippy
2988
2989 The file args.h contained a codeblock in #ifdef ZIPPY, in stead of
2990 fields.
2991
2992 2010-08-01 13:27:23 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
2993 Fix zippy handling of draw offers from ICS
2994
2995 The patch by DM to fix the problem introduced by the coloration of
2996 zippy-matched commands (namely that the coloration code beat the zippy
2997 draw recognition to it, and ate the draw offer away) was only targeting
2998 ICC. The new fix should work on any ICS (by using the same pattern in
2999 zippy as in the colorization code).
3000
3001 2010-08-01 13:15:27 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3002 Fix regression in colorization of zippy-matched commands
3003
3004 The patch by Daniel Mehrman from 4.2.pre8 was not properly merged, so
3005 that in XBoard no coloration would take place of ICS commands that were
3006 matched by zippy. (It was using &i as input pointer, rather than &backup.
3007 The XBoard-specific code now has been deleted completely, to remove a
3008 seemingly needless dependence on _WIN32_ of the back-end. Both WB and XB
3009 now use the XBoard method, to only match zippy commands when logged in.
3010
3011 2010-07-31 22:48:45 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3012 Suggest default file name in browser dialog
3013
3014 The argument 'def' to FileNamePopUp() was not passed through to the new
3015 file-browser routine, which got NULL in stead, and thus started with an
3016 empty input field.
3017
3018 2010-07-30 23:28:57 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3019 Define /firstUCI and /secondUCI as synonyms for /fUCI, /sUCI
3020
3021 Because the %s expansion of WB options in the /fcp and /scp lines only
3022 works for options that contain 'first' or 'second', and /fUCI thus did
3023 not work, PSWBTM had to rely on the cumbersome /firstIsUCI=true to
3024 install UCI engines. (The latter option should be deprecated really;
3025 the UCI-ness of the engines is a volatile option, so it makes no sense
3026 to supply a way to set them both to false or true. One only needs to be
3027 able to set it to the non-default state.)
3028
3029 2010-07-30 23:21:50 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3030 Add string option /pieceNickNames
3031
3032 This (volatile) option allows definition of alternate letters for the
3033 pieces, which will be recognized next to the standard symbols as given
3034 in the /pieceToCharTable on input. (Output always uses the standard.)
3035 This can be useful for reading PGN from another language, or
3036 non-compliant FENs (e.g. using B and N for E and H in Xiangqi).
3037   The format of the argument is the same as for /pieceToCharTable.
3038 Because the nickNames are consulted before the standard table, it is
3039 possible to redefine a standard name as a nick for another piece.
3040
3041 2010-07-30 23:10:42 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3042 Fix deadlock in match-result display
3043
3044 At the end of a match, GameEnds() was recursively calling itself,
3045 through DisplayFatalError() and ExitEvent(), and the latter was then
3046 delaying until the calling GameEnds() terminated. (Which it would of
3047 course never do before ExitEvent returned; fortunately there was a tim
3048 limit to this delay, but in XBoard it was 10 sec in stead of 10 msec.)
3049  Now the calling of DisplayFatalError() (to show the result popup) is
3050 delayed until after GameEnds completes (and resets the anti-recursion
3051 flag 'endingGame'), so that it is simply executed a second time, unaware
3052 of the earlier call. But this second time it does not do anything,
3053 because the gameMode ws set to EndOfGame the first time, and the writing
3054 of the PGN is blocked by the checksum being still the same.
3055
3056 2010-07-12 11:10:17 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3057 Fix WinBoard game-list title
3058
3059 Number of displayed games and WDL stats were always appended to the
3060 existing title, leading to an ever-growing title in the game-list
3061 window. Now the old actual title is ignored, and the starts is appended
3062 to the original title "Game List". (In the future we could use the
3063 filename here?)
3064
3065 In addition, the title was not updated when re-opening the game-list
3066 window, while the stats could change if filtering was active when the
3067 window was closed. (In that case the filter is cleared on re-opening, so
3068 the number of displayed games changes.) Now a title-update (after
3069 recalculating the stats) is done every time the game-list window is
3070 opened.
3071
3072 2010-07-11 11:06:27 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3073 Refactoring of material-draws adjudication code
3074
3075 Insufficient mating material is now determined per side individually, by
3076 testing for MatingPotential of each side. If both lack mating potential
3077 the game is adjudicated as draw (if the -materialDraws option is set).
3078
3079 This way MatingPotential() can later also be used to correct losses by
3080 forfeit to draws (which currently is only done when the opponent has a
3081 bare King).
3082
3083 The accuracy of this type of adjudication in Xiangqi has been highly
3084 improved.
3085
3086 2010-07-11 10:54:59 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3087 Fix bug in sending cores command to engine
3088
3089 The cores command was alwas sent to the engine(s) when the user changed
3090 it through the menu, even when the engine had sent feature smp=0 (which
3091 is default anyway). NewSettingEvent() was patched to send the new
3092 setting conditionally, based on the engine properties as recorded in
3093 ChessProgramStates first, second; In this particular case it now
3094 consults cps->maxCores. (Note the code for testing the second engine
3095 contains some dirty pointer arithmetic.)
3096
3097 2010-07-11 10:42:00 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3098 Fix oneClickMove bug
3099
3100 When checking for unique captures, no attention was payed to the option
3101 setting, so the capture was also made when the option was off.
3102
3103 2010-07-11 10:39:28 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3104 Remove duplicate testing for cores feature
3105
3106 The testing for this BooleanFeature occurred twice.
3107
3108 2010-07-11 10:35:13 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3109 Remove misspelled prototype
3110
3111 NewSettingEvent occurred, next to the correct one, in misspelled form.
3112
3113 2010-07-05 10:00:01 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3114 Fix parsing of SAN shogi promotions
3115
3116 A missing promotion character defaults to promotion in the move type,
3117 but the promotion character was not set when this happened in variant
3118 shogi. And it is especially important there, as the promotion character
3119 '+' will always be missing, as the parser will take it to be a 'check'
3120 symbol, and strip it from the move.
3121
3122 2010-07-05 09:55:14 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3123 Fix variant switch on PGN loading
3124
3125 When the PGN specified an essentially different variant, the
3126 piece bitmaps were not properly adapted, because the switch was done by
3127 calling InitPosition(), rather than Reset(). (The latter would destroy
3128 the PGN tags info.) We now added an explicit call to ResetFrontEnd(),
3129 (which is normally done from Reset()).
3130
3131 2010-07-05 09:51:53 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3132 Adjudicate Xiangqi material draws with Advisor-less Cannons
3133
3134 Used the Queen counter for counting Cannons. Note that material draws
3135 with stale Pawns (i.e. on the back rank) are not yet adjudicated.
3136
3137 2010-07-05 09:34:21 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3138 Remove font settings from master settings file
3139
3140 xboard.conf should not contain general font settings (not specific to
3141 one board size) with specified point size. In fact it should not even
3142 specify sizable fonts, as the new system would make specification of a
3143 general font overrule the size-specific settings in the .xboardrc file,
3144 so the persistence of fonts would be completely broken.
3145
3146 2010-06-30 10:52:27 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3147 Cut board squares out of texture bitmap more cleverly
3148
3149 When the bitmap is larger than the entire board, the squares are now cut
3150 out of the center of the virtual squares from subdividing the bitmap, so
3151 that they stay centered on the grid of a Xiangqi board bitmap. If the
3152 board size exceeds that of the bitmap, the old algorithm is still used,
3153 as the centering would make the edge squares exceed the bitmap, and
3154 cause a black rim around the board.
3155
3156 2010-06-30 10:49:12 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3157 Allow -flipBlack to work with font-based piece rendering
3158
3159 In addition the font-based pieces will also be flipped vertically in
3160 flipView for variant shogi when -flipBlack is off.
3161
3162 2010-06-30 10:46:43 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3163 Allow font-based piece rendering in board sizes below petite
3164
3165 At least for variants that use unorthodox pieces, so that switching back
3166 to using bitmaps is not really an option anyway.
3167
3168 2010-06-30 10:41:25 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3169 Ignore checks in 50-move count for Xiangqi
3170
3171 Both checks and evasions are discounted; this is only done after the
3172 naive counting exceeds the maximum, so during most of the game it causes
3173 no CPU load.
3174
3175 2010-06-05 14:38:47 -0700 Arun Persaud <arun@nubati.net>:
3176 removed some garbage from configure.ac that got added a while ago
3177
3178
3179 2010-05-25 21:20:27 -0400 Clint Adams <schizo@debian.org>:
3180 Remove unnecessary double equals from configure.ac.
3181
3182
3183 2010-05-28 11:07:06 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3184 Fix e.p. bug in xiangqi with -serverMoves option
3185
3186 Sideway Pawn moves were written as e.p. captures in the file with moves,
3187 which led to disappearence of pieces in the viewer.
3188
3189 2010-05-28 11:05:00 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3190 Repair score printing with -serverMoves option
3191
3192 A previous patch had moved MakeMove to before the update of pvInfoList,
3193 so that the score/depth info would not appear in the file with moves.
3194
3195 2010-05-28 11:02:54 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3196 Repair animate dragging
3197
3198 The previous patch had left a stray semicolon in the mouse handler.
3199
3200 2010-05-10 10:32:19 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3201 Fix game end during dragging
3202
3203 The stale-first-click fix interfered with proper handling of a piece
3204 being dragged when a game suddenly ended (because of opponent resign,
3205 or caling the flag), because up-clicks when the from-square was reset
3206 were completely ignored. Now such an 'unmatched' upclick calls
3207 DragPieceEnd() and redraws the board.
3208
3209 2010-05-10 10:09:36 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3210 Pop down old tags on loadng new game in WinBoard
3211
3212 ResetFrontEnd(), called from Reset(), did not do this in WinBoard
3213 (unlike XBoard), so that the tags from the previous game were left on
3214 display when -autoDisplayTags was off.
3215
3216 2010-05-09 22:15:27 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3217 Reverse mousewheel action
3218
3219 Apparently WinBoard was stepping in the opposite direction through the
3220 game in reaction to the mousewheel as every other GUI in existence.
3221
3222 2010-05-09 22:07:30 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3223 Fix bug in sending "usermove" when forcing book moves
3224
3225 The keyword "usermove" was copied to the buffer, but not sent before it
3226 was overwritten by the actual book move.
3227
3228 2010-05-06 17:23:24 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3229 Fix engine stall on perpetual-check evasion
3230
3231 The adjudication code had already put the engine in force mode after
3232 postponing the actual adjudication to the next move. Now first determine
3233 if we want to adjudicate now, and with which result, before stopping the
3234 engine and ending the game.
3235
3236 2010-05-06 16:37:04 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3237 Let move parser return ImpossibleMove for off-board moves
3238
3239 It used to return 0, which interfered with buiding a game list. This
3240 broke reading of multi-game PGN files containing games in a variant with
3241 a board size larger than that of the currenty active variant.
3242
3243 2010-04-06 15:05:10 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3244 Alter XBoard key bindings to mimic WinBoard
3245
3246 A lot of new bindings were added, and four menuProcs had to be registered
3247 to be able to add bindings to them. The use of the control key as
3248 temporary take-back for the last move conflicted with the use of Ctrl
3249 keystrokes, and this function was migrated to '.'. The iconify function
3250 had no shortcut in WinBoard, but to get rid of letter bindings it was
3251 migrated to '-'.
3252
3253 2010-04-05 20:45:45 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3254 Update README file
3255
3256
3257 2010-04-03 14:00:40 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3258 Fix typos in html help file
3259
3260
3261 2010-04-01 15:22:41 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3262 Fix JAWS piece drop cursor, and streamline some sentences
3263
3264 The cursor square was reset to a1 after every use of the piece menu,
3265 which was very inconvenient. Some of the spoken sentences have been
3266 improved; the square is read before the piece now, when using the arrow
3267 keys on the board.
3268
3269 2010-03-31 22:31:44 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3270 Allow escape sequences in telluser(error) messages
3271
3272 The routine EscapeExpand was moved to backend.c, and applied to the
3273 message received from the engine.
3274
3275 2010-03-31 21:29:39 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3276 Allow lower-case promochar in moves of type h8=Q
3277
3278 Updated the parser rules. Other move formats already allowed this.
3279
3280 2010-03-31 21:36:14 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3281 Fix Alt+M JAWS command in Two-Machines mode
3282
3283 The command refused to read the ast move because it contained thinking
3284 output of the other engine. Let it pay attention to evenIfDuplicate.
3285
3286 2010-03-29 09:57:48 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3287 Fix rep-draw recognition
3288
3289 The refactoring had broken the rep-draw recognition, by adding and extra
3290 condition in a conditional with side effects. The testing of this extra
3291 condition is now moved to after the side effect.
3292
3293 2010-03-28 12:32:07 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3294 Allow any %ENVIRONMENTVAR% in WB settings file name rather than ~
3295
3296 Only a single variable at the beginning of the file name is recognized,
3297 and the matching is not fool proof (it matches across backslashes).
3298
3299 2010-03-28 11:24:44 +0200 H.G. Muller <h.g.muller@hccnet.nl>:
3300 Fix info lines being used as normal thinking output
3301
3302 The new standard of using thinking output with time = nodes = score = 0
3303 as info messages for printing in the Engine-Output window was not
3304 understood everywhere, and led to such info lines being used for
3305 autoKibitzing and PGN annotation. The programStats are now only updated
3306 from thinking output received from an engine when it is not an info line.
3307
3308 2010-03-27 11:54:41 -0700 Arun Persaud <arun@nubati.net>:
3309 new developer release
3310
3311
3312 2010-03-26 21:16:52 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3313 Suppress background observe for boards with own game number
3314
3315 This is really a work-around for an ICS bug. The Variant-ICS sent the
3316 initial board of a game in a move list with relation = 0, which means
3317 'observed'. So XBoard was thinking it was observing its own game, and
3318 switched to dual board. It seems harmless to suppress such a switch for
3319 all boards of your own game, however, which is now done.
3320
3321 2010-03-26 21:12:19 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3322 Fix crash on switching to ICS xiangqi game
3323
3324 The oldBoard was a local variable, and only squares of the old board
3325 were initialized. This led to a crash if the copied board was enlarged,
3326 and then displayed. The variable is now declared static, so the
3327 uninitialized squares contain harmless zeros.
3328
3329 2010-03-26 18:32:36 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3330 Let Chat Boxes pop up above console, rather than on top of it
3331
3332 Use EnsureOnScreen() to have them overlap if there was no room.
3333
3334 2010-03-26 18:26:04 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3335 Fix disabling of Chat Box navigation buttons
3336
3337 The buttons for non-open boxes were enabed, rather than disabled.
3338
3339 2010-03-26 18:17:44 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3340 Prevent <Esc> closing chat box
3341
3342 Let it in stead switch focus back to the console window.
3343
3344 2010-03-26 15:28:54 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3345 Let WinBoard recognize ~ in settings file name as HOMEPATH
3346
3347 Fetch the appropriate environment variable to build the mathname in
3348 MySearchPath() whenever the file name starts with "~\".
3349
3350 2010-03-26 13:59:28 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3351 Change name of Global Settings menu item to Common Engine Settings
3352
3353 The old name confused ICS users, as this is an engine-only dialog.
3354
3355 2010-03-26 13:58:46 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3356 Update WinBoard RTF docs
3357
3358
3359 2010-03-26 13:57:59 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3360 Update WinBoard html help
3361
3362
3363 2010-03-24 18:00:08 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3364 Allow adjustment of clocks in any mode with shift+click
3365
3366 In practice changing to edit-game mode during a game was very
3367 cumbersome. In WinBoard shift+click is now offered as an alternative.
3368 Make sure a right-click in the clock area is not also counted for other
3369 purposes.
3370
3371 2010-03-24 17:21:47 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3372 Allow loading of PGN variations in XBoard
3373
3374 Right-clicking variation comments in the comment-window was implemented
3375 through a translation. The right button is now bound to routines that
3376 set both the end and start of the selection, as setting a new start does
3377 not seem to work if the previous select-start was not completed by a
3378 select-end or extend-end. Finally the main handler uses the selection
3379 cursors to know what was clicked.
3380
3381 2010-03-24 17:16:59 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3382 Update XBoard docs
3383
3384 Added a descripton of the new ICS options (seek graph, back-ground
3385 observe) and menus (Upload) to the texi file. Also added a description
3386 of the variation (Annotate menu item and PGN variation comments) and PV
3387 walking (clicking engine-output). Describe the -shuffleOpenings option.
3388
3389 2010-03-24 13:30:59 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3390 Paint highlights on dual board (WB)
3391
3392 The highlight info is hidden in the partner board to pass it to the
3393 front-end.
3394
3395 2010-03-24 13:14:54 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3396 Fix handling username change during game
3397
3398 The title bar and gameInfo (going into the PGN) were not adapted when
3399 the username was changed through the menu, so that the change became
3400 only effective on the next game. Requires SetGameInfo to be called from
3401 the front-end, and thus a prototype for it in backend.c.
3402
3403 2010-03-24 11:04:00 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3404 Fix window-position upset on failing engine start in WinBoard
3405
3406 The main window was only positoned according to the settings-file data
3407 after the engine was started up from InitBackend2(), so that if the
3408 latter gave a fatal error, and Save Settings on Exit was on, a wrong
3409 position for the main window would be saved. The call to InitBackend2()
3410 is now moved until after setting the main-window position.
3411
3412 2010-03-23 23:22:46 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3413 Display PV from Engine-Output window (XBoard)
3414
3415 Translations are added to bind button 3 to the PV walk for the memo
3416 widgets, and the corresponding handlers are ported from wengineoutput.c.
3417
3418 2010-03-10 18:54:28 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3419 Set keyboard focus at startup to board window
3420
3421 This makes XBoard sensitive to the keybindings also when the cursor is
3422 outside the board window. This focus seems to persist indefinitely: each
3423 time the board window gets selected, the key bindings become activem
3424 wherever the mouse pointer is. Downside: the mouse pointer is no longer
3425 an arrow outside the board window, but becomes a text-insert tool there.
3426
3427 2010-02-27 20:49:21 -0800 Arun Persaud <arun@nubati.net>:
3428 added logo files for xboard
3429
3430 logos are installed in the hicolor theme [1] using $datadir as the basedir.
3431 Added both png and svg logo.
3432
3433 [1] http://standards.freedesktop.org/icon-theme-spec/icon-theme-spec-latest.html
3434
3435 2010-02-27 17:36:10 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3436 Remake programVersion string after receiving engine features
3437
3438 The engine could have sent a more accurate version of its own name
3439 than the one derived from the exe filename in a myname feature, and we
3440 better use that in the programVersion string, which will be sent as
3441 interface name to the ICS.
3442
3443 2010-02-25 19:22:00 -0800 Arun Persaud <arun@nubati.net>:
3444 Revert "Repair settings-file name"
3445
3446 This reverts commit a02042ef83ce1f3632f0cf3e0a2a4ce9a3ac5d85.
3447
3448 2010-02-25 20:32:23 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3449 Add -autokibitz checkbox to UCI-options menu dialog
3450
3451
3452 2010-02-25 20:29:45 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3453 Also capture (numeric) whispers of players for -autoKibitz
3454
3455
3456 2010-02-25 20:25:32 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3457 Add kibitzes and c-shouts Chat Box
3458
3459 A box dedicated to c-shouts will snatch any c-shout before it is
3460 diverted to a normal shouts box. The kibitzes box can capture the
3461 left-overs of -autoKibitz, if the latter is active.
3462
3463 2010-02-25 15:45:16 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3464 Mark non-compliant lines of engine in debug file
3465
3466 The option -engineDebugOutput is extended to accept value 3 for printing
3467 a cear indication of non-compliancy in the debug file.
3468
3469 2010-02-25 12:02:58 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3470 Redraw second board on expose events
3471
3472 The -dualBoard option now does refresh the second board after another
3473 window uncovers it. To acheive this, some data structures remembering
3474 what is displayed had to be duplicated. (lastBoard and damage for XB,
3475 lastReq, lastDrawn, lastReqValid and lastDrawnValid for WB.)
3476 WinBoard now uses clipping also for second board. This required the
3477 clips for the destination to be translated horizontally!
3478
3479 2010-02-25 15:13:00 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3480 Print seconds with 2 digits in backgroundObserve status line
3481
3482
3483 2010-02-24 17:01:23 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3484 Do not recognize non-ICS variants from PGN event tag
3485
3486 These variants were introduced after supporting the variant tag, so if
3487 the variant tag is missing, their recognition from the event tag will be
3488 a false match. (Mainly to prevent events with 'super' in the name being
3489 recognized as Superchess.)
3490
3491 2010-02-23 13:52:51 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3492 Fix display of uninitialized boards in background observe
3493
3494 A variable partnerBoardValid is cleared on starting our own game, and
3495 set when a board from the background game comes in during it. At the end
3496 of our own game, a valid partner board now is put in the display.
3497
3498 2010-02-23 13:46:25 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3499 Add option Display Logo in WB general-options menu
3500
3501 Changing the option requires InitDrawingSizes to be called for
3502 re-formatting the board window. Switching it off requires clearing of
3503 the cps->programLogo fields to take effect immediately. Switching it on
3504 only takes effect the next session, as we will need some refactoring to
3505 redo the figuring out what logos to display.
3506
3507 2010-02-22 12:02:59 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3508 Group Chat Boxes with console in stead of board window
3509
3510 They now open and close with the console, which seems more natural, and
3511 prevents the console from covering them.
3512
3513 2010-02-22 11:50:59 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3514 Put new options in WB ICS-options dialog
3515
3516 The Seek-Graph, background-observe and Chat-Box options are added to the
3517 ICS options dialog. They only control the appData settings, there are no
3518 special actions yet on switching the settings.
3519
3520 2010-02-22 11:46:33 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3521 Create space in WinBoard ICS-options dialog
3522
3523
3524 2010-02-20 12:42:09 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3525 Use side-by-side boards to display background game
3526
3527 A game observed in the background (i.e. if -backgroundObserve true) will
3528 be displayed right of the normal board in the same window if the new
3529 (persistent) Boolean option -dualBoard is also set.
3530 Very flakey hack, especially in XBoard, where clocks and messsage
3531 field all get the wrong width (and resist adjustment in the strangest
3532 ways). The clocks of the partner game are not yet displayed, and
3533 disaster happens when the background and foreground games do not have
3534 the same board format.
3535
3536 2010-02-23 14:57:01 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3537 Repair background-observe patch
3538
3539 Apparently a commit was lost that I collapsed with 3018a6 while the
3540 latter was already pushed to savannah. Here I recreated this commit from
3541 a diff between the respective commits in the savannah & nubati gits.
3542
3543 2010-01-31 11:07:33 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3544 Repair settings-file name
3545
3546 The default name is put back to /etc/xboard/xboard.conf, so that XBoard
3547 can again find its settings file. "make install" will still install it
3548 in the wrong place.
3549
3550 2010-02-21 18:43:59 -0800 Arun Persaud <arun@nubati.net>:
3551 new developer release
3552
3553
3554 2010-02-21 19:45:58 -0800 Arun Persaud <arun@nubati.net>:
3555 fixed compiler warning for file-browser code
3556
3557 missing "void"s in the function declaration and missing returns showed up when trying to build on the opensuse build server. fixed now.
3558
3559 2010-02-21 23:09:24 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3560 Put newly opened Chat Box on top
3561
3562 Dialogs always pop up in front, so set the onTop variable that prevents
3563 highighting the button to navigate to it from other Chat Boxes
3564 to reflect that a newly opened Chat Box is in view.
3565
3566 2010-02-21 18:55:03 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3567 Fix copying of kibitzed info in Engine-Output window
3568
3569 Make sure all lines end with "\r\n" to not lose line breaks on
3570 copy-paste from the memo. (XBoard would strip those again.)
3571
3572 2010-02-21 18:25:45 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3573 Allow walking a kibitzed PV
3574
3575 If no tabs are found in te 'thinking output' we assume it is a captured
3576 kibitz message, and look for "PV=" to locate the start of a PV in it.
3577 Also try to include any continuation lines below the selected line.
3578
3579 2010-02-21 17:45:37 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3580 Insert autoKibitz continuation lines at end of line
3581
3582 In the engine-output window lines that start with the ICS continuation
3583 sequence "\   " are inserted behind the line they belong to, in stead of
3584 at the top. This required keeping thrack of the length of the currently
3585 active line in OutputKibitz().
3586
3587 2010-02-20 15:39:29 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3588 Don't disturb background observe when receiving new piece
3589
3590 When new holdings are sent when the background game is displayed, we now
3591 ignore this, as presumably we are peeking at our partners game, and thus
3592 should be well aware of what is captured there.
3593
3594 2010-02-19 21:52:06 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3595 Newly lexed parser in XBoard directory
3596
3597
3598 2010-02-19 11:18:21 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3599 Let yy_text determine progress of PV parsing
3600
3601 The parsed unit yy_text was not available after ParseOneMove(), because
3602 the buffer switch in yylexstr() apparently destroys it. To solve that,
3603 yylexstr() now is equiped with an extra buffer argument, where it copies
3604 yy_text before the switch, so the caller, ParsePV(), can see what was
3605 parsed in yy_textstr. This is used to update the PV pointer, but also to
3606 save any parsed comments (when ParsePV is used for parsing a PGN variation).
3607
3608 2010-02-18 17:42:48 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3609 Support playing through PGN variation comments
3610
3611 Right-clicking a variation line in the comment dialog will shelve the
3612 current variation, and parse the comment to replace it. This uses
3613 ParsePV() in an alternative way, for which the latter had to be
3614 enhanced: it was made resistent to move numbers and comments inside
3615 the PV. It now has an argument to indicate if such comments should be
3616 stored with the moves. The Comment Popup is closed on revert, to
3617 make sure no comments to moves that are destroyed, containing
3618 variations on a non-valid line, can keep hanging around.
3619
3620 2010-02-18 16:05:35 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3621 Add Annotate item in Step menu
3622
3623 This does the same as Revert, except that it adds the destroyed
3624 variation as comment to the original movem in PGN variation format.
3625 RevertEvent now has an argument to indicate if it should add the
3626 comment, or not. Comments in the abandoned variation are included in the
3627 varriation command to the main line. (The exact layout of the variation
3628 comment that results leaves still to be desired.)
3629
3630 2010-02-15 19:07:12 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3631 Add option -shuffleOpenings
3632
3633 This volatile option is added just to make the existing variable
3634 available from the command line, not only from the menus.
3635
3636 2010-02-19 11:48:49 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3637 Let the sounds sound on receiving a message in a Chat Box
3638
3639 Use Colorize() to the applicable color to trigger the sound, and then
3640 restore the original color as 'continuation', to do it silently.
3641
3642 2010-02-10 10:55:51 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3643 Allow WB Chat Box to be dedicated to shouts and 'it'
3644
3645 By putting 'shouts' in the handle field, a chat window will capture all
3646 shouts and c-shouts, and send messages typed into it as shouts.
3647 The bracketing of the shouter name now indicates the type of shout.
3648 The handle for WHISPER Chat Boxes has been changed to 'whispers', to
3649 make it easier to pop them up by clicking the console.
3650
3651 2010-02-16 22:34:23 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3652 Add -chatBoxes option to open Chat Boxes at startup
3653
3654 This string option contains a semicolon-separated list of handles for
3655 which Chat Boxes should be opened at startup. The value saved in the ini
3656 file is the value that was read, not the actual chat boxes that were
3657 open at the time of saving.
3658
3659 2010-02-16 19:44:46 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3660 Make Chat Windows pseudo-tabbed
3661
3662 By adding buttons in every Chat Box to navigate directly to every other
3663 Chat Box, a stacked set of Chat Windows behaves like a single tabbed
3664 window, but can still be unstacked. The buttons turn grey to warn that
3665 new text appeared in hidden boxes (i.e. not the one last brought to top).
3666
3667 2010-02-19 21:46:05 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3668 Allow arrow keys in WB Chat Box to access command history
3669
3670 The history is shared between al boxes and the ICS console.
3671
3672 2010-02-12 22:35:11 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3673 Make WB Chat Boxes wrap and handle URLs
3674
3675 Cloned the code for the console text field to hande URL. (Initialization
3676 to recogize the link, and notifiction to open it when clicked.)
3677 Removed the ES_AUTOHSCROLL style from the RichEdit in the resource.
3678
3679 2010-02-10 10:58:29 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3680 Fix copying of WB Chat Window contents
3681
3682 All line breks were lost on copy-pasting the contents of a chat window.
3683 Adding CR to each outputted line in the front-end (wchat.c) solves this.
3684 (Tell messages sent to a handle (which are not echoed by the ICS, and
3685 thus have to copied to the chat box directly) also need CR!)
3686
3687 2010-02-19 22:34:30 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3688 Add upload of game to ICS for examining
3689
3690 New item "Upload to Examin" in Action menu, calls UploadGameEvent().
3691 Use SAN moves to upload game to ICS, rather than long algebraic
3692 (The ICS did not understand long-algebraic promotion moves)
3693 Use bsetup within examine to set position onFICS, and also variant.
3694 Castling rights do not work yet for FRC. Totally different set of
3695 commands are needed on FICS and ICC.
3696  FICS does not understand w23 or wild/23, but needs 'crazyhouse' in the
3697 besetup command that specifies the variant. XBoard variant names are
3698 used, except for fischerandom, which is 'fr'. Things like nocastle will
3699 probably still not work.
3700
3701 2010-02-18 17:41:10 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3702 Handle display of PV that starts with other move than played
3703
3704 Insert the retraction of the played move, without premove highlighting.
3705
3706 2010-02-16 19:36:18 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3707 Bugfix smart capture
3708
3709 Disambiguate was changed to make sure that for ambiguous moves, a
3710 capture would always prevail in the closure, rather than the last move
3711 that happened to be generated. Before, double-clicking a piece would
3712 sometimes plsy a non-capture.
3713
3714 2010-02-13 15:34:04 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3715 Fix XB crash on giving keyboard focus to non-text widget
3716
3717 In the Engine-Settings dialog SetFocus() could be called for non-text
3718 widgets, and this made XawTextSetInsertionPoint() croak. Setting the
3719 insertion point to the end in SetFocus() was a bad ide anyway, as it
3720 interfered with copying from the engine-output window, which would
3721 uncontrollably scroll on getting focus. It is solved now by setting the
3722 insertion point already on creation of the text widgets.
3723
3724 2010-02-19 22:32:35 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3725 Seek-Graph bugfix: disappearing output in ICS console
3726
3727 Suppression of output to the cosole was handled fundamentally wrong: it
3728 was not enough to set next_out to after the unit that should be
3729 suppressed, as there can be a backlog in printing of previous units that
3730 came in the same packet. So this has to be flushed first, or it will be
3731 lost. -autoKibitz probably got away with that, because it comes in a
3732 separate packet. But seek ads are often suffixed to other output, and
3733 then that output disappeared! Now we flush everywhere before suppressing.
3734 We now totally rely on the prompt to restart the printing, so that
3735 acknowledgements following the echo of the sent message are also
3736 suppressed. Also suppress LF before diverted chat messages.
3737   Also fixed is the 'mamer bug' in Chat Boxes, due to false parsing of
3738 a "* (*): " pattern in tell messages, because of a missing continue.
3739
3740 2010-02-12 18:08:29 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3741 Pop up ICS text menu with default item under mouse pointer
3742
3743 The menu popup is migrated to the down-click (was up-click), so the
3744 up-click can select the item. Some trickery is needed to fool the menu
3745 into thinking that the mouse moved, so that a moveless up-down click in
3746 the ICS text field selects the default item (the upper-right one).
3747 Also allow dummy item in ICS text menu: The command "none" in the ICS
3748 text menu will now be treated as a grayed-out (disabled) entry, so it
3749 can be defined in the position underthe mouse pointer to prevent the
3750 up-click from doing anything, while keeping the menu open. Recommended
3751 for use with an entry of spaces.
3752
3753 2010-02-10 14:42:49 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3754 Allow ICS context menu to pop up a Chat Box on clicking handle
3755
3756 A command "chat" defined in the WinBoard icsMenu string will cause
3757 ChatPopUp() to be called when it is clicked, with the clicked handle
3758 (name) in the ChatPartner field, and focus on the input field.
3759 ChatPopUp() had to get a parameter (the handle) to make this possible.
3760 If that parameter is NULL (as when it is called from the Mode menu),
3761 focus will still start on the (empty) ChatPartner field of the box.
3762
3763 2010-02-10 10:50:11 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3764 Fix right-edge spillover of Seek-Graph dots in WinBoard
3765
3766 Rescale the X-axis to allow margin for dot size and color offset.
3767
3768 2010-01-30 11:05:52 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3769 Interface XBoard to GhostView file-browser dialog
3770
3771 Note: The Ghostview dialog was using some deprecated variables for error
3772 printing, and conditionally used getwd() on some systems that presumably
3773 do not have getcwd(), but it did not assess the latter properly.
3774
3775 2010-02-09 14:38:09 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3776 Allow recalling history in ICS input box with arrow keys
3777
3778 By adding translations for the Up and Down keys, and stealing some code
3779 from winboard.c. Still needs some refactoring to move the duplicate code
3780 to the back-end.
3781
3782 2010-02-09 14:34:33 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3783 Start insertion point at end of text edits in XB dialogs
3784
3785 The function SetFocus now uses XawTextSetInsertionPoint to position the
3786 end of the string it aready contains, rather than at the beginning.
3787
3788 2010-02-08 17:55:44 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3789 Capture holdings of background observed game
3790
3791
3792 2010-02-08 11:57:57 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3793 Match handles with multiple titles for channel Chat Boxes
3794
3795 Only handles with at most one suffixed 'title', such as (U), (C), (IM)
3796 or (TD), followed by the parenthesized channel number, were recognized,
3797 so tells by people with more titles always went to the ICS console window.
3798 Patterns are added to recognize handles with upto three such qualifiers.
3799
3800 2010-02-08 11:54:55 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3801 Do not pop down Seek Graph on on-dot click
3802
3803 Leave the graph up, and let the incoming board of a started game cause
3804 the pop-down. This in case the clicked ad is no longer vailable, or
3805 manuay refused, and fails to start a game.
3806
3807 2010-02-07 21:26:39 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3808 Observe a game in the background while playing
3809
3810 A new (persistent) option -backgroundObserve true|false is added. When
3811 set, observed boards received while playing a game will not trigger a
3812 game switch, but will be ignored except for storing in a dedicated board
3813 buffer. Pressing the right mouse button will cause the board to be
3814 displayed, until we release it. Time, strength and stm are always
3815 displayed in the message window.
3816
3817 2010-02-07 16:43:36 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3818 Remove race condition in clock switching
3819
3820 The move number is now incremented inside SwitchClock, when no timer
3821 interrupt is scheduled, so the interrupt cannot occur at the wrong side
3822 of the increment, and decrement the wrong clock.
3823
3824 2010-02-07 11:53:03 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3825 Let second click on piece make only capture, with -oneClickMove
3826
3827 Normally this would clear the highlighting of that piece.
3828 Required new field in DisambiguateClosure to count nr of captures.
3829
3830 2010-02-07 11:18:56 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3831 Bugfix stale first-click
3832
3833 When the opponent resigned after the user had cicked a from-square,
3834 clicking the from-square for the first move in the next game would
3835 produce an "illegal move" message, because it was considered a to-click!
3836 We now set fromX and fromY to invalid in GameEnds().
3837 Should we also reset them on mode changes?
3838
3839 2010-02-07 11:08:05 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3840 Add promotions and e.p. to oneClickMove
3841
3842 For e.p. the to-Square of the Pawn has to be clicked. Promotions are
3843 always to Queen when you click the to-square, but use the promotion
3844 pop-up when you click the from-square.
3845
3846 2010-02-07 10:38:38 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3847 Fix error that compiler does not notice
3848
3849 Boolean GLT_GetFromList did not return a value. But no error on Ubuntu!
3850
3851 2010-02-06 18:55:38 -0800 Arun Persaud <arun@nubati.net>:
3852 new developer release
3853
3854
3855 2010-02-06 18:30:42 -0800 Arun Persaud <arun@nubati.net>:
3856 updated year in copyright info
3857
3858
3859 2010-02-05 22:27:51 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3860 One-click moves
3861
3862 Playing on ICS or against engine, clicking a square from or to which
3863 only a single move can be made causes the move to be done, when the new
3864 option -oneClickMove is set to true.
3865
3866 2010-02-04 16:09:25 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3867 Use squares for computer seek ads
3868
3869 Shape indication passed in sign bit of color (char) variable.
3870
3871 2010-02-04 22:46:41 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3872 Use right mouse button to view seek ads
3873
3874 Right down-click does the same as left down-click, right up-click
3875 simulates a left up-click off board (so it misses all dots).
3876
3877 Use right-click miss to refresh Seek Graph
3878
3879 The 'moving' parameter had to be made into an int for this, to indicate
3880 right clicks with code 2. Right press now already pushes the clicked ad
3881 to the back, so that the up-click will display an underlying one.
3882
3883 Bugfix pushing back seek ads on right-click
3884
3885 On a right button press the previous in stead of currently hit ad was
3886 receiving the penalty.
3887
3888 Indicate seek-ad multiplicity
3889
3890 If more than one seek ad is inside the capture range of the mouse
3891 pointer, an exclamation point is printed before the seek-ad text.
3892
3893 Some fixes to make seek-ad suppression work in WinBoard
3894
3895 In WinBoard the z-depth was immediately erased by redrawing the graph;
3896 the clearing of zlist had to be moved from PlotSeekAd() to AddAd()
3897 (where it really belongs). Also aging of z-depth is now suppressed on
3898 mere pointer motion.
3899
3900 2010-02-04 22:45:01 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3901 Dynamic Seek Graph
3902
3903 The new option -autoRefresh sets FICS and ICC to report removal of seek
3904 ads, and then removes those from the Seek Graph. New seek ads are added
3905 to the graph, as soon as the ICS reports them.
3906
3907 2010-02-04 22:42:15 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3908 Implement SeekGraph in XBoard
3909
3910 For now only controlled by left mouse clicks on board. New options
3911 -seekGraph true|false and -sg to switch this feature on.
3912
3913 Facilitate selection of coinciding seek ads
3914
3915 Seek-ads that are viewed but not answered get a distance penalty on the
3916 up-click that makes their selection more difficult next time, so that
3917 the ad they covered gets a (better) change. The penalty ages away in the
3918 course of 5 clicks.
3919
3920 Slightly offset Seek-Graph dots of different color
3921
3922 Dots of different color are now displaced horizontally be 3 pixels, to
3923 prevent them from completely covering each other. (Required the axis
3924 labels to be moved a little too, to not be covered by the 1-min ads.)
3925
3926 Auto-show seek-ad texts in WinBoard
3927
3928 Hovering the mouse above a Seek-Graph dot will make the text belonging
3929 to it appear in the message field without the need to press a button.
3930 Required SeekGraphClick() to be called from the WB mouse event handler,
3931 with an extra argument 'moving' to make the distinction with a real
3932 click.
3933
3934 Show seek-ad text on mouse hovering (XBoard)
3935
3936 The Eventproc is also set to trigger on PointerMotion, and this event
3937 then calls SeekGraphClick with motion=true to handle it.
3938
3939 Put poetic name of wilds in seek-ad text
3940
3941 Use XBoard variant names, except for 'loadable' and 'fischerandom'
3942 (becomes 'setup' and 'chess960'), but leave number (to distinguish wilds
3943 that transate to same XBoard variant).
3944
3945 2010-02-05 20:36:50 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3946 Fix highlighting bug in XBoard
3947
3948 The from-square was drawn before the to-square was erased, which led to
3949 a missing highlight line if they shared an edge or corner.
3950
3951 2010-02-05 15:49:59 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3952 Shorten autoKibitz confirmation on FICS
3953
3954 Strip off the "players)", but leave the separatng space.
3955
3956 2010-02-05 14:39:55 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3957 Repair damage to -autoKibitz done by FICS atomic zippy claim
3958
3959 The sending of -autoKibitz info was also moved back in that patch, but
3960 unfortunately to after clearing of the programStats info. Now the
3961 clearing has been moved also, to remain after it.
3962
3963 2010-02-04 23:33:50 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3964 Send continuation lines to chat box they belong to
3965
3966 The variable savingComment is used as a kludge to remember where the
3967 comment should go (i.e. which chatbox, or elsewhere), so that when a
3968 continuation line is matched, chatPartner (which was reset at EOL) can
3969 be restored to its original value. Also put space after handle of talker
3970 in channel Chat Windows
3971
3972 2010-02-02 19:08:42 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3973 Fix u64 format for cygwin
3974
3975 With a -mno-cygwin compile %llu and %lld are definitely not understood
3976 by scanf and printf, although they are by the compiler. In stead, %I64u
3977 seems to work. Put it in under control of a switch USE_I64, which is
3978 defined only in the gcc makefile when MINGW is used.
3979
3980 2010-02-02 19:02:28 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3981 Remove stray dot from WinBoard makefiles
3982
3983 There was a period suffixed to config.h in the wgamelist.o dependency.
3984
3985 2010-02-01 14:50:01 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3986 Fix bug in display of logos
3987
3988 The logo continued to be drawn after a boardSize change to a tinyLayout
3989 size, although there was no space reserved for it. Fixed by explicitly
3990 resetting logoHeight when no logo space is reserved in InitDrawingSizes().
3991
3992 2010-01-19 20:15:49 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
3993 Right-click refactoring: step III
3994
3995 Let WinBoard call RightClick in back-end, and delete the duplicate code
3996 it had for this, after rescuing the front-end bits, and let the letter
3997 act depending on the result returned by RightClick.
3998
3999 2010-01-19 19:07:15 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4000 Right-click refactoring: step II
4001
4002 Migrate the Right-click routine to the back-end. Let it communicate back
4003 square coordinates through pointer arguments, to accomodate their
4004 different naming in XBoard and WinBoard. Template added in frontend.h.
4005
4006 2010-01-19 17:55:05 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4007 Right-click refactoring, step I
4008
4009 Divorce front-end part from back-end part of PieceMenuPopup in XBoard
4010 front-end, and forge the back-end part into a new routine RightClick.
4011 The right up-click in XBoard, which called unLoadPV() directly, now
4012 calls RightClick through PieceMenuPopUp().
4013
4014 2010-02-04 23:09:47 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4015 Merge gamelistopt sources into gamelist source files
4016
4017 The files xgamelistopt.c and gamelistopt.c are merged with xgamelist.c
4018 and gamelist.c, respectively. The WB front-end for the dialog already
4019 resided in winboard.c, so there was little need to move it to wgameist.c
4020 file. Makefiles adapted accordingly. Unsuitable key bindings were
4021 removed. The low-level front-end prototypes are now defined in in
4022 frontend.h.
4023
4024 2010-01-29 21:47:47 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4025 Game-List options dialog for XBoard
4026
4027 A dialog similar to that of WinBoard was cloned from the game-list
4028 window. The XBoard front-end is in a separate file xgamelistopt.c,
4029 which in fact implements most of the low-level front-end as back-end.
4030
4031 2010-01-29 12:48:50 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4032 Refactoring of game-list-options dialog
4033
4034 The back-end part is separated off, and moved to a file gamelistopt.c.
4035 Front-end for now stays in winboard.c. No prototypes in frontend.h yet.
4036
4037 2010-01-26 19:28:43 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4038 Fix of ancient WB bug: test integer option values for validity
4039
4040 Only a string of digits preceded by an optional sign is accepted now.
4041 Before, any string was accepted, and leaving out a value could lead to
4042 the next option being ignored (if it did not need a value) because it
4043 was considered the value for the previous one!
4044
4045 2010-01-26 19:00:54 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4046 Fix bug in edit-position of holdings
4047
4048 The holdings were effectivelly taken one too large, so that a promoted
4049 shogi Pawn moved to, or created in the holdings was not demoted to Pawn,
4050 but put in the dark (which you could see by the holding count if you did
4051 it twice). The overflow tests in these two cases now have been corrected.
4052
4053 2010-01-25 13:54:40 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4054 Save fonts in XBoard settings file per boardSize
4055
4056 Each -boardSize now can have its own font specified in the settings file
4057 (and thus by a command-line option, although it would in general not be
4058 very useful to specify a font for a size other than the selected). E.g.
4059 a prefix "size33:" to the font name will apply it only to -size 33.
4060 An unspecified-size font option (not normally in the settings file) will
4061 always prevail over a font option specific for the current size.
4062 A font of some size must have been used or specified in order to be
4063 saved.
4064
4065 2010-01-25 08:56:35 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4066 Fix width of filter field in XBoard GameList
4067
4068 An empirical dependence of the width of this text edit on the square
4069 size now makes for an acceptable layout at any board size.
4070
4071 2010-01-24 19:09:45 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4072 Use FICS atomic draw claim for sending move in zippy mode
4073
4074 For this the relaying of the move had to be moved until after the
4075 adjudication, which again has to be done after MakeMove(), which is a
4076 bit dubious, as MakeMove might take significant time when animating.
4077
4078 2010-01-24 18:51:38 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4079 Send FICS atomic claim to ICS if move creates draw after offer
4080
4081 The FICS format "draw MOVE" is used to send the move to the ICS  when
4082 the user enters a move that adjudicates as a claimable draw, and he
4083 offered a draw before the move. For the benefit of ICS that do not
4084 understand this format, the plain move is sent afterwards.
4085
4086 2010-01-24 18:16:14 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4087 Also allow user to claim by offering draw before his move
4088
4089 Use the existing userOfferedDraw variable to test for such offers in
4090 Adjudicate().
4091
4092 2010-01-24 17:29:42 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4093 Also adjudicate after user move
4094
4095 Call Adjudicate() in FinishMove().
4096
4097 2010-01-24 15:56:56 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4098 Refactoring of adjudication code
4099
4100 Put all the rule-based (as opposed to score-based) adjudications in a
4101 separate routine, so they can also be called on user moves. This
4102 requires sending the drawing move to the opponent engine to be made
4103 conditional on existence of the latter. Execution of the code is no
4104 longer dependent on the condition TwoMachinesPlay, but actual game
4105 terminations are now all restricted by an alternative condition (no ICS
4106 mode).
4107
4108 2010-01-24 11:46:30 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4109 Use -keepAlive option to determine connection health
4110
4111 When there has been no ICS response since the previous 'ping', assume we
4112 are disconnected and do a fatal-error exit. Also auto-start the ping
4113 process in InitBackend3().
4114
4115 2010-01-23 23:00:10 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4116 Use arrow keys in XBoard GameList for entry selection
4117
4118 Add translations for arrows and home/end, to call LoadSelectedProc with
4119 argument to indicate the step, and let the latter perform the action.
4120
4121 2010-01-23 22:24:20 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4122 Allow <Enter> to apply filter in XB GameList filter edit
4123
4124 Apply a translation to intercept the <Enter> key. Set focus back to the
4125 list display afterwards.
4126
4127 2010-01-23 21:44:36 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4128 Accept <Enter> for changing chat partner
4129
4130 A kludge stolen from Alessandro's GameList filter allowed to let the
4131 typing of <Enter> while updating the chat-partner field of the WinBoard
4132 chat windows to act as pressing the Change button. Gives focus to the
4133 input field of the window afterwards.
4134
4135 2010-01-23 21:42:38 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4136 Move duplicat gamelist code to backend
4137
4138 The filtering routines are moved from xgamelist.c and wgamelist.c to
4139 gamelist.c, and a prototype for them is placed in backend.h.
4140
4141 2010-01-23 19:29:18 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4142 Port game-list filtering to XBoard
4143
4144 Added a text edit and apply button to the XBoard game-list dialog, and
4145 only have it print those lines that match the filter. Translate index in
4146 list to index of game in file when a game is selected, and index in file
4147 to index in list when a line is highlighted. Duplicates some code
4148 between xgamelist.c and wgamelist.c, which should be moved to back-end.
4149
4150 2010-01-21 19:24:49 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4151 Convert to DOS line endings
4152
4153 For easier understanding of upcoming diffs of winboard.c
4154
4155 2010-01-21 14:32:46 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4156 Refactoring of move-history code
4157
4158 The WinBoard code in whistory.c was split in a front-end part (remaining
4159 in whistory.c) and a back-end part (now in history.c in the xboard
4160 directory). This to allow easy porting to other platforms.
4161
4162 2010-01-20 12:48:30 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4163 Add fixed-time/move button in XBoard time-control dialog
4164
4165 Put the TC-type buttons in a radio-group, and highlight the selected mode.
4166
4167 2010-01-19 18:27:14 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4168 Fix bug in XBoard PV display
4169
4170 The PV was unloaded on anything but a button release, in stead of the
4171 other way around.
4172
4173 2010-01-23 11:04:11 -0800 Arun Persaud <arun@nubati.net>:
4174 fixed hardcoded location of config file for xboard
4175
4176 the location should now follow sysconfdir during the configuration process.
4177 Also added some more output to the configure script.
4178
4179 2010-01-18 12:18:32 -0800 Arun Persaud <arun@nubati.net>:
4180 new developer release
4181
4182
4183 2010-01-18 12:15:06 -0800 Arun Persaud <arun@nubati.net>:
4184 fixed Makefile.am to handle config file correctly
4185
4186
4187 2010-01-15 21:55:29 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4188 Change opening array -variant fairy
4189
4190 We now use the position of "Chess with Different Armies", FIDE army vs.
4191 a fantasy army (inspired on the Color-bound Clobberers) as opening
4192 position.
4193
4194 2010-01-13 19:08:45 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4195 Add variant Makruk
4196
4197 Thai Chess, played by 2 million world-wide. Required pawn promotion to
4198 happen in a zone, and the Alfil to move as Shogi Silver, a new opening
4199 array, and unusual Pawn placement. Because of the latter, I consider it
4200 a setup position, so a FEN will always be sent to the engine.
4201
4202 2010-01-17 14:17:10 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4203 Fix parsing of O-O and O-O-O after FEN pasting in FRC
4204
4205 Because the initial rights were not set in the FEN reader, the
4206 initial rights of the previous game remained in force, so that the
4207 parser did not understand OO-castling (although it would allow KxR
4208 castling).
4209
4210 2010-01-15 14:40:43 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4211 Fix reading FEN castling rights for knightmate and twokings
4212
4213 Scanning the back-rank for a King did not work in these variants,
4214 because either the Unicorn castles, or there might be two Kings.
4215
4216 2010-01-13 11:42:52 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4217 Fix omission in castling refactoring for ICS received boards
4218
4219 A default of -1 was still used, in stead of NoRights, when no Rook was
4220 found. In theory this could have had effect in a setup board 0 in FRC,
4221 when there were no Rooks on the back rank.
4222
4223 2010-01-13 11:35:34 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4224 Fix TwoKings ICS castling-rights bug
4225
4226 Scanning the rank (as is done because of FRC) assigned castling rights
4227 to the rightmost King. Even scanning the opposite direction would not
4228 work, as it is not always the eftmost King that can castle. So we now
4229 explicitly test for a King on e1/e8 in TwoKings and assign it rights,
4230 relying on the Rook rights received from the ICS to control castling.
4231
4232 2009-11-18 19:12:25 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4233 fix double start of zippy engine after switch to gothic
4234
4235 In ICS mode we now switch to the proper variant as soon as we receive
4236 the generic game-start message, to prevent a mismatch when the first
4237 board is received (which would trigger fetching of a move list).
4238
4239 2010-01-11 16:44:40 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4240 Extensive bugfix of -autoKibitz
4241
4242 Suppression of printing of diverted kibitz messages failed when they
4243 extended over more than one read. This could even lead to such
4244 messages being erroneously saved as comments, which then lead to
4245 crashes. The suppression mechanism now waits for a prompt, in stead of
4246 the end of buffer. This required the printing of any leftover in the
4247 buffer to be deferred until the next read completes it.
4248 The number of people kibitzed to is now printed.
4249
4250 2010-01-11 16:30:59 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4251 Fix piece-to-char table -variant fairy
4252
4253 The letters for Lance and Snake where swapped.
4254
4255 2010-01-09 11:54:20 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4256 Make WinBoard makefiles use parser.c in XBoard directory
4257
4258
4259 2010-01-08 18:23:39 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4260 Docs update for new features
4261
4262
4263 2010-01-08 15:18:37 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4264 Fix new args parsing of -lowTimeWarningColor
4265
4266 This did not occur in the XBoard color translation table yet.
4267
4268 2010-01-08 14:16:59 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4269 Allow editing of holdings in EditPosition mode
4270
4271 Dragging pieces to and from the holdings now consistently keep track of
4272 the home square of pieces and the piece counts, as does creation of
4273 pieces in the holdings through the piece menu.
4274
4275 2010-01-08 13:59:57 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4276 Indicate squares a lifted piece can legally move to
4277
4278 Under control of the new option -showTargetSquares when
4279 -highlightDragging and -testLegality are on, the squares a piece can
4280 move to are marked by fat dots in the highlightColor (non-captures) and
4281 premoveHighlightColor (captures), as soon as you grab it for dragging.
4282 In variants with mandatory capture, the capture target of other pieces
4283 is marked with the highlightColor (as non-captures are then not allowed).
4284
4285 2010-01-08 12:35:10 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4286 Fix bug for incommensurate time odds
4287
4288 After normalization (-timeOddsMode 1) the time odds factors can be
4289 non-integer, and thus must be stored as float.
4290
4291 2010-01-08 11:41:26 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4292 Display PV right-clicked from EngineOutput window
4293
4294 The clicked PV is selected and the memo gets focus, so that it is
4295 highlighted. This selection is restored in the proper place after
4296 insetrtion of a new line in the memo.
4297
4298 2010-01-08 10:19:32 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4299 Display PV on right-clicking board
4300
4301
4302 2010-01-08 09:21:04 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4303 Bugfix legality null move in parsing with -testLegality off
4304
4305 The pointers were compared, in stead of the values.
4306 Furthermore, instead of null moves, it rejected moves on the main diagonal when legality checking was off.
4307
4308 Also exclude moves with empty squares and enemy pieces.
4309
4310 2010-01-07 19:10:39 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4311 Newly lexed winboard/parser.c
4312
4313
4314 2010-01-07 19:05:17 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4315 Harmonize declarations of XBoard and WinBoard
4316
4317 The engine-exit and settings patches make some stuff common to WinBoard
4318 and XBoard, which needed to be harmonized, and is moved to frontend.h.
4319
4320 2010-01-07 13:07:57 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4321 Allow Ctrl-C copying from EngineOutput window text to clipboard
4322
4323
4324 2010-01-07 12:52:17 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4325 Allow popup-less (fatal) exit of engine after tellusererror
4326
4327
4328 2010-01-07 12:40:12 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4329 Improve layout of Engine #N Settings dialog
4330
4331 An attempt is made to align the input fields of spins and text-edits
4332
4333 2010-01-07 00:31:11 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4334 Let XBoard print version with argument --version or -v
4335
4336
4337 2010-01-07 00:25:57 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4338 Fix castling rule assignment in shuffle games
4339
4340 The conversion to in-board storage for rights copied directly to boards[0] in steadof
4341 initialPosition, and was then overwritten when the latter was copied with uninitialized
4342 rights to boards[0]. This affected FRC and CRC, where rights are non-standard.
4343
4344 2010-01-07 00:17:25 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4345 Implement castling in -variant caparandom
4346
4347 CRC should be treated as FRC, but until now it never was. We now test for FRC_TYPE_CASTLING.
4348
4349 2010-01-07 00:09:18 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4350 Fix default castling rights on reading incomplete FEN
4351
4352 This was overlooked in the conversion to the in-board storage of rights.
4353
4354 2010-01-07 00:03:09 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4355 Fix NoncompliantFEN defaults.
4356
4357 This must be NULL to get compliant FENs, not "", which would suppress castling and e.p. fields.
4358
4359 2010-01-06 23:54:49 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4360 Change format of -adapterCommand.
4361
4362 first or f at the start of an option name are now automatically changed into second or s,
4363 rather than needing %% to be recognized. The values of -ec and -ed in the default
4364 -adapterCommand are now quoted (now XBoard understands quoting in the engine command line).
4365
4366 2010-01-06 23:51:16 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4367 Make WinBoard defaults for -fd and -sd equal to "." rather than empty strings.
4368
4369
4370 2010-01-06 23:28:47 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4371 Delete old indirection settings-file code
4372
4373
4374 2010-01-06 21:45:14 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4375 Correct XBoard default debug file name
4376
4377
4378 2010-01-06 21:34:48 +0100 H.G. Muller <h.g.muller@hccnet.nl>:
4379 Suppress saving font settings.
4380
4381 The fonts are size dependent, and might thus not be reusable in the next
4382 session. For now we therefore suppress the saving of them in the
4383 settings file, until we diversify the fonts per boardSize.
4384
4385 2009-12-12 23:38:20 -0800 Arun Persaud <arun@nubati.net>:
4386 added missing sounds files to be able to compile on windows
4387
4388
4389 2009-12-09 17:29:37 -0700 Eric Mullins <emwine@earthlink.net>:
4390 Changes needed to compile master branch.
4391
4392
4393 2009-12-06 12:11:46 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4394 implements the eval-graph window for XBoard
4395
4396
4397 2009-12-06 11:58:34 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4398 improves the XBoard handling of the engine command line
4399
4400 it now understands limited forms of quoting, so engine binaries with spaces in their file name can be handled.
4401
4402 2009-12-06 11:56:40 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4403 A better and more flexible way of invoking Polyglot
4404
4405 rewrote uci.c. No more use of temporary files, all data passed through the engine command line. Adds a new command-line option -adapterCommand for this.
4406
4407 2009-12-06 11:34:50 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4408 remove trailing \r in xboard output
4409
4410 there is an annoying carriage return (displayed as ^M) at the end of the PV in the engine-output window, not
4411 only with Fairy-Max, but also with UCI engine running under Polyglot. This patch replaces the trailing CR that Linux programs send after the PV line y a space.
4412
4413 2009-11-29 11:56:32 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4414 double buffer size to prevent overflow
4415
4416 This patch doubles the size of the ICS input buffer to 16KB, to prevent
4417 the suspected overflow with -keepLineBreaksICS false when using
4418 "inchannel 1" on FICS and over 500 people are tuned in.
4419
4420 2009-11-28 13:33:52 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4421 fix problem with empty string in -firstNeedsNoncompliantFEN
4422
4423 This fixes a bug in the use of the -firstNeedsNoncompliantFEN option with
4424 an empty string as argument. (Which led to truncation of the FEN.)
4425
4426 2009-11-28 13:32:12 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4427 updates makefiles to include dependency on config.h
4428
4429 adds the dependency of wbres.o on config.c introduced by having the VersionInfo in the resource
4430
4431 2009-11-28 13:28:00 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4432 correctly apply some check boxes from the option menu
4433
4434 Usng the check-boxes in the Option->Adjudications menu to indicate the
4435 engine reports absolute scores is now copied directly to the ChessProgramState,
4436 from where it is used, in stead of only to appData. This makes the change take
4437 effect immediately, in stead of after restarting.
4438
4439 2009-11-28 13:27:43 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4440 score sign in analysis mode
4441
4442 this does not alter any of the current behavior with compliant engines,
4443 but does extend the correction for non-compliant score reporting under
4444 control of the -first(second)ScoreIsAbs option to cases where the engine
4445 is analyzing or playing on an ICS.
4446
4447 2009-11-24 21:09:30 -0800 Arun Persaud <arun@nubati.net>:
4448 fix for bug #28077: xboard needs to link against x11
4449
4450 hopefully fixed automake to take care of this
4451
4452 2009-11-23 20:37:20 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4453 Fix castling rights when copying FEN to clipboard (again)
4454
4455 missed a spot last time
4456
4457 2009-11-23 20:22:58 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4458 restoring windows (EngineOutput and MoveHistory) on startup
4459
4460 restoring the open / closed status of the
4461 auxiliary windows (EngineOutput and MoveHistory) on startup
4462 in XBoard like they do in WinBoard, which makes sense now that
4463 we aso remember their coordinates between sessions.
4464
4465 2009-11-23 20:21:14 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4466 fixed some outstanding pixmaps
4467
4468 fixed transparency issues
4469
4470 2009-11-23 20:17:25 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4471 use linux style options for config file and add a system config file for XBoard
4472
4473 This patch makes XBoard write the options to its conf file in
4474 Linux style, "-option value" rather than Windows style "/option=value".
4475
4476 The WinBoard option parsing code has always understood both formats
4477 (including any hybrids), but the format it preferred for writing might
4478 look quite strange to Linux users. I also attached a file to be installed
4479 as /etc/xboard/xboard.conf on "make install".
4480
4481 2009-11-23 19:58:55 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4482 fix window positioning
4483
4484 This patch adds stuff in the header files that allow the various front-end files
4485 to share information on which windows exist, are up, and how they are positioned.
4486 The EngineOutput, MoveHistory and GameList windows now all remember their
4487 position and size, even when they are closed when XBoard exits.
4488
4489 2009-11-23 19:51:19 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4490 same argDescriptor parsing for Xboard and Winbaord
4491
4492 This patch makes XBoard and WinBoard use the same argDescriptor
4493 list of options, and (largely) use the same code for parsing and saving them.
4494 This is acheived by moving this code to a new file args.h, and #including this
4495 in both winboard.c and xboard.c (so that tiny differences, e.g. in default
4496 values in the table, are decided by the context). XBoard has new menu items
4497 "Save Settings Now" and "Save Settings on Exit" in the "Option" menu.
4498 XBoard uses /etc/xboard/xboard.conf as default settings file.
4499 A new option, -saveSettingsFile, can specify where settings should be saved,
4500 without parsing the file. (So that it also works if the file does not yet exist.)
4501
4502 2009-11-22 13:00:31 -0800 Arun Persaud <arun@nubati.net>:
4503 new developer release
4504
4505 changed release name to <branch>-<date>
4506
4507 2009-11-22 12:34:13 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4508 fix the irritating wandering off of the MoveHistory window in XBoard on opening/closing.
4509
4510
4511 2009-11-22 12:29:47 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4512 use xtell for talking to handles, but tell for talking into a channel.
4513
4514 by changing the chatboxes to use xtell in stead of tell, we broke
4515 the possibility to use the chat-box for chatting into a channel (which is
4516 apparently not possible with xtell).
4517
4518 2009-11-22 12:15:15 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4519 fix bug in bughouse drop menu
4520
4521 This patch fixes the bughouse drop menu, which was broken by the
4522 new mouse driver, and could no longer drop white Pawns.
4523
4524 2009-11-18 19:29:57 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4525 2nd step for moving option parsing from winboard to the backend
4526
4527 This is the next step in option-setting refactoring: All options that are
4528 defined in XBoard are now included in the WinBoard ArgDescriptor list.
4529 The handling of sound option has been harmonized: the sound names
4530 now all initially go to the appData array, (as in XB) in stead of directly to the
4531 WB-specific variables, and LoadAllSounds now takes care of the copying.
4532 A new routine ExportSounds copies them back before saving settings
4533 (which, in XBoard, could be a no-op).
4534
4535 The definition of defaults for the XB-only options has been moved to common.h.
4536
4537 2009-11-18 19:24:35 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4538 1st step for moving option parsing from winboard to the backend
4539
4540 This is a preparatory step in moving option parsing of WinBoard to the back-end.
4541 The table of command-line options now contains a fifth field, holding the compiled-in default.
4542 This obviates most of the front-end routine InitAppData, which now is replaced by a table-driven
4543 initialization routine SetDefaultsFromList(), which could be back-end.
4544
4545 2009-11-18 12:33:39 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4546 refactoring evalgraph code
4547
4548 This is the refactored EvalGraph code: the back-end part is separated off,
4549 and put in a file evalgraph.c, which in the future can also be used with XBoard.
4550 Only the WinBoard front-end code is left in the file wevalgraph.c. A new
4551 header file defines the variables and routines they share.
4552
4553 2009-11-18 12:29:06 -0800 Arun Persaud <arun@nubati.net>:
4554 clean-up
4555
4556 some file permissions where set up wrong
4557 (e.g. execute permissions for text files)
4558
4559 2009-11-18 11:34:22 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4560 refactoring of engineoutput
4561
4562 This refactoring patch separates the back-end part out of
4563 xengineoutput.c, and puts it in a separate file engineoutput.c.
4564 A new header engineoutput.h included by both defines the routines
4565 for cross calling. Similarly wengineo.c will be stripped from its
4566 back-end code, (and renamed to wengineoutput.c), so WinBoard and
4567 XBoard now both use engineoutput.c rather than maintaining duplicate
4568 code in their front-end part.
4569
4570 I also let the back-end now call EngineOutputUpdate directly, rather then
4571 through a relay in the front-end, by renaming it to SetProgramStats
4572 (the former name of the relay in winboard.c / xboard.c).
4573
4574 Moved some templates of functions in engineoutput.c from winboard.h
4575 to frontend.h
4576
4577 2009-11-14 22:13:10 -0800 Arun Persaud <arun@nubati.net>:
4578 fixed build on openbsd
4579
4580 added missing header file
4581
4582 2009-11-14 22:06:58 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4583 improve thinking-output for mulit-variant
4584
4585 Improve multi-variant support by sorting the Thinking-Output lines of the most recent depth by score in the Engine-Output window.
4586
4587 2009-11-14 22:05:12 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4588 fix castling rights when copying FEN to clipboard
4589
4590 This patch forces leaving of Edit-Position mode before copying a FEN to the clipboard, to make sure castling rights are faked in a consistent way. Before you could get FENs that had castling rights for non-existent Rooks.
4591
4592 2009-11-14 22:03:47 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4593 This patch gives a better handling of comments in PGN files, and adds the variation as comment to the main line on using Revert in local mode.
4594
4595
4596 2009-11-06 18:53:19 -0800 Arun Persaud <arun@nubati.net>:
4597 fixed prototype for AppendComment
4598
4599
4600 2009-11-06 09:06:44 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4601 cleaned up some debug messages and typos
4602
4603
4604 2009-11-06 09:05:09 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4605 variation-support patch
4606
4607 It allows you to Revert to the main line (or previous variation) when
4608 playing variations on an existing game in EditGame or Analyze mode.
4609
4610 2009-11-06 08:48:09 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4611 fix for new way of saving castling and e.p. information
4612
4613 I forgot to make some conversions to the new-style encoding of castling there
4614 (using the enum constant NoRights instead of -1 to indicate
4615 the absence of rights, which was the price of storing the
4616 rights in the board, which is an unsigned enum type.)
4617
4618 I also was a bit worried about portability, because I casted the enum type ChessSquare
4619 to (int) before comparing it with (possibly negative) constants EP_NONE etc.
4620 Now on my system enum types are (unsigned int), and this works, but I could
4621 imagine there are systems where this would be an unsigned char. (Not sure
4622 if there are rules for this). So to be safe I cast ChessSquare to (signed char),
4623 which should always work to make small negative ints assigned to it read
4624 back as themselves.
4625
4626 2009-11-06 08:44:59 -0800 Arun Persaud <arun@nubati.net>:
4627 removed files that should only be in the windboard directory
4628
4629
4630 2009-11-05 19:32:35 -0800 Arun Persaud <arun@nubati.net>:
4631 add Winboard source files into tar-ball
4632
4633 forgot to add them when rewriting the Makefile.am
4634
4635 2009-11-05 19:23:44 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4636 Integrate castling and e.p. rights into board array; bugfix for EditPosition
4637
4638 A large-scale operation that I have been postponing since the very first 4.4.0:
4639 The castling and e.p. rights are now integrated into the board array, as
4640 boards[moveNr][CASTLING][i] replacing castlingRights[moveNr][i] and
4641 boards[moveNr][EP_STATUS] replacing epStatus[moveNr]
4642 These quantities are now automatically copied with the position by CopyBoards
4643 (allowing the removal of lots of dedicated copying code), and passed as
4644 function arguments with the position (so that the moves.c functions like
4645 TestLegality, MateTest, CoordsToAlgebraic, Disambiguate, GenLegal
4646 no longer need explicit e.p. and castling parameters.
4647
4648 Also fixed a bug introduced by a recent previous fix: by adding fake castling
4649 rights to a position set up through the EditPosition menu, I destroyed the
4650 castling rights of a pasted FEN. Faking castling rights is now made conditional
4651 in EditPositionDone(), depending on the caller. (I had not realized it was also
4652 called after FEN pasting, to send the position to the engine.)
4653
4654 2009-11-05 19:03:17 -0800 Arun Persaud <arun@nubati.net>:
4655 added missing library for build on OS X
4656
4657 Xmu seems to be missing
4658
4659 2009-11-04 22:57:30 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4660 Some code refactoring and cleanup; one small bug fix
4661
4662 Some code refactoring, mainly to bring definitions of routines and variables
4663 shared between winboard.c and one of the auxiliary-windows files
4664 whistory.c, wevalgraph.c, wgamelist.c, wengineo.c somewere in a header file
4665 (winboard.h). Unfortunately this made winboard.h dependent on data types
4666 defined in frontend.h, so that the #include order had to be changed in many
4667 other .c files.
4668
4669 The operation revealed one potentially bad bug: engineOutputDialogUp was
4670 written as int in engineo.c, but declared as char in winboard.c.
4671
4672 I also changed the storage mechanism of the the comment and tags window
4673 positions to use WindowPlacement structs rather than simple variables,
4674 so that in the future they can be docked, like the others.
4675
4676 I also removed some remnants of the Analysis window.
4677
4678 The wgamelist.h and wedittags.h header files contained only 3 lines, and
4679 I absorbed them in winboard.h, rather than creating other such nearly empty
4680 headers engineo.h, whistory.h and wevalgraph.h. This affects the make files.
4681
4682 2009-11-03 18:26:06 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4683 let the clocks run in -searchTime mode
4684
4685
4686 2009-11-02 17:41:12 -0800 H.G. Muller <h.g.muller@hccnet.nl>:
4687 add fixed time per move to the WinBoard time-control menu dialog
4688
4689
4690 2009-10-31 10:42:50 -0700 Arun Persaud <arun@nubati.net>:
4691 updated version number to unstable
4692
4693
4694 2009-10-31 10:25:37 -0700 Arun Persaud <arun@nubati.net>:
4695 release of version 4.4.1
4696
4697
4698 2009-10-30 19:59:23 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4699 cleaned up ChangeLog and NEWS
4700
4701 2009-10-30 20:02:40 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4702 use xtell instead of tell in wchat
4703
4704 2009-10-28 20:35:06 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4705 prevent buffer overflow
4706
4707 This is a buffer-size adjustments to prevent the JAWS version from
4708 crashing when it has to read out loud very long comments.
4709
4710 2009-10-28 02:17:16 -0700 Tim Mann <tim@tim-mann.org>:
4711 Further copy/paste fixes
4712
4713 We needed to implement the XA_TARGETS target in order for more
4714 sophisticated apps to really believe we put anything on the clipboard
4715 they can use.
4716
4717 2009-10-27 23:57:25 -0700 Tim Mann <tim@tim-mann.org>:
4718 Make copy/paste position and game use clipboard, bug #27810
4719
4720 Copy actually sets both the clipboard and the selection for
4721 convenience and compatibility with the old way of doing things.
4722 Paste pastes from the clipboard by default, but the new -pasteSelection
4723 option lets you get back the old behavior of pasting from the
4724 selection.
4725
4726 2009-10-27 15:44:28 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4727 switch focus to the board after loading a game
4728
4729 2009-10-27 15:32:07 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4730 fix for bug #27826: fixed autoDisplayComment
4731
4732 apparently the -autoDisplayComment option was not working,
4733 not even in WinBoard. This patch should fix it,both for WB and XB.
4734 (Unfortunately xboard.c and winboard.c were using a different name
4735 for the same front-end variable I needed, so I had to change one of them.)
4736
4737 2009-10-27 12:24:56 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4738 fix for bug #27826: ported two options to xboard
4739
4740 also updated the documentation
4741
4742 2009-10-27 12:22:36 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4743 fixed jaws version
4744
4745 turns out the new mouse handler broke the JAWS patch, as I discarded
4746 the function IsPromotion. I adapted it to call HasPromotionChoice instead.
4747 Also fixed two arnings by removing a no-longer needed debug print.
4748
4749 2009-10-27 12:03:02 -0700 Arun Persaud <arun@nubati.net>:
4750 reformated html to be correctly validated
4751
4752 2009-10-27 10:33:42 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4753 quick fix for "White Mates" in parser.l
4754
4755 2009-10-27 10:32:24 -0700 Arun Persaud <arun@nubati.net>:
4756 fixed a regression
4757
4758 2009-10-26 20:45:15 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4759 changed stderr to debug output, since stderr is closed in winboard
4760
4761 2009-10-26 20:42:24 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4762 removing empty lines from ICS play
4763
4764 this patch causes removal of spurious prompts during ICS play
4765 also if the prompt is preceeded by a number of empty lines
4766 (as the board for the opponent move is on FICS).
4767
4768 2009-10-26 20:40:00 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4769 another bug in VariantSwitch: an unitialized board was printed.
4770
4771 Must have been there a long time, but this time it crashed WinBoard.
4772
4773 2009-10-26 20:38:37 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4774 more work on variant switch
4775
4776 the previous solution to the cosmetic problem of displaying a wrong shuffle
4777 in an ICS game that was observed from the very start unfortunately turned
4778 out to cause a real error in diplaying a stored game through the smoves
4779 command, for variants not using the FIDE setup as standard.
4780
4781 This patch displays the position from before setting up the start position
4782 of the new variant, but does setup boards[0] to the initial position of that
4783 variant. (If this is a wrong shuffle, it is thus ot displayed, and a new board
4784 will immediately be sent from the ICS to correct the shuffle.)
4785
4786 2009-10-26 20:34:04 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4787 force full redraw in winboard
4788
4789 Full redraw is now always forced when highlightMovesWithArrow is on,
4790 rather than only when highlight info is available. (As in drop moves the
4791 latter is invalid, but we must still erase the arrow from the previous move.)
4792
4793 2009-10-26 20:25:55 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4794 fix for bug #27790 and #277772. Suppressing the display of a wrong shuffle
4795 when observing shuffle games from the first move (#27790 bis),
4796 and the sounding of the FICS bell on crazyhouse captures (#27772 bis).
4797
4798 2009-10-26 20:22:13 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4799 fixed bug related to unsigned char in convert.c
4800
4801 I also fixed the unsigned-char bug in the convert.c for bitmaps that caused the
4802 129x129 XBoard bitmaps to be defective, and a bug that required fixup with sed
4803 afterwards (so I could use it to create a new m33s.bm)
4804
4805 2009-10-25 23:37:48 -0700 Arun Persaud <arun@nubati.net>:
4806 unguarded debug printf. added the appropiate if statement
4807
4808 2009-10-25 23:31:13 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4809 fix for two compiler warnings
4810
4811 2009-10-25 23:29:43 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4812 fix for bug #27799: fix for nested-nested-nested variations
4813
4814 2009-10-25 23:21:07 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4815 The book-probe code forgot to close the book file after opening it.
4816
4817 fixed by adding an fclose at two points.
4818
4819 2009-10-25 23:18:18 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4820 removed unused v54?.bm bitmaps from resource file
4821
4822 it seems the v54?.bmp bitmaps were actually included in the WinBoard build
4823 (in the resource file), although they were never actually used. So I have
4824 removed their inclusion in the resource file now.
4825
4826 2009-10-25 23:05:30 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4827 replaced defective bitmaps with copies from 4.2.7
4828
4829 2009-10-25 23:02:08 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4830 removed bitmaps files that are not needed any more
4831
4832 2009-10-25 22:58:34 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4833 fixed some bitmaps
4834
4835 2009-10-24 09:41:39 -0700 Tim Mann <tim@tim-mann.org>:
4836 Drop an obsolete script that was only used to update my personal web site
4837
4838 2009-10-24 01:23:29 -0700 Tim Mann <tim@tim-mann.org>:
4839 Silence warnings when compiling 64-bit xboard
4840
4841 Some harmless warnings were caused by 64-bit mode having 32-bit
4842 int but 64-bit long and pointer.  Add casts (etc.) to silence them.
4843 This might require adding a definition of intptr_t (a signed int
4844 type that is the same width as a pointer) on old systems that don't
4845 have it.
4846
4847 2009-10-24 00:56:37 -0700 Tim Mann <tim@tim-mann.org>:
4848 Fix up man page some more
4849
4850 Sigh, the project history was still partly in reverse chronological
4851 order and partly in forward order.  Swapped the order of some
4852 sentences to help straighten it out.  I don't really care about this,
4853 so other project members should feel free to do what they like here,
4854 but the messed-up order was bugging me.
4855
4856 2009-10-24 00:46:20 -0700 Tim Mann <tim@tim-mann.org>:
4857 Fix some issues in the XBoard man page
4858
4859 Correct places where the XBoard man page was calling XBoard
4860 "WinBoard".  Change references to "WinBoard engines" and "WinBoard
4861 protocol" to "XBoard/WinBoard ...".  Update bug reporting guidelines.
4862 Reorganize project history to something more like chronological order
4863 -- it had gotten pretty randomly ordered.
4864
4865 2009-10-22 21:45:32 -0700 Arun Persaud <arun@nubati.net>:
4866 new pre-release version; updated version numbers
4867
4868 2009-10-22 21:33:07 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4869 This patch adds <Enter> to the characters that cause an automatic
4870 switch to the ICS console when typed to the board window.
4871
4872 2009-10-22 21:31:16 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4873 fix to the minor graphics issue contained some typos,
4874 as was remarked in the bugs reports
4875
4876 2009-10-22 21:30:08 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4877 improved mouse handler
4878
4879 The improved mouse handler still needed an extra call to DrawPosition to
4880 work in XBoard.
4881
4882 2009-10-22 21:28:38 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4883 NPS plays and pondering
4884
4885 Clock updating did not work correctly in node-based time controls when the
4886 engine was pondering. (It was not really meant for use with pondering. Oh well...)
4887 This patch checks if the engine reporting the node count is indeed thinking
4888 (as opposed to pondering).
4889
4890 2009-10-22 21:25:36 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4891 holdings update and regression fix
4892
4893 The holdings-update patch was not yet satisfactory, because FICS seems to send
4894 holdings both before and after the board! And those received before did overwrite
4895 the holdings received after the previous board. I know tried to fix that in a kludgey
4896 way, by hiding a flag in the board that tells if the holdings have already been written
4897 by the ICS or not, and ignore new holdings when they are. (Except in bughouse,
4898 where holdings updates cannot be tied to a particular board and multiple updates
4899 between boards are normal. (I hope?).)
4900
4901 I also undid a regression in my previous fix for the minor graphics problem,
4902 and solved it in a slightly different way to prevent flicker.
4903
4904 2009-10-22 21:23:39 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4905 improved mouse handler
4906
4907 I improved the mouse handler in a way which will preclude disappearence of pieces
4908 on off-board or ambiguous (in-between squares) drag & drop moves. (As was reported
4909 in the "premove bug?" thread. Also the command-line premove problem reported there
4910 is now fixed, by removing the prefixing.
4911
4912 2009-10-22 21:18:05 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4913 fix for bug #8847: moving backward while examining on FICS not reported to engine
4914
4915 I moved Daniel's code that backs up the engine when a bord with a
4916 lower number is received to a place where it is always done in zippy mode,
4917 rather than only when the engine is analyzing.
4918
4919 Apart from taking back moves, there was also the case where the
4920 user moves forward by more than one move (usually immediately to
4921 end-of-game). In this case a new movelist is fetched from the ICS
4922 to recover the moves that were skipped. But this assumes that the
4923 engine is at the start of the game and feeds all these moves to the
4924 engine. So the engine had to be reset in this case to stay in sync.
4925
4926 2009-10-22 21:16:56 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4927 better init for random number generator
4928
4929 2009-10-21 23:01:09 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4930 fix for bug #27772: holdings not updated
4931
4932 holdings lines from the ICS nor update the holdings
4933 of boards[forwardMostMove] in stead of boards[currentMove].
4934
4935 2009-10-21 21:32:14 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4936 allowe parsing / disambiguation of SAN moves like Xe4 in certain situations
4937
4938 This patch allows parsing / disambiguation of SAN moves like Xe4, if there
4939 is only one wild-card piece X on the board. Moves with wild-card pieces
4940 are now considered illegal if they leave the King in check by a piece of
4941 known gait.
4942
4943 2009-10-20 19:09:46 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4944 fixed bug when switching to variantsuper
4945
4946 2009-10-20 19:06:43 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4947 fix for bug #27715: 2 (minor) graphic issues
4948
4949 I forced a total redraw when Reset is called from the ICS code in case a
4950 new game is encountered, in the hope it will make the reported
4951 (irreproducible) problem go away. As game switches are not frequent, I
4952 guess there is hardly any downside to this.
4953
4954 2009-10-20 18:57:17 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4955 fix for bug #27667: PV line missing in analysis window, part 3
4956
4957 "3. Wish for Engine state string (right to the icon):
4958 Can you add the actual search depth in analyzing mode? A change like "
4959
4960 I also added the requested display of depth of the analysis move in the
4961 EngineOutput window. I guess a similar change could be made to wengineo.c
4962 (as this is in the code they share in common), but no one ever requested
4963 that in the 5 years since Alessandro wrote it. So for now I leave it alone.
4964
4965 2009-10-20 18:52:14 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4966 fix for bug #27760: debug printf in backend.c and additional check for variant
4967
4968 2009-10-19 23:17:46 -0700 Arun Persaud <arun@nubati.net>:
4969 fix for bug #10990: cmail does not seem to support .cmailgames or .cmailaliases
4970
4971 this is correct, deleted the text out of the documentation that claims we support it
4972
4973 2009-10-19 18:40:40 -0700 Arun Persaud <arun@nubati.net>:
4974 new alpha version; first one with new naming scheme
4975
4976 2009-10-19 18:07:21 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4977 smarter analysis of the boards that XBoard receives from an ICS
4978
4979 I added smarter analysis of the boards that XBoard receves from an ICS,
4980 based on board size and piece types in the position, to recognize cases
4981 where the board does not match the current variant, and switch to an
4982 appropriate variant.
4983
4984 2009-10-19 18:04:08 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4985 fix for bug #27667: window should be reference to toplevel
4986
4987 The remaining objections of #27667 should be fixed by bringing the
4988 EngineOutput window under control of the TOPLEVEL compile-time switch.
4989
4990 2009-10-19 18:02:42 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4991 partly fix for bug #27715: scaling of menu bar
4992
4993 the menu bar to the left edge of the window.
4994
4995 2009-10-19 17:59:43 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
4996 fixed bug reported in WB forum: second game of a match would
4997 not start when using the GUI book
4998
4999 2009-10-19 17:57:14 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5000 fix for bug #27751: negative holding counts displayed
5001
5002 I put code in the back-end to prevent holdings counts from
5003 becoming negative when a drop move is made from empty holdings.
5004 (This can happen when re-loading ICS bughouse games,
5005 as the smoves command fails to fill the holdings.)
5006
5007 2009-10-18 20:54:53 -0600 Eric Mullins <emwine@earthlink.net>:
5008 Updated compiling instructions.
5009
5010 2009-10-18 11:32:55 -0600 Eric Mullins <emwine@earthlink.net>:
5011 Changes to allow fonts with any charset (such as terminal)
5012
5013 Affects winboard only.
5014
5015 2009-10-16 23:02:41 -0600 Eric Mullins <emwine@earthlink.net>:
5016 Moved SIGWINCH signal so it can be used...
5017
5018 I goofed putting this in StartChildProcess() originally.
5019
5020 2009-10-16 22:54:12 -0600 Eric Mullins <emwine@earthlink.net>:
5021 Added internal wrapping ability.
5022
5023 New options:
5024   -wrapContinuationSequence "foo"  (default: "\\   "
5025   -useInternalWrap (Winboard default: false, XBoard default: true)
5026
5027 Note: -keepLineBreaksICS if set, prevents wrapping, usurping the
5028    useInternalWrap setting.  The idea is if you want to keep ICS line
5029    breaks, then you don't want internal wrapping.  Because of this,
5030    the new default for keepLineBreaksICS is now false for XBoard.
5031
5032 2009-10-16 19:14:34 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5033 fixed segfaul in convert.c used to convert pixmaps
5034
5035 2009-10-15 19:46:07 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5036 new mousehandler to correct for premove and promotion popup
5037
5038 this is the new mouse handler for XBoard, which should fully implement
5039 premove, including promotion popup, and yet suppress the promotion popup
5040 on illegal moves that are not premoves. It is almost completely moved to
5041 the back-end now, so that WinBoard will be able to use it as well. I just
5042 must hook it up to winboard.c, in particular harmonize the call-backs of
5043 the mouse driver into the front-end for grabbing and releasing pieces for
5044 dragging, to make sure they have the same names and arguments.
5045
5046 2009-10-15 19:32:55 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5047 updated black fairy pieces
5048
5049 here is a set of black fairy pieces with opaque white details,
5050 so they have the same style as the orthodox XBoard pieces.
5051
5052 2009-10-15 16:54:51 -0600 Eric Mullins <emwine@earthlink.net>:
5053 Adjustment to joining to work around server not always including space.
5054
5055 This patch implements commit 98aa02bda540f17f1f50be00e494efafe439b004
5056 into the updated joining routine.  This issue seems not to be server
5057 variance, but instead the server electing to omit the space between
5058 words when it occurs at exactly your width setting (-1 actually).
5059
5060 This patch makes the joiner add back the space just like the referenced
5061 commit.  Note: this is just a workaround to a server issue-- the joiner
5062 actually joins correctly before this patch.
5063
5064 2009-10-15 07:18:42 -0600 Eric Mullins <emwine@earthlink.net>:
5065 Fixed joiner detection, allowing it to work with timeseal
5066
5067 When timeseal's buffer fills in the middle of the continuation
5068 sequence, detection fails, and the lines aren't joined.
5069
5070 As a result of this fix, measures intended to bypass joining are
5071 no longer needed, so I removed them.  These utilize server vars
5072 when available to prevent splitting.
5073
5074 2009-10-14 14:42:37 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5075 fixed engingeoutput routine
5076
5077 removed outdated code regarding analysis window
5078
5079 2009-10-14 14:39:06 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5080 moved bitmap to correct location
5081
5082 was misplaced in a previous commit
5083
5084 2009-10-14 14:26:09 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5085 fixed wrong number of arguments for EngineOutputPopUp
5086
5087 2009-10-13 21:00:27 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5088 new bitmap converter (including fill option) and new pixmaps
5089
5090 2009-10-13 20:52:40 -0700 Arun Persaud <arun@nubati.net>:
5091 forgot to add these two lines to the last commit
5092
5093 2009-10-13 20:51:17 -0700 Arun Persaud <arun@nubati.net>:
5094 removed AnalysisPopUp. Use EngineOutputPopUp instead
5095
5096 this was already in Winboard, copied it to xboard and removed unused code.
5097
5098 2009-10-13 20:32:32 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5099 Proper board and holdings size when switching to variants
5100 gothic, capablanca, great and super within an ICS game.
5101
5102 2009-10-13 20:25:13 -0700 Arun Persaud <arun@nubati.net>:
5103 cleaned up an old #ifdef in zippy
5104
5105 2009-10-12 19:25:17 -0600 Eric Mullins <emwine@earthlink.net>:
5106 neglected this for the auto-width updating in xboard
5107
5108 2009-10-12 19:19:59 -0600 Eric Mullins <emwine@earthlink.net>:
5109 Added server width adjustment based on client width changes
5110
5111 2009-10-12 19:14:53 -0600 Eric Mullins <emwine@earthlink.net>:
5112 silence some compiler warnings
5113
5114 2009-10-11 18:39:24 -0600 Eric Mullins <emwine@earthlink.net>:
5115 Maintainence to support all compilers.
5116
5117 2009-10-11 17:07:27 -0600 Eric Mullins <emwine@earthlink.net>:
5118 Adjusted alternative joining method to obey keepLineBreaksICS
5119
5120 2009-10-11 14:48:55 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5121 fix for bug #27668: e.p. field still not passed to engine
5122
5123 PositionToFEN now takes the e.p. rights from epStatus[moveNr],
5124 rather than calculating it on the spot from moveList[moveNr-1]
5125 (which failed on the first move).
5126
5127 2009-10-11 14:46:14 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5128 fix for bug #27666: naming of variants
5129
5130 Variant names "misc/xxx" are recognized as "normal", rather than "xxx"
5131 to not get confused by the board "misc shogi" run by FICS.
5132
5133 2009-10-11 10:14:09 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5134 changed enable menus
5135
5136 Put the "Open Chat Window", "Machine Both", and "Engine #N Settings" menu items
5137 in the appropriate enable lists for graying them out wen not applicable.
5138
5139 2009-10-11 10:13:14 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5140 Added a command-line option -keepLineBreaksICS true/false to control line joining.
5141
5142 2009-10-10 19:30:23 -0600 Eric Mullins <emwine@earthlink.net>:
5143 Added code to prevent unnecessary width updates.
5144
5145 2009-10-10 18:34:37 -0600 Eric Mullins <emwine@earthlink.net>:
5146 Turned off wrap when possible on ICS servers.
5147
5148 Turning off line wrap prevents splitting lines up using the
5149 continuation sequence "\\   ".  This is desirable when using
5150 timeseal because timeseal's buffer is sometimes too small,
5151 causing it to break lines itself.  These lines can't be joined.
5152
5153 2009-10-10 16:30:56 -0600 Eric Mullins <emwine@earthlink.net>:
5154 vsnprintf() must be _vsnprintf() for MSVC
5155
5156 2009-10-10 16:16:45 -0600 Eric Mullins <emwine@earthlink.net>:
5157 added code to handle initial width update
5158
5159 2009-10-10 14:21:12 -0600 Eric Mullins <emwine@earthlink.net>:
5160 Added width updates to ICS client on font and window size changes
5161
5162 What still needs to be done is placing an update call after login
5163 to initialize with the correct width.  I didn't see where to put
5164 that.
5165
5166 2009-10-10 14:19:30 -0600 Eric Mullins <emwine@earthlink.net>:
5167 added ics_printf() and ics_update_width() and utility functions
5168
5169 2009-10-10 11:15:50 -0600 Eric Mullins <emwine@earthlink.net>:
5170 Cleaned up ConsoleWndProc  (not complete, see below)
5171
5172 Using static variables this way is not appropriate.  I only addressed
5173 hInput and hText in this commit though.  But imagine the WndProc being
5174 used by multiple windows instead of just one, and you can see why
5175 using static variables in this way is wrong.
5176
5177 2009-10-10 11:12:10 -0600 Eric Mullins <emwine@earthlink.net>:
5178 Restructured URL code so it fits better with how winboard is set up.
5179
5180 2009-10-10 08:57:39 -0700 Arun Persaud <arun@nubati.net>:
5181 cleanup: removed "#if 1" statements
5182
5183 2009-10-10 08:55:21 -0700 Arun Persaud <arun@nubati.net>:
5184 cleanup: removed "#if 0" from source
5185
5186 a bit of cleanup of the source code
5187
5188 2009-10-10 08:34:10 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5189 fix joining of lines split by ICS
5190
5191 This patch fixes the joining of lines that were split by an ICS, so that adding
5192 a space at the break point is done only when there was not a space already.
5193 (Some ICS leave a space at the end of the broken line, others do not.)
5194 An extra space would interefere with board12 in Gothic Chess, which is so
5195 long that the ICS breaks it, and the WB parser could not handle a double
5196 space within the board.
5197
5198 2009-10-10 08:27:55 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5199 fix for bug #27642: Clock jumps strangely in engine mode
5200
5201 This moves SwitchClocks() back to after incrementing forwardMostMove,
5202 so that it knows again who has the move (which was broken by the "bare" patch),
5203 and will take the appropriate tick length.
5204
5205 2009-10-10 08:26:13 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5206 removed test for premove
5207
5208 this was added while looking for the premove bug, but is not needed
5209
5210 2009-10-10 02:03:45 -0600 Eric Mullins <emwine@earthlink.net>:
5211 added URL detection and provided hotlinks in the ICS client
5212
5213 2009-10-10 02:00:52 -0600 Eric Mullins <emwine@earthlink.net>:
5214 reverted winboard.c beofre URL commit to correct whitespace conversion
5215
5216 2009-10-09 02:14:22 -0600 Eric Mullins <emwine@earthlink.net>:
5217 Added URL detection into the console text window for ICS.
5218
5219 2009-10-08 23:51:06 -0700 Arun Persaud <arun@nubati.net>:
5220 added some comments and formated code
5221
5222 2009-10-08 23:46:52 -0700 Chris Rorvick <>:
5223 fix printing out help message (list of command line options) (tiny change)
5224
5225 The postfix increment always resulted in an attempt to print out an
5226 option on the right side regardless of one actually existing. Use
5227 prefix increment to prevent a crash when printing an odd number of
5228 options.
5229
5230 2009-10-09 00:04:51 -0600 Eric Mullins <emwine@earthlink.net>:
5231 Updated navigation accelerators, fixing ICS problems.
5232
5233 Recent changes to the navigation accelerators were in the wrong
5234 accelerator table.  Since the goal was to correct non-JAWS versions
5235 back to 4.2.7 behavior, I updated it to how 4.2.7 did it, but still
5236 retained the #ifdef JAWS conditional compilation.
5237
5238 On an ICS, the navigation keys took control away from the ics
5239 client to navigate the game.  The update requires the ALT key to
5240 be pressed, but it works identical to 4.2.7, not causing an
5241 unexpected focus back to the board window when you're just editing
5242 text.
5243
5244 2009-10-08 20:33:39 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5245 fixed premove recapture problem;promotion popup appearing on
5246 obviously illegal moves; promotions in Superchess and Great Shatranj
5247
5248 1) the premove recapture problem
5249 2) the promotion popup appearing on obviously illegal moves (the 1. e2a8
5250 problem)
5251 3) promotions in Superchess and Great Shatranj, where the piece can now be
5252 selected from the holdings
5253
5254 2009-10-08 20:28:50 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5255 added forceIllegalMove to xboard
5256
5257 2009-10-05 21:01:32 -0700 Arun Persaud <arun@nubati.net>:
5258 bugfix: segfault when invalid option argument was given (bug #27427)
5259
5260 when given a wrong argument to an option (e.g. -tc 0) xboard aborts
5261 before setting up the window, but tried to write a message to the
5262 messageWidget which doesn't exist at that point.
5263
5264 2009-10-05 20:05:00 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5265 small improvement for JAWS version
5266
5267 This is a patch to make JAWS read out any comments when /autoDiplaycomment=true.
5268 As focus does not stay on the Comment window, the comment was not spoken otherwise.
5269
5270 2009-10-05 20:02:50 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5271 updated to winboard internationalization scripts
5272
5273 Also a slight improvement of the internationalization scripting,
5274 to prevent it from crashing on messages containing a slash.
5275
5276 2009-10-05 20:01:53 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5277 new forceIllegalMoves option
5278
5279 The -forceIllegalMoves option uses setboard or edit to force a position
5280 when an engine refuses the move leading to it by an "Illegal Move" message.
5281 Especially for engines using the edit command this was a bit tricky,
5282 because of the a2a3 kludge to avoid using the white and black commands.
5283
5284 2009-10-05 01:01:54 -0600 Eric Mullins <emwine@earthlink.net>:
5285 removed _winmajor if not defined so that VC 2008 can compile the project
5286
5287 The oldDialog variable should just be set to 0 in all cases now, and
5288 as such, legacy code supporting the old dialog ought to be removed.
5289 The test for _winmajor is against < 4, which is always false at present,
5290 causing oldDialog to be 0 in every conceviable circumstance.
5291
5292 2009-10-04 09:58:29 -0700 Arun Persaud <arun@nubati.net>:
5293 getting ready for 4.4.1 release
5294
5295 2009-10-02 20:47:01 -0600 Eric Mullins <emwine@earthlink.net>:
5296 Simplified future version changes.
5297
5298 Added a numeric version to config.h that is now used in winboard.rc
5299 instead of being hard-coded there.  Just be sure to preserve the
5300 proper format (4 comma-separated 16 bit integers) or else it won't
5301 compile.
5302
5303 2009-10-02 16:56:01 -0700 Arun Persaud <arun@nubati.net>:
5304 updated version number to 4.4.1.pre
5305
5306 should have done this straight after the last release, but forgot...
5307
5308 2009-10-02 16:48:03 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5309 worked on premove bug
5310
5311 I made an attempt to make premove unsensitive to a race condition,
5312 just in case the premove problem was caused by that (which seems unlikely,
5313 but in any case  I added some debug printout to test this).
5314
5315 2009-10-02 16:41:12 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5316 fixed loading of saved games via command line
5317
5318 the variables forwardMostMove and backwardMostMove where set to zero
5319 at the wrong place.
5320
5321 2009-10-02 16:39:20 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5322 small fixes for the JAWS version
5323
5324 * I moved saying 'check' by the JAWS version to where castling also benefits from it.
5325 * I made sure the check symbols are also recognized on promotion moves
5326 * In the non-JAWS version, define the plain arrows as shortcut keys for the button bar
5327
5328 2009-10-01 16:50:28 -0600 Eric Mullins <emwine@earthlink.net>:
5329 Fixed bug dereferencing garbage, causing crash.
5330
5331 Commit fa8be4a3fc5d81e9ec1f6c218fcf55c95d34fd10 included code to free the
5332 resultDetails of the gameInfo structure.  That exact code exists a few lines
5333 above where it was added.  None of these free() calls finish by setting the
5334 member to NULL afterword, therefore repeated attempts to test/free() the
5335 members result in an attempt to free() memory winboard no longer owns, and
5336 an eventual crash.
5337
5338 link to problematic commit: http://git.savannah.gnu.org/cgit/xboard.git/commit/?id=fa8be4a3fc5d81e9ec1f6c218fcf55c95d34fd10
5339
5340 2009-10-01 16:49:57 -0600 Eric Mullins <emwine@earthlink.net>:
5341 Added wchat.c to the project files we maintain.
5342
5343 2009-10-01 15:52:50 -0600 Eric Mullins <emwine@earthlink.net>:
5344 Previous fix for VC++/strcasecmp() was wrong-- use StrCaseCmp().
5345
5346 2009-10-01 14:49:58 -0600 Eric Mullins <emwine@earthlink.net>:
5347 Add resource ID for new Mute menu item.
5348
5349 I know this was probably done by HG, and simply left out of
5350 his commit.  Anyway, the project can be built now after this change.
5351
5352 2009-10-01 14:49:09 -0600 Eric Mullins <emwine@earthlink.net>:
5353 Use of strcasecmp() broke Visual C++.
5354
5355 2009-09-30 20:47:00 -0700 Arun Persaud <arun@nubati.net>:
5356 wrong default value for engineDebugOutput
5357
5358 the new default is now 1
5359
5360 2009-09-29 22:55:41 -0700 Arun Persaud <arun@nubati.net>:
5361 updated cmail.in to adapt the CVS->git change
5362
5363 don't reference $Revision:$ anymore.
5364 Instead use reference xboard-version via autoconf.
5365
5366 2009-09-29 22:04:25 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5367 bugfix for protocol extensions: egtbpath -> egtpath
5368
5369 A new and very bad bug was discovered in the implementation of
5370 the protocol extensions: XBoard sends a command "egtbpath" to the
5371 engine in stead of "egtpath" from the protocol specs.
5372 After discussion on WB forum it was decided that egtpath was better
5373 than the egtbpath I originally had proposed, and I changed it accordingly,
5374 but I had not realized that this string occurred TWICE in backend.c,
5375 depending on if matched the -defaultPathEGTB of -egtFormats option.
5376 I only changed the first occurence.
5377
5378 2009-09-27 12:27:44 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5379 fix for edit-position "moves" being sent by XBoard to the engine
5380
5381 2009-09-27 12:25:25 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5382 Engine did not start playing when out of GUI book on second move with white
5383
5384 2009-09-27 12:24:30 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5385 Opening Engine #1 Settings crashed XBoard when there were no
5386 text-edit options in the dialog (to which to set keyboard focus)
5387
5388
5389 2009-09-27 12:18:35 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5390 added a "Mute All Sounds" item in the WinBoard Options menu, on Eric's request
5391
5392 2009-09-27 12:15:20 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5393 Updated the RTF docs for the chat windows, engine-settings dialog,
5394 /keepAlive option and new game-list tag
5395
5396 2009-09-27 12:14:25 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5397 Made the beep sounds for JAWS board navigation configurable through
5398 command-line options
5399
5400 2009-09-27 12:11:49 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5401 Prepared a system to internationalize the WinBoard menus
5402
5403 2009-09-27 12:10:38 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5404 added the result comment to the game-list tags when the game list is
5405 exported to the clipboard
5406
5407 2009-09-27 12:05:32 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5408 rewrote wevalgraph for better frontend/backend separation
5409
5410 I have finished re-writing the eval-graph code to have some
5411 front-end / backe-end separation, something I had already started on my
5412 holiday in Norway (when I had no internet :-)  ).
5413 The new code now appears to work exactly like the old code,
5414 and I guess it could be ported to gtk comparatively easily.
5415
5416 2009-09-27 12:00:51 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5417 fix for keepalive and chat window
5418
5419 I made a fix to the keepAlive option so it does not send the date command
5420 to the ICS after every move. This required changing ScheduleDelayedEvent()
5421 so that it does not execute the event if a new identical one gets scheduled.
5422 I also added the option to XBoard. Affects xboard.c (DOS!) and winboard.c
5423
5424 (This also cures the regression of the winboard.c copyright patch)
5425
5426 I extended the chatbox patch to also listen to channel tells, and divert
5427 them to a chatbox for that channel number. Affects
5428 backend.c and wchat.c
5429
5430 That should make those patches fully operational. No docs for either of them
5431 yet, though.
5432
5433 2009-09-27 10:36:23 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5434 fixed parse bug for pgn files
5435
5436 fixed the existing bug that the time-control tag was displayed as "?"
5437 in the game list; turns out it was never parsed on reading PGN files
5438
5439 2009-09-27 10:35:58 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5440 allow the result comment as a display item in the game list
5441
5442 2009-09-27 10:35:13 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5443 fixed the HAVE_LIBXPM-dependent compile errors
5444
5445 2009-09-27 10:24:47 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5446 added a chat window to keep track of multiple conversations
5447
5448 The chat-window patch affects:
5449 winboard.c, backend.c, winboard.rc, resource.h, backend.h, and adds
5450 the file winboard/wchat.c, which also affects makefile.gcc and makefile.ms.
5451
5452 In addition I added a new option -keepAlive, which affects
5453 common.h (in addition to winboard.c and backend.c).
5454
5455 As I had to modify backend.h, I also defined the -reset option type there,
5456 which we are going to add later. This required some changes
5457 to suppress warnings in wsettings.c.
5458
5459 2009-09-27 10:22:16 -0700 Arun Persaud <arun@nubati.net>:
5460 more files for git to ignore
5461
5462 most of these are generated by make distcheck
5463
5464 2009-09-08 09:33:53 -0700 Arun Persaud <arun@nubati.net>:
5465 another bug fix found by Stanislav Brabec
5466
5467 returned -1  in some case although the variable was a char...
5468 changed to signed char
5469
5470 2009-09-20 23:13:13 -0600 Eric Mullins <emwine@earthlink.net>:
5471 Swapped 'tell' and 'message' parsing order for colorization.
5472 Sometimes messages are relayed as tells and should be colorized as tells.
5473
5474 2009-09-08 09:10:34 -0700 Arun Persaud <arun@nubati.net>:
5475 added some more files to be distributed via make dist
5476
5477 as suggested by Stanislav Brabec
5478
5479 2009-09-08 09:01:07 -0700 Arun Persaud <arun@nubati.net>:
5480 fixed some implicit declarations reported by Stanislav Brabec
5481
5482 2009-09-07 22:04:39 -0700 Arun Persaud <arun@nubati.net>:
5483 fixed a few more small bugs reported by Stanislav Brabec
5484
5485 - A function uses a 'return;' statement, but has actually a value to
5486 return, like an integer ('return 42;') or similar: xboard voidreturn
5487 xengineoutput.c:766, 782
5488
5489 - Program returns random data in a function at xengineoutput.c:602
5490
5491 - With a new toolchain, AM_LDFLAGS cannot contain libraries. Linker
5492 ignores them. Fix is attached.
5493
5494 - ToDo: Convenient name in most projects is TODO (autotools package it
5495 automatically).
5496
5497 2009-09-06 19:11:22 -0700 Arun Persaud <arun@nubati.net>:
5498 reverted .texi file and fixed Makefile.am
5499
5500 the problem was actually not in the texi-file, but the Makefile.am.
5501 Reverted changes in the .texi and fixed it (hopefully) correctly now.
5502
5503 2009-09-06 18:23:01 -0700 Arun Persaud <arun@nubati.net>:
5504 get "make distcheck" to work
5505
5506 needed to add all *.h files to Makefile.am and also the bitmaps that
5507 are needed and some other files. Also had modified copyright.texi.
5508
5509 2009-09-05 09:54:37 -0700 Arun Persaud <arun@nubati.net>:
5510 changed to version 4.4.0
5511
5512 2009-09-05 09:44:21 -0700 Arun Persaud <arun@nubati.net>:
5513 updated AUTHORS, README and ChangeLog files for release
5514
5515 2009-09-05 08:52:09 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5516 fixed some typos
5517
5518 2009-09-04 22:39:45 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5519 set castling rights after setting up a position
5520
5521 I was going through old WB forum posts, and I encountered a
5522 bug report for a bug that I never fixed: The castling rights should
5523 be properly set (actually: cleared) after setting up a position
5524 in Edit Position mode (as opposed to pasting a FEN).
5525
5526 2009-09-03 23:11:18 -0700 Arun Persaud <arun@nubati.net>:
5527 removed install files from master
5528
5529 they now live in their own branch
5530
5531 2009-09-03 22:30:18 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5532 updated polyglot protocol
5533
5534 I added a new option type "-reset" to the protocol for the new option feature.
5535 4.4.0 does not implement it yet, but Michel wants it for future Polyglots,
5536 and I think it is best to update the protocol in one big swoop.
5537 So I want to already include it in the specs now. (engine-intf.html)
5538 I made xboard's response to an unknown option type compliant
5539 with the new protocol specs.
5540
5541 2009-09-03 22:28:50 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5542 fixed some typos
5543
5544 2009-09-03 20:47:13 -0600 Eric Mullins <emwine@earthlink.net>:
5545 Updated project files for DevCpp and Visual Studio to add wsettings.c
5546
5547 2009-09-03 20:46:33 -0600 Eric Mullins <emwine@earthlink.net>:
5548 Added newline at end of file to silence warning.
5549
5550 2009-08-31 20:29:49 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5551 workaround for error message for missing pieces used in variants
5552 and initstring bugfix: error messages showed for non-existing pieces
5553 showed up for old user supplied pixmaps.
5554 Loading a pixmap of the king for the missing pieces now.
5555
5556 Another bad bug surfaced: the -initString argument does not work in any
5557 XBoard version! (Including 4.2.7b) The escape sequences for linefeed in
5558 the string are not understood: -initString "new\nrandom\n" actually sends
5559 the \ and n to the engine (which then does not recognize the line as a
5560 valid command)!
5561
5562 So I also added a patch to expand escape sequences in the InitString and
5563 ComputerString command-line options.
5564
5565 2009-08-31 20:27:24 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5566 updated installe script
5567
5568 I re-organized the doc files in the install, so they now all go in the
5569 WinBoard\doc folder (and none in the root). I so included the COPYING
5570 and COPYRIGHT files there. This required some updates of the links in
5571 some html files, and of the menu link to README.html in the install script.
5572 I also fixed an error with the current directory
5573 in the menu short-cuts of some engines (which started in the fonts folder,
5574 and could not find the opening book there...).
5575
5576 2009-08-31 20:25:17 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5577 updated documentation
5578
5579 2009-08-31 20:20:55 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5580 updated installer script
5581
5582 2009-08-31 19:51:48 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5583 new help files for windows
5584
5585 2009-08-25 20:41:29 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5586 updated installer
5587
5588 2009-08-25 20:36:53 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5589 undid some previous changes
5590
5591 some files got mixed up
5592
5593 2009-08-25 20:32:22 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5594 fixed small bug in wsetting
5595
5596 2009-08-25 20:29:06 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5597 trigger a focus switch to ICS input field when typing
5598
5599 old behavior was that "." or "," triggered this,
5600 now every printable character  except 1-9 will trigger the focus switch
5601
5602 2009-08-25 20:26:20 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5603 bug in backend.c when receiving lines from ICS
5604
5605 A space was appended to every character received from an ICS
5606 in stead of just at line breaks.
5607
5608 2009-08-24 23:47:48 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5609 fixed warning messages from compiler
5610
5611 2009-08-23 14:24:38 -0700 Arun Persaud <arun@nubati.net>:
5612 fixed build on OS X
5613
5614 this seems to fix it. Bug reported by Louis Zulli who also did the testing.
5615
5616 2009-08-23 11:54:28 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5617 OK, this is the beefed up version of the Polyglot info-string kludge,
5618 for WB and XB.
5619
5620 2009-08-23 10:22:48 -0700 Arun Persaud <arun@nubati.net>:
5621 added missing X_LIBS references to Makefile.am
5622
5623 2009-08-22 23:33:44 -0700 Arun Persaud <arun@nubati.net>:
5624 made the install script and executable
5625
5626 2009-08-22 23:19:07 -0700 Arun Persaud <arun@nubati.net>:
5627 changed beta1 to beta2
5628
5629 2009-08-22 23:14:11 -0700 Arun Persaud <arun@nubati.net>:
5630 fixed enable zippy in configure script and added some checks for OS X
5631
5632 make tried to compile zippy even when --disable-zippy was given.
5633 Also fixed a bug in xboard.c where #ifdef instead of #if was used
5634 to test for ZIPPY (it's either 0 or 1, so we need #if). Also added
5635 some special checks for OS X, not sure if these will do it, but it's a start;)
5636
5637 2009-08-22 19:09:54 -0700 Arun Persaud <arun@nubati.net>:
5638 added configure summary to configure output, also cleaned up configure.ac a bit
5639
5640 used AS_HELP_STRING where possible
5641
5642 2009-08-22 18:10:57 -0700 Arun Persaud <arun@nubati.net>:
5643 added check for malloc.h
5644
5645 this should fix a build error on OS X
5646
5647 2009-08-22 17:47:44 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5648 A small cosmetic change in the size of buttons
5649 inside a groupbox of the Engine-Setup dialog.
5650
5651 2009-08-22 17:32:14 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5652 make xboard usable with UCI engines
5653
5654 I made a small patch in xoptions.c (where the corresponding Engine Settings
5655 dialog was for XBoard), to make it at least usable for UCI engines: I now
5656 divide the options over upto 4 columns, if there are too many to fit into
5657 a single column. This seems to work. Still looks very ugly, but it is
5658 functional.
5659
5660 2009-08-22 17:30:05 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5661 fix premove for winboard
5662
5663 This might fix the illusive premove problem. In 4.2.7 the code was not properly
5664 indented, and this led to an unbalanced braces error that I then fixed the
5665 wrong way. Click-click premoves did only work after clicking the toSquare twice.
5666 It might be that they actually did work after clicking it once,
5667 but that the highlights were not displayed (although set)
5668 for lack of a display refresh.
5669
5670 2009-08-22 17:28:11 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5671 fixed bug for double saved games
5672
5673 This patch should solve the problem with doubly saved games when XBoard is
5674 closed. I calculate a cecksum of each saved game now (including move comments),
5675 and suppress saving if the checksum is not changed.
5676
5677 2009-08-22 17:25:58 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5678 fixed xengineoutput.c, to keep the duplicated code identical to that of wengineo.c.
5679
5680 2009-08-22 17:24:08 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5681 updated xboard.texi: added warning that pixmaps are not build for all variants
5682
5683 2009-08-22 17:19:11 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5684 added a dialog for engine-specific option settings
5685
5686 2009-08-22 17:09:58 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5687 updated some documentation
5688
5689 2009-08-22 17:07:10 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5690 fixed several bugs in the backend and added some more polyglot support
5691
5692 * I added recognition for the new UCI3 option types that are recognized in the WB
5693 option features, to make sure this version is compatible with future Polyglots.
5694 Also fixed a bug that failed to strip an asterisk prefix from the first
5695 combo-box item.
5696
5697 * I fixed the ICS-time-in-PGN bug.
5698
5699 * I fixed a bug which caused a space to be missing when long lines broken up by
5700 an ICS were joined.
5701
5702 2009-08-22 17:02:58 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5703 better polyglot support for engine ouput
5704
5705 I fixed the algorithm for clearing the Engine Output window to work better with
5706 the latest Polyglot, whight outputs UCI "info strings" amongst the thinking
5707 output.
5708
5709 2009-08-22 16:23:32 -0600 Eric Mullins <emwine@earthlink.net>:
5710 Beginnings of installer for 4.4.0.  HGM asked me to forward the nsi file,
5711 but it seemed best to just add the installer tree to git even though
5712 it's not finished.  You must install NSIS then FontName-0.7.exe
5713 (included in installer folder) then run build.bat in the same directory.
5714
5715 2009-08-05 22:18:29 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5716 patch backend.c to make the -noGUI option also work in ICS mode.
5717
5718 2009-08-01 13:09:49 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5719 temporary fix for pre-select
5720
5721 As a temporary kludge I replaced looking into the holdings for the piece type
5722 by figuring out which piece would belong on the clicked holdings square.
5723 This is a non-trivial process, as it depends on which pieces participate
5724 in a certain variant.
5725
5726 2009-07-30 00:19:37 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5727 changed click-click moves
5728
5729 I got complaints about the way XBoard 4.4.0 handles click-click moves,
5730 in particular changing the selected piece after selecting King
5731 (for which I suppressed interference with FRC castling in a rather brutal way).
5732 People tell me it is very annoying that clicks sometimes don't work to select a piece.
5733 WinBoard uses refined logic in the back-end to handle this, but the XBoard
5734 front-end is not interfaced with that yet.
5735 (This would require a major rewrite of the mouse handler.)
5736 This temporary patch suppresses this behavior in all variants that do not support
5737 Fischer castling, and even there only exhibit it for Rook-after-King selection
5738 (which will be interpreted as an attempt to enter a castling move as K x own R).
5739
5740 2009-07-26 08:43:35 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5741 option -adjudicateDrawMoves is not included in the XBoard list.
5742
5743 added it to the option list
5744
5745 2009-07-21 20:23:23 -0700 Arun Persaud <arun@nubati.net>:
5746 converted files from dos to unix format
5747
5748 run dos2unix over a bunch of files
5749
5750 2009-07-16 07:43:38 -0600 Eric Mullins <emwine@earthlink.net>:
5751 Stripped out unused VersionInfo
5752
5753 2009-07-15 23:16:19 -0700 Arun Persaud <arun@nubati.net>:
5754 changed version to 4.4.0.beta1
5755
5756 2009-07-15 23:12:37 -0700 Arun Persaud <arun@nubati.net>:
5757 updated INSTALL file to add ./autogen.sh
5758
5759 2009-07-15 22:44:05 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5760 higher number of engine options possible now
5761
5762 I upped the number of options per engine from
5763 50 to 100, and the average number of characters per option from 10 to 20.
5764
5765 2009-07-15 12:30:37 -0600 H.G. Muller <h.g.muller@hccnet.nl>:
5766 Fix of bad bug
5767
5768 2009-07-14 23:41:36 -0600 Eric Mullins <emwine@earthlink.net>:
5769 Added version information to resources.
5770
5771 2009-07-14 23:40:50 -0600 Eric Mullins <emwine@earthlink.net>:
5772 Added Jaws targets to IDE projects.
5773
5774 2009-07-14 23:39:12 -0600 Eric Mullins <emwine@earthlink.net>:
5775 Final makefile adjustments and compiling instructions.
5776
5777 2009-07-13 22:35:17 -0600 Eric Mullins <emwine@earthlink.net>:
5778 Cleaned up garbage left behind from my makefile update.
5779
5780 2009-07-13 22:26:56 -0600 Eric Mullins <emwine@earthlink.net>:
5781 Updated cmdline makefiles to be able to produce JAWS binaries.
5782
5783 This breaks support for MSVC 4.x.  It may still be possible to
5784 use that compiler if you obtain the latest SDK from Microsoft.
5785 MSVC 6.0 still works, but I had to change the target windows
5786 version to 0x500 which causes warnings about building beta
5787 applications.  This is all due to the use of MENUBARINFO data
5788 type in the jaws binary.  You can reduce the WINVER to 0x0400
5789 safely if you are not building a JAWS binary, and MSVC 4.x
5790 will work fine.
5791
5792 2009-07-13 22:26:10 -0600 Eric Mullins <emwine@earthlink.net>:
5793 Removed dependency on jfwapi.h
5794
5795 Allows anyone to compile a jaws compatible binary.
5796
5797 2009-07-13 22:23:31 -0600 Eric Mullins <emwine@earthlink.net>:
5798 Fixed duplicate resource in winboard.rc
5799
5800 PLEASE remember to pull before commiting.  This is the 2nd
5801 time I've fixed this.  It's a waste of time to keep fixing
5802 the same problems.
5803
5804 2009-07-13 19:36:58 -0700 Arun Persaud <arun@nubati.net>:
5805 resolved conflict between Xt and Xaw libraries
5806
5807 seems like we don't need to link against Xt.
5808
5809 2009-07-13 19:33:57 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5810 help-menu was not un-grayed in the JAWS version, when it played with engines
5811
5812 2009-07-13 19:29:53 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5813 integrated jaws into winboard
5814
5815 I integrated the JAWS patch now into WinBoard in such a way that the
5816 JAWS and standard version can use the same resource file. This new
5817 winboard.c contains the improved dialog layot of the JAWS version,
5818 but none of the menus and JAWS-specific acclerator keys. The latter
5819 are now generated at run time by code in jaw.s. As a result jaws.h
5820 could be cancelled, as there the JAWS-specific defines are no
5821 longer needed outside jaws.c (now the .rc does not use them), and
5822 is incorporated in it.
5823
5824 2009-07-12 15:37:26 -0700 Arun Persaud <arun@nubati.net>:
5825 fixed problem in autoconf using Xaw3d
5826
5827 rewrote the section for Xaw3d in the autoconf file
5828
5829 2009-07-12 15:29:28 -0600 Eric Mullins <emwine@earthlink.net>:
5830 Added Jaws support to GCC makefile
5831
5832 2009-07-12 15:28:20 -0600 Eric Mullins <emwine@earthlink.net>:
5833 added help support: MSVC IDE and DevCpp IDE project files
5834
5835 2009-07-12 15:26:49 -0600 Eric Mullins <emwine@earthlink.net>:
5836 Removed obsolete makefiles and support files.
5837
5838 2009-07-12 12:33:26 -0700 Arun Persaud <arun@nubati.net>:
5839 updated AUTHORS with the help of git. use
5840
5841 git log --pretty=oneline --name-only --author=AUTHORNAME v4.2.7..HEAD  |sort |uniq
5842
5843 a bit of hand editing and a quick emacs macro later and you have a nice
5844 comma seperated list of all files changes by one author between two commits.
5845
5846 2009-07-12 12:31:47 -0700 Arun Persaud <arun@nubati.net>:
5847 updated Changelog using git log --no-merges --pretty="* %ai: %s%n %b" HEAD v4.2.7
5848
5849 2009-07-12 11:34:28 -0700 Arun Persaud <arun@nubati.net>:
5850 cleaned up some more copyright notices
5851
5852 2009-07-12 11:22:30 -0700 Arun Persaud <arun@nubati.net>:
5853 updated copyright to reflect A. Scotte as copyright holder
5854
5855 need to mention him, since the paperwork won't be finished before the next release
5856
5857 2009-07-12 10:56:29 -0700 Arun Persaud <arun@nubati.net>:
5858 updated patchlevel to "k"
5859
5860 2009-07-12 10:53:50 -0700 Arun Persaud <arun@nubati.net>:
5861 fixed autoconf problem with VERSION/PATCHLEVEL variables
5862
5863 xboard used it's own version of PRODUCT, VERSION and PATCHLEVEL variables.
5864 Switched to PACKAGE_STRING provided by autoconf
5865
5866 2009-07-12 10:29:46 -0700 Arun Persaud <arun@nubati.net>:
5867 cleaned up old CVS left overs
5868
5869 removed $Id tags from all files
5870
5871 2009-07-12 10:10:17 -0700 Arun Persaud <arun@nubati.net>:
5872 converted xhistory via dos2unix
5873
5874 2009-07-12 10:09:24 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5875 fixed crash in history window
5876
5877 someone discovered that opening the move-history window in XBoard leads to
5878 an immediate crash. Turns out that renaming the menu item broke it! (The
5879 name of the item was apprently used elsewhere in the code to access it,
5880 for putting a check mark there.)
5881
5882 2009-07-12 10:04:30 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5883 fix for Animation of castling moves in Chess960
5884
5885 Animation of castling moves in Chess960 turned out to sometimes make the
5886 king disappear from the display. For the time being I patched this in
5887 xboard.c to suppress animation of FRC castling moves altogether. As FRC
5888 castlings internally are represented as KxR, the to-square does not make
5889 sense anyway, which made the animation look very weird even when it led
5890 not to a king disappearance act. And the Rook move of a castling is never
5891 animated.
5892
5893 2009-07-11 22:44:53 -0600 Eric Mullins <eric@hiarcs.(none)>:
5894 Update GCC makefile to remove .obj targets.
5895
5896 Dunno how they got in there, but they should be .o
5897
5898 2009-07-11 22:42:41 -0600 Eric Mullins <eric@hiarcs.(none)>:
5899 Update makefile dependencies on help.c and help.h.
5900
5901 2009-07-11 22:36:59 -0600 Eric Mullins <eric@hiarcs.(none)>:
5902 Allow compiling with MSVC6.0 and 4.1
5903
5904 Move prototypes into help.h, after making sure that DWORD_PTR is
5905 defined.  Include help.h from winboard.c and help.c so both files
5906 benefit from the definition.
5907
5908 2009-07-11 18:26:16 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5909  lists these accelerator keys in the menus for JAWS
5910
5911 2009-07-11 18:24:19 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5912 added shortcuts
5913
5914 This patch allows the use of Ctrl+C and Ctrl+V for Copy Game
5915 and Paste even in I C S mode when the board has focus.
5916
5917 2009-07-11 18:22:17 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5918 better handling of pasting a game without PGN tags
5919
5920 patch in wclipbrd.h to make it smarter to decide between pasting
5921 a game or a position so it can handle games without PGN tags.
5922 If it doesn't parse as a FEN it is assumed to be a game.
5923
5924 2009-07-11 18:20:56 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5925 fixed parser error for knight move
5926
5927 The parser had a strange quirk: it recognized bd2 as a valid Knight move
5928 (Nb1-d2) while this SAN format should be reserved for Pawn moves only.
5929
5930 2009-07-11 18:19:30 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5931  fixed a few warnings in connection with the help patch (now warning free)
5932
5933 2009-07-11 18:13:50 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5934 some major re-assignment of accelerator keys in the JAWS
5935
5936 2009-07-11 16:54:53 -0600 Eric Mullins <eric@hiarcs.(none)>:
5937 several small fixes
5938
5939 uptracked winboard.ini
5940
5941 * Cleanup: moved "Some definitions required..." from winboard.c to config.h,
5942 and combined some definitions from borland w/ MS.
5943
5944 * Changed internal HtmlHelp return type and 4th argument to facilitate various
5945 compilers.  These changes, while not strictly adhering to HtmlHelp() conventions,
5946 won't impact anything since the function modified is internal only.
5947
5948 * Modified HtmlHelp return values to integer to silence warnings.
5949 * Added help.c to the project in makefile.gcc & makefile.ms.
5950 * Fixed duplicate resource in winboard.rc.
5951
5952 2009-07-09 22:08:15 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5953 added JAWS support; help files for Vista; bugfixes for winboard.c
5954
5955 * JAWS support
5956 * help files should now work under Vista (the user has to have either
5957   a program to view old windows help files or to view html-files installed)
5958 * I fixed the tabbing between all windows that were added according to Tim's sugestions.
5959 * I added typing in of a move number in the move type-in dialog as a shortcut
5960   to going to that position by use of the < and > buttons. Mainly intended to
5961   ease life for the blind, but I think it can be generally useful.
5962   (Although the move-history dialog provides that functionality too,
5963   this is quicker if you don't happen to have it open.)
5964 * I added typing of a FEN in the move type-in dialog in Edit Position mode.
5965   (Which could not be used without mouse at all, and is defective
5966   in crazyhouse even with mouse, as there was no way to populate holdings.)
5967
5968 2009-07-09 22:03:00 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5969 some bugfixes: ICS error handling
5970
5971 * play a different sound for takebacks in ICS mode
5972 * pop up error messages for illegal moves for typed-in moves
5973
5974 2009-07-09 21:50:41 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5975 removed no longer needed debug message
5976
5977 2009-07-09 21:48:23 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5978 fixed compile error from a previous change
5979
5980 2009-07-09 21:44:54 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5981 user selectable font in game list
5982
5983 This makes the game list use the same (user selectable) font
5984 as the the move-history window.
5985
5986 2009-06-30 21:27:34 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5987 fixed typos in xboard.texi documentation.
5988
5989 2009-06-30 21:16:59 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5990 updated the FAQ
5991
5992 2009-06-27 17:06:26 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
5993 changed font in engine output window
5994
5995 The engine-output window now uses the same font as the move-history window
5996 (which was selectable in the "Options  -> Fonts..." menu, while the other
5997 wasn't).
5998
5999 2009-06-27 17:03:19 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6000 fixed some characters in xboard.texi
6001
6002 It seems that copying manual sections from the RTF to th texi file did
6003 somehow mess up the double-quote characters, and changed them into some
6004 strange (unicode?) symbols.
6005
6006 2009-06-27 16:56:36 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6007 two shogi related bugfixes
6008
6009 I discovered a bug in the move generator for the Shogi Dragon King. I
6010 guess it went unnoticed so far because this is a promoted version of the
6011 Rook, which hardly occurs in games. (moves.c)
6012
6013 There was also a problem with the piecesfix I sent you before; Shogi
6014 chosen as initial variant did use wrong piece symbols. (I had tested this
6015 on gothic, but there it happened to work for a different reason, unique to
6016 gothic.) This affects xboard.c.
6017
6018 2009-06-27 16:54:04 -0700 Arun Persaud <arun@nubati.net>:
6019 small cleanup
6020
6021 2009-06-27 16:51:02 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6022 adds bitmaps for shogi promotions, and selects the bitmaps or
6023 pixmaps for the more rarely used piece types on a per-variant basis.
6024
6025 2009-06-27 16:44:36 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6026 adds new piece types in the promotion dialog and edit-position piece menu
6027
6028 2009-06-27 16:13:15 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6029 updated bitmaps files: files for fairy pieces where missing,
6030 others had names that didn't work with autoloading.
6031
6032 2009-06-27 16:06:35 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6033 fixed a bug concerning bitmaps
6034
6035 2009-06-27 15:53:45 -0700 Arun Persaud <arun@nubati.net>:
6036 give a default directory for bitmaps files (tiny change)
6037
6038 this is also one of the debian patches, should be rewritten to use
6039 the correct install directory. No Author was given.
6040
6041 2009-06-27 15:47:52 -0700 Brian May <>:
6042 verbose_error_message_about_recognized_options (tiny change from Debian patches)
6043
6044 2009-06-27 15:45:14 -0700 Matt Zimmerman <>:
6045 add a visual low time warning (tiny change from Debian patches)
6046
6047 2009-06-24 23:31:52 -0700 Arun Persaud <arun@nubati.net>:
6048 dos 2 unix conversion of backend.c
6049
6050 2009-06-24 23:30:07 -0700 Arun Persaud <arun@nubati.net>:
6051 exchanged some sprintf with snprintf found in a patch for the debian system,
6052 extended it a bit to other sprintf's original patch included only 11 lines
6053 by Florian Ernst <florian@debian.org>
6054
6055 2009-06-24 23:07:23 -0700 Mark Ioli <chessknight>:
6056 enabled a patch for default settings in winboard
6057
6058 2009-06-24 22:53:11 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6059 updated copyright notice
6060
6061
6062 2009-06-24 22:52:20 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6063 patches a bug in chosing the initial board size on a virgin startup
6064 I introduced recently
6065
6066 2009-06-24 22:49:33 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6067 I put in testing for the winning condition in 3checks
6068
6069 on a check it just goes through the entire game to subject
6070 every position on a check test, to see if there were two more.
6071
6072 2009-06-24 22:47:01 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6073 updated copyright notice in docs
6074
6075 2009-06-24 22:41:40 -0700 Florian Ernst <florian@debian.org>:
6076 added small patch from debian (tiny change)
6077
6078 according to the debian patch tracker, this patch is by
6079 Florian Ernst <florian@debian.org>.
6080 It fixes whitespace issues in filename called from cmail.
6081
6082 2009-06-24 22:33:13 -0700 Arun Persaud <arun@nubati.net>:
6083 converted dos2unix format for xboard.texi
6084
6085 2009-06-24 22:31:57 -0700 Arun Persaud <arun@nubati.net>:
6086 deleted two more files that don't need to be in git
6087
6088 these files can be generated by autogen.sh
6089
6090 2009-06-21 12:10:31 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6091 major overhaul of the -stickyWindows feature
6092
6093 I did a major overhaul of the -stickyWindows feature.
6094 The game-list and ICS-interaction windows are now also sticky.
6095 I also added a form of stickiness when the main window is resized;
6096 edges of auxiliary windows sticking to the right or bottom side of
6097 the main window stay attached when the window resizes
6098 (due to nr of board squares or their size). The way the window
6099 coordinates are saved in the .ini file is now relative to the
6100 main window, and some dummy options are added to be able to
6101 recognize right- and bottom-edge sticking, and reconstruct that
6102 when WB starts up with another board size. Also added are
6103 volatile options to ensure there will be space for auxiliary windows
6104 above and left of the main window.
6105
6106 2009-06-21 12:07:01 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6107 fixed long-algebraic form of drops
6108
6109 The WB parser turned out not to understand the long-algebraic form
6110 of drops send by an ICS. (like B/@@-e4), so even with
6111 legality testing off I now use the SAN move for drops.
6112
6113 2009-06-18 18:35:31 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6114 Refined stalemate adjudication in Suicide, some cleanup
6115
6116 Refined stalemate adjudication in Suicide, which seems to be not always won
6117 for the stalemated side, but for the side with the smallest number of pieces.
6118 Cleaned up the adjudication code in the process. (backend.c moves.c, moves.h)
6119 Also includes a tiny change in the -autoKibitz format, as requested on
6120 Talkchess.
6121
6122 2009-06-18 18:32:57 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6123 Enhancement of the way -autoLogo decides which logos to display
6124
6125 2009-06-16 00:06:59 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6126 bugfix and enhancement in autoKibitz mode
6127
6128 changed the format of the autoKibitz: score/depth in stead of depth/score,
6129 as in PGN. I also supress the ICS time for the move now in the PGN
6130 if extended info is available. When enhancing the functionality of
6131 the autoKibitz command (using the opponent engine kibitz for the saved PGN)
6132 I discovered that the xengineoutput.c in our tree was obsolete,
6133 and contained a routine of which the arguments were no longer compatble
6134 with the call from backend.c, and caused segfaulting. I copied in
6135 the  corresponding routine in wengineo.c, which was compatible. That the
6136 compiler did not flag this is a sign of badly organized code, I suppose...
6137
6138 The enhancement itself affected backend.c.
6139
6140 2009-06-16 00:04:13 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6141 modified clock layout
6142
6143 I altered the display of the clocks in the presence of engine logos; I used to
6144 stack them, but some inquiry on Talkchess sowed that people disliked the
6145 stacking. So now I display them next to each other again, but as 2-line-high
6146 fields to make room for te logos.
6147
6148 2009-06-15 23:59:32 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6149 new zippy option zippyShortGame
6150
6151 On request of Mike Adams I added a new zippy option, -zippyShortGame,
6152 to make life more difficult for abusers of abort and disconnect for cheating.
6153
6154 2009-06-15 23:56:40 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6155 fixed some bugs in the animation of atomic captures
6156
6157 2009-06-13 15:27:26 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6158 some small bugfixes
6159
6160 I had overlooked one place from which the FEN writer
6161 (of whicf I changed the argument types), which made WB crash
6162 if you copied a FEN (or PGN that cotained FEN) to the clipboard.
6163 I must have overlooked a warning during compile, or some depedency
6164 is not correct in the makefile. Anyway, wclipboard.c had to be changed.
6165 I also moved adjudication of some losing conditions to before tetsing
6166 for stalemate, (e.g. in atomic, if your king get destroyd you lose,
6167 even if you have no moves after that because it was your only piece.).
6168 this affects backend.c.
6169 I had used the same bits in the rule-modifier flags for indicating
6170 mandatory capture as was already used for indicating FRC-style castling.
6171 This led to frequent illegal move calls in FRC... (moves.h)
6172
6173 2009-06-13 10:45:17 -0700 Arun Persaud <arun@nubati.net>:
6174 cleaned up HTML in FAQ.html -- still need to work on content
6175
6176 2009-06-13 09:36:26 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6177 added option for work-around for some FRC engines in regards to FRCFENs
6178
6179 It suddenly occurred to me that I had promised on CCC to include an option
6180 to provide a work-around for the problem that some FRC engines do not
6181 understand FRC FENs (and thus do not play at all under WinBoard,
6182 as FRC always has to begin with sending the initial position).
6183 So I added the options -firstNeedsNoncompliantFEN, -secondNeedsNoncompliantFEN.
6184 This affects winboard.c and xboard.c, (for defining the option),
6185 common.h, backend.h, backend.c, (for implementing it),
6186 xboard.texi and winboard.rtf (decribing it).
6187 This option provides users with a means to always force the FEN castling field
6188 to KQkq (but can be used for many other work-arounds as well).
6189
6190 2009-06-13 09:30:31 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6191 fixed bug with random calls
6192
6193 There also seemed to be a bug with the shuffling of opening positions;
6194 I had changed the declaration of the position number from
6195 long long int to u64 to comply with MSVC, but this suppressed shuffling
6196 completely. I now changed it to int. I recently noted a problem with true
6197 randomizing anyway: this was based on srand(time()), but time() apparently
6198 did not change fast enough, so that starting several games in rapid succession
6199 (because the book line contained a 3-fold repetition) produced identical games.
6200 So I now seed the random once and for all during startup, based on the msec of
6201 the time mark, and removed the other calls to srand().
6202
6203 2009-06-13 09:26:14 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6204 changed name for fairymax program in xboard.h
6205
6206 2009-06-13 09:25:07 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6207 removed my name from copyright message in help->about menu
6208
6209 2009-06-13 09:22:02 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6210 fixed -stickyWindows option
6211
6212 I figured out why -stickyWindows was not working in XP and Vista
6213 (while it always worked under Win2K), and I think I found a fix for
6214 it that works under all Windows versions. (I tried XP and Win2K.)
6215
6216 2009-06-13 09:20:38 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6217 Updated docs for Engine-Settings menu
6218
6219 2009-06-13 09:19:05 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6220 Awareness of winning conditions for atomic and giveaway variants; two bugfixes
6221
6222 fixed bug in claim verification
6223 Bugfix on initial position of Great Shatranj
6224
6225 2009-06-13 09:16:47 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6226 Legality testing (mandatory capture) in giveaway variants
6227
6228 2009-06-13 09:16:17 -0700 Arun Persaud <arun@nubati.net>:
6229 don't ignore winboard/parser.c
6230
6231 2009-06-13 09:12:15 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6232 Added new variant Twilight Chess
6233
6234 2009-06-13 09:08:57 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6235 some renaming and restructuring of WB menu items, to conform more to XBoard
6236
6237 2009-06-13 09:07:07 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6238 Fixed bug in atomic patch that interfered with non-atomic variants
6239
6240 2009-06-10 21:46:11 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6241 fixed different use of engine option compared to Polyglot
6242
6243 it turns out the new Polyglot uses a sightly different version
6244 of the GUI->engine option command than the one I proposed
6245 (and implemented in XBoard; Michel sneaked in an '=' sign
6246 between the NAME and VALUE of the option, to allow for
6247 more unambiguous parsing. I guess in principle this is a good idea,
6248 so I adapted XBoard to Polyglot rather than the other way around.
6249 The result is that there are canges in xboard.c, and the documentation.
6250 I noticed that I unjustly had internationalized the option strings
6251 to be send to the engine in xoptions.c; this was of course nonsense,
6252 as this was WB protocol. So I undid that too.
6253
6254 2009-06-10 21:37:47 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6255 add the already supported variants 3check and great (=Great Shatranj)
6256 to the New Variant... menu.
6257
6258 2009-06-10 21:32:22 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6259 animate explosions in variant atomic (if animate moves is on).
6260
6261 2009-06-10 21:30:19 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6262 fixed castling bug in variant twokings.
6263
6264 2009-06-10 21:22:36 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6265 fixed forteitary wins for special game variations
6266
6267 feature that corrects forfeitary wins (e.g. on time)
6268 of a bare King to draws of course breaks proper operation
6269 in losers, suicide and giveaway
6270
6271 2009-06-09 21:02:51 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6272 automatically test ini file extension for files from commandline option @filename
6273
6274 The winboard.c is a patch that automatically tries indirection files on the
6275 command line (@filename type arguments) also with an extension .ini if the name itself
6276 did not match any existing file and contained no period. This saves the user typing the
6277 .ini all the time (which I started to find pretty annoying while working on the installer
6278 package).
6279
6280 2009-06-08 15:23:58 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6281 added gamelisttag option to xboard
6282
6283 also updated documentation.
6284
6285 2009-06-08 15:20:00 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6286 updated RTF file for winboard
6287
6288 2009-06-06 09:12:48 -0700 Arun Persaud <arun@nubati.net>:
6289 fixed syntax error in texi file
6290
6291 2009-06-06 08:57:52 -0700 Arun Persaud <arun@nubati.net>:
6292 updated to patchlevel "j"
6293
6294 2009-06-06 09:00:25 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6295 fixed adjudicating probelm in Shantranj
6296
6297 Refrain from adjudicating a draw based on insufficient mating material
6298 (except bare King vs bare King) in Shatranj (where in this case you can
6299 still win by baring the opponent's King).
6300
6301 2009-06-06 08:55:17 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6302 updated documentation and FAQ
6303
6304 2009-06-04 22:52:31 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6305 source clean up. Fix compiler warning, removed unused variables, etc.
6306
6307 2009-06-04 20:43:29 -0700 Eric Mullins <emwine at earthlink.net>:
6308 adding support for different windows compiler
6309
6310 Eric kindly provided us with some makefiles for different windows
6311 compiler and also fixed some issues that came up while using those compilers.
6312
6313 2009-06-04 18:27:26 -0700 Arun Persaud <arun@nubati.net>:
6314 cleanup: got rid of a lot of files that are not needed for a new release
6315
6316 lots of documentation was available in several places,
6317 old unused source files and not used graphics file were floating around
6318 in the tree. This should clean up most of it. No need to keep these files
6319 around, especially since we are using version control.
6320
6321 2009-05-29 18:56:06 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6322 Added the Action-menu items that allow the user to adjudicate
6323 ongoing games in Two-Machines mode. This was an already existing
6324 backend function from Winboard_x; I only had to create a menu item for it
6325 to be called. Due to an oversight I had forgotten to do that so far.
6326 (Logically, I should have done it in the 4.3.5 release,
6327 where I updated the XBoard menus to conform to the WinBoard menus.)
6328
6329 I tested them, and they seem to work. (As expected.)
6330
6331 2009-05-28 22:23:00 -0700 Arun Persaud <arun@nubati.net>:
6332 updated patchlevel to "i"
6333
6334 2009-05-28 22:19:08 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6335 small change to mousewheel support; two changes in window behaviour
6336
6337 * Visible effects during resizing suppressed, bug in chosing new size fixed.
6338 * No longer reserves left and top margins next to main window on first popup.
6339 * built in some hysteresis into mousewheel support, ignorng the first event in any new
6340 direction to suppress effects from accidential mouse movement.
6341
6342 2009-05-28 22:11:11 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6343 corrected 'animate dragging'
6344
6345 I finally figured out how the 'animate dragging' works in XBoard,
6346 so that I could add code to do the unstacking of multiple pieces
6347 in the holdings, rather than always leaving an empty square while
6348 you drag them. (And then suddenly re-growing the remaining pieces
6349 as you make the drop.)  It does not look as fancy as in WinBoard
6350 yet, because the counts still only decrease when you release the
6351 piece, rather than when you lift it. But this is not nearly as
6352 disturbing as leaving empty holdings (if only temporarily) when
6353 you still have pieces there.
6354
6355 2009-05-28 22:06:15 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6356 Added comand-line options -debugFile (as synonym for -nameOfDebugFile,
6357 as WinBoard also has these synonyms), and -engineDebugOutput
6358 (wich already existed in the backend).
6359
6360 2009-05-28 21:57:53 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6361 updated documentation for new release
6362
6363 2009-05-28 21:55:51 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6364 added Xiangqi perpetual-chase detection
6365
6366 2009-05-28 00:06:53 -0700 Arun Persaud <arun@nubati.net>:
6367 Updated all files to GPL version 3.
6368
6369 2009-05-28 00:03:32 -0700 Arun Persaud <arun@nubati.net>:
6370 converted two files from dos to unix format
6371
6372 2009-05-27 23:12:24 -0700 Arun Persaud <arun@nubati.net>:
6373 updated INSTALL, NEWS and other files for new release
6374
6375 cleaned up a bit and updated some information in the text files.
6376
6377 2009-05-07 21:48:23 -0700 Arun Persaud <arun@nubati.net>:
6378 winboard/config.h shouldn't be in .gitignore, only ./config.h
6379
6380 2009-05-07 21:47:37 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6381 bumped patchlevel to 0g
6382
6383 2009-05-07 21:46:02 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6384 corrected path in makefile
6385
6386 2009-05-07 21:45:48 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6387 updated rtf
6388
6389 2009-05-07 21:45:25 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6390 added firstOptions, secondOptions, noGUI, firstXBook, secondXBook
6391
6392 2009-05-07 21:44:03 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6393 handle promotion case for Shogi
6394
6395 2009-05-07 21:43:34 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6396 add note about RESULT command for GUI programmers
6397
6398 2009-05-07 21:42:37 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6399 small changes to book.c
6400
6401  added code for different board sizes
6402  added some debuginfo
6403  handle promotion of pieces
6404
6405 2009-05-05 23:07:18 -0700 Arun Persaud <arun@nubati.net>:
6406 added a .gitignore file
6407
6408 2009-05-03 12:41:06 -0700 Arun Persaud <arun@nubati.net>:
6409 wrong line ending for Unix... ran dos2unix on both files
6410
6411 2009-05-02 13:51:50 -0700 Arun Persaud <arun@nubati.net>:
6412 fixed texinfo files, added windows help file, removed config.h from git
6413
6414 texinfo.in is not needed anymore, since it only provided a
6415 version string, but this can be created automatically using autotools
6416
6417 deleted config.h from version control, since it is automatically created.
6418 added winboard.hlp file (not sure if needed)
6419
6420 2009-04-26 23:34:34 -0700 Arun Persaud <arun@nubati.net>:
6421 updated autoconf init file
6422
6423 * renamed autoconf init file from configure.in to configure.ac
6424 * added bug-report email address to ac_init
6425 * replaced ac_output(...) with ac_config_files, ac_config_commands and ac_output
6426
6427 2009-04-26 14:49:03 -0700 Arun Persaud <arun@nubati.net>:
6428 parser.c is generated by lex, so it shouldn't be tracked
6429 and also parcer.c shouldn't be in Makefile.am
6430
6431 2009-04-26 14:44:51 -0700 Arun Persaud <arun@nubati.net>:
6432 added book.c to Makefile.am
6433
6434 2009-04-26 13:49:15 -0700 Arun Persaud <arun@nubati.net>:
6435 use autoheader to create config.h.in
6436
6437 no need to track this in git anymore
6438
6439 2009-04-26 11:13:26 -0700 Arun Persaud <arun@nubati.net>:
6440 fixed autoheader warings, remove depreciated acconfig.h
6441
6442 2009-04-26 10:30:23 -0700 Arun Persaud <arun@nubati.net>:
6443 added a autogen.sh
6444
6445 2009-05-02 10:55:39 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6446 changes from H.G. Muller; version 4.3.16
6447
6448 2009-05-02 10:50:10 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6449 changes from H.G. Muller; version 4.3.15
6450
6451 2009-05-02 10:38:39 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6452 changes from H.G. Muller; version 4.3.14
6453
6454 2009-05-02 10:13:41 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6455 HGM fixed cygwin compile for winboard
6456
6457 2009-04-24 16:11:57 -0700 Arun Persaud <arun@nubati.net>:
6458 cross compilier working
6459
6460 2009-04-19 10:00:52 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6461 changes from H.G. Muller; version 4.3.13
6462
6463 2009-04-19 09:52:47 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6464 changes from H.G. Muller; version 4.3.12
6465
6466 2009-04-19 09:48:59 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6467 changes from H.G. Muller; version 4.3.8
6468
6469 2009-04-19 09:44:15 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6470 changes from H.G. Muller; version 4.3.7
6471
6472 2009-04-19 09:39:19 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6473 changes by H.G. Muller; version 4.3.4
6474
6475 2009-04-19 09:34:31 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6476 changes from H.G. Muller; version 4.3.2
6477
6478 2009-04-19 10:26:24 -0700 H.G. Muller <h.g.muller@hccnet.nl>:
6479 changes from H.G. Muller
6480
6481 2009-04-16 23:06:13 -0700 Arun Persaud <arun@nubati.net>:
6482 cleaned up the directory a bit. Removed winboard-dm-beta,
6483 merged the two Changelogs together
6484
6485 2009-04-16 14:12:48 -0700 A. Scotti <dev@ascotti.org>:
6486 changes from Alessandro Scotti from 20060129
6487
6488 2009-04-16 14:09:33 -0700 A. Scotti <dev@ascotti.org>:
6489 changes from Alessandro Scotti from 20060112
6490
6491 2009-04-16 14:04:02 -0700 A. Scotti <dev@ascotti.org>:
6492 changes from Alessandro Scotti from 20051231
6493
6494 2009-04-16 13:59:12 -0700 A. Scotti <dev@ascotti.org>:
6495 changes from Alessandro Scotti from 20051129
6496
6497 2009-04-16 13:53:41 -0700 A. Scotti <dev@ascotti.org>:
6498 changes from Alessandro Scotti from 20050322
6499
6500 2009-04-10 04:18:59 +0000 Arun Persaud <arun@nubati.net>:
6501 translated a handfull of strings and set the codeset to UTF-8
6502 for the translations.
6503
6504 2009-03-18 03:20:50 +0000 Arun Persaud <arun@nubati.net>:
6505 Translation: added German po file (roughly 50% translated)
6506
6507 2009-03-01 04:23:54 +0000 Arun Persaud <arun@nubati.net>:
6508 fixed bug #22853: changed all .Xdefaults to .Xresources in xboard.texi
6509
6510 2009-03-01 02:43:43 +0000 Arun Persaud <arun@nubati.net>:
6511 fixed bug #25672, patch #6182 by adding DESTDIR support to Makefile.in
6512
6513 2009-03-01 02:33:26 +0000 Arun Persaud <arun@nubati.net>:
6514 fixed a warning message in the configure script
6515
6516 2009-02-28 22:58:57 +0000 Arun Persaud <arun@nubati.net>:
6517 fixed parser.l. Should fix bug #22812
6518
6519 2009-02-28 22:58:14 +0000 Arun Persaud <arun@nubati.net>:
6520 fixed parser.l. Should fix bug #22812
6521
6522 2009-02-28 22:55:30 +0000 Arun Persaud <arun@nubati.net>:
6523 added myself to the AUTHOR file
6524
6525 2007-06-15 04:26:57 +0000 Mark Loli <chessknight>:
6526 Initial check-in of NSIS Winboard installer files.
6527
6528 * 06/12/2005: bugfix some more possible buffer overflows.
6529
6530 * 06/27/2004: added simple icsEngineAnalyze for xboard
6531
6532 * 06/26/2004: added icsEngineAnalyze for winboard: Analyze observe games
6533 with a chessprogram on a Internet Chess Server (ICS)
6534
6535 * 02/12/2004: Bugfix ICS interaction console crashed while chess
6536 engine starting and user type in some stuff. We wait now to finish
6537 the engine boot.
6538
6539 * 02/11/2004: Winboard: Added color lines for the ics interaction
6540 console if zippy used
6541
6542 * 02/09/2004: Added mousewheel support for winboard. Play moves
6543 backward and forward with the mousewheel.
6544
6545 xboard/WinBoard 4.2.7 -- Fri Nov 28 13:36:00 PST 2003 -- Tim Mann
6546
6547 * 11/26/2003: In WinBoard, setting the -debug flag now logs ICS output
6548 to WinBoard.debug too.  (This isn't needed in xboard because ICS
6549 output already goes to stdout, so it's easy to capture along with the
6550 debug output on stderr.)  This was issue #280 in the ToDo file.
6551
6552 * 11/23/2003: Cleaned up some minor problems in cygwin.mak.  Thanks to
6553 Hans Werner Strube for the problem report.
6554
6555 * 11/23/2003: Updated the default list of chess servers in
6556 winboard/defaults.h.  Deleted two that appear to be dead and added a
6557 new one that is active.
6558
6559 * 11/19/2003: Swapped icon_white.bm and icon_black.bm in XBoard.
6560 Hopefully this will get them the right way around by default on more X
6561 window managers.  I wish I understood this better.
6562
6563 * 11/18/2003: Implemented a simple 32-bit random number generator for
6564 WinBoard, replacing the Windows rand(), which ranges only up to
6565 0x7fff.  Formerly on Windows, only zippy.lines sayings that started in
6566 the first 32767 bytes of the file could ever be used.  This was issue
6567 #505 from the ToDo file.
6568
6569 * 11/16/2003: The xboard man page and info files are now built from a
6570 common set of texinfo source files, and the xboard man page now covers
6571 cmail as well.  Formerly, ever since the texinfo file was first
6572 contributed to the project, it was separate from the man page and the
6573 two files had to be updated in parallel, making for a maintenance
6574 nightmare.  To make combining the files possible, I took the Perl
6575 script "texi2man" from the GNU Units project and added support for a
6576 larger subset of the texinfo markup language.  I then carefully
6577 compared the old man page and old texinfo file to make sure the latest
6578 and clearest words survived into the new combined texinfo file.  It
6579 would be great to merge in WinBoard's help file too, but that's a
6580 larger project.  It would have to be heavily conditionalized to
6581 deal with differences in features between XBoard and WinBoard.
6582
6583 * 11/15/2003: Cleaned up and applied a small patch from Daniel
6584 Mehrmann, to stop overly long PVs in thinking output from causing a
6585 buffer overflow crash in backend.c.
6586
6587 * 11/5/2003: When a chess engine sends a "telluser" command (including
6588 the cases where "tellall" or "tellopponent" acts like telluser), the
6589 information now goes into a nonmodel popup that is automatically
6590 dismissed when the user clicks anywhere on the board.  This fix is
6591 more significant on WinBoard, where formerly you got a fully modal
6592 dialog that had to be dismissed by clicking on OK before anything else
6593 could happen.  The bug was issue #406 in the ToDo file.
6594
6595 * 11/1/2003: Removed email addresses from this file to reduce spam
6596 load, as it gets linked to from the Web.
6597
6598 * 11/1/2003: Updated READ_ME and winboard/READ_ME.txt.
6599
6600 * Modified xboard and winboard makefiles to be able to build the
6601 project in the new combined directory structure.
6602
6603 * Applied a small security fix to pxboard, from Martin Maeok.
6604
6605 * Fixed a bug in the game list dialog.  The change in 4.2.6 to opening
6606 games in text mode (meant to avoid getting extra \r's into comments)
6607 caused a new bug in determining seek offsets when parsing a game file
6608 to form the game list.  Also, the change was incomplete; on some code
6609 paths games were still being opened in binary mode.  Thanks to Lenik
6610 Terenin for reporting the offset bug.  I've now gone back to always
6611 using binary mode when reading game files, and I've fixed the comment
6612 bug by adding code to remove \r's from parsed comments explicitly.  I
6613 still use text mode for writing game files so that games written by
6614 WinBoard will have Windows-style line endings.
6615
6616 * Fix for minor bug in WinBoard installer.  If you chose a non-default
6617 destination directory, the default directory was still used for a
6618 couple of unimportant things, namely setting the App Paths registry
6619 keys (unused by WinBoard) and trying to copy the existing WinBoard.ini
6620 file to WinBoard.old.  I inherited this bug from the InstallShield 5
6621 sample template.  Thanks to "l.d." for noticing the incorrect keys.
6622
6623 * Patch from Chris Priest: when two engines are being run through rsh,
6624 avoid reusing the same stderr port for both.  I'm not sure why this
6625 should be needed, but it's harmless, at least.
6626
6627 * Bugfix: The kludge to deal with old engines that give an error
6628 message because they don't know the "st" command was too sloppy; it
6629 could hit on an "st" substring anywhere in an error message.  GNU
6630 Chess 4 is the only engine I know of where the kludge was needed, so I
6631 changed the kludge to match a longer, more GNU-specific string.
6632
6633 * Changed the WinBoard self-extracting installer to choose a unique
6634 temporary subdirectory name within the Windows temp directory instead
6635 of always putting wb-setup directly in temp.  Besides being better
6636 practice, this avoids the need to deltree wb-setup first, which
6637 occasionally alarms someone who thinks that deltree is only used by
6638 trojans to delete all your files.  (Yes, I'm serious.)
6639
6640 * Fixed a bug where FICS-style "wild/0" strings were not parsed as the
6641 proper wild type.  The "/" was not being skipped.
6642
6643 * Fixed a WinBoard bug where temporary files created by game
6644 copy/paste were being created in the root directory of the current
6645 drive instead of the TMP directory and were not always deleted on exit.
6646
6647 * Fixed a small bug in winboard.c's ErrorDialog() function.  Thanks to
6648 "Ron" (no last name given).  The bug might have caused a problem when
6649 pressing OK or Cancel in an error dialog when more than one error
6650 dialog was being displayed, but I'm not really sure.
6651
6652 * Removed a hack that worked around a bug in very old versions of
6653 Crafty, where it would sometimes reply "illegal move" to a "."
6654 command.  The hack kept us from recognizing real illegal move messages
6655 in analyze mode from engines that don't respond to the "." command.
6656 Thanks to Fabien Letouzey for the report.
6657
6658 * Fixed a bug in the xboard version of GetDelayedEvent.  It would
6659 return the most recently scheduled event even if it had already fired.
6660 This caused at least one visible error: in -ics -xreuse mode, starting
6661 the engine again and seeing another "feature done=1" would re-run the
6662 initialization code in InitBackEnd3, including the code that opens the
6663 connection to ICS.  The WinBoard version didn't have this bug.  Thanks
6664 to Bob Hyatt for the bug report.
6665
6666 * The promotion popup for ICC wild 26 (giveaway) now includes King.
6667 Thanks to Fredrik Josefsson for the bug report.
6668
6669 * The first game in a file (or being pasted from the clipboard) can
6670 now start with a bare move -- no PGN tags, no move number "1", etc.
6671 Suggested by Shane Harrelson.  One could imagine taking this farther
6672 and accepting something like "e4 e5 1/2-1/2 d4 d5" as two games, but
6673 I haven't done that.
6674
6675 * Bug fix: xboard didn't really accept a paste of multiple games,
6676 contrary to what I wrote when adding the feature to WinBoard in
6677 4.2.4.  Now it works in both.
6678
6679 * Fixed generic start/end of game messages to work on chess.net, where
6680 they put ratings in parens after the player names.
6681
6682 * Updated config.sub and config.guess to newer versions from
6683 automake-1.4p5-2.  This makes configure work with MacOS X + X11.
6684
6685 * Bugfix: when examining a game fragment on FICS where black plays
6686 first, don't show two "(0:00.000)" times on the initial "none" move.
6687
6688 * If TestLegality is on and one of the engines makes an illegal move
6689 in TwoMachines mode, it forfeits immediately.  Formerly the game would
6690 get stuck at that point and the engine that made the illegal move
6691 would eventually lose on time.
6692
6693 xboard/WinBoard 4.2.6 -- Fri Feb  1 22:26:31 PST 2002
6694 Tim Mann
6695
6696 Another small bugfix release.
6697
6698 * Put in a small change from Alexander Mai to allow xboard to build in
6699 an OS/2 EMX environment.
6700
6701 * Fix WinBoard-only bug where editing a PGN file with comments would
6702 insert more \r characters before the \n after every Load/Save cycle.
6703 For some unknown reason we were reading the files in "rb" mode but
6704 writing them in "a" mode, so we kept the \r characters on reading and
6705 added an extra one on writing.  Fix: change the "rb" to "r".  Thanks
6706 to Joel (last name not given) for the bug report.
6707
6708 * Put the arguments to rsh/remsh in the right order for better
6709 portability.  Thanks to Michael Kalisz.
6710
6711 * FreezeUI is now implemented in WinBoard; it was previously only
6712 implemented in xboard.  This function prevents the user from entering
6713 moves or other commands while we are waiting for an engine to
6714 initialize itself.  Implementing it fixes a bug where the user could
6715 start a game (etc.) during feature negotiation.  One of the symptoms
6716 of this bug was that we could send "new" one or move moves *after* the
6717 first game started!
6718
6719 * Fixed some handle leaks (WinBoard only), including a nasty one that
6720 leaked one handle per command sent to ICS.  Thanks to several folks
6721 who helped characterize the bug and tried to look for leaks.
6722
6723 * We now install and look for the info file in ${prefix}/share/info
6724 instead of ${prefix}/info.  The latter is still the default in
6725 autoconf, but the former is currently used in Red Hat Linux and
6726 probably elsewhere.
6727
6728 xboard/WinBoard 4.2.5 -- Sat Dec 15 11:42:51 PST 2001
6729 Tim Mann
6730
6731 * Changed the bundled GNU Chess 5.02 in the WinBoard package to
6732 include a much smaller book and to use much less hash table space by
6733 default (8 MB transposition table, 0.5 MB pawn evaluation table).  The
6734 large book included with 4.2.4 made the WinBoard download too big for
6735 some people, and the default hash tables were larger than the
6736 available physical memory on some people's computers. I built the
6737 small book by running Crafty's "small.zip" book line collection
6738 through a Perl script that makes it look enough like real PGN games
6739 that the GNU Chess book builder will accept it.  The script and some
6740 minor patches to GNU Chess 5 are available in the WinBoard source
6741 distribution and at http://www.tim-mann.org/gnuchess.html.
6742
6743 * Fixed a bug in the code that deals with engines that complain that
6744 "time" and "otim" are illegal moves.  This was a new bug in 4.2.4.
6745
6746 * Revamped the implementation of ToStart in analysis mode.  Formerly
6747 there was some ill-conceived code that would try to get back to the
6748 start of the game by doing a "new" command (and all the followup
6749 commands that requires) while remaining in analysis mode.  This is
6750 problematic for engine authors to support, though it works with
6751 Crafty.  This code was trying to solve the problem of ToStart being
6752 slow because the engine would try to start an analysis after every
6753 "undo" command all the way back to the start.  But ToEnd already had a
6754 much better solution to this problem, and now ToStart does the same
6755 thing: we exit from analysis mode and enter force mode instead,
6756 make/unmake moves to get to the end/start of the game, and then
6757 reenter analysis mode.
6758
6759 * Formerly, Zippy could try to start playing a game before the engine
6760 was initialized; that is, during the initial timeout for protover 1
6761 engines, or before "feature done=1" for protover 2 engines.  We now
6762 wait until the engine is initialized before connecting to ICS, which
6763 fixes this in the common case.  If you turn off engine reuse for
6764 multiple games (that is, if you give the -xreuse option), there could
6765 still be problems; see item 503 in the ToDo file.  Thanks to Dieter
6766 Buerssner for the bug report.
6767
6768 * Bugfix: All WinBoard versions since the merge with WinBoard Plus
6769 (but not xboard) have had a bug in changing the PeriodicUpdates,
6770 PonderNextMove, and ShowThinking options from the menu.  The bug
6771 mostly just caused changing these options during a game to not take
6772 effect until after the next reset.  For TwoMachines games, though,
6773 changing PonderNextMove just before the game would take effect
6774 immediately for the second engine but not until the next game for the
6775 first engine.  Thanks to Koundinya Veluri for the bug report.
6776
6777 * Bugfix: In 4.2.4, we sometimes got confused when trying to leave and
6778 reenter analyze mode.  One symptom was that Analyze File did not work.
6779 Thanks to Igor Syry for the bug report.
6780
6781 xboard/WinBoard 4.2.4 -- Sun Dec  9 14:56:30 PST 2001
6782 Tim Mann
6783
6784 * WinBoard now includes GNU Chess 5.02 in place of GNU Chess 5.00.
6785
6786 * WinBoard's PasteGameFromClipboard will now handle a paste with
6787 multiple games in it, popping up the game list dialog.  xboard
6788 already did this.  Suggested by Robert Gerstman.
6789
6790 * We now use the "clearboard" command on ICC where appropriate.
6791
6792 * Bugfix: don't generate a bogus "variant normal" command to an engine
6793 for the loadable ICC wild types that we internally flag as
6794 VariantLoadable.  Also clarified the message that Zippy sends when
6795 declining such wild games -- it can't deal with the possibility of
6796 loading an arbitrary position into the game.  Thanks to Dieter
6797 Buerssner for reporting the problem.  It would be nice to be able to
6798 actually play these wild types some day; presumably there would have
6799 to be an option to either send "loadgame" with a specified position,
6800 or to deal with an opponent sending it.
6801
6802 * If we get a holdings message from ICS when we thought we were
6803 playing normal chess, we now try asking for a move list so that we can
6804 find out from the header what's really happening.  Formerly we guessed
6805 bughouse in this case.  Response to a comment from Gian-Carlo
6806 Pascutto.
6807
6808 * Fixed two longstanding bugs in the clock code.  These affected only
6809 play between a user and a local engine, or between two local engines,
6810 not ICS play.  (1) The last fractional second used by a player before
6811 moving and virtually pushing his clock was being charged to his
6812 opponent instead of to him.  (2) The time and otim commands were being
6813 sent to an engine before the (buggy) fractional second update was
6814 done.  The second bug was pretty harmless in itself, but the first one
6815 was serious.  Many thanks to Peter Rosendahl for carefully diagnosing
6816 and reporting these bugs!
6817
6818 * Changed WinBoard timestamp key.  Nothing is changed other than the
6819 key and a recompilation.  ICC may phase out the old key soon; if they
6820 do, you'll need to use the timestamp.exe from WinBoard 4.2.4 or later
6821 to connect to chessclub.com.
6822
6823 * Fixed an xboard-only bug where most dialogs would not take keyboard
6824 input unless the mouse was actually over the dialog, even if the
6825 dialog window had focus.  Thanks to Jason Varsoke for the bug report.
6826
6827 * Bugfix; Remember to send time and otim commands to engine before
6828 sending playother.  Thanks to Bob Hyatt for the bug report.  Also
6829 fixed a bug where time and otim were sometimes sent even with feature
6830 time=0.
6831
6832 * Added small patches from Wilkin Ng that are meant to fix a crash in
6833 CopyGameToClipboard and a "can't unlock clipboard memory" error in
6834 PasteTextFromClipboard, under Windows 2000.
6835
6836 * Changed cygwin.mak to not use -mno-cygwin.  In other words, it now
6837 uses cygwin1.dll instead of the mingw libraries.  This works around
6838 bugs in fileno() and stat() that I encountered in mingw.  (fileno
6839 seems to always return 0.  stat fails because the library routine uses
6840 a different definition of struct stat than the header files provide.)
6841 Thanks to Robert Gerstman for reporting the symptoms these bugs caused
6842 when WinBoard was compiled with Cygwin.
6843
6844 * Added -showButtonBar option.  This lets you delete the << < P > >>
6845 buttons and thus widen the message widget a bit.
6846
6847 * Added code to address a very obscure bug.  If an engine dies and
6848 needs to be restarted while in one of the analyze modes, it was not
6849 getting put back into analyze mode.  This bug should not really ever
6850 have gotten tickled unless reuse was turned off and the engine sends
6851 game end commands (such as 1-0) when a game ends by rule while in
6852 analyze mode.  The next version of the protocol spec will say that
6853 engines should not do that, but version 2 and earlier didn't address
6854 the issue.
6855
6856 * We now use the FICS "iset ms 1" feature to get times in ms instead
6857 of seconds.  Thanks to DAV for email telling me about this feature.
6858
6859 * Changed clock display to show tenths of seconds for 9.9 seconds and
6860 less, instead of 0.9 seconds and less as before.
6861
6862 * It has been discovered that Zippy can play simuls on ICC (but not on
6863 FICS).  If you arrange for Zippy to send the ICC command "simulize" in
6864 the -zippyGameStart string, it will accept additional games while
6865 playing.  Zippy will use the same engine for every game, so whenever
6866 it switches opponents, the engine's state will be reset with the "new"
6867 command.  This will of course weaken its play, so don't enable simuls
6868 if you want your engine to have the highest possible rating.  Zippy
6869 was never designed to work with simuls; it just works by accident, and
6870 it hasn't been tested much.  So please report any bugs you notice, but
6871 don't expect them to be fixed rapidly.  Thanks to Paul McGuire for
6872 noticing that this works.
6873
6874 * Bugfix: Suppress the direct command to engine popup if there is no
6875 engine.  In WinBoard this case used to cause a crash.  Thanks to
6876 "Dargon" for the bug report.
6877
6878 * Bugfix: formerly we did part of the engine initialization for the
6879 very first game too soon, before feature negotiation.  One result of
6880 this is that engines would never get the "ics" command for the first
6881 game.
6882
6883 * Lengthened timeout to detect protocol version 1 chess engines to 10
6884 seconds.  This should reduce problems with protocol version 2 engines
6885 that are slow to initialize missing the timeout and not getting a
6886 chance to send their feature commands before the first game starts.
6887
6888 * Klaus Friedel says that adding a short sleep to WinBoard after
6889 starting a new chess engine solves a problem that occurs under Windows
6890 2000, in which engines sometimes don't see the initial command(s) from
6891 WinBoard and hang.  I don't understand how that can happen, but the
6892 sleep is harmless, so I've put it in.  Others have also reported what
6893 may be the same problem, so hopefully this will fix it for them too.
6894
6895 * Bugfix: editing the Result field in EditTags will no longer cause a
6896 later crash.  Thanks to DAV for a clear bug report that let me
6897 reproduce the problem.
6898
6899 * ICC wild 28 is now recognized as shatranj, but it is not supported.
6900 You might be able to play it by turning off Test Legality.
6901
6902 * Formerly we would always turn off "feature time" if the engine
6903 printed an error message with the string "time" or "otim" in it; now
6904 we do that only if the message comes before the engine makes its first
6905 move.  This change is useful because some engines spew a lot of bogus
6906 error messages about commands they don't fully parse, so something
6907 like "result 0-1 {White lost on time}" could generate such a message.
6908 Engines shouldn't do that, but if they do, mysteriously turning off
6909 "feature time" is not a good way to react.
6910
6911 * Fixed an infrequently occurring Zippy bug: formerly, resuming from
6912 adjournment by position (that is, with GetMoveList turned off) or
6913 starting/resuming a wild game (nonstandard starting position) would
6914 try to set up the position without putting the engine into force mode
6915 first.  That was probably tolerated by most engines, but if the
6916 position was black-to-play and the engine hadn't set feature
6917 setboard=1, then the fake "a2a3" move (which we use as a kludge to get
6918 black to be on move before sending the edit command) would appear to
6919 be a real move, and the engine might reply to it!  This bug could also
6920 be seen when trying to use Zippy to play a simul -- something that
6921 Zippy was never designed to support, but which seems to mostly work
6922 anyway.  Thanks to Paul McGuire for sending a WinBoard.debug file that
6923 showed the bug occurring.  Some other cases of resuming adjournments
6924 or starting games from nonstandard positions may have been broken too;
6925 I think I've straightened out the problems.
6926
6927 * Agreeing to a draw in the human vs. local engine case formerly did
6928 not work if the human offered first; now it does.  A human's
6929 unsolicited offer is considered valid until he makes another move.
6930 Thanks to Bruce Moreland for the bug report.
6931
6932 * Bugfix: We used to look for just "fr" in Event tags or strings from
6933 ICSes to recognize Fischer Random games.  This caused a lot of false
6934 matches.  Now we look for "wild/fr" instead, which is what FICS uses.
6935
6936 * Bugfix: Clicking on a move in the MoveList window only updated the
6937 displayed position; if a chess engine was active, its state was not
6938 updated.  Thanks to Alejandro Dubrovsky for the bug report.
6939
6940 * Bugfix: The "resign" command from engine to xboard formerly did not
6941 work in ICS (Zippy) mode.
6942
6943 * Bugfix: Formerly we would register a garbage premove if the user
6944 clicked on a piece, then clicked on an edge or outside the board.  Now
6945 such an errant click is ignored.
6946
6947 * Bugfix: GameEnds would send "exit" to an engine in analyze mode even
6948 if we did not actually want to leave analyze mode.
6949
6950 * Bugfix: "feature pause" was being rejected.  We don't currently use
6951 it, but that is no reason to reject it.  Thanks to Gian-Carlo Pascutto
6952 for the bug report.
6953
6954 * Bugfix: when "partner" needed to be sent both to ICS and the engine,
6955 Zippy was erroneously sending the ICS prefix character to the engine
6956 too.  Thanks to Gian-Carlo Pascutto for the bug report.
6957
6958 * Zippy now declines challenges when the engine is not yet ready to
6959 play again, instead of ignoring them.  This is needed so that the
6960 server will let the opponent repeat the challenge.  It might be better
6961 to remember such challenges and accept them when the engine is ready,
6962 but that would be a bit more complicated to implement.
6963
6964 * Bugfix: Zippy's emotes didn't work on FICS because there, "i" is a
6965 built-in alias for "it", not a real command.  So sending "$i foo" gave
6966 an error message instead of doing "it foo".  We now leave out the
6967 alias-suppressing prefix for emotes.
6968
6969 xboard/WinBoard 4.2.3 -- Mon Feb 19 19:55:05 PST 2001
6970 Tim Mann
6971
6972 * Bugfix: The error message "Variant X not supported by gnuchessx"
6973 formerly could pop up even in -ncp mode.
6974
6975 * Fixed an xboard bug in premove highlighting.  If you had
6976 HighlightLastMove turned on, premoves got highlighted in
6977 highlightSquareColor (yellow) instead of premoveHighlightColor (red).
6978
6979 * Modified premove again.  Now we are back to displaying the move
6980 locally immediately after sending it to the server, as in versions
6981 prior to 4.2.1.  This is good because it lets you register your next
6982 premove sooner.  As a better fix to the problem that the change in
6983 4.2.1 had been trying to address, we now suppress animating the
6984 opponent's move if you have a premove reply pending.  However, it's
6985 probably still a good idea for you to turn off AnimateMoves entirely
6986 if you are trying to play extremely fast games.
6987
6988 * Removed an erroneous patch that left zombie chess engines around
6989 when both sigterm and reuse were turned off.  (Bug was in xboard only,
6990 not winboard.)
6991
6992 * Bugfix: loading a game with autostepping did not work for games with
6993 PGN result "*" (unfinished).  This bug was introduced in 4.1.0, caused
6994 by some outdated code that was supposed to leave you in EditGame mode
6995 after loading an unfinished game.  I fixed this, and also changed it
6996 to leave you in EditGame mode after loading *any* game, but without
6997 changing the tags to say it's an edited game.  It's not really clear
6998 whether that is the best thing is to do here -- ideally, perhaps, the
6999 tags should change to say "edited game" if you actually make any
7000 changes, but that is harder to make work.
7001
7002 xboard/WinBoard 4.2.2 -- Tue Feb  6 20:00:00 PST 2001
7003 Tim Mann
7004
7005 * Fixed a problem introduced in 4.2.1.  In -zippyPlay mode, 4.2.1
7006 started sending the initString immediately after the old game ended,
7007 but then when the next game started, it would still send "force" and
7008 another initString.  Another problem was that the first initString put
7009 the engine out of sync with the displayed board position, though that
7010 might not usually have been noticeable.  This is now changed to do a
7011 full Reset at the end of the previous game, and avoid doing a Reset at
7012 the start of a new game if we are still in BeginningOfGame mode.
7013
7014 * Fixed some limitations in -zippyPlay mode.  The engine was not being
7015 fed the moves or history of games that were displayed but not being
7016 played, so it would get confused if you tried to do something like
7017 examine a game, then enter EditGame mode from somewhere in the middle
7018 of the game.
7019
7020 * Made a small change so that cygwin can compile xboard for Windows
7021 (an X server is required to run it).  Thanks to Volker Zell.  Most
7022 people would probably prefer to run WinBoard on Windows, however; note
7023 that cygwin could already compile WinBoard.
7024
7025 * Added some missing documentation to engine-intf.html: It is okay to
7026 send "feature done=0" even before you receive the xboard and protover
7027 commands, if this is needed to give your engine enough time to
7028 initialize.  See engine-intf.html for more discussion.
7029
7030 * Bugfix: "feature done=0" did not work for the second engine; now it does.
7031
7032 xboard/WinBoard 4.2.1 -- Sat Feb  3 19:52:26 PST 2001
7033 Tim Mann
7034
7035 * Bugfix: in Zippy mode with feature san=1, the elapsed time was being
7036 sent to the engine after the SAN move; for example, "e4 (0:01)" was
7037 sent instead of just "e4".
7038
7039 * It seems that scroll wheel mice with incompletely installed software
7040 (under Windows 95, at least) can send repeated middle button up events
7041 when the wheel is turned.  Moved QuickPaste from middle button up to
7042 middle button down to avoid problems with this.
7043
7044 * A premove is now sent *before* the opponent's move that it replies
7045 to is animated.  The premove itself is no longer displayed (or
7046 animated) when sent; instead, it is displayed when the chess server
7047 echoes it back as a board update.
7048
7049 * Bug fix: in -xreuse mode, xboard was only sending command line
7050 arguments to the engine the first time it was started.  (WinBoard
7051 didn't have this bug.)
7052
7053 * In -zippyPlay mode, we now initialize the chess engine for a new
7054 game immediately after the old game ends.  (In -xreuse mode, this
7055 means starting a new engine process; in the default -reuse mode, it
7056 just means sending "new".)  If the engine supports ping, we don't
7057 accept challenges until the "new" has finished.  This should help
7058 avoid losing time (re)initializing the engine after the game starts.
7059
7060 * We now handle the new FICS field in style 12 that says whether the
7061 clocks are ticking.
7062
7063 * whiteFlag and blackFlag are now reset whenever an ICS board image
7064 arrives, giving autoflag a fresh chance to work.
7065
7066 * Suppressed "geometry error" debug messages unless -debug flag is given.
7067
7068 * Bugfix: avoid core dump on Solaris with -debug flag, caused by
7069 passing NULL to a %s format in GameEnds.
7070
7071 * Added -firstProtocolVersion and -secondProtocolVersion.  This will
7072 allow use of extremely broken engines that hang or die when given the
7073 "protover 2" command.  It should be rarely if ever needed.
7074
7075 * Zippy now strips highlights from player names in the Creating
7076 message; previously the ratings would not be extracted from this
7077 message properly if you had set the highlight variable.
7078
7079 * Bug fix: Zippy with -zp but not -zt used to be fooled by false
7080 partner tells inside channel tells; e.g.:
7081 Garf(24): Garf (your partner) tells you: sit
7082
7083 * Bug fix: when an engine reported its name with the new "feature
7084 myname=" command, we had been putting just that name into the window
7085 title even when in TwoMachines mode.
7086
7087 * By default, WinBoard no longer uses the new feature introduced in
7088 4.2.0beta of keeping the ICS menu, ICS server list, and lists of chess
7089 engine command lines in separate files; instead, the lists are back in
7090 the winboard.ini file.  This gets rid of some problems where the
7091 separate files could not be opened because the working directory was
7092 not set to WinBoard's installation directory.
7093
7094 * WinBoard command lines and ini files now have another optional
7095 syntax for quoting an option value.  All characters within { } curly
7096 braces are interpreted literally except for '}' itself.  SaveSettings
7097 now uses this syntax for string values that contain a backslash or
7098 newline and do not contain a '}'.  This should address the problem
7099 that the separate .ini files had been meant to fix; engine command
7100 line lists can now be written without \-escapes.
7101
7102 * Fixed three bugs in relaying moves between engines in TwoMachines
7103 mode: an engine would be sent SAN if the *other* engine had set
7104 feature san=1, a relayed SAN move did not end with a newline, and
7105 feature usermove was not implemented for relayed moves.
7106
7107 * Fixed several bugs in exiting: File/Exit would sometimes hang;
7108 timestamp/timeseal would not get killed off; an engine crash would
7109 cause error messages to be printed recursively until stack overflow.
7110
7111 * Fixed a bug in the code to detect which ICS is in use and adapt to
7112 it; the chess.net case was broken.
7113
7114 * Removed the leading alias-suppression character when sending a move
7115 to ICS, because it seemed to break accuclock on chess.net.
7116
7117 * Fixed a bug where a FICS prompt like "10:01_fics%" would be matched
7118 as finger note number 10, causing a problem detecting when the user is
7119 logged in.
7120
7121 * Added tellicsnoalias command to protocol.
7122
7123 * Changed st command in protocol back to old behavior.
7124
7125 * Added done=0 feature to protocol, to lengthen initial timeout.
7126
7127 * Added missing -colorSeek command line option to xboard.  (Was
7128 present in WinBoard.)
7129
7130 * Bug fix: setting feature reuse=0 was not working.
7131
7132 xboard/WinBoard 4.2.0beta -- Sat Dec 16 16:34:56 PST 2000
7133 Tim Mann
7134
7135 * Setting -searchTime no longer turns off -clockMode.  Note that when
7136 -searchTime is set, some engines may search for the lesser of
7137 searchTime and the amount of time their normal clock management would
7138 dictate, while others will disable their normal clock management and
7139 always search for exactly searchTime.
7140
7141 * Fixed WinBoard bug where on Windows 2000 (and maybe Windows 98) the
7142 ICS Interaction window would scroll back to the top whenever it filled
7143 to capacity and WinBoard trimmed some text off the top.
7144
7145 * Changed xboard dragging so that the center of the dragged piece is
7146 forced to be over the mouse cursor.  (WinBoard dragging already worked
7147 that way.)  This should avoid confusing cases when you start a drag
7148 with the mouse near the edge of a square -- formerly most or all of
7149 the piece could be over one square but the mouse cursor over another.
7150 Suggested by DAV.
7151
7152 * Added move list window for xboard.  Code contributed by Manuel
7153 Hoelss and re-hacked a bit by me.  Performance of this window is poor,
7154 because the implementation regenerates the entire window contents
7155 whenever anything changes.  It's hard to avoid this when using the
7156 Athena List widget, though we could be a little smarter and notice
7157 when the current move number has changed but the move list has not.
7158 There are also several drawing problems caused by bugs in the Athena
7159 Form and List widgets.  The window should not really allow a
7160 horizontal scroll bar, but the bugs are much worse if I turn it off.
7161 In both Xaw and Xaw3d, the List widget tries to resize itself when
7162 XawListChange is called, even if you tell it not to; and what's worse,
7163 if the widget cannot resize itself to be large enough to avoid
7164 clipping any of the list item, it does not change the list!  Arrgh.
7165 On top of that, the Xaw Form widget is very buggy in XFree86 4.0.1
7166 (X11R6.4.3).
7167
7168 * The OK button in the WinBoard startup dialog is now simply disabled
7169 if none of the radio buttons is selected, instead of bringing up an
7170 error dialog.  Suggested by Ted Milbaugh.
7171
7172 * Used ping to address the worst of the race conditions in the
7173 protocol.  Now if an engine supports ping, we ping it after sending
7174 the "new" command and after trying to place it in force mode at the
7175 end of a game.  When a ping has been sent and the corresponding pong
7176 has not yet come back, we (1) ignore or undo any moves the engine
7177 sends, (2) ignore game end messages (such as "offer draw", etc.) from
7178 the engine, (3) ignore thinking output from the engine, (4) delay
7179 starting the next game if in -matchGames mode, (5) in -zippyPlay mode,
7180 respond to challenges with a polite message to try again soon instead
7181 of accepting them.  There are a few more things that should be done
7182 (and item 5 might not be quite what we want), but it's hard to fit
7183 them all into the existing code.
7184
7185 * Patched the version of GNU Chess 5.00 included with WinBoard to
7186 support protover, feature, setboard, and ping, and to fix some minor
7187 bugs.  See gnu500+.patch.
7188
7189 * Changed the GNU Chess 4 kludges for missing "st" and "sd" commands
7190 to be invoked only if the engine gives an error message for "st" or
7191 "sd", and to always use protocol commands instead of engine
7192 command-line options.  See "Idioms" in engine-intf.html.
7193
7194 * Added new protocol command "protover 2" to tell the engine what
7195 version of the protocol is in use.  Version 2 is still compatible with
7196 old engines; see engine-intf.html.
7197
7198 * Add new protocol command "feature ..."  The engine can send this in
7199 response to the protover command command, to say what extended
7200 protocol features it would like to enable, etc.  xboard responds
7201 "accepted F" or "rejected F" for each feature F that is set.  See
7202 engine-intf.html.
7203
7204 * Added new protocol command "setboard <fen>".  This is an alternative
7205 to "edit", used only if the engine says "feature setboard=1".
7206
7207 * Added new protocol command "ping <msg>".  The engine is supposed to
7208 respond "pong <msg>".  This gives us a tool to fix some race
7209 conditions in the protocol, but it is not used to the fullest yet.
7210
7211 * Added new protocol command "tellopponent".  This will do a "say" if
7212 you're on a chess server in Zippy mode, or pop up an information
7213 dialog otherwise.
7214
7215 * Added new protocol command "tellall".  This will do a "kibitz" if
7216 you're on a chess server in Zippy mode, or pop up an information
7217 dialog otherwise.
7218
7219 * Added new protocol command "tellothers".  This will do a "whisper" if
7220 you're on a chess server in Zippy mode, or do nothing otherwise.
7221
7222 * Changed the WinBoard /icsNames, /icsMenu, /firstChessProgramNames,
7223 and /secondChessProgramNames options to accept a filename preceded by
7224 "@", meaning to find the value in the file.  Changed the defaults to
7225 use this feature, with filenames icsnames.ini, icsmenu.ini, fcp.ini,
7226 and scp.ini.  This should make it easier for users to edit the values,
7227 since one less level of quoting is needed, and each value is in its
7228 own file, not mixed into winboard.ini.  Those who upgrade from an
7229 older winboard version and already have a winboard.ini file will not
7230 automatically have these values moved to a file; that has to be done
7231 by hand if desired.
7232
7233 * We now strip .exe from engine names for "name" command, tags, etc.
7234
7235 * Allowed WinBoard input widget to hold more than one line.  You can get
7236 a newline into the widget with copy/paste or with Ctrl+Enter.
7237
7238 * Fixed an xboard bug where the [P] button would appear in the
7239 opposite highlight state from what it should be after being pressed.
7240
7241 * We now use the "/" or "$" alias suppression feature on the chess
7242 servers, to avoid problems if the user inadvertently aliases a
7243 needed command to something else.
7244
7245 * Changed the method used to deiconize xboard in AutoRaise and cmail.
7246 This may fix bugs under some window managers where after
7247 deiconization, the board window was mapped but nothing was drawn
7248 inside.
7249
7250 * Preliminary, partial support for playing several chess variants
7251 against a local engine or editing variant games.  The -variant option
7252 must be given on the command line or WinBoard startup dialog; there is
7253 no menu.  The current variant is not displayed (except in the
7254 Tags/EditTags window).  Many variants will not work quite right even
7255 if the engine supports them; see item 326 in the ToDo file for
7256 details.
7257
7258 * Added a workaround to detect the variant type when examining a
7259 scratch wild game on an ICS.
7260
7261 * Fixed two cases where "variant" command should be sent to the engine
7262 when necessary but was not: loading a game from a file and restarting
7263 a dead engine.  Thanks to Gian-Carlo Pascutto.
7264
7265 * Added missing support for FICS games that start from a bsetup position
7266 with Black moving first.
7267
7268 * Fixed a bug in loading a file from the game list window while in
7269 Analysis or AnalyzeFile mode.  This now leaves us in AnalyzeFile
7270 mode, analyzing the new file.
7271
7272 * Fixed a bug in loading games with a comment before the first move.
7273
7274 * Fixed a bug in handling LoadGame (or -lgf) with -td 0.
7275
7276 * Added a command line option to select an initial minor mode from the
7277 Mode menu.  This should satisfy requests from a couple of users with
7278 special applications.
7279
7280 * Fixed a problem where some things in WinBoard's General Options
7281 dialog box were grayed out at the wrong time.
7282
7283 * We look for a few messages from the chess engine pipe that are
7284 intended to catch problems starting an engine via rsh, such as "No
7285 such file".  Moved code so that these strings won't match until other
7286 protocol messages have been looked for, and documented the messages in
7287 engine-intf.html.
7288
7289 * Fixed the WinBoard bug that sometimes made the console input box
7290 white-on-white even when not in password-entry mode.
7291
7292 * Small changes to WinBoard to be compilable with the latest Cygwin
7293 net release (as of 10-16-2000).  Thanks to Mark Schoenberg.
7294
7295 * Recompiled GNU Chess 5.0 for WinBoard with the latest Cygwin net
7296 release (as of 10-16-2000).  Also rebuilt the book just to be sure,
7297 since I had one bug report about it.  It came out identical and seems
7298 to work fine.
7299
7300 * Added messages for some common InstallShield errors instead of just
7301 printing InstallShield's stupid error code numbers.
7302
7303 * Added -firstComputerString and -secondComputerString, allowing you
7304 to suppress or change the command that is sent to a chess engine when
7305 its opponent is another computer.
7306
7307 * Added "configure --with-Xaw3d" to allow use of Xaw3d widgets instead
7308 of Xaw widgets in xboard.  Thanks to Johnny C. Lam of the NetBSD
7309 project.  I've left Xaw as the default because Xaw3d is too ugly.
7310
7311 * The version of the Xaw Form widget released in XFree86 4.0.1
7312 (X11R6.4.3) has a bug that causes xboard to display the button bar
7313 on top of the message widget.  I've reported the bug and have
7314 installed a kludge workaround into xboard.
7315
7316 xboard/WinBoard 4.1.0 -- Sun Sep 17 17:30:14 PDT 2000
7317 Tim Mann
7318
7319 * Merged Winboard Plus 4.0.8 from Mark Williams into xboard
7320   source pool.  Status of Winboard Plus features in xboard:
7321
7322   - White pieces now have borders, but the implementation is
7323     completely different from WinBoard's; see below.
7324
7325   - Options menu not changed, probably won't be.
7326
7327   - Copy&paste support working, using Mark's changes to backend.c, Ben
7328     Nye's changes to xboard.c for FEN positions, and some code of my
7329     own in xboard.c for PGN games.
7330
7331   - Premove hooked up and working.  No pre-first-move, though.
7332
7333   - ICS Alarm hooked up and working.
7334
7335   - Auto-flip working.
7336
7337   - PGN Training mode hooked up and working.
7338
7339   - Improved menu item enable/disable working.
7340
7341   - Improved >> button working.
7342
7343   - Auto activate board working.  I changed this to be optional; you
7344     might not always want it, especially in Zippy mode.
7345
7346   - Blindfold working.
7347
7348   - Documentation updated.
7349
7350 * Fixed more colorization bugs.  Commands like "message foo tells you:
7351 xxx" and "tell 33 tells you: xxx" will no longer generate bogus
7352 colorization.
7353
7354 * Added low-tech sound support to xboard, by invoking an external
7355 program on a filename for each sound to be played.
7356
7357 * ICC wild 27 is now recognized as VariantAtomic, and it sets the
7358 "ignore check" flag, but is not otherwise supported.
7359
7360 * Converted the piece bitmaps from .bm to .xpm for use with xboard's
7361 xpm support.  (An .xim version was not created.)  Wrote a shell script
7362 using ImageMagick to do the conversion and to bucket fill from
7363 coordinate 0,0 with the background color.  Used xpaint by hand to
7364 clean up a few pieces where background color "leaked" into the inside
7365 or didn't flow all the way around the outside, then a sed script to
7366 fix up color names and bitmap names in the xpaint output.  If any more
7367 sizes are added later, they should be straightforward to convert with
7368 reference to the existing scripts.  With this conversion, not only do
7369 the white pieces now have dark borders, but (unlike with WinBoard) the
7370 light details on the black pieces are opaque.
7371
7372 * If the XPM library is found when building xboard, the new xpm pieces
7373 are compiled in as the default.  External bitmap (or xpm) pieces can
7374 still be used by giving the -bitmapDirectory (or -xpmDirectory)
7375 option.  If the XPM library is not found, the old bitmap pieces are
7376 the default.  In this case external bitmap (or xim) pieces can be used
7377 by giving the -bitmapDirectory (or -xpmDirectory) option.  There is no
7378 way to compile in xim pieces.
7379
7380 Winboard Plus 4.0.8 -- Sat Aug 5 15:51 PDT 2000
7381 Mark Williams
7382
7383 * Bugfix release.
7384
7385 * Main menu now visible in Win NT.  Thanks to Microsoft for creating a
7386 compiler which auto-mutilates the WinBoard.rc file so that the menu is
7387 displayed under Win 98 but not Win NT.  I fixed the problem by hand editing the
7388 .rc file.  Sigh.
7389
7390 * "Reset game" now works properly when invoked from Analysis mode when two
7391 engines are present. Correction of bug introduced in Winboard Plus. Thanks to
7392 Mogens Larsen for reporting the bug.
7393
7394 * Pasting a FEN position with Black to move now works in all modes.
7395 Thanks to Mogens Larsen for reporting the bug.
7396
7397 * Added gnuchess.dat to the distribution and a couple of text files that were
7398 missing in 4.0.7.
7399
7400 *** Merged in the following changes from Tim Mann:
7401
7402 * Bugfix: Highlights would sometimes not be taken down, at least in
7403 xboard.  The problem is that SetHighlight works in chess coordinates,
7404 not view coordinates, so if flipView has been toggled since the
7405 highlight was put up, it gets taken down from the wrong square.  Fixed
7406 by being careful to call ClearHighlights before toggling flipView, not
7407 after.  Ugh.
7408
7409 * Bugfix: HighlightLastMove would sometimes highlight square a1 after
7410 a FICS "tomove black" command.
7411
7412 * Bugfix: a move list with initial position that has black to play was
7413 not being handled correctly.
7414
7415 * Removed "decline abort" and "decline adjourn" commands from Zippy.
7416 The syntax is changing on FICS, and Zippy really doesn't have to
7417 explicitly decline the requests anyway; it's sufficient to not accept
7418 them.
7419
7420 * ICC wild 26 is now recognized as VariantSuicide (the FICS name; ICC
7421 calls it "giveaway").
7422
7423 * Bugfix: PGN games with black to move in the initial position weren't
7424 being legality checked correctly.  I think this was introduced in
7425 4.0.6 when I fixed a different PGN bug.  Thanks to Mark Williams for
7426 spotting the bug and suggesting a fix.
7427
7428 * Bugfix: the initial "name(" of a kibitz wasn't being colorized.
7429
7430 Winboard Plus 4.0.7 -- Thu May 12 17:57 PDT 2000
7431 Mark Williams
7432
7433 * New white pieces with black borders.
7434
7435 * Major overhaul to Options menu. New dialogs for setting General Options,
7436   Board Options, ICS Options, Sounds, Fonts, Colors.
7437
7438 * Clipboard support for PGN game scores and FEN positions.
7439
7440 * Optional ICS Premove with user-specified first moves for White and Black.
7441
7442 * New sound events: ICS Win, ICS Loss, ICS Draw, ICS Unfinished, ICS Alarm.
7443
7444 * New auto-flip option when playing against a chess program.
7445
7446 * Added PGN Training mode.
7447
7448 * Certain menu options now disabled while program is thinking.
7449
7450 * ">>" button now always goes to the end of the game.
7451
7452 * In ICS mode, the board is automatically activated at the start of a
7453 new game.
7454
7455 4.0.7 -- Sun Mar  5 17:17:49 PST 2000  Tim Mann
7456
7457 * Fixed a nasty bug in parsing ICS game histories that was introduced
7458 in 4.0.6.
7459
7460 4.0.6 -- Fri Mar  3 16:20:11 PST 2000  Tim Mann
7461
7462 * Fixed bugs in Zippy's code for responding to messages sent with the
7463 ICS "message" command.
7464
7465 * Fixed bugs where xboard could still create dialogs partially off the
7466 top of the screen.  Fixed unwanted interactions between initial sizes
7467 and positions of various unrelated xboard dialogs.  Deleted
7468 borderXoffset and borderYoffset resources.
7469
7470 * Fixed restoring the xterm name on exit to work in more cases.
7471
7472 * Small fix to the WinBoard self-extracting installer: when it starts
7473 up, it now always deletes any old wb-setup directory left over from a
7474 previous installation.  Formerly this worked only on Windows 95/98, so
7475 on NT the self-extractor would sometimes stop and ask the user whether
7476 it was OK to overwrite the old wb-setup files.
7477
7478 * Modified WinBoard to be compilable with the free Cygwin tools
7479 available from http://sourceware.cygnus.com/cygwin/.  Based on work by
7480 Mark Schoenberg.  (His mods were enough to get WinBoard through the
7481 compiler, but a few things were broken along the way, so I reworked them.)
7482
7483 * Merged changes from Don Fong to make WinBoard compilable with
7484 Borland C++ 4.5.  I do not have Borland C++ and am unable to test with
7485 it, but I did make sure the changes don't stop it working with MSVC++
7486 5.0 and Cygwin.
7487
7488 * Forbade entering TwoMachines mode from MachineWhite or MachineBlack
7489 mode when machine is on move.  This used to confuse the engine and
7490 cause problems, because when we try to get the engine to stop, it
7491 might make a move first, and it might not do that immediately.
7492
7493 * Variant classification now deals with new ICC wild 25, classifying
7494 it as "3check".  Also, we are now conservative about new wild numbers
7495 we don't know about, classifying them as "unknown" instead of
7496 "normal".
7497
7498 * Replaced bad GNU Chess 5.00 book in WinBoard distribution with a
7499 correct one.  1.e4 now no longer takes GNU Chess 5.00 out of book!
7500 Thanks to Pete Galati.
7501
7502 * Made move parser accept and ignore nonstandard ep suffix on PGN moves,
7503 e.g., "exf6ep" or "exf6e.p."
7504
7505 * Fixed bugs in parsing PGN files starting with no move number, or
7506 with a move number other than "1." (including "1...").  Thanks to
7507 Michael Soulier and Stefan Zipproth for example PGN files
7508 demonstrating the bugs.
7509
7510 * Changed InitComboStringsFromString to not modify the input string;
7511 this caused an exception when WinBoard was compiled with MSVC++ 6.
7512 Thanks to Bert Tuyt for the report.
7513
7514 * In WinBoard, dragging a piece off the edge of the board without
7515 releasing the mouse button no longer instantly aborts the move.  You
7516 still must release the mouse button inside a square to complete a
7517 move, but you can now drag off the edge and come back inside.
7518
7519 * WinBoard bugfix: If you went into EditGame or EditPosition mode
7520 while observing or playing an ICS game, and a new move came in
7521 (snapping you back to ICSClient mode) while you were dragging a piece
7522 around, the drag state would not be reset, causing the piece you were
7523 dragging to remain on the board wherever you dropped it.  Thanks to
7524 David Brinegar for the bug report.
7525
7526 * WinBoard bugfix: If you moved or resized the board while your
7527 opponent was moving, and you had AnimateMoving on, his move would not
7528 be displayed until after your next move.  Thanks to DAV for reporting
7529 the bug repeatedly until I finally understood it.
7530
7531 * Added a Zippy "farewell" feature; see zippy.README.
7532
7533 * Fixed a bug (xboard only) in processing -zippyReplayTimeout on the
7534 command line.  Thanks to Steve Beer for the report and patch.
7535
7536 * Send "computer" command to both sides in TwoMachines matches.
7537
7538 * Fixed a Y2K bug in Evan's cmail code!  Thanks to Brian Mays for the
7539 report and patch.
7540
7541 * Bugfix: Initialize variant field of GameInfo struct in gameinfo.c.
7542 This could cause crashes in LoadGame.  Thanks to Andrzej Nagorko.
7543
7544 * Fixed several pattern matching problems: Finger notes and formula
7545 vars no longer get replied to by zippyTalk or colorized.  Channel
7546 tells by players with many titles are now colorized fully, and
7547 zippyTalk handles channel tells by such players correctly.  The shout
7548 "--> foo(99): bar" no longer gets colorized as a channel tell.  Code
7549 is cleaned up a bit, and autocomment capture now uses the same
7550 criteria as colorization.
7551
7552 * xboard fix: Enter key now closes error popups as in WinBoard.
7553 Especially nice for the "Exiting: Connection closed by ICS" popup.
7554
7555 4.0.5 -- Tue Dec  7 10:30:40 PST 1999  Tim Mann
7556
7557 * Added missing documentation of SIGTERM usage into engine-intf.html.
7558
7559 * Bugfix: New -zippyReplayTimeout option was misspelled in WinBoard as
7560 -zippyReplyTimeout.  Thanks to Francesco Di Tolla.
7561
7562 * xboard -ics now restores the xterm's original title upon exit, at
7563 least if $WINDOWID is set.
7564
7565 * Bugfix: -matchGames mode wasn't terminating properly.  Final score
7566 popup would come up twice and engines would not be killed off.  Thanks
7567 to Frank Quisinsky for the bug report.  Bug was introduced in 4.0.4.
7568
7569 * Bugfix: "tell 50 foo shouts: bar" no longer gets colored as a shout;
7570 similarly for "...s-shouts:" and "...c-shouts:".  Thanks to David Lee
7571 for the bug report.
7572
7573 4.0.4 -- Fri Dec  3 17:51:27 PST 1999  Tim Mann
7574
7575 * Bug fix: formerly if you invoked SaveGame from EditPosition mode
7576 with black to play, the position was not saved properly.  As a quick
7577 fix, SaveGame now takes you out of EditPosition mode before saving.
7578
7579 * Changed -matchGames to keep track of the score (won-lost-drawn) and
7580 display it in the banner.  The final score is displayed in a modal
7581 popup before the program exits.
7582
7583 * Changed "Connection closed by ICS" to display in a model popup
7584 before the program exits.
7585
7586 * Added -popupExitMessage option, default on.  Setting this to false
7587 suppresses the modal popups that you sometimes get just before
7588 xboard/winboard exits -- both the two new ones listed above and the
7589 existing Fatal Error popup.  This is useful when running Zippy
7590 unattended from a shell script (or .bat file) that loops and starts a
7591 new copy after a time delay when there is an error.
7592
7593 * In xboard, added missing support for WM_DELETE_WINDOW to all
7594 windows.  This makes xboard a better citizen, and is much needed with
7595 the newer X window managers that put an [X] button on every window and
7596 bind it to "kill application" if the applicationd does not support
7597 "delete window".  We can't allow xboard to be thoughtlessly killed,
7598 since that leaves the chess engine running in the background.
7599
7600 * We now avoid positioning tops of xboard dialog boxes offscreen.
7601
7602 * zippy.lines can now use the caret ('^') character as an inter-saying
7603 separator. You no longer need to dig up a text editor that can put NUL
7604 ('\000') characters in text files.
7605
7606 * Bugfix: In traditional chess clock mode, White now gets time added
7607 to its clock as soon as it makes time control.  Previously both White
7608 and Black got their time added only when Black made time control,
7609 which would cause some engines to make their 41st move as White too
7610 quickly, thinking they were low on time.
7611
7612 * The zippyAcceptOnly feature no longer sends a decline command or
7613 a tell.  Thus you can use it to put Zippy into a manual accept mode.
7614
7615 * Bugfix: "tell 50 foo tells you: bar" no longer gets colored as a
7616 personal tell; similarly for "...whispers:" and "...kibitzes:".
7617
7618 * WinBoard no longer blanks the message line when you start a new
7619 move, unless there was an error message there from the previous move.
7620
7621 * WinBoard now never puts the white piece drop menu on the middle
7622 mouse button.  Both colors are always on the right button.  Windows
7623 users often don't think to look for a middle button menu, or don't
7624 really have a working middle button despite what Windows says.
7625
7626 * Guest login handles on ICC are now parsed again; an ICC wording
7627 change had broken this feature.
7628
7629 * Autodetect when the engine does not support the "draw" command and
7630 don't relay the command to it in that case.  Needed because sending an
7631 unsupported command to GNU Chess makes it move immediately, so people
7632 could make Zippy move without thinking by continually offering a draw.
7633 Thanks to Frank Walker for the problem report.
7634
7635 * Small changes based on code from Robert Jurjevic: The WinBoard
7636 analysis window can be minimized (though not to the taskbar).  The
7637 WinBoard ICS Interaction window will autoscroll if you drag the mouse
7638 above or below the window while selecting, and password entry mode
7639 leaves the entry line as the background color instead of using 75%
7640 gray.  Seeks are now colorized with a new color of their own.
7641
7642 * Added -zippyMaxGames feature.
7643
7644 * -zippyNoplayCrafty command line option was missing in xboard; fixed.
7645 Thanks to John Perry.
7646
7647 * Fixed bug in detecting when Zippy loses his bughouse partner.
7648 Thanks to Ben Dean-Kawamura.
7649
7650 * allobs fix in 4.0.3 didn't work; corrected it.
7651
7652 * WinBoard will now update the board immediately if a move is made
7653 while the window is being moved or resized.
7654
7655 4.0.3 -- Sun Aug 15 18:44:39 PDT 1999  Tim Mann
7656
7657 * Bugfix: moved winboard wizard functions that send a command directly
7658 to the chess engine from Ctrl+Alt+1 and Ctrl+Alt+2 to Alt+1 and Alt+2.
7659 Ctrl+Alt is equivalent to the European AltGr key, so the old assignments
7660 conflicted with typing an @-sign on some keyboards.
7661
7662 * Bugfix: prevent "If this message stays up, your chess program does
7663 not support analysis" from appearing if AnalysisMode is selected when
7664 already in Analysis or AnalyzeFile mode.  Also, deleting analysis window
7665 in WinBoard now switches you to EditGame mode, to avoid the anomaly of
7666 being in an analysis mode with no analysis window present.
7667
7668 * Change all Zippy environment variables to work as command line
7669 options.  For now they still work as environment variables too, but
7670 the environment variables are deprecated.
7671
7672 * Use unsigned long to hold node counts from engines.
7673
7674 * Print error instead of crashing on attempts to use xpm or xim pieces
7675 in monochrome mode.  Thanks to Jim Torrance for the bug report.
7676
7677 * Tightened pattern recognition for ICS messages sent to Zippy; should
7678 no longer match ICC allobs output.  Fixed recognition of when Zippy is
7679 sent a message; small change to FICS output had broken it.
7680
7681 * Zippy now exits if the engine dies unexpectedly.
7682
7683 * Added Zippy "spoofedby" feature; see zippy.README.
7684
7685 * Narrowed the margins on some older WinBoard dialogs to make their
7686 style uniform with the newer ones.
7687
7688 * Bugfix: Changing Ponder Next Move from the Options menu did not take
7689 effect until the next game.  This bug was in WinBoard only.  Thanks to
7690 Stefan Zipproth for the bug report.
7691
7692 * Got rid of "Internal error: bad move type" message when the engine
7693 makes a move that we can parse but think is illegal.  Now the move is
7694 just passed on (which also may be the wrong thing to do).
7695
7696 4.0.2 -- Thu Feb 25 19:55:32 PST 1999  Tim Mann
7697
7698 * Added one more built-in sound choice to WinBoard: move.wav from Pete
7699 Galati.
7700
7701 * Added new larger piece sizes: big, huge, giant, colossal, titanic.
7702
7703 * Modified the xboard font searcher to be able to use scalable fonts.
7704 The new -fontSizeTolerance flag controls how closely a nonscalable
7705 font must match to be used in preference to a scalable font.
7706
7707 * Zippy environment variables ZIPPYABORT and ZIPPYADJOURN now control
7708 whether Zippy will accept abort and adjourn requests.
7709
7710 * We now determine the variant type being played on ICS, send it as a
7711 command "variant VARTYPE" to the chess engine (if in Zippy mode), and
7712 put it in the PGN tags.  See engine-intf.txt for variant names.  See
7713 ZIPPYVARIANTS in zippy.README to control what variants Zippy will
7714 accept.  Note that this now applies to bughouse, too.
7715
7716 * Zippy now won't do -zippyTalk in a channel unless his handle is
7717 mentioned there.
7718
7719 * Zippy now ignores bughouse holdings if not actually playing, instead
7720 of stupidly trying to abort the game.  Let me know if other strange
7721 things happen when Zippy is observing a game.
7722
7723 * Set ICS Interaction title bar to "user@server".  User name is
7724 determined by parsing message during the login sequence.  Zippy now
7725 uses this method to get its name too, so ZIPPYNAME is eliminated.
7726 Problem: with xboard, the title bar gets set to "xterm" upon exit,
7727 since we didn't know what it was to start with.
7728
7729 * Fixed xboard-only bug in -colorChannel1 command line option.  Thanks
7730 to Fredrik Sandstrom for the bug report and fix.
7731
7732 * Check for overflow of MAX_MOVES.  Still not sure this is checked for
7733 everywhere it needs to be.
7734
7735 * Added .epd to suffixes recognized by WinBoard as position files.
7736 This is a bit of a kludge, as the .fen reading code was not written
7737 with .epd files in mind, but reading them with it is said to work.
7738
7739 * Added ZIPPYGAMESTART feature, suggested by Jason Hoblit.  See
7740 zippy.README.
7741
7742 * Restored the feature of soaking up the moves from a user-typed "moves",
7743 "oldmoves", or "smoves" ICS command when xboard/WinBoard is idle, but
7744 changed it so that the move list is also echoed to the screen.  Some folks
7745 still liked the old feature since it is faster than examine mode, and
7746 printing the moves to the screen should eliminate the confusion it caused
7747 for other people.
7748
7749 * Bugfix: in WinBoard, starting a click-click move and then clicking on
7750 a black line would cause the source square to be forgotten without taking
7751 the highlight down.  Now the errant click is ignored.
7752
7753 * Corrected shortcut key labels for LoadNext/PrevPosition in WinBoard's
7754 File menu.  Thanks to Andreas Stabel for the bug report.
7755
7756 * Bugfix: if you had a completely full ICS context menu in WinBoard
7757 (90 items), the last one would do nothing if selected.
7758
7759 * The "computer" engine command added in 4.0.1 was not working; I had
7760 left out part of the code patch.  Oops.
7761
7762 4.0.1 -- Fri Feb 12 21:24:15 PST 1999  Tim Mann
7763
7764 This is a minor bugfix release.  The first item listed below is the
7765 only interesting new feature.
7766
7767 * You can now type in moves from the keyboard in WinBoard.  Either
7768 select TypeInMove from Step menu, or (if you are not in ICS mode),
7769 just start typing.  In ICS mode you can type moves into the ICS
7770 interaction window anyway, so I've retained the feature that typing
7771 switches you there.  Not implemented in xboard.
7772
7773 * Removed the "noise 1000" command that used to be sent to the chess
7774 engine when entering analysis modes.
7775
7776 * Deleted the feature where we soak up the output of a user-typed ICS
7777 "moves" or "oldmoves" command.  This ancient feature is not really
7778 useful anymore, now that "examine" exists, and it caused a lot of
7779 complaints.
7780
7781 * Increased maximum size of ICS text menu to 90 entries and added
7782 overflow checking.
7783
7784 * The command sent to ICS by Zippy at the end of each game can now be
7785 customized with the ZIPPYGAMEEND environment variable.
7786
7787 * We treat xboard.info as a pseudo-source since most people don't have
7788 the tools to rebuild it.  But "make install" erroneously had a
7789 dependency on it, even though "make all" did not.  Fixed.
7790
7791 * Miscellaneous minor updates and clarifications to engine-intf.txt.
7792 In particular, documented the st and sd commands (support for command
7793 line options -searchTime and -searchDepth), warts and all.
7794
7795 * Added a small code patch from Bob Hyatt to detect when Zippy's ICS
7796 opponent is a computer and send the command "computer" to the engine.
7797 Added this command to engine-intf.txt.  Thanks, Bob.
7798
7799 * Bugfix: configure was looking for usleep(), but config.h.in didn't
7800 have an entry for it, so HAVE_USLEEP was never defined.  Also, in the
7801 non-HAVE_USLEEP case, there was a possible race condition between the
7802 signal handler and the pause() call.  Thanks to Ben Dean-Kawamura for
7803 the bug reports.
7804
7805 * Bugfix: a "1..." preceding Black's first move (usually present if
7806 there is a comment on White's first move) would cause the parser
7807 to think a new game started there and report "End of game" on the
7808 current game.  Thanks to Dell Garner for the bug report.
7809
7810 * Changed the abbreviation for -searchDepth from -sd to -depth to fix
7811 a clash with -secondDirectory.
7812
7813 * Changed -searchDepth to be orthogonal to the various timing options.
7814 Previously it would search for an unlimited time to the given depth;
7815 now the engine is allowed to choose its search time in the normal way,
7816 but is told to cut off the search early if it reaches the given depth.
7817
7818 * Bugfix: SaveSettings in WinBoard was saving both the long form
7819 option highlightSquareColor and its abbreviation (hsc).
7820
7821 * Fixed a redisplay bug in DisplayBothClocks that could cause White's
7822 clock to be highlighted in EditPosition mode when Black's should have been.
7823
7824 * Fixed Zippy's feature of passing on draw offers from the ICS opponent.
7825 The colorization code was eating the offer before Zippy saw it, so I disabled
7826 colorization of offers while in -zp or -zt mode.  (Other types of
7827 colorization are already disabled in Zippy mode for similar reasons.)
7828
7829 * Added some more commands to the default ICS context menu in WinBoard,
7830 and put "(name)" on the ones that insert a playername (or game number).
7831
7832 * Added missing documentation to WinBoard help file: PonderNextMove, the
7833 -ponder/-xponder argument, and the up/down arrow history feature in the
7834 ICS Interaction window.
7835
7836 * Fixed ZIPPYNOPLAYCRAFTY feature to fire only if the opponent is Crafty,
7837 not if some other Crafty is observing the game and kibitzes.
7838
7839 * Fixed bugs in generating "partner" commands when Zippy is playing
7840 bughouse.
7841
7842 4.0.0 -- Sat Jun 20 16:59:47 PDT 1998  Tim Mann
7843
7844 * Fixed WinBoard resizing so that the edges you do not drag remain in
7845 place, even when the final size is different from what you dragged to.
7846 (This doesn't work on NT 3.51 or earlier, if anyone cares.)
7847
7848 * Fixed problems with resizing WinBoard on Windows NT: you no longer get
7849 whitespace around the board, a clipped board, or a lot of flashing during
7850 the drag.
7851
7852 * Added customization for highlight-square color.
7853
7854 * Bugfix: backend.c wrote to stderr in a few obscure places, which doesn't
7855 work in WinBoard.
7856
7857 * Added Index Number field back to LoadGame/LoadPosition dialog boxes in
7858 WinBoard.  This required some extra code to work with both the
7859 Explorer-style dialog boxes and the old-style NT 3.51 dialog boxes.  Ugh.
7860
7861 * WinBoard startup dialog now understands -zp mode.  The first chess
7862 engine selector is enabled and the value is used.
7863
7864 * Bugfix: ResetGame would send "exit" to engine twice if it was in an
7865 analysis mode.
7866
7867 * Bugfix: The response "Illegal move: bk" to the "bk" command, indicating
7868 that it is not implemented, would confuse xboard.
7869
7870 * Bugfix: Ignore empty hints ("Hint:\n") instead of printing a message
7871 saying that some bogus string (often "Hint:") is illegal.
7872
7873 * Bugfix: LoadNextGame/LoadPreviousGame/ReloadSameGame were broken.
7874
7875 3.6.12 -- Sat Jun 13 14:57:10 PDT 1998  Tim Mann
7876
7877 Beta test release of xboard and WinBoard.
7878
7879 * Spruced up xboard man page a bit.
7880
7881 * Added Highlight Last Move to xboard too.
7882
7883 * The revamped xboard mouse click code had several more bugs than the
7884 previous version, so I revamped it again.  All fixed now, I hope.
7885
7886 * xboard bugfix: crash in CreatePieceMenu.
7887
7888 * Oops.  winboard-3_6_11beta.exe installed 3.6.10beta, not the new version.
7889
7890 3.6.11 -- Fri Jun 12 20:00:48 PDT 1998  Tim Mann
7891
7892 Beta test release of xboard and WinBoard.
7893
7894 * Major reorganization to engine-intf.txt.  Some new features added,
7895 many existing features clarified and hints for engine programmers added.
7896 Support for new features added to program.
7897
7898 * Changed defaults for -scp (etc.) back to being independent of -fcp, as
7899 in 3.6.2. That is, the default is no longer to copy the value from -fcp if
7900 -scp is not specified.  This will sometimes make command lines longer but
7901 will remove some confusing situations.
7902
7903 * Split -reuseChessPrograms into two options: -reuseFirst and
7904 -reuseSecond.  Fixed obscure bugs when reuse is off.
7905
7906 * Detect ICC and change some command usage slightly there: only ICC has
7907 set-quietly; only FICS has iset and bsetup clear.  With this feature, we
7908 can now safely use bsetup clear when appropriate instead of deleting each
7909 piece one by one.
7910
7911 * Added indent to lines that are wrapped by WinBoard ICS Interaction
7912 window.  This seems to tickle a Microsoft bug in the RichEdit control:
7913 occasionally the start of the next line after the wrapped line is indented
7914 too.  I think the wrapped indent feature is useful enough that it's worth
7915 having in spite of the bug.
7916
7917 * WinBoard bugfix: bounding box for the board was computed incorrectly by
7918 mouse code.  It would think you moved off the bottom of the board before
7919 you really did, so it was hard to drag pieces along the bottom rank on
7920 smaller board sizes.
7921
7922 * Fixed obscure parser.l bug: ambiguity between capture using : instead of
7923 x and email header line.  Also removed or simplified a lot of complex
7924 patterns for English (as opposed to PGN) end-of-game indications while I
7925 was in there.
7926
7927 * Added PonderNextMove option.
7928
7929 * xboard EditPosition piece menus now let you set the side to play by
7930 selecting the "White" or "Black" label at the top of the menu, like
7931 WinBoard.  (Both xboard and WinBoard still let you set the side to play by
7932 clicking on the clock.)
7933
7934 * Merged documentation of Crafty and GNU Chess thinking output in
7935 engine-intf.txt.  Corrected code in backend.c to match documentation; it
7936 used to require the PV to start in column 27 (!).
7937
7938 * Fixed bug that caused crashes in "-reuseChessProgram false" mode.
7939
7940 * Draw by agreement in Two Machines mode now works as it is supposed to.
7941 Other minor bugs in handling game end messages from machines are also
7942 fixed, and engine-intf.txt is revised in this area.
7943
7944 * Revamped xboard code for handling mouse clicks on the board.  In
7945 particular, it had a bug if a click-click promotion move was made.
7946
7947 * Fixed and reinstated optimization for << in analysis modes: send
7948 initString and re-send the board if needed.  Sending repeated undos
7949 is bad because Crafty prints some analysis after every one.
7950
7951 * Don't go into a spin loop while pausing between xboard animation frames.
7952 This caused problems, especially when compiling with -O2 on HP-UX.
7953
7954 * WinBoard Options/Colors/RevertToDefaults now also turns off Monochrome
7955 if it was on, and similarly for Options/ICSInteractionColors/RevertToDefaults.
7956 This seemed to confuse people before.
7957
7958 * Bugfix: ICS Interaction context menu items with neither of the two
7959 optional flags set did not work.
7960
7961 * Bugfix: PGN move numbers are optional, but we were insisting on "1"
7962 right after the tags.
7963
7964 * Bugfix: only the first game of an -mg match was loading -lpf or -lgf.
7965
7966 * Other minor fixes and code cleanup.
7967
7968 3.6.10 -- Mon Jun  1 01:32:31 PDT 1998  Tim Mann
7969
7970 * Added ZIPPYNOPLAYCRAFTY feature; see zippy.README.
7971
7972 * Added timestamps for chess engine interaction to -debug output.
7973
7974 * Now allow 10 seconds (was 5) between games in match mode for engines to
7975 respond to "force" command that ended previous game.
7976
7977 * When a game is picked from the game list and the names of White and
7978 Black are known, display them in the window banner instead of the filename
7979 and game number.
7980
7981 * Changed default for -scp and -sd to be the values of -fcp and -fd.
7982
7983 * Added boxes for both engines to WinBoard startup dialog.  Changed to
7984 dropdown boxes whose content can be set from winboard.ini, similar to
7985 the box for ICS name.
7986
7987 * Accept "offer draw" (or "*offer*draw*") from engine to offer a draw.
7988
7989 * Accept "move mmmm" from engine as well as silly "1. ... mmmm" syntax.
7990
7991 * Added support for bughouse engines (Zippy mode only).
7992
7993 * Move bombproofing for engines sending illegal or out of turn moves.
7994
7995 * Always send "xboard\n" to engine as first command.  Eliminates need
7996 to run crafty as "crafty xboard".
7997
7998 * Rewrote xboard code for input from engines to fix longstanding bugs.
7999 Previously an engine that sent one line in two separate writes with
8000 some time lapse in between (or perhaps that sent several lines in one
8001 write) could make xboard hang.  WinBoard did not have this bug.
8002
8003 * Fixed minor bugs in dealing with illegal moves.
8004
8005 * Added "iset startpos 1" for FICS.
8006
8007 * Removed special support to put "GNU Chess" or "Crafty" in the window
8008 banner instead of the engine's base filename.  This gives a more level
8009 playing field for other engines.  Also fixed bugs in the code that finds the
8010 engine's base filename.
8011
8012 * Bugfix: Abort or Resign at the very start of a game in chess engine mode
8013 would fail to send "force" to the engine.
8014
8015 * Fixed some minor bugs in new "result" messages, and changed format to
8016 include a trailing PGN comment giving the reason the game ended.
8017
8018 * Changed syntax of /font options in WinBoard; old syntax was assuming
8019 that a font name can't contain a digit, which is wrong.  Old font names in
8020 WinBoard.ini files are still accepted.
8021
8022 * Serious further work on getting WinBoard to read/write files in the
8023 "right" directories and documenting exactly what it does.
8024
8025 * Added LoadPreviousPosition, LoadNextPosition, ReloadSamePosition.
8026
8027 * Misc. tiny fixes and cleanup.
8028
8029 3.6.9 -- Sun May 24 20:53:08 PDT 1998  Tim Mann
8030
8031 xboard and WinBoard beta release.
8032
8033 * Tightened up illegal move handling.  Illegal or meaningless moves from a
8034 file or chess engine should no longer get translated into a1a1 and blindly
8035 applied.  Explicit moves to the same square (like a1a1) no longer make the
8036 piece on that square capture itself and vanish.
8037
8038 * Added AlwaysOnTop feature to winboard.
8039
8040 * Fixed bug in winboard "@" command line indirection operator.
8041
8042 * Removed buggy "optimization" code for ToStart in analysis modes.
8043
8044 * Fixed typo bug in zippy.c that would often cause winboard to crash
8045 right after starting a game in -zp mode.
8046
8047 3.6.8 -- Sat May 23 22:23:19 PDT 1998  Tim Mann
8048
8049 xboard and WinBoard beta release.
8050
8051 * Added -firstDirectory and -secondDirectory so that chess engines can
8052 be started in a different directory from xboard/WinBoard itself.
8053
8054 * Added -matchGames to allow more than one game in -matchMode.  The games
8055 are played with colors alternating between the two chess engines.  Had to
8056 add a time delay at the end of each game to catch up with game ending
8057 messages from both chess engines -- yuck.
8058
8059 * Changed TwoMachines mode to have firstChessProgram play White by
8060 default.  Added -firstPlaysBlack to restore old behavior.
8061
8062 * Major rework of code in backend.c for dealing with first and second
8063 chess engines.  Generalized the code and created a struct type with one
8064 instance for each engine.  Several small bugs fixed along the way.
8065
8066 * Fixed bugs in Abort in local chess engine mode.
8067
8068 * Tightened pattern matching to recognize moves from machine.  Should cure
8069 bogus "Illegal move" errors while Crafty is pondering with Show Thinking
8070 on, among other things.
8071
8072 * WinBoard keeps focus in board window after popping up a comment due to
8073 Forward/Backward/ToStart/ToEnd commands.
8074
8075 * Finally got rid of warnings on compiling moves.c under Windows.
8076
8077 * Fixed so WinBoard will compile on machines where WM_MOUSELEAVE is not
8078 defined.
8079
8080 * Removed various bits of unused code.
8081
8082 * Parse (and ignore) NAGs in PGN files.
8083
8084 * Updated engine-intf.txt.
8085
8086 * Send "result R" to the chess program at the end of each game, where
8087 R is the PGN result 1-0, 0-1, 1/2-1/2, or *.
8088
8089 * Bugfix: suppress animation when loading a game with timeDelay=0.
8090
8091 * Bug fix: pondering output from Crafty that contained "..." could be
8092 mistaken for a move, causing bogus error messages and general chaos.
8093
8094 * xboard "make clean" bug fix: moved things created by configure to be
8095 removed only by "make distclean".
8096
8097 * Fixed a remaining case where move was being animated before being
8098 relayed to opponent.
8099
8100 * Backend was reversing time/otim commands to the chess program (new bug),
8101 and was often not sending them on the first move of a game or the first
8102 move after a mode change (old bug).  Fixing the latter required a kludge
8103 to work with both GNU Chess and Crafty, because Crafty swaps white and
8104 black clock times when it swaps sides, while GNU Chess does not.  The
8105 kludge is that we always make sure the chess engine thinks its opponent is
8106 on move before we set the clock.  This will sometimes result in sequences
8107 like "white\ntime xxx\notim yyy\nblack\ngo", or the same with white and
8108 black interchanged.
8109
8110 * Removed last trace of old -whiteString and -blackString arguments.
8111
8112 * Fixed so that you can type "bd" into the Direct Command dialog when
8113 debugging gnuchess, without having xboard parse the clock display
8114 (starting with "White") as "White wins" and end the game.
8115
8116 * Changed moves.c to make a distinction between IllegalMove (where we
8117 could tell what move was intended, but it violates the chess rules) and
8118 MeaninglessMove (where we could not tell).  This is a step towards getting
8119 rid of cases where we translate meaningless moves into "a1a1", but some
8120 work is probably needed to track them all down.
8121
8122 * Fixed bug in WinBoard monoMode dragging.
8123
8124 * Changed WinBoard to new style file dialogs.  In the process, disabled
8125 the feature that let you enter the index number of a game or position within
8126 the file in the dialog.  This is no loss in LoadGame, as you can pick your
8127 game from the game list dialog that follows, but it does remove some
8128 functionality from LoadPosition.
8129
8130 3.6.7 -- Mon May 18 21:25:00 PDT 1998  Tim Mann
8131
8132 xboard and WinBoard beta test release.  I've been unable to reproduce some
8133 reported drawing bugs, so they may still not be fixed.
8134
8135 * Changed PopUpErrors option to PopupMoveErrors, which is more useful, and
8136 changed default to off.  Errors other than move errors should always be in
8137 popups; they are often too big for the message area and too important to
8138 put where they can be easily missed.  But it seems good to get rid of the
8139 popups for move errors by default.
8140
8141 * xboard analysis window no longer forces itself to top whenever there is
8142 new output.  Also, now uses built-in Xaw word wrapping instead of trying
8143 to do its own; works better.
8144
8145 * Bugfix: Reset did not take Crafty out of analyze mode.
8146
8147 * A chess engine no longer has to claim to be Crafty to be able to use
8148 AnalysisMode and AnalyzeFile; it just has to implement the analyze
8149 command as Crafty does.  Put in heuristics to generate more informative
8150 error messages if the engine does not support analyze, and checked that
8151 they work at least with GNU Chess.
8152
8153 * Added click-click moving, HighlightLastMove, and HighlightDragging to
8154 WinBoard.  The highlight features are unlikely to go into xboard unless
8155 the xboard drawing code is cleaned up to do *all* drawing on the board
8156 from DrawPosition, as WinBoard does.  This is low priority for me.
8157
8158 * Eliminated bogus "Error gathering move list: no header" popup.  You
8159 could get this by observing two fast games at once without turning off
8160 GetMoveList.
8161
8162 * Disable WinBoard Sounds menu entirely in -ncp mode, since not even
8163 MoveSound is used in that mode.
8164
8165 * WinBoard bugfix: Several problems were caused if the user changed
8166 WinBoard's current directory in a Load, Save, or Browse dialog.  In
8167 particular, WinBoard.ini would get saved in the wrong directory, and
8168 sound .wav file names would not get saved with a full pathname.  I think
8169 all such problems are now fixed.
8170
8171 * WinBoard bugfix: iconizing the board after an aborted mouse resize would
8172 (partially) resize it to Tiny.
8173
8174 * WinBoard bugfix: board was not being drawn in color on 256-color
8175 displays.  This bug was introduced in 3.6.6.
8176
8177 3.6.6 -- Tue May 12 17:43:43 PDT 1998  Tim Mann
8178
8179 xboard and WinBoard beta release.  Note: not all reported bugs are fixed.
8180
8181 * Move animation in WinBoard, programmed by Henrik Gram.  Great stuff!
8182
8183 * Animate backward moves too.
8184
8185 * xboard bugfix: -font (and friends) can now specify a font alias (such
8186 as "fixed"), not just a full X Consortium name pattern.  Previously this
8187 would give a resource conversion error message.
8188
8189 * Some coding style cleanup in xboard.c.
8190
8191 * Earlier error check for moving wrong color piece in EditGame mode.
8192
8193 * Completed fix to pattern matching; see 3.6.5.
8194
8195 * Fixed some software rot bugs in Zippy.
8196
8197 * Split AnimateDragging as separate option from AnimateMoves.
8198
8199 * Added FlashMoves to options menu and -flash/-xflash to command line
8200 options (xboard only).
8201
8202 * Some preliminary work on visible bughouse holding support.  Most of the
8203 code is not present in this release because I have not gotten it working
8204 properly yet; my first approach went down a blind alley and I had to
8205 remove most of the partially working code in preparation for a rewrite.
8206
8207 3.6.5 -- Fri May  8 14:22:09 PDT 1998  Tim Mann
8208
8209 Not generally released.
8210
8211 * Pack bughouse holdings display in banner more tightly when board is one
8212 of the smaller sizes (when smallLayout or tinyLayout is true, that is).
8213 An interim measure, but should help.
8214
8215 * Completed fix to make move list parsing recognize the end condition and
8216 final comment.
8217
8218 * Fixed pattern matching for chatter (tells, etc.) to be more reliable.
8219 This should reduce the incidence of colors starting in the wrong place and
8220 of incorrectly matching things that look like other patterns inside
8221 chatter, such as "shout <12>".  (These errors were already rare.)
8222
8223 * WinBoard now lets you customize the list of ICS's in the startup dialog.
8224 For now, at least, requires editing WinBoard.ini with a text editor.
8225
8226 * Bug fix: WinBoard window sizing and position setting save/restore did
8227 not work right when the taskbar was at the top (or left side) of the
8228 screen and not in autohide mode.
8229
8230 * Merged xboard click/click mode and drag mode, and deleted
8231 ClickClickMoving option on menu.  Now if you click on a piece, it
8232 highlights and a further click on another square will move it.  (A second
8233 click on the same square takes down the highlight.)  Or if you press down
8234 on a piece and start to drag, you can drag it to a new square.
8235
8236 * When making click/click style moves, if your second click is on a piece
8237 of the same color, instead of saying "Illegal move", we now cancel the first
8238 starting square, replace it with the second, and wait for another click to
8239 finish the move.
8240
8241 * Separate -secondInitString.  Default: same as -initString.  Suggested by
8242 Remi Coulom.
8243
8244 * Patch from Frank McIngvale to make animation work with XIMs.  Yay!
8245
8246 * Changed move animation to happen after move is passed on to ICS or the
8247 chess engine, where applicable.  Fixed problems with updating moveList
8248 that this uncovered.
8249
8250 * Changed game list to show PGN result token for each game.
8251
8252 * The usual minor bug fixes.
8253
8254 3.6.4 -- Thu Apr 30 23:14:43 PDT 1998  Tim Mann
8255
8256 xboard and WinBoard beta test release.
8257
8258 * xboard documentation updated, both man page and info file.  An attempt
8259 to generate both from the same source with LinuxDocSGML was abandoned, at
8260 least for now.  WinBoard doc updated too.
8261
8262 * Merged updates to animation code from Hugh.  Fixed a couple of remaining
8263 bugs, mostly to do with handling Pause mode correctly.
8264
8265 * Added SaveSettingsOnExit to WinBoard.
8266
8267 * WinBoard now saves the last screen position of the Comment, Edit Tags,
8268 Game List, and Analysis windows (in addition to the board and ICS
8269 Interaction windows) in WinBoard.ini.
8270
8271 * WinBoard now provides a way to customize the right-button context menu
8272 in the output area of the ICS Interaction window.  For now, requires
8273 editing WinBoard.ini with a text editor.
8274
8275 * Various minor fixes to ICS message recognition, most affecting only Zippy.
8276
8277 * Colorize the notification when someone sends you a message while you are
8278 logged in, not the output of the "messages" command.
8279
8280 * Fixed colorization to turn off at the right place more reliably.
8281
8282 * Added a new color and WinBoard sound for "requests": abort, adjourn,
8283 draw, pause, and takeback.  The same color and sound are used for all of
8284 these.
8285
8286 * Added GUI to change sounds in WinBoard.
8287
8288 * Suppressed WinBoard error popup when a sound can't be played.  They were
8289 popping up when two separate WinBoards tried to play a sound at the same
8290 time (such as during a bughouse match).
8291
8292 * Fixed WinBoard crash when a sound file didn't exist.
8293
8294 * WinBoard ports of timestamp and timeseal now produce decent error
8295 messages if they fail to connect, and WinBoard captures the messages and
8296 puts them into a popup.  Previously WinBoard would exit with no message on
8297 such errors.
8298
8299 * WinBoard resizing with mouse improved; now accurately picks the largest
8300 size that fits in the new area.
8301
8302 * Added option to turn off error message popups.
8303
8304 * Added sizes slim, dinky, and teeny.
8305
8306 * Fixed some minor problems with error message wording.
8307
8308 3.6.3 -- Mon Feb 23 19:08:57 PST 1998  Tim Mann
8309
8310 xboard beta test release only.  Man page is updated for the changes, but info
8311 file is not.
8312
8313 * Bug fix: LoadGame could not load a PGN game whose first move was
8314 castling (which is possible from setup positions).
8315
8316 * Bug fix: we were ignoring illegal move messages from chess engines in
8317 modes where the engine is refereeing but not participating (EditGame,
8318 LoadGame, AnalyzeFile).  The problem was in a workaround for a Crafty bug,
8319 where Crafty generates a bogus illegal move message if a "." (used by
8320 the PeriodicUpdates feature) is sent in analysis mode when the current
8321 analysis reveals a forced mate.  Installed a different workaround (that
8322 works in most but not all cases) and reported the Crafty bug.  Bob Hyatt
8323 replied with a fix, so the Crafty bug should be gone in Crafty 14.12 or so.
8324
8325 * WinBoard only: enabled resizing board with the mouse.  It snaps to the
8326 nearest (but not too much larger) predefined size.
8327
8328 * The xboard default font is now sized according to piece size, just as
8329 clockFont and coordFont have always been.
8330
8331 * Added more sizes: bulky, moderate, average, middling, mediocre, petite.
8332
8333 * xboard only: Added Animate Moves and Click-Click Moving to Options menu.
8334
8335 * xboard only: Added code to animate piece movement, from Hugh Fisher.
8336
8337 * New feature: autoflag is implemented in MachineWhite, MachineBlack, and
8338 TwoMachines modes.  If it is on and either a chess program or the user
8339 oversteps his time, xboard will automatically call the flag and end the
8340 game.  This feature was requested by someone who runs matches between
8341 programs and wants to penalize GNU Chess for its habit of running slightly
8342 over at the end of a time control.  I personally think it's pointless.
8343
8344 * Fixed a bug in Zippy's pattern matching; he can now reply to ICC
8345 messages again.
8346
8347 * Generate prettier notation for illegal moves.  If a move is illegal only
8348 because it leaves the player in check, generate notation as if that were
8349 not illegal.  For instance, if two knights are a knight's move away from
8350 f3, one on g1 and one on e5 that is pinned, the notation would be Nf3 to
8351 move the g1 knight, Nef3 to move the e5 knight.  (Suggested by Philippe
8352 Schnoebelen.)  In addition, if a move is illegal because the type of piece
8353 moved cannot go that way, would be jumping over another piece, etc., we
8354 give fully disambiguated coordinate notation; for example, Ng1g3, Ke1xe8,
8355 d2xd8=Q, etc.  An alternative would be to still write Ng3 if there is only
8356 one knight on the board, or Ngg3 if the other knight is not on the g file,
8357 but life is too short to code up all this stuff, and perhaps the way I did
8358 it is better as it emphasizes that this move was really made despite being
8359 illegal.  I wonder if the new PGN standard revision will speak to notation
8360 of illegal moves?
8361
8362 * Fixed gross bug from 3.6.2: if a chess program said "checkmate" and
8363 White was left on move, the PGN outcome was "1-0 {Black mates}" instead
8364 of "0-1 {Black mates}"!  The bug occurred only for that specific string.
8365
8366 3.6.2 -- Wed Jul 23 16:47:29 PDT 1997  Tim Mann
8367
8368 * There was a bug in backing up from the end of a game against a chess
8369 engine, introduced when -reuse mode was added.  Fixed.
8370
8371 * Recognize "{" as terminating an ICS move list.  Previously we needed to
8372 see a prompt (containing %), but occasionally ICC can send more stuff
8373 right after a move list with no prompt in between.
8374
8375 * In WinBoard, -mm now implies -cp, so you don't get the startup dialog.
8376
8377 * WinBoard startup dialog no longer sets -scp.  People used to get
8378 confused because they would give the -fcp and -scp arguments, but omit
8379 -cp.  This would bring up the startup dialog, which would set both -fcp
8380 and -scp to the value in the engine name box.  Now you can change -scp
8381 only with the command-line argument.  That will confuse some people too,
8382 but hopefully fewer.  I think overall it's better than putting spaces for
8383 both -fcp and -scp in the dialog, which would puzzle newbies.
8384
8385 * Bug fix: Analyze File mode now works in WinBoard.
8386
8387 * Bug fix: WinBoard window no longer cuts off part of the bottom row if
8388 the menu bar wraps to a second line.
8389
8390 * Accept game end messages of the form "PGN-result {comment}" from the
8391 chess engine, where PGN-result is 0-1, 1-0, or 1/2-1/2.  Accept "resign"
8392 or "computer resigns" from the chess engine as a synonym for "0-1 {White
8393 resigns}" or "1-0 {Black resigns}". Accept any message from the chess
8394 engine containing "game is a draw" as a synonym for "1/2-1/2 {Draw}".
8395 Accept "White resigns" or "Black resigns".
8396
8397 * Enable "Action / Draw" menu item in chess engine mode.  It sends the
8398 command "draw" to the engine.  Accept any message from the chess engine
8399 containing "offers a draw" as a draw offer.  WARNING: Draw offers from the
8400 user and the engine (or from two engines) are not yet matched up by xboard
8401 in chess engine mode.  Two engines could get into a loop offering each
8402 other draws.
8403
8404 * Bug fix: Game end messages from the chess engine are always ignored in
8405 Zippy mode.  Previously they could sometimes be processed, which was
8406 sometimes making Zippy hang at the start of a new game that followed
8407 quickly after an old one.
8408
8409 * Zippy can now respond to titled players in channels.  Zippy will avoid
8410 talking to himself in a channel if he knows his own name.
8411
8412 * Bug fix: in colorization arguments, the bold setting was being ignored
8413 if the background color was defaulted.  (xboard only.)
8414
8415 * Extended ParseFEN to accept Crafty 12.2's interpretation of FEN.
8416 If fewer than 8 squares are given in a row, or fewer than 8 rows are
8417 given, the uncovered squares are empty.  Also, there can be a / after the
8418 8th row.
8419
8420 3.6.1 -- Sat May 17 01:02:33 PDT 1997  Tim Mann
8421
8422 * Bug fix: Hitting escape while entering a password on WinBoard no longer
8423 sets the font color back to black (which made further typing visible).
8424
8425 * Bug fix: On Windows NT 4.0, WinBoard /ics /icshelper=timestamp would
8426 often hang if you tried to exit with the Exit menu item, the [X] button,
8427 etc.  The same fix may also have corrected the problem where running a
8428 chess program with /xreuse would sometimes crash Windows 95 (but not NT)
8429 when the chess program was killed and quickly restarted.
8430
8431 * Bug fix: Periodic Updates would not work if turned on after having been
8432 off.  Also, the default was needlessly "off" in WinBoard.
8433
8434 * Zippy bug fix: Continuing an adjourned game was totally broken.  The
8435 wrong moves, or no moves at all, were being fed to the chess program.
8436
8437 * WinBoard change: Giving -ics without -icshost now pops up the startup
8438 dialog with "Use an Internet Chess Server" pre-selected, so that you get a
8439 menu of chess servers instead of going directly to ICC.
8440
8441 * Bug fix: WinBoard's SaveSettings was saving -icshost, -icsport, and
8442 -icshelper in winboard.ini.  This causes a problem if you use a different
8443 icshost later that needs the default values for icsport (5000) and
8444 icshelper ("", meaning none).
8445
8446 * Disabled complaints about unexpected "[Ii]llegal move" messages from
8447 the chess program; we still get them at times.
8448
8449 * Greatly simplified the code for Move Now and SIGINT (ATTENTION).  Fixes
8450 the bug where Move Now did not work with GNU Chess in WinBoard, and
8451 several more obscure bugs as well.  Reintroduces a minor bug: GNU Chess might
8452 not think on your time after a Move Now command.  Trying to fix this
8453 causes too many other problems.  Documented change in engine-intf.txt.
8454
8455 * Cleaned up code for obtaining ratings from ICS.  It was kludgey and may
8456 have had bugs on systems with no "Creating:" message.  It should fail
8457 gracefully there, just not finding the ratings.
8458
8459 3.6.0 -- Thu May  8 19:55:58 PDT 1997  Tim Mann
8460
8461 * WinBoard now has right-button context menus in the ICS Interaction
8462 window.  Some of the items do immediate commands on the player name you
8463 have selected or pointed to.  (Suggested by Paolo Casaschi.)  Also, the
8464 middle button or shift+right does a immediate Copy and Paste.
8465
8466 * Fixed a bug in Zippy's wild rejection.  The bug was causing Zippy to
8467 reject all forms of wild.  Now it rejects only 1, 9, 16, 17, and 24, as
8468 was intended.  These variants have different rules, while the other
8469 variants defined so far only have different starting positions.
8470 (Actually, wild 2, 3, and 4 never allow castling, but may sometimes by
8471 chance have king and rook start on squares where castling appears legal.
8472 This could cause a problem later.)
8473
8474 * Zippy now resumes adjourned games by feeding the chess program
8475 the move list instead of the position.  Setting -getMoveList to False
8476 restores the old behavior.  Feeding in the move list is better because
8477 it enables the chess program to correctly handle en passant legality,
8478 castling legality, draw by repetition, and draw by the 50 move rule.
8479
8480 * Added a WinBoard startup dialog for people who run WinBoard.exe without
8481 using the Start menu or reading the help file.  Instead of being dumped
8482 directly into GNU Chess mode, you now get a menu of choices.  You now have
8483 to give the new WinBoard -cp option to go directly into chess engine mode.
8484 I did not add this feature to xboard.
8485
8486 * Handling of "illegal move" from Crafty is now back on.  (It was turned
8487 off in 3.4.6; see below.)  Crafty 12.0 doesn't seem to send bogus ones
8488 anymore.  I did have to suppress sending time and otim in analyze mode to
8489 make this work, but there is no harm in that.
8490
8491 * Zippy now sends "gameend" to ICS at the end of each game.  You can alias
8492 this to "seek" or whatever you like.
8493
8494 * Added Crafty support for Move Now, using the "?" command.  We test
8495 whether this command exists by trying it once at the start of the first
8496 game, before it really makes sense.  If we don't get a message like
8497 "Illegal move ... ?", we assume it's OK.  (We're careful about this
8498 because sending a "?" to GNU Chess on Move Now keeps it from pondering the
8499 next move as it should.)
8500
8501 * Added support for a tellusererror command from the chess engine.  See
8502 engine-intf.txt.
8503
8504 * Attempted to make engine-intf.txt complete.
8505
8506 * Minor fixes/cleanup to GameEnds code, to be sure we always interrupt
8507 when needed, and always undo an extra move generated by stopping the chess
8508 program while it is thinking.
8509
8510 3.5.7 -- Sat May 03 22:37:44 PDT 1997  Tim Mann
8511
8512 Beta release of both xboard and WinBoard.
8513
8514 * Updated xboard documentation.  I really wish the man page was built from
8515 the info file instead of being separate!  It's a pain to update them both.
8516
8517 * Updated documentation of the interface between XBoard/WinBoard and chess
8518 programs, and renamed it to engine-intf.txt.
8519
8520 * Added support for tellics, telluser, and askuser commands from the chess
8521 engine.  See engine-intf.txt.
8522
8523 * Various bug fixes.  On WinBoard, 256 color displays are finally handled
8524 right; no more color flashing when you switch windows unless the colors
8525 really need to be updated.  Also, I think the problem of the console font
8526 failing to change or changing back by itself is finally fixed.
8527
8528 3.5.6 -- Tue Apr 29 03:08:00 PDT 1997
8529
8530 Beta release, WinBoard only.  ChangeLog was out of date in release,
8531 updated here.
8532
8533 * Added ICC timestamp and FICS timeseal to WinBoard distribution.  These
8534 are my own ports to Win32, based on and used by permission of the owners
8535 of the proprietary source code (Daniel Sleator for timestamp, Henrik Gram
8536 for timeseal).  The owners permit these programs to be distributed only in
8537 binary form (to help prevent cheating), so to avoid running afoul of the
8538 GPL, I have kept them as separate programs, not linked into the WinBoard
8539 address space.  Updated Start menu icons to use them.
8540
8541 * Miscellaneous smaller changes.
8542
8543 3.5.5 -- Fri Apr 25 03:06:00 PDT 1997
8544
8545 Beta release, WinBoard only.  ChangeLog was out of date in release;
8546 updated here.
8547
8548 * Added simple sound support to WinBoard.
8549
8550 * Updated WinBoard documentation.
8551
8552 * Internal implementation of the telnet protocol is now more complete.
8553 You can now hop through a VMS host on the way to ICS.  For example, do
8554 "xboard -ics -icshost vms.host.edu -icsport 23", then log in.  Do not use
8555 the -telnet flag; that says to use an *external* telnet program.  To avoid
8556 double echoes, you need to force character mode in VMS telnet after
8557 connecting from VMS to ICS.  Do "^]^Mset mode char^M^M".
8558
8559 * Display opponent names in the title bar for MachineWhite, MachineBlack,
8560 and TwoMachines modes.
8561
8562 * WinBoard now has an installer, built with InstallShield.  The installer
8563 works with a binary-only distribution.  Sources are still freely
8564 available, but now separately.
8565
8566 * Added SaveSettings to WinBoard, which saves current option settings to
8567 winboard.ini.  Made sure all options can be saved and loaded, including
8568 fonts and com port settings.
8569
8570 * If the game ends while you are dragging a piece, we now don't let you
8571 finish the move.  Formerly the move was accepted and your opponent's clock
8572 would start running again.
8573
8574 3.5.4 -- Fri Apr 18 01:15:24 PDT 1997  Tim Mann
8575
8576 Beta test release of WinBoard and xboard.  The documentation remains
8577 out of date.
8578
8579 * Many fixes and improvements to new WinBoard user interface code.
8580
8581 * In Zippy mode, avoid sending another copy of the same move to the chess
8582 program if ICS sends us another copy of the board image.  Hard to believe
8583 it took me until now to diagnose and fix this problem!
8584
8585 3.5.3 -- Sat Apr 12 19:49:33 PDT 1997  Tim Mann
8586
8587 Beta test release of WinBoard and xboard.
8588
8589 * Fixed fatal bug in WinBoard input handling.
8590
8591 * Made code to stop chess program for reuse a bit smarter.  Removed kludge
8592 of "white" in initString; it didn't work well, and is unneeded
8593 with Crafty 11.21 and later.
8594
8595 3.5.2 -- Sat Apr 12 15:40:01 PDT 1997  Tim Mann
8596
8597 Beta test release of WinBoard.
8598
8599 * Ignore check and permit promotion to King during suicide games; no need
8600 to turn off TestLegality.
8601
8602 * Renamed CheckLegality to TestLegality to avoid confusion with the chess
8603 term "check".
8604
8605 * Added Rematch to Action menu.
8606
8607 * WinBoard now has a custom ICS interaction window with scrollback, a
8608 separate line for input, and colorization.  Accelerators that conflict
8609 with normal editing keys were changed (by requiring Alt+) so they can work
8610 in both the console and the main window.
8611
8612 * WinBoard error popups are now non-modal and disappear when you make a
8613 new move, as in xboard.
8614
8615 * Configure now defaults to --disable-ptys on all systems.  If anyone has
8616 an ancient SysV system where pipes don't work with select, they can still
8617 do "configure --enable-ptys" explicitly.  I would appreciate getting a bug
8618 report if this happens to anyone, with complete output from configure and
8619 "uname -a".
8620
8621 * "make install" now makes the installation directories too.
8622
8623 * Fixed a bug that would cause an "Illegal move" message for Black from
8624 GNU Chess to be incorrectly considered bogus.
8625
8626 * Handle name changes during an ICS game (FICS bname and wname commands).
8627
8628 * You can force both chess programs to be killed at the end of each game
8629 by turning off the reuseChessPrograms option.  There are still some
8630 problems with reusing Crafty even in version 11.20.
8631
8632 * Now the second chess program stays around by default too, if it ever
8633 gets started.
8634
8635 3.5.1 -- Sat Apr  5 16:47:48 PST 1997  Tim Mann
8636
8637 Beta test release.
8638
8639 * Don't kill off and restart the chess program for each game; keep the
8640 same one running, using the "new" command to start a new game.  This
8641 change works around the problem in Windows 95 that makes WinBoard crash it
8642 at times, and is generally desirable to make new games start faster.  The
8643 second chess program (for TwoMachines) is still killed at the end of the
8644 game, and unfortunately this can still crash Windows 95.  Temporarily
8645 added "white" to the initString to make this work with Crafty 11.20, which
8646 has a minor bug in "new".  Older versions of Crafty have worse bugs in
8647 "new"; they should not be used with this version of xboard.
8648
8649 * Support for FICS suicide chess: Parse illegal moves (that leave King in
8650 check) in game history.  If CheckLegality is off, allow promotion to King
8651 and illegal moves in game files.  We still generate e2e4 style notation
8652 for illegal moves.
8653
8654 * Handle FICS "has timeseal; checking" message.
8655
8656 * Changed the coords from white back to black; this was a bug.
8657
8658 * Fixed problems compiling with K&R compilers.
8659
8660 * Fixed an old bug in RegisterMove that was crashing cmail on some systems
8661 (notably linux).
8662
8663 3.5.0 -- Thu Jan  2 16:59:49 PST 1997  Tim Mann
8664
8665 Thanks to Frank McIngvale for much of the work on versions 3.4.4 and above!
8666
8667 * Fix Crafty resumed game time bug (frankm)
8668
8669 * Word wrap text in Analysis window (frankm)
8670
8671 * More debug info for XPM loading (frankm)
8672
8673 * Replaced config.sub, config.guess, etc., with up-to-date versions from
8674 autoconf 2.12.  Hopefully this will fix problems on Pentium Pro machines.
8675
8676 * Removed some Makefile gunk that was causing looping for one person.
8677
8678 3.4.7 -- Thu Dec 19 14:22:41 PST 1996  Tim Mann
8679
8680 All changes from Frank:
8681
8682 * Retrieve ratings from ICC (and FICS, etc., when they add the Creating:
8683 message), save them in the PGN tags, and pass them to Crafty in Zippy mode.
8684
8685 * Add settable time delay between characters in ICS login script.
8686
8687 * Colorize messages like personal tells.  Fix false recognition of channel
8688 tells.
8689
8690 * Pass "tells" from Crafty through to ICS (in Zippy mode).
8691
8692 * Implement ~/ filename convention from C shell for game and position file
8693 names.
8694
8695 * ZIPPYACCEPTONLY feature for testing.
8696
8697 3.4, patchlevel 6 -- Sat Nov 23 16:58:50 PST 1996  Tim Mann
8698
8699 * Put recognition of "illegal move" messages from Crafty for
8700 illegal castling, etc., inside an #if that is currently turned off,
8701 because of a bug in Crafty that generates bogus "illegal move" messages
8702 after some moves that are actually legal and accepted by Crafty.
8703
8704 * Added -checkLegality option; previously this could not be turned off.
8705
8706 * Fixed an old bug in finding default board size parameters.
8707
8708 * Differentiated among channel tell, kibitz/whisper, and personal tell/say.
8709
8710 * Fixed a bug in detecting Xpm in the configure script.
8711
8712 3.4, patchlevel 5 -- Mon Nov 18 16:22:53 PST 1996  Tim Mann
8713
8714 * Added zic2xpm to the kit; it had been omitted by mistake.
8715
8716 * Added some default colors for -colorize
8717
8718 3.4, patchlevel 4 -- Sat Nov 16 18:10:17 PST 1996  Tim Mann
8719
8720 This is meant to be a beta release in preparation for version 3.5.
8721
8722 * Added InfoXBoard and ManXBoard to the Help menu.
8723
8724 * Made Frank's ICS input box optional, defaulting to off.
8725
8726 * Merged in Frank McIngvale's XbKit.  Many new features, including
8727 -clickClick mode, the Analysis modes, piece flashing, ZIICS import,
8728 ICS text colorization, and the ICS input box.  Many thanks to Frank for
8729 supplying and documenting this code.
8730
8731 3.4, patchlevel 3 -- Mon Nov 11 18:23:14 PST 1996  Tim Mann
8732
8733 Small set of changes made while Frank McIngvale was working on XbKit in
8734 parallel.  Unreleased in this form.
8735
8736 * Updated zippy.README.
8737
8738 * Removed useless X event handler and removed strange code for copying
8739 form translation table to board that worked around the bug it caused.
8740 This makes changing bindings in .Xdefaults more straightforward.
8741
8742 * Now pressing the Control key steps back one move, and releasing it steps
8743 forward again.
8744
8745 * Moved quit from "q" to "Q" for greater safety.
8746
8747 * Use "unobserve" instead of "observe" to stop observing; needed on FICS.
8748
8749 * Support for interface variable.
8750
8751 * Strip titles from people who are talking to us, so (for example) Zippy
8752 won't try things like "tell Darooha(*) hello".  Needed on FICS.
8753
8754 3.4, patchlevel 2 -- Tue Jul  9 19:06:42 PDT 1996  Tim Mann
8755
8756 This patchlevel is not planned to be an announced release.  It's in
8757 preparation for integrating Frank McIngvale's XbKit.  It mostly contains
8758 minor fixes I've accumulated since 3.4.pl1.
8759
8760 * WinBoard /telnet option now fires up an external program, as
8761 with xboard, instead of trying to use a feature of NT 3.1 that does not
8762 exist in later versions of NT or in Windows 95.  ChangeLog for 3.4.pl1
8763 said this had been implemented there, but it really wasn't.
8764
8765 * Indicating player to move by the icon color now works under Windows 95.
8766
8767 * WinBoard now kills the chess program when you exit using the system menu
8768 or the [X] button.  Thanks to Michael Lowe.
8769
8770 * Minor changes to Zippy, including: Now understands wild challenges on
8771 FICS; these used to crash it.  Removed limit on how fast a game will be
8772 accepted.  Use "set formula ..." on the chess server to limit this if you
8773 are using GNU Chess.  Now sends correct opponent name to Crafty.
8774
8775 * Added some missing default values to documentation.  Thanks to Stuart
8776 Cracraft.
8777
8778 * Bugfix: Trying to print "No fonts match pattern" error message would
8779 crash.  This can happen to Linux users who don't install Helvetica, for
8780 example.
8781
8782 * Bugfix: Defaulting feature in -size n,n,n,n,n,n would put us in an
8783 infinite loop.
8784
8785 * Added more directories to search for Athena widgets on HPUX.
8786
8787 * New cmail (3.12) from Evan Welsh; includes small fix from Kayvan Sylvan.
8788
8789 * Recognize "illegal move" messages from Crafty for illegal castling, etc.
8790
8791 * Bugfix: "name" command added to zippy.c for Crafty was producing error
8792 message if GNU Chess was in use.
8793
8794 * In bughouse mode, suppress holding messages from console window; show
8795 holdings only in banner.
8796
8797 * Minor fixes/cleanup to Makefile.in and configure.in.
8798
8799 3.4, patchlevel 1 -- Mon Dec 11 13:43:12 PST 1995  Tim Mann
8800
8801 * This patchlevel updates WinBoard to match xboard, and includes a few
8802 fixes and minor improvements.  "-size tiny" and "-size n,n,n,n,n,n"
8803 are still not implemented for WinBoard.
8804
8805 * Installed support for Crafty based on code from Bob Hyatt.
8806 Currently the only documentation for this is in the FAQ, and a few
8807 things don't work with Crafty 8.23.  Please do not report these
8808 problems as bugs in either xboard or Crafty.  Bob and I know about
8809 them.  The worst ones (if not all of them) should be fixed in Crafty
8810 8.24.
8811
8812 * Changed the kludge command we send when gnuchess wants to print
8813 something that doesn't end with a newline, from "help" to "bogus".
8814 This works because the error message gnuchess prints ends with a
8815 newline.  It also improves compatibility with Crafty, which doesn't
8816 need the kludge, but for which sending "help" causes a problem.
8817
8818 * Don't draw grid at all if lineGap is 0; previously we drew the grid
8819 with X "0-width" lines (usually 1 pixel wide) and then overwrote it.
8820
8821 * Makefile: Removed xboard.info from "all" target so we won't try to
8822 rebuild it, because this fails on hosts that don't have makeinfo
8823 installed.  Other minor fixes to "clean" targets, etc.
8824
8825 * Fixes and cleanup to Auto Comment code that handles continuation
8826 lines and highlighting.
8827
8828 * Auto Observe now tries to observe the game from the point of view of
8829 the player who was on your gnotify list.  Requested by rng.
8830 Limitations: We can't tell which player it was unless you have ICS
8831 highlighting turned on.  Also, currently "observe foo" works as
8832 required (observing from foo's point of view) only on ICC, but FICS
8833 will probably implement this soon.
8834
8835 * "-size tiny" now makes the default font smaller automatically.  This
8836 was implemented by introducing an extra Form widget in the hierarchy
8837 for all xboard windows, named either normalLayout, smallLayout, or
8838 tinyLayout.  So you can have resource specifications that apply only
8839 to certain layouts; in particular, XBoard*tinyLayout*font.
8840
8841 * Bug fix: EditGame or EditPosition while playing or examining still was
8842 not really being permitted.
8843
8844 * WinBoard bug fix: On the EditPosition menu, King did not work.
8845
8846 * Added text catalog of WinSock error messages to WinBoard, because
8847 Microsoft still has not put them in the system message catalog.
8848
8849 * Removed support for older ICS game-ending messages that do not have
8850 a PGN result token (*, 0-1, 1-0, or 1/2-1/2) after the closing '}'.
8851 The code for older messages was sometimes firing on the newer
8852 messages, due to parsing ambiguity.  If the current code sees an old
8853 message, it will understand that the game is over, but will always
8854 display * as a result token instead of trying to guess the result by
8855 interpreting the text message.
8856
8857 3.4, patchlevel 0 -- Tue Nov 21 01:02:50 PST 1995  Tim Mann
8858
8859 * This patchlevel was released for xboard only.
8860
8861 * Updated the info file.  It should now be as up-to-date as the man page,
8862 with good English except in the parts that pertain only to AmyBoard.
8863
8864 * Added "-size tiny", requested by Bob Hyatt.  Also cleaned up bitmap
8865 support and added "-size n,n,n,n,n,n" to allow arbitrary-sized bitmaps,
8866 if the actual bitmaps are supplied by the user.
8867
8868 * Updated bughouse support.
8869
8870 3.3, patchlevel 4 -- Sat Nov 18 02:27:21 PST 1995  Tim Mann
8871
8872 * Unreleased beta that works with preliminary FICS bughouse code.  Will
8873 need changes before release to track FICS message changes.
8874
8875 * Removed use of .EX macro from man page.  It is not supported by some
8876 nroff -man macro packages, notably the one on Slackware Linux.  Switched
8877 to boldface for references to xboard and other commands within the man
8878 page, as this seems to be the modern way.
8879
8880 * Bug fix: If ICS rejected a move, it was correctly undone on the board,
8881 but the message widget still displayed the bad move.  Reported by DAV.
8882
8883 * Normally, xboard in ICS mode fetches the move list whenever the board
8884 display switches to a new game.  Doing this is now an option
8885 (getMoveList) that can be turned off, which is useful if you are watching
8886 multiple blitz games.  Requested by rng.
8887
8888 * Move list fetching code is now smarter: it ignores a move list if it is
8889 not for the right game.
8890
8891 * Added support for bughouse as implemented on FICS.  Holdings are shown
8892 in the window title in place of the strength numbers.  A menu on mouse
8893 buttons 2 and 3 (same on both) lets you drop pieces.  There is no checking
8894 as to whether you actually hold the piece you are trying to drop; we rely
8895 on ICS to check that.  Notation of the form P@f7 is generated and parsed.
8896 The mate detector does not understand that non-contact mate is not really
8897 mate in bughouse, but this does no real harm.  It results in a "#"
8898 suffix being displayed on the move notation, but xboard does not assume the
8899 game is over.
8900
8901 * Bug fix: Promotion to a knight was not working with ICC!  Thanks to
8902 Wendigo for the report.
8903
8904 * Bug fix: Special pty code for host types *-*-aix3* and *-*-irix3*
8905 (supplied from configure.in) had a bug that would cause childio.c to
8906 fail to compile, due to a "continue" that was not within a loop.
8907
8908 * Bug fix: In pgntags.c, memory was being freed while still in use.  One
8909 symptom this caused was that on some machines, cmail would fail with a
8910 message that it could not find the BlackNA tag.  The error was in some
8911 submitted code that I included in version 3.2.pl3 without reading
8912 carefully enough.  Anders Forberg noticed the symptoms, and Evan Welsh
8913 (who had nothing to do with causing the bug) found the bug and submitted a
8914 fix; thanks to them both.
8915
8916 * Removed restriction against using EditGame while playing, observing,
8917 or examining on ICS.  You still get a warning popup.
8918
8919 3.3, patchlevel 3 -- Sat Sep 16 11:44:05 PDT 1995  Tim Mann
8920
8921 * Bug fix: Going directly from MachineWhite to TwoMachines mode would kill
8922 off the second chess program after Black's first move.
8923
8924 * Added -timeIncrement feature.  Thanks to Joel Rivat.
8925
8926 * Deleted code that tries to keep you from observing more than one game,
8927 or observing while playing or examining.  There is actually no problem in
8928 doing this, except that every time an update comes in from a different
8929 game than is currently being displayed, xboard fetches the history of the
8930 new game, which may be time-consuming if you are on a slow link.
8931
8932 * Fixed configure so as not to crash when neither lex nor flex is found.
8933 lex or flex is needed only if the user wants to rebuild parser.c.  Thanks
8934 to Phil Humpherys for reporting the crash.
8935
8936 * Bug fix: config.h.in used #define instead of #undef for some macros used
8937 in the pty code in childio.c.  This causes the code to fail to compile on
8938 some architectures, because the symbols are supposed to be undefined, not
8939 defined to empty, when they are not set in configure.  Bug originated in
8940 3.3.pl0 when config.h was introduced.  Thanks to Phil Humpherys for report.
8941
8942 * Bug fix: ShowThinking would not show anything when current position had
8943 no move to display in the move window.  E.g., if position was created by
8944 LoadPosition or EditPosition.
8945
8946 3.3, patchlevel 2 -- Mon Aug 28 11:11:11 PDT 1995  Tim Mann
8947
8948 * Zippy code was omitted from xboard-3.3.pl1 by mistake; now included.
8949
8950 * For WinBoard, added hint to help file that you may need to turn off
8951 LocalLineEditing while typing dialing commands to your modem.
8952
8953 3.3, patchlevel 1 -- Sat Aug 19 15:13:30 PDT 1995  Tim Mann
8954
8955 * Zippy distribution is no longer separate from regular xboard distribution.
8956
8957 * Deal properly with Show Thinking output from GNU Chess when it is
8958 thinking on its opponent's time.  In TwoMachines mode this output is
8959 suppressed to avoid interfering with the output from the machine that is
8960 on move; in other modes it is displayed (including the move that GNU Chess
8961 is predicting the user will make next).  GNU Chess produces this output
8962 only if it is built without -DQUIETBACKGROUND defined; this symbol is
8963 defined by default in patchlevels before pl75, but undefined by default in
8964 pl75.
8965
8966 * Bug fix: Handling of initial board position in move list for wild games
8967 was broken, so wild games could not be observed and adjourned wild games
8968 could not be continued.  Thanks to "Maximum Entropy" for the bug report.
8969
8970 * Added feature: algebraic notation now shows "+" indicator for check
8971 and "#" for checkmate, as called for in PGN standard.  Thanks to Kevin
8972 Maher for the suggestion.
8973
8974 3.3, patchlevel 0 -- Thu Jul 27 22:21:07 PDT 1995  Tim Mann
8975
8976 * Changed configuration to use a config.h file instead of passing zillions
8977 of -D options on the cc command line.
8978
8979 * Merged a small fix and some updates to the texinfo file from Jochen
8980 Wiedmann.  The texinfo file still needs work.
8981
8982 3.2, patchlevel 5 -- Tue Jul 18 20:29:39 PDT 1995  Tim Mann
8983
8984 * Beta test release of xboard only.
8985
8986 * Updated WinBoard code to include new xboard features.
8987
8988 * Added texinfo file from Jochen Wiedmann to the release, but not as the
8989 primary documentation.  It needs updating, and the English needs work.
8990 I did make a few improvements, mostly to change incorrect uses of @var to
8991 either @samp or @code as appropriate.
8992
8993 * Merged in code changes to 3.2.pl4beta from Jochen Wiedmann.
8994
8995 * Fixed EditComment; did not pop up window in previous beta.
8996
8997 * Added AutoComment feature.
8998
8999 * Added GameListDestroy to disable the outdated game list popup in cases
9000 where we load a new game file without building a new popup.
9001
9002 * Added yyskipmoves feature to parser.l to speed up building of gamelist.
9003
9004 * gamelist.c wouldn't compile with a non-ANSI compiler.  Fixed.
9005
9006 * Change to yy_text handling in patchlevel 3 still had problems.  Can't
9007 use AC_DECL_YYTEXT in configure.in, because that defines YYTEXT_POINTER
9008 according to whether the lexer on the current host makes yytext a pointer.
9009 But most people will be using a parser.c that was generated on another
9010 host and shipped with the package.
9011
9012 3.2, patchlevel 4 -- Sun Jun 25 19:13:43 PDT 1995  Tim Mann
9013
9014 * Beta test release of xboard only.
9015
9016 * Added FIREWALLS section to man page.
9017
9018 * Changed -icsport to be a string.  Now with the -telnet option,
9019 specifying -icsport "" suppresses the second argument to telnet.
9020
9021 * Added EditTags feature.  Removed AboutGame from menu, because EditTags
9022 subsumes it.  EditTags suggested by Jochen Wiedmann and first implemented by
9023 him in AmyBoard.  xboard implementation is my own.
9024
9025 * Fixed some missing or incorrect prototypes.
9026
9027 3.2, patchlevel 3 -- Sat Jun  3 18:57:38 1995  Tim Mann
9028
9029 * Beta test release of xboard only.
9030
9031 * New version of cmail from Evan Welsh, to fix compatibility problems with
9032 perl 5.0.
9033
9034 * Added game list feature on Load Game, based on code from Jochen
9035 Wiedmann.  Integrated it with cmail.
9036
9037 * Several bug fixes from Jochen Wiedmann, including one to my yy_text
9038 workaround for the difference in the type of yytext between lex and flex.
9039
9040 * Handle clock pause on FICS.
9041
9042 * Suppress clocks in untimed FICS games (time control 0 0).
9043
9044 * Rebuilt configure script with autoconf 2.3.  This fixes a bug in
9045 configuring for X11R6, where -lSM -lICE would not be added when needed.
9046
9047 * Fixed inconsistent type declarations on IntSigHandler and
9048 CmailSigHandler.  Bug report from Josh Daynard.
9049
9050 * backend.c wouldn't compile with a non-ANSI compiler.  Fixed.
9051
9052 3.2, patchlevel 2 -- Tue Feb  7 14:50:30 1995  Tim Mann
9053
9054 * Minor release of both xboard and WinBoard.
9055
9056 * Added recognition of some FICS messages.  On the other hand FICS is also
9057 changing some of its messages to match what xboard already recognizes.
9058
9059 * Temporarily went back to using "promote" command on ICS instead of
9060 "a7a8=Q", because FICS doesn't implement the latter yet.
9061
9062 * We now avoid using overlapped I/O on pipes in WinBoard, to make Windows
9063 95 beta 2 happy.  This lets WinBoard work with GNU Chess on Windows 95!
9064
9065 * Installed patches from Jochen Wiedmann to coordinate with Amiga XBoard.
9066
9067 * Installed patch to cmail bug in LoadGame from Evan Welsh.
9068
9069 * Bugfix: checkmate and stalemate moves entered with EditGame in ICS mode
9070 were not being handled correctly.  Bug was in GameEnds().
9071
9072 * Implemented EchoOn and EchoOff for xboard, using system("stty echo\n").
9073 Now passwords won't be echoed when you connect directly to ICS.  Also,
9074 telnet negotiation characters aren't displayed (when possible).
9075
9076 * Implemented more of the telnet protocol.  Now connecting to a telnet
9077 server with "-icsport 23" should work even without giving the -telnet
9078 option.  The telnet is in "old line-by-line mode".
9079
9080 3.2, patchlevel 1 -- Sat Dec 10 13:50:46 1994  Tim Mann
9081
9082 * This patchlevel released for WinBoard only.
9083
9084 * winboard.c: Fixed ConsoleInputThread().  Needed to change CRLF to LF,
9085 not to CR.  This was stopping normal /ics mode from working.  Thanks to
9086 Asher Kobin for the bug report.
9087
9088 * winboard.c: Fixed Raw(), EchoOn(), EchoOff().  Now they take effect
9089 immediately, not on the next console read after the one in progress.
9090
9091 * winboard.c: Attempted to make WinBoard work with gnuchessx running
9092 directly on Windows (not remotely via rsh).  It now works on NT, but only
9093 if gnuchess is told not to think on its opponent's time ("easy\n" removed
9094 from initString).  The problem seems to be that GenerateConsoleCtrlEvent
9095 is not doing anything.  On Windows 95 beta 2, we get error messages on
9096 both reading and writing to gnuchessx; I didn't investigate why.
9097
9098 3.2, patchlevel 0 -- Wed Dec  7 13:23:36 1994  Tim Mann
9099
9100 * Thanks to all the beta testers who gave me feedback: Josef Nelissen,
9101 Steve Booth, Evan Welsh, Dima Dakhnovsky, Chris Petroff, Peter Jansen,
9102 Derek Terveer, Michel van der List, Richard Lloyd, Shelly Mistry, and Mike
9103 Lee.  Sorry if I forgot anyone.  Thanks to Virendra Kumar Mehta for
9104 information about DYNIX/ptx.
9105
9106 * Don't exit on keyboard EOF unless we get two in a row.
9107
9108 * WinBoard only: added -localLineEdit switch to allow turning off local
9109 line editing if you really want to.  It is still a bad idea to let the
9110 echoing be done remotely, however; see below.
9111
9112 * Fixed some configure problems on HP-UX.  [Steve Booth]
9113
9114 * Fixed (I hope) configure problem on SunOS 5.3/Solaris 2.3.  [Josef Nelissen]
9115
9116 * cmail bugfix from Evan Welsh (cmail 3.4).
9117
9118 3.1, patchlevel 9 -- Fri Dec  2 23:54:56 1994  Tim Mann
9119
9120 * Beta distribution only
9121
9122 * Always do local echo/edit of user typing in ICS mode.  Doing the echo
9123 downstream may seem nicer in some modes, and it can be hard to turn that
9124 echo off, but the echoed characters can be interleaved with ICS output
9125 and make it impossible to parse correctly.  For xboard this involved only
9126 a change to recommendations in the man page, as Raw() isn't implemented.
9127 For WinBoard, removing Raw() made a real difference.  Added code in
9128 WinBoard to change /r/n back into /r on keyboard input, as we get the
9129 former when Raw() is not called.
9130
9131 * Do not issue ICS "refresh" command after we start to observe a game
9132 unless we get to the next prompt without seeing a board image.  Newest
9133 version of ICS doesn't require this refresh, but old versions around still
9134 do.
9135
9136 * cmail bugfix and small code cleanup in LoadGame, from Evan Welsh.
9137
9138 * Added keyboard accelerators N/P for LoadNextGame/LoadPreviousGame.  Evan
9139 Welsh request.
9140
9141 * Using "-" on the command line as a filename for loading (saving) games
9142 or positions specifies the standard input (standard output).  Alain Picard
9143 suggestion.
9144
9145 * On WinBoard only, a command line option without a leading '-' or '/' is
9146 now taken as the value of -lgf.
9147
9148 * Changed to not use stdin, stdout, stderr as initializers in backend.c;
9149 needed for GNU libc compatibility.  You also must build parser.c with flex
9150 (not lex) if you are using GNU libc, to avoid having the same problem
9151 there.
9152
9153 * Changed WinBoard to avoid using "overlapped" input on the console.  It
9154 now seems to fully work on Windows 95 beta 2.
9155
9156 * Improved comment popups on WinBoard.  Now newlines are handled properly,
9157 and the plain Comment popup window doesn't disappear and reappear when we
9158 step to a new move with a new comment.
9159
9160 * Fixed bugs in detecting the absence of the time and otim commands.
9161
9162 * Added built-in implementation of rcmd protocol to WinBoard.  Windows NT
9163 does not implement passing signals through rsh, and Windows 95 does not
9164 have rsh at all.
9165
9166 * Added -remoteUser option.
9167
9168 3.1, patchlevel 8 -- Mon Nov 28 15:26:07 1994  Tim Mann
9169
9170 * Beta distribution only
9171
9172 * Rearranged ChangeLog file into reverse chronological order to be closer
9173 to GNU standards.
9174
9175 * Integrated new cmail code from Evan Welsh (including cmail RCS rev 3.2).
9176 Includes a bug fix to TruncateGame.
9177
9178 * Updated ICS address to be chess.lm.com.
9179
9180 * Bug fixes to handling the aftermath of FatalError.  Thanks to Chris
9181 Petroff for the bug report.
9182
9183 * Test for remsh before rsh, other fixes for HP-UX.  Thanks to Richard
9184 Lloyd.  I wasn't able to do all the things he suggested, so there may
9185 still be some rough edges in building on HP-UX.  See the FAQ file for hints.
9186
9187 * Bug fix; added missing check for HAVE_SYS_SYSTEMINFO.  Thanks to Josef
9188 Nelissen for testing on Solaris 2.x.
9189
9190 * Updated WinBoard to match xboard.  (WinBoard still has a few option
9191 dialogs that don't exist in xboard.)
9192
9193 * Changed Hint output to a popup.
9194
9195 * ShowThinking output and move output no longer overwrite each other.
9196 ShowThinking output won't appear if the displayed position is not current.
9197 ShowThinking output in TwoMachines mode made clearer and documented.
9198
9199 * Implemented --enable-ptys and --disable-ptys arguments to configure.
9200
9201 * Fixed Book and Hint code to work over a pty with echo enabled and tabs
9202 expanded to spaces.  Thanks to Dima Dahknovsky for the bug report.
9203
9204 * Moved Attention calls from all over xboard to one place, inside
9205 SendToProgram.
9206
9207 * Added bulletproofing to ShowThinkingEvent.
9208
9209 * Added code to handle "refresh N" boards that come in from ICS properly,
9210 assuming ICS is changed to mark them with a new relation code (-3).
9211
9212 3.1, patchlevel 7 -- Sun Nov 13 22:16:01 PST 1994 -- Tim Mann
9213
9214 * Beta distribution only
9215
9216 * Changed ShowThinking to just show the current best line in the
9217 DisplayMessage area, instead of dumping everything to stdout.
9218
9219 * Installed new cmail (RCS rev 3.1) and cmail.man (RCS rev 1.10), and
9220 changes to cmail code in backend.c, from Evan Welsh.
9221
9222 * Miscellaneous minor fixes.
9223
9224 3.1, patchlevel 6 -- Fri Nov  4 12:53:53 PST 1994 -- Tim Mann
9225
9226 * This patchlevel was not actually released to anyone.
9227
9228 * Updated the pty code to be based on GNU Emacs 19.24, and moved it to a
9229 separate file.  It was hard to split out just the pty configuration from
9230 all the stuff emacs does with its custom configure script and .h files,
9231 but I did my best.
9232
9233 * Converted from imake to GNU autoconf.  This was a serious upheaval.
9234
9235 * Put in code to help trap "error gathering move list" problem reported by
9236 Michel van der List if it recurs.  I couldn't reproduce it.
9237
9238 3.1, patchlevel 5 -- Mon Oct 31 21:12:00 PST 1994 -- Tim Mann
9239
9240 * Beta distribution only.
9241
9242 * We now test for checkmate or stalemate in EditGame mode after every user
9243 move, and in LoadGame mode whenever we hit the end of a game without
9244 seeing a PGN end marker.  cmail needs an update to deal with this
9245 correctly; Evan promises one.
9246
9247 * Bugfixes in new move generator.  Thanks to Mike Lee for reporting one of
9248 the bugs.
9249
9250 * Imakefile was omitted from patchlevel 4.
9251
9252 3.1, patchlevel 4 -- Mon Sep 19 18:19:46 PDT 1994 -- Tim Mann
9253
9254 * Beta distribution only.
9255
9256 * The move generator includes a mate tester.  Initially this is used only
9257 by cmail, and even that usage needs further work.
9258
9259 * Wrote a true move generator and used it to replace all the move
9260 disambiguation and legality checking code in parser.l.  The move generator
9261 is capable of dealing correctly with en passant and castling availability,
9262 but the rest of the program still does not keep track of this information.
9263
9264 * Bug fix: xboard did not handle "foo has made you an examiner of game 23"
9265 message.  Thus you could not use examine features until the next board
9266 came in, showing your new relation to the game.  Thanks to POOKIEWOOKIE on ICS
9267 for the bug report.
9268
9269 * Added AutoObserve feature.  Thanks to Chris Petroff for the idea.
9270
9271 * Added Book feature to use new gnuchess "bk" command.  Mike McGann request.
9272
9273 * Redid code to handle missing "time" command in gnuchess, because latest
9274 gnuchess no longer sends a response to this command.
9275
9276 * Eliminated need for -DFLEX.  Thanks to Michael Shields (Vladimir?) for
9277 the idea.
9278
9279 * Added missing code to implement MoveNow in TwoMachines mode.
9280
9281 * Added ShowThinking feature.  Thanks to Richard Lloyd for the idea.
9282
9283 * Applied patches from Evan Welsh; some fixes and improvements to the
9284 cmail code.
9285
9286 * Fixed bug in moving from EndOfGame mode to MachineWhite or MachineBlack,
9287 introduced in previous patchlevel.  Also fixed related bug in ending a
9288 game in ICS mode; was entering EndOfGame mode instead of IcsIdle.
9289
9290 * Added patch to implement internetChessServerLogonScript flag, from Kevin
9291 O'Connor.  Thanks!
9292
9293 3.1, patchlevel 3 -- Wed Sep  7 13:22:07 PDT 1994 -- Tim Mann
9294
9295 * Beta distribution only.
9296
9297 * Merged in new cmail code from Evan Welsh.  He added the ability to have
9298 more than one game per message, needed for official IECG matches.  I added
9299 the ability to resign or offer/accept/decline a draw in a cmail game.
9300
9301 * Bugfix: invalid -tc option caused segmentation fault; DisplayFatalError
9302 was called too early in initialization.  Georges Honore reported this bug.
9303
9304 * Decided to keep EndOfGame mode as an element of the user interface---it
9305 means that a gnuchess game or loaded game has ended, and the user must
9306 explicitly select EditGame to edit it, rather than just being able to
9307 enter more moves freely.  But internally there is no longer an invariant
9308 tying this mode to whether the chess program is running.
9309
9310 * Zippy bugfix: Was saving only the final position in the -sgf file when
9311 the game ended by something other than resignation or flag.  Also fixed
9312 the longstanding bug that Zippy would think the final board of such a game
9313 was a new game and restart the chess program.
9314
9315 * Now does a better job of faking castling availability in FEN.  We still
9316 don't really keep track of it, but now at least we don't say that castling
9317 is still available when the king or rook is not on its home square.
9318
9319 * Bugfix: Initial board of game history for wild games was going through
9320 too much processing, causing us to forget the game length, which is now
9321 needed by ParseGameHistory.  This was causing problems with resuming
9322 adjourned wild games.
9323
9324 * Updated ICS host to ics.onenet.net.
9325
9326 * Zippy now accepts challenges where the opponent specified his color.
9327
9328 * Added ZIPPYPASSWORD2 to let operator give commands directly to gnuchess.
9329
9330 * Bitmap directory can include alternative icons now, too.
9331
9332 * Handle "Game * (*) has no examiners" message from ICS.
9333
9334 * Revamped window title and icon name selection.
9335
9336 3.1, patchlevel 2 -- Sun Jun 12 17:16:28 PDT 1994 -- Tim Mann
9337
9338 * "Beta" distribution for Zippy users only.
9339
9340 * Bugfix: common.h was assuming that X11 type Boolean is char, which is
9341 not always true.  This might have caused all sorts of obscure bugs!
9342
9343 * Installed new bitmaps from Elmar Bartel as the default.  Many thanks!
9344 The old bitmaps can be used by changing the "bitmaps" symbolic link before
9345 compiling xboard, or by using the -bitmapDirectory option at runtime.
9346
9347 * Loading a game that ends with the PGN unfinished symbol ("*") now always
9348 leaves you in EditGame mode.
9349
9350 * Added documentation of -icscomm to man page.  Thanks to Maarten Remkes
9351 for the linux script.
9352
9353 * ^C now kills gnuchess as well as xboard.  Thanks to Dima Dakhnovsky for
9354 reminding me how to do this.
9355
9356 * Bitmap icon color now indicates player to move.  Stuart Cracraft
9357 suggestion.
9358
9359 * Changed piece bitmap flags to have just one flag, which points to a
9360 directory full of bitmaps, instead of a flag for each bitmap.  Also
9361 changed bitmap naming convention.
9362
9363 * "Connection closed by ICS" is no longer a FatalError popup.  This was
9364 too annoying in the normal case where the user typed "quit".
9365
9366 * Changed default font to 14 pixels instead of 10 points.  This seems to
9367 make it close to the size I want it to be on more displays.
9368
9369 * Major mode (GNU Chess, etc.) appears in title bar.  Stuart Cracraft
9370 request.
9371
9372 * Bug fix: EditGameEvent, MachineBlackEvent, MachineWhiteEvent, and
9373 TwoMachinesEvent were calling PauseEvent to get out of pause mode, which
9374 now has undesired side effects, such as advancing the display to the
9375 forwardMostMove.  It works fine to just set pausing = FALSE instead.
9376
9377 * IcsExamining mode now lets you access ICS edit position commands using
9378 the same popup menus as xboard's EditPosition mode.  Thanks to DAV on ICS
9379 for inspiring the idea.
9380
9381 * Corrected test for gcc on HP in Imakefile; thanks to Richard Lloyd.
9382
9383 3.1, patchlevel 1 -- Wed Jun  1 16:25:11 PDT 1994 -- Tim Mann
9384
9385 * Added parser.c.lex and parser.c.flex to the distribution.
9386
9387 * Added HP gcc options to Imakefile, from Mats Nylen.
9388
9389 * EndOfGame mode no longer highlights EditGame mode indicator, because the
9390 modes really do differ.  I would like to get rid of EndOfGame mode in the
9391 future, at least as far as users can see.
9392
9393 * Larger %a in parser.l, needed for RS/6000 users.
9394
9395 * Minor improvements to Mail Move error messages.
9396
9397 * When -debug flag is given to xboard, -v is passed to cmail.
9398
9399 * Old Save Style uses "1. ..." instead of "1..." when black moves after a
9400 comment; more like xboard 3.0's actual style.
9401
9402 * New version of cmail from Evan Welsh.  Looks for UCB Mail in a more
9403 portable way and has some minor bug fixes.
9404
9405 * Bug fix: Saving a FEN position while in EditPosition mode with black to
9406 play was showing white to play in the saved position.
9407
9408 3.1, patchlevel 0 -- Fri May 20 16:36:15 PDT 1994 -- Tim Mann
9409
9410 * This is the first general release since 3.0, patchlevel 9.  Releases
9411 since then have been limited-distribution or beta releases.
9412
9413 * Thanks to my version 3.1 beta testers: Dmitry Dakhnovsky, Ed Hanway,
9414 Richard Lloyd, Mike McGann, Shelly Mistry, Josef Nelissen, Chris Petroff,
9415 Jack Robertson, Michel van der List, Ky Macpherson, Derek Terveer, and
9416 Evan Welsh.  Sorry if I've forgotten anyone who gave me feedback.
9417
9418 * Updated man page.
9419
9420 * Minor cleanup on menu sensitivity code.
9421
9422 * Integrated another even better version of cmail from Evan Welsh,
9423 including some code he supplied in xboard itself.
9424
9425 * A few more fixes to cmail support.
9426
9427 * Automatically update clocks after an ICS "moretime" command.
9428
9429 * Handle ICS automatic examine mode (set examine 1) after a game.
9430
9431 3.0, patchlevel 14 -- Tue May 17 13:41:44 PDT 1994 -- Tim Mann
9432
9433 * Beta test release only.
9434
9435 * Don't suppress prompt on first board of game being examined; otherwise
9436 it looks like nothing happened at all (i.e., like you're lagged).
9437
9438 * Added StopExamining and StopObserving (Chris Petroff suggestion).
9439
9440 * Made Reset do a refresh on ICS.  John Chanak's original ICS code for
9441 xboard tried to do this; I finally decided it was a good idea after all.
9442
9443 * Fixed bugs in handling updates that come in while you are pausing in
9444 examine mode.  This is pretty tricky to do right.
9445
9446 * Made un-Pausing immediately pop you to the current position.  This is
9447 always necessary in examine mode, since the game may have changed under
9448 you; your remembered moves might no longer be right.  So I made it do the
9449 same in all modes.
9450
9451 * Took Detach Examine mode back out...used Pause mode for this instead!
9452
9453 * Put in a trap for the GNU Chess bug of printing an Illegal Move message
9454 when its own hint move is illegal.
9455
9456 * Attempted to fix a Zippy bug; bogus "exited unexpectedly" messages after
9457 it checkmates its opponent.  This involved adding an argument to GameEnds
9458 to say who says it ended (ICS, GNU, etc.)  and taking different actions in
9459 different cases.  Unfortunately, this just restored an older Zippy bug, where
9460 Zippy restarts gnuchess when it gets the board with the final position,
9461 because GameEnds still puts xboard in EndOfGame mode.  Sigh.
9462
9463 * We now capture elapsed time on last move when getting game history.
9464 (Josef Nelissen bug report)
9465
9466 * Rewrote code to redisplay last file title so it really works.
9467
9468 * Fixed bug in oldSaveStyle.
9469
9470 * Larger %a and %o were needed for lex.
9471
9472 3.0, patchlevel 13 -- Mon May 16 16:26:22 PDT 1994 -- Tim Mann
9473
9474 * Beta test release only.
9475
9476 * FatalError popups stay on the screen now.  If the error is really fatal,
9477 all functions are disabled, and the program exits when you press OK.
9478
9479 * Redisplay last file title when using Load (Next/Previous/Same) Game.
9480
9481 * Zippy understands new match challenge message format on ICS.
9482
9483 * Added Revert command.
9484
9485 * When examining a game on ICS, < > buttons do ICS backward/forward
9486 commands, unless you set the Detach Examine option.  Thanks to Dima
9487 Dakhnovsky for the idea.
9488
9489 * Fixed various minor problems in cmail mode.
9490
9491 * cmail generates the tags now.  New version of cmail from Evan Welsh.
9492
9493 * cmail mode won't let you do MailMove unless the currently displayed
9494 position is exactly one move past the end of the game you loaded.
9495
9496 * Fixed building of man pages in Imakefile
9497
9498 * Updates to INSTALL file
9499
9500 3.0, patchlevel 12 -- Sat May  7 21:10:03 PDT 1994 -- Tim Mann
9501
9502 * Beta test release only.
9503
9504 * Brought man page up to date.
9505
9506 * Added Shift+R to resign from keyboard.
9507
9508 * Some items on Action menu available in GNU Chess mode now.
9509
9510 * Revamped Action menu.
9511
9512 * Reordered functions in backend.c as a small step toward reorganizing
9513 this whole mess.
9514
9515 * Generate TimeControl PGN tag.
9516
9517 * Get type of ICS game (e.g., rated blitz) and save in PGN tags.
9518
9519 * Bug fix: Clocks were not redisplayed when entering EditGame mode.
9520
9521 * Bug fix: Clocks were not being redisplayed after loading a game file
9522 with -td 0, so they could show the wrong color active.
9523
9524 * Bug fix: Chess programs would be killed and match mode would exit
9525 prematurely when loading a PGN game fragment ending with "*".
9526
9527 * ICS command "sposition" no longer confuses xboard.
9528
9529 * Integrated new version of cmail (with support code in xboard) from Evan
9530 Welsh.
9531
9532 * Added TruncateGame, MoveNow, RetractMove, and QuietPlay.
9533
9534 * Bug fix: switching between MachineWhite and MachineBlack was not calling
9535 Attention().  Reported by Dino Dini.
9536
9537 * More improvements to INSTALL and Imakefile.
9538
9539 * Pack moves into 79 character lines in PGN output.  We don't generate
9540 check indications, and we always break the line before the result,
9541 so this is not quite PGN export format.
9542
9543 * Use FEN tag in PGN.
9544
9545 * Improved finding and counting of game starts in save files.
9546
9547 * Negative position or game numbers in -lpi/-lgi mean to seek to that byte
9548 offset.  Hook for possible future features, not in man page.
9549
9550 * Detect and handle absence of either "time" or "otim" commands in
9551 gnuchess.
9552
9553 * Don't use "promote" command to ICS anymore.
9554
9555 * Handle switching sides and taking back moves on FICS.
9556
9557 * Handle flip state flag in style 12 board.
9558
9559 * Handle examine mode on ICS.
9560
9561 * Improved error popups for various kinds of illegal moves.
9562
9563 * Suppress unasked-for hints from gnuchess (which it generates in post
9564 mode).
9565
9566 * Load/save position functions use FEN.  Old style also supported.
9567
9568 * Added detailed error messages if loading a bitmap file fails.
9569
9570 * Small board has 2-pixel lines between squares instead of 3-pixel.
9571
9572 * Added OldSaveStyle and AboutGame.
9573
9574 * Renamed ForceMoves to EditGame.
9575
9576 3.0, patchlevel 11 -- Tue Sep 21 15:25:36 PDT 1993 -- Tim Mann
9577
9578 * The following changes were present in xboard 3.0, patchlevel 11, but the
9579 first group did not make it into WinBoard 3.0 until later.  xboard
9580 3.0.pl11 was a limited-distribution release only, mostly to Zippy users.
9581
9582 * Man page minor fixes.
9583
9584 * Added a missing file close.
9585
9586 * Removed automatic error popdown on Reset, which was destroying some
9587 error messages before they could be read.
9588
9589 * Fixed char vs. unsigned char warnings on bitmaps.
9590
9591 * Use ICS board style 12.  Some improvements to ICS parsing.
9592
9593 * Comment window is now labelled with the move the comment is on, and
9594 comments don't pop down when you step to the next move.
9595
9596 * Save files now in PGN format.
9597
9598 * Support for loading PGN files.  PGN tags pop up when a PGN game file
9599 is loaded.
9600
9601 * More info in INSTALL and Imakefile about building for Suns (and
9602 other systems).
9603
9604 * WinBoard 3.0 patchlevel 11 split off from an early version of xboard
9605 3.0 patchlevel 11, so it does not have all the features of that
9606 patchlevel.  The following changes made it into both xboard and
9607 WinBoard:
9608
9609 * Made Comment dialog non-modal in WinBoard.
9610
9611 * EndOfGame mode is now more transparent.  It looks like ForceMoves
9612 mode except that there is no chess program running.
9613
9614 * Small bug fixes in clock management.  Most noticeably, pausing when
9615 it is gnuchess's move now works as documented (again).
9616
9617 * Add minimal support for -icscomm option.  Not documented yet because
9618 I haven't sorted out the issues with setting the tty modes on the comm
9619 port device, or with locking it properly.  But it's usable by wizards.
9620
9621 * Don't restart the chess program upon Backward event from EndOfGame mode.
9622
9623 * Suppress extra prompt after ICS sends us a board.
9624
9625 3.0, patchlevel 10 -- Sat Sep 11 18:44:03 PDT 1993 -- Tim Mann
9626
9627 * Beta test release only.
9628
9629 * Zippy now plays chess.  zippy.c and zippy.h are still not included
9630 in the standard distribution, but are available on request.
9631
9632 * Switched to using style 12 on ICS.
9633
9634 * Updated man page, and documented use of XBoard*form.translations to
9635 add more shortcut keys.
9636
9637 * Added shortcut keys "d" to claim/offer/accept a draw, and "t" to
9638 call flag.  Suggested by venu on ICS.
9639
9640 * More explicit instructions in INSTALL file.
9641
9642 3.0, patchlevel 9 -- Tue Sep  7 14:02:00 PDT 1993 -- Tim Mann
9643
9644 * General release, minor update to 3.0.pl8.
9645
9646 * Loosened checking on whether it's okay to start a move, to satisfy
9647 ICS ultra-blitz players.  Now we don't check whether it's your turn
9648 until you let go of the piece.
9649
9650 * Parser now recognizes "+-+" as meaning the game ended in a draw.
9651
9652 * Got rid of S_NONE symbol, which seems to conflict with some symbol
9653 Sun defines.
9654
9655 * Tweaked the man page.  Clarified that there is currently no way for
9656 two people running copies of xboard to play each other without going
9657 through the Internet Chess Server.
9658
9659 * Fixed a bug in color name conversion.  Asking for two different
9660 colors whose names were the same in the first four characters would
9661 get you two copies of the first one.  Thanks to Volker Zink for the
9662 bug report.
9663
9664 * Improved confusing Usage() message.
9665
9666 * Added a bunch of Sun information to the Imakefile and INSTALL file.
9667 Thanks to Ed Hanway, Arik Klingensmith, and others who responded.
9668
9669 * Test for defined(WIN32) instead of !defined(unix).
9670
9671 * Avoid using (void *) type with non-ANSI C compilers.  Thanks to
9672 James Altucher for the bug report.
9673
9674 3.0, patchlevel 8 -- Thu Sep  2 12:23:01 PDT 1993 -- Tim Mann
9675
9676 * Note: Patchlevel 8 was the first non-beta release of xboard 3.0
9677
9678 * Added cmail to distribution.  Contributed (and still maintained) by
9679 Evan Welsh.
9680
9681 * Bug fix: -queen option wasn't initializing menu check.  Reported by
9682 Pat Surry.
9683
9684 3.0, patchlevel 7 -- Thu Aug 26 13:23:24 PDT 1993 -- Tim Mann
9685
9686 * Sent WinBoard 3.0.pl7 to Torre on ICS
9687
9688 * Added parser.h to hold the interface to parser.l
9689
9690 * Upgraded COPYING file and copyright notices to GNU GPL version 2.
9691
9692 3.0, patchlevel 6 -- Tue Aug 24 15:16:13 PDT 1993 -- Tim Mann
9693
9694 * We no longer display intermediate positions or intermediate comments
9695 while loading a game file with -timeDelay 0 or loading an opening to
9696 start up a -matchMode game.
9697
9698 * Loading an empty game from an xboard save file now gives a status
9699 message "No moves in game" instead of an error popup saying "Game not
9700 found in file."
9701
9702 * Added comment.awk to distribution.
9703
9704 3.0, patchlevel 5 -- Tue Aug 17 16:45:54 PDT 1993 -- Tim Mann
9705
9706 * Bug fix:  xboard would crash if it couldn't get all its colors; now
9707 it switches to monoMode instead.  Also, xboard was trying to convert
9708 color resources even when using a b/w display.  Reported by Larry
9709 Rogers.
9710
9711 * Bug fix: Declared fields of TimeMark as signed so that we get signed
9712 instead of unsigned arithmetic.  SubtractTimeMarks was breaking on
9713 Alpha AXP (which has 64-bit longs) with old declarations.  Reported by
9714 Michel van der List.
9715
9716 * Bug fixes:  Keyboard accelerators now work after EditComment window is
9717 popped down.  Iconize keyboard accelerator now works even if xboard
9718 was started with -iconic flag and later deiconized.
9719
9720 * Bug fix:  The routine that tests whether a move is illegal because it
9721 would leave you in check was not handling e.p. captures properly.
9722 Reported by Patrick Surry.
9723
9724 * Bug (?) fix:  Was adding time to clocks at time control even when
9725 loading a game file.  Actually it's not entirely clear how time
9726 controls should be dealt with when some moves are loaded from a file
9727 or clicked in with ForceMoves.  For now ForceMoves mode does add the
9728 time (because it can be used to change moves during a live game), but
9729 LoadGame mode does not.
9730
9731 * Updated usage message.
9732
9733 * Previous attempted fix to matchMode had broken TwoMachines mode and
9734 generally needed more work.  Also simplified command line interface to
9735 matchMode.
9736
9737 3.0, patchlevel 4 -- Thu Aug  5 14:17:18 PDT 1993 -- Tim Mann
9738
9739 * Thanks again to the beta testers listed for 3.0 patchlevel 3, and also
9740 Desnogues, Steve Cariglia, Niklas Engsner, Mark Silver, and Roger Rowe.
9741
9742 * Reorganized man page, splitting OPTIONS into subsections.
9743
9744 * matchMode was very broken; fixed.
9745
9746 * Changed convention for turning off command line options from --opt
9747 to -xopt, to be less inconsistent with GNU standards.  Also changed
9748 the long command line options to take True/False arguments like
9749 resources; seems to make more sense this way.
9750
9751 * Added AlwaysQueen option -- suppresses promotion dialog and always
9752 promotes to a queen if you move a pawn to the last rank.  Has no
9753 effect on gnuchess (or your ICS opponents!) -- they can still
9754 underpromote.
9755
9756 * Subtracted an extra fudge term when determining how wide message and
9757 title widgets should be.  This fixes a problem some beta testers had.
9758 Wish I knew why it's needed.
9759
9760 * Bugfix in parser; symptom was that you couldn't do LoadGame after
9761 observing a game on ICS.
9762
9763 * Bugfix in Forward; didn't work after game ended while Pause was turned on.
9764
9765 * Removed bogus execute bits on .h files.
9766
9767 * Use REMOTE_SHELL and TELNET_PROGRAM definitions.
9768
9769 * MachineWhite and MachineBlack now work from TwoMachines mode.
9770
9771 * Popping down an error message with the [ok] button was not turning off
9772 the errorUp flag, so the next move would cause xboard to try to pop it
9773 down again, resulting in a wild memory reference and sometimes a crash.
9774
9775 3.0, patchlevel 3 -- Tue Aug  3 17:40:27 1993  -- Tim Mann
9776
9777 * Thanks to my beta testers: Patrick Surry, Takuya Kojima, Robert J. Luoma,
9778 Chris L.  Petroff, Richard K. Lloyd, Michel van der List, Craig Metz,
9779 Antoon Frehe, Simon Clift, Shelly, Eric Peterson, Christopher Mitchell,
9780 Martin Koch, Ed Hanway, Steve Booth, Udo, Ken Hobday, and Joseph Duhamel.
9781
9782 * Improved error messages for trying to move the wrong color pieces or
9783 to move when it's not your turn.
9784
9785 * Special code for monoMode on 1-bit displays now understands displays
9786 where 1=white and 0=black.
9787
9788 * Declare getenv() if <stdlib.h> not included; avoids a compiler warning.
9789
9790 * Documented borderXoffset and borderYoffset.
9791
9792 * Added -titleInWindow option for use with X window managers that
9793 don't let us set the title in the window banner.
9794
9795 * Fixed error message printing in WinBoard; system error messages no
9796 longer appear as numeric codes.
9797
9798 * The error message popup is now non-modal; you don't have to press the
9799 [ok] button before you can do something else.  In addition, the popup is
9800 positioned so that it doesn't cover up the board (too much), and making a
9801 move or otherwise clicking on the board pops it down.  (Not implemented in
9802 WinBoard.)
9803
9804 * You can now call your opponent's flag in ICS mode by clicking on his
9805 clock.
9806
9807 * Fixed minor bugs in -flipView option and documented exactly how xboard
9808 decides which way to flip the view.
9809
9810 3.0, patchlevel 2 -- Fri Jul 30 22:20:23 PDT 1993 -- Tim Mann
9811
9812 * Added Autosave to Options menu.  Would be better to have Save
9813 Options dialog as in WinBoard, but this was quick to do and gives the
9814 most-needed functionality.
9815
9816 * Changed "Reload Game" on menu to "Reload Same Game".
9817
9818 3.0, patchlevel 1 -- Thu Jul  8 21:22:59 PDT 1993 -- Tim Mann
9819
9820 * Sent a copy of patchlevel 1 to Patrick Surry to beta-test.
9821
9822 * Added -cmail option that sets appData.cmailMode.  Currently a no-op.
9823 In the future this may set special modes for use by the cmail script
9824 for playing chess by email.
9825
9826 * Added LoadNextGame, LoadPreviousGame, and ReloadGame to File menu.
9827 ReloadGame suggested by Patrick Surry.
9828
9829 * Added -flipView command-line option.  Suggested by Patrick Surry.
9830
9831 * Fixed bugs in parser.l:  (1) Pattern for "# xboard game file ..."
9832 needed to match to end of line.  (2) Start of a new file was not matching
9833 the ^ start-of-line character.  The fix for this is a kludge.
9834
9835 * Made game counting code in LoadGame more robust, and made LoadGame
9836 able to detect the end of a saved partial game (by noticing the start
9837 of the next game) in game files created by XBoard itself.  We don't
9838 try to find the start of the next game that way in other kinds of game
9839 files, because the only way I can think of to do that is to look for
9840 another move #1, and that technique gets too many false hits.
9841
9842 * Fixed recently introduced bug in LoadGame when game starts with a
9843 position diagram.
9844
9845 3.0, patchlevel 0 -- Fri Jun 25 14:17:17 PDT 1993 -- Tim Mann
9846
9847 * Changes in this patchlevel were too numerous to list.  Larger ones are
9848 listed below.
9849
9850 * Added a popup dialog to enter and edit comments.  Inspired by some
9851 code from Patrick Surry.  Changed the normal read-only comment popup
9852 to the same style.
9853
9854 * Added ICS init script feature from Karl Schwamb.
9855
9856 * Added some ESIX fixes and OMIT_SOCKETS ifdef option, from Kayvan Sylvan.
9857
9858 * Revamped code to allow use of flex instead of lex on parser.l.
9859 Using flex requires adding -DFLEX to defines in Imakefile.
9860
9861 * Source code is split into front end (xboard.c), which knows about X
9862 and Unix, and back end (backend.c), which knows about chess, gnuchess,
9863 and the ICS.  There is also a front end for Windows NT.
9864
9865 * Boolean command line options now use "-foo" to turn on and "--foo"
9866 to turn off instead of "-foo true" and "-foo false".  [Later -xfoo;
9867 see above.]
9868
9869 * Added menu commands to control autoflag, bell, and coords options.
9870
9871 * User interface has a new look: (1) Menu bar instead of array of
9872 buttons.  A few very commonly used features have small buttons in
9873 addition to being on the menus. (2) Large font for clock.  (3) Pop-up
9874 dialogs for errors.
9875
9876 2.1, patchlevel 11 -- Sat Jun  5 00:01:01 PDT 1993 -- mann@src.dec.com
9877
9878 * Added code to deal with "wild" games on ICS.  This includes allowing
9879 castling with the king on d1 or d8, which is allowed in wild(1) games
9880 if the king started there.  Notation is o-o to castle "short"---to
9881 whichever side the king is closer to---and o-o-o to castle "long."
9882 Right now wild castling is always allowed by xboard; we rely on ICS or
9883 gnuchess to reject it when we aren't really in wild mode.
9884
9885 * memcpy call had arguments in wrong order.
9886
9887 * Removed April Fool code
9888
9889 2.1, patchlevel 10 -- Mon Feb 15 10:19:31 PST 1993 -- mann@src.dec.com
9890
9891 * Avoid trying to select on a pipe when using System V.  Needed to
9892 copy some code from InitChessProgram() up into establish().
9893
9894 * Bug fix in disambiguating pawn moves like "ed".
9895
9896 * Fix to error handling in ReceiveFromProgram.
9897
9898 * Bug fix: entering EditPosition mode with black to play highlighted
9899 White's clock instead of Black's.
9900
9901 * Added telnetProgram resource in case "telnet" is not the name of the
9902 telnet program.
9903
9904 2.1, patchlevel 9 -- Fri Jan 22 19:08:27 PST 1993 -- mann@src.dec.com
9905
9906 * Entering Force Moves mode clears "flag has fallen" messages from display.
9907
9908 * ICS host name can now be in numeric format; for example 128.2.232.4.
9909
9910 * Bug fix: LegalityTest was failing to test whether a pawn move was
9911 illegal because the move would discover a check.
9912
9913 * Handle ICS message "mann asserts a win over manntest, who disconnected."
9914
9915 * Bug fix: A recent change to PromotionCallBack had broken
9916 underpromotion to a knight.
9917
9918 * Bug fix: In EditPosition mode, dragging a piece onto a square border
9919 would make it vanish.  xboard wasn't distinguishing this case from
9920 dragging the piece off the board.  Thanks to Matthew Kidd.
9921
9922 * Removed "static" declaration from yywrap for compatibility with IRIX
9923 version of lex.  Thanks to stiller@blaze.cs.jhu.edu.
9924
9925 * Added substitutes for bzero, bcopy, and gethostname for Solaris
9926 SVR4.  Thanks to Michael Grant.
9927
9928 * Bug fixes to queen move disambiguation.  Bugs showed up only when
9929 promotion resulted in more than one queen on the board.
9930
9931 2.1, patchlevel 8 -- Fri Dec 11 17:54:18 PST 1992 -- mann@src.dec.com
9932
9933 * parser bug fix: It now really works to leave off the piece a pawn is
9934 promoting to and let it default to queen.
9935
9936 * When starting to observe or play an ICS game, don't draw board in
9937 initial position and then immediately redraw it in the current
9938 position.
9939
9940 * Handle ICS messages when an "abuser" forfeits a game by
9941 disconnecting and when a game is aborted ("removed") by an
9942 administrator.
9943
9944 * Bug fix: A user move when in LoadGame+Pause mode was resuming the
9945 game load instead of putting us in force mode.
9946
9947 * It seems that crashes inside sscanf when xboard is compiled with gcc
9948 (as on IBM PS/2 AIX, mentioned below, and also on VAX Ultrix 3.1) are
9949 caused by an incompatibility between gcc and the sscanf implementation
9950 on these platforms.  A workaround is to specify -fwritable-strings to
9951 gcc (see the gcc documentation).  Added info on how to do this to the
9952 Imakefile.  Thanks to Tom McConnell for this information.
9953
9954 * Clocks are allowed to go negative.  This is mostly for ICS
9955 compatibility, but it affects gnuchess mode too.  Also, we give the
9956 time bonus when a player hits the time control boundary even if his
9957 flag is already down.  This choice is a bit debatable, but it makes
9958 things look better when you are in TwoMachines mode and gnuchess's
9959 time management screws up causing it to exceed its time limit.
9960
9961 * Implemented move legality checking code.  Moves made with the mouse
9962 or parsed from a file are checked for legality before being made.
9963 This is mostly in preparation for future extensions, such as
9964 human-human play.  For now it makes -noChessProgram mode more useful.
9965
9966 * If the user takes back moves, we restore the clocks to the earlier
9967 settings.
9968
9969 * We now handle the output of the ICS oldmoves command, including
9970 parsing the game end condition.
9971
9972 * Added autoCallFlag mode.
9973
9974 * Fixed glitches in the medium size outline king and rook bitmaps, and
9975 touched up the medium size solid king and outline queen.
9976
9977 * bug fix: DisplayMove would not display backwardMostMove - 1.
9978
9979 * Added CallFlag button and removed AcceptMatch.  CallFlag is more
9980 important with new ICS, and accepting the current match offer is easy
9981 with the new ICS command "accept" (can be abbreviated "ac").
9982
9983 * LoadGame and LoadPosition display tail of file name (plus index
9984 number, if any) as title.
9985
9986 * MachineWhite, MachineBlack, and TwoMachines now work properly from
9987 LoadGame and LoadGame+Pause mode.
9988
9989 * Use o-o and o-o-o to castle on ICS, not 00 and 000.
9990
9991 * Stripped out code for old ICS messages; new ICS is now installed.
9992
9993 * Bug fix: don't offer autosave when paused during LoadGame.
9994
9995 2.1, patchlevel 7 - Fri Dec 11 17:40:56 PST 1992 - mann@src.dec.com
9996
9997 * Track change to "Illegal move" message in new ICS.
9998
9999 2.1, patchlevel 6 -- Tue Dec  8 10:48:44 PST 1992 -- mann@src.dec.com
10000
10001 * Kludged around bug in keeping comment popup where you put it by
10002 adding borderXoffset and borderYoffset resources that give the width
10003 of the borders added by the window manager.  Yucch.
10004
10005 * Changed searchDepth kludge back to using "help" instead of "bd"; the
10006 latter didn't work because the output contains a line starting with
10007 "White", so we think gnuchess is telling us that White won.  Oops.
10008
10009 * Removed some code that uses an X11R5 feature, XrmGetDatabase.
10010 Without this, the auto font sizing code is harder to make work, so to
10011 keep my sanity I had to change it to affect only the fonts that appear
10012 in the main window and the comment popup, not the other popups.  Maybe
10013 this is better anyway.
10014
10015 * AcceptMatch button now works after a counterchallenge, too.
10016
10017 * Added code for more variants of messages about games being adjourned
10018 or aborted.  These messages need to be unified in new version of ICS.
10019
10020 * Added workaround for minor bug in ICS; game number on first board
10021 can be wrong.
10022
10023 * Removed code to say "refresh n" instead of "refresh"; was broken and
10024 wasn't needed anyway.
10025
10026 * Added missing casts for compilers that distinguish enums from ints
10027 and missing cast in connect call.
10028
10029 * Added code to recognize "both sides are out of time" draw message
10030 proposed for next version of ICS.
10031
10032 * Thanks to Danny Sleator and Joe Peterson for bug reports.
10033
10034 2.1, patchlevel 5 -- Sun Dec  6 19:52:40 PST 1992 -- mann@src.dec.com
10035
10036 * Removed gcc and CDEBUGFLAGS from Imakefile.
10037
10038 * Corrected setting of mode to ForceMoves when game file ends or
10039 contains an AmbiguousMove or BadMove.  Previous bug was harmless.
10040
10041 * Added AcceptMatch button and mention of 50-move rule for Draw button
10042 to man page.
10043
10044 2.1, patchlevel 4 -- Sun Dec  6 02:55:42 PST 1992 -- mann@src.dec.com
10045
10046 * Now handles revised messages from new version of ICS.  New ICS is
10047 not released yet, so this code might change further.  Next patchlevel
10048 will remove support for old ICS; both are there now.
10049
10050 * Initial processing for a new game being watched or played now
10051 happens when we see the first board image.  Removes the need to parse
10052 some messages and unifies some code.
10053
10054 2.1, patchlevel 3 -- Tue Dec  1 19:40:40 PST 1992 -- mann@src.dec.com
10055
10056 * Handles ICS messages "Draw : neither player has mating
10057 material" and "Draw : White has no material, Black has no time."
10058
10059 * Added AcceptMatch button for ICS mode.
10060
10061 * Fixed bug in previous fix to yylexstr().
10062
10063 * Fixed bugs in code for loading old position files that don't start
10064 with "#" and for handling case where user asked for nth position in
10065 file but there aren't that many.
10066
10067 * Handles ICS message "* has restored your old game"
10068
10069 * ResetProc always clears title line now.
10070
10071 * Don't issue just "refresh" when watching a game; use game number.
10072 Upcoming new version of ICS may need this.
10073
10074 * Added code to try to prevent user from watching and/or playing more
10075 than one game at a time.  There is a race condition inherent here; if
10076 we get more than one board from the game before our command to stop
10077 watching it takes effect, we'll think the user started it again.  Not
10078 clear how to fix this.
10079
10080 * Redid ParseBoard8 to use sscanf.  Code is a good deal cleaner now.
10081 Also, we now parse out the game number too, though we don't make much
10082 use of it yet.
10083
10084 * (Tried to put in a feature that recognizes the current game in a
10085 game file must have ended when we see the start of a new one, but had
10086 to disable it because we have too many false hits with the current
10087 parser, especially in gnuchess listing files.)
10088
10089 * Moves read from game files or received from ICS are now translated
10090 into canonical algebraic form just like all other moves.  Minor nit:
10091 If you use Reset while playing or observing a game in ICS mode, the
10092 game history (including the current board position) is lost, so the
10093 next move of the current game can't be translated.
10094
10095 * Default fonts now vary with board size, and are chosen by pixel size
10096 instead of point size (since piece bitmaps have a fixed pixel size).
10097
10098 * Bug fix: An extra Forward was required to skip over time indications
10099 in game files.
10100
10101 2.1 patchlevel 2 -- Fri Nov 27 23:30:00 PST 1992 -- mann@src.dec.com
10102
10103 * If you move the comment popup, the next time it pops up it will come
10104 back where you put it.
10105
10106 * Fixed yylexstr() so calls to it can be interspersed with calls to
10107 yylex().
10108
10109 * Fixed bugs in Forward/Backward while in LoadGame mode.
10110
10111 * Changed Save{Game,Position} functions to append instead of
10112 overwriting if file exists.  Changed Load{Game,Position} functions to
10113 deal with multiple games/positions per file.
10114
10115 * Changed load{Game,Position}File resources to trigger automatic load
10116 on program startup.  Changed save{Game,Position}File resources to
10117 trigger automatic save after every completed game and on program exit.
10118
10119 * Added autoSaveGames mode.
10120
10121 * Fixed bug with PromoPiece in call to MakeAlg from MakeMove.
10122
10123 * Many changes to get rid of picky compiler warnings and generally
10124 clean up the code.
10125
10126 2.1 patchlevel 1 -- Fri Nov 27 02:45:00 PST 1992 -- mann@src.dec.com
10127
10128 * A last minute change before patchlevel 0 went out broke
10129 ParseGameHistory().  Immediately fixed in patchlevel 1.
10130
10131 Version 2.1, patchlevel 0 -- Fri Nov 27 02:00:00 PST 1992 -- mann@src.dec.com
10132
10133 * Uses "time" command of gnuchess 4.0 and following to keep clocks in
10134 sync.  Still works with older versions without this command; we test
10135 whether the command is present the first time each chess program is
10136 started.
10137
10138 * File name dialog pops up under the mouse cursor, so that it's got the
10139 keyboard focus if the window manager is using pointer focus.
10140
10141 * Attempts to move the wrong color piece or an empty square are filtered
10142 out in xboard instead of being passed on to GNU Chess or the ICS.
10143
10144 * The reason a game ended is now remembered even if you move backward
10145 and forward after it ends.  It is forgotten only if you make a move
10146 (which is as it should be---this is now a different game, which hasn't
10147 ended yet).  The message saying why the game ended no longer wipes out
10148 the last move.
10149
10150 * Pause, Backward, Forward, ForceMoves, and EditPosition now work from
10151 TwoMachines mode.
10152
10153 * Forward and Backward now change only the board display unless you
10154 are in ForceMoves mode.  Pause mode keeps new moves that are received
10155 from being displayed on your screen until you unpause (or use
10156 Forward).
10157
10158 * Added option to ring the bell after opponents' moves.
10159
10160 * Saved games that start from other than the standard initial position
10161 now begin with a postion diagram as in saved position files.  The
10162 loader is modified to understand such save files.
10163
10164 * Improved error checking when trying to read from gnuchess.
10165
10166 * Parser understands things that look like time indications, e.g., (0:12),
10167 instead of popping them up as comments.
10168
10169 * Send "quit" to gnuchess before trying to kill it.  I needed this
10170 locally because sending a SIGTERM to rsh was not killing the remote
10171 program on some internal field test systems we have.
10172
10173 * Merged in code from John Chanak to make xboard a front end to the
10174 Internet Chess Server, and added several improvements of my own.
10175 (These include parsing end of game messages, loading the current state
10176 and previous history of a game that's joined in progress via "watch"
10177 or "load", automatic switch from board style 1 to 8 when needed,
10178 removing irrelevant buttons and adding some new ones, adding the
10179 useTelnet and gateway resources, and miscellaneous code cleanup, bug
10180 fixes, and documentation.)  Many thanks to John for writing and
10181 contributing the initial version of this code.
10182
10183 Fri Oct 30 20:16:40 PST 1992 (patchlevel 25) mann@src.dec.com
10184
10185 * gnuchess now castles by sending us "o-o" or "o-o-o" (starting with a
10186 preliminary version of 4.0.pl60 that I have).  Added code to handle
10187 this.  The old format ("e1g1", etc.) still works too.
10188
10189 * Added code to format moves in normal abbreviated algebraic notation
10190 (for example, e4, exd4, f8Q, Nf6, 0-0) instead of coordinate algebraic
10191 (for example, e2e4, e3d4, f7f8q, g1f6, e1g1).  Moves entered with the
10192 mouse or received from gnuchess are translated into this canonical
10193 format for display on the message line or in saved game files.  Moves
10194 read from game files are not translated, however; they are shown and
10195 saved just as they appear in the file.
10196
10197 Mon Sep 14 13:19:01 PDT 1992 (patchlevel 24) mann@src.dec.com
10198
10199 * It's not really correct to write an ep capture of a pawn on e5 as
10200 fxe5; this should be written as fxe6 because e6 is where the capturing
10201 pawn ends up.  Nevertheless, the parser now interprets fxe5 as the ep
10202 capture f5xe6 unless there is a pawn on f4, in which case it
10203 interprets fxe5 as f4xe5.  By design, the parser does not flag fxe5 as
10204 ambiguous if there are pawns on both f4 and f5; instead it prefers the
10205 more legitimate f4xe5 interpretation.
10206
10207 * A move like fxe6 or fe6 is now interpreted as an e.p. capture of the
10208 pawn on e5 if there is one there and e6 is empty.
10209
10210 * A move like fxe5 can no longer be interpreted as an e.p. capture if
10211 there isn't a pawn on e5 to be captured.  Previously this could happen
10212 erroneously if there were pawns on both f4 and f5, and the f4 pawn was
10213 capturing a piece on e5.
10214
10215 * The parser no longer munges the move it is parsing; in the past, for
10216 instance, it would remove the "x" from a move like dxc5 before echoing
10217 it to the screen.
10218
10219 * The parser now detects when a move is ambiguous and returns an
10220 error, instead of arbitrarily choosing one possibility as it used to.
10221
10222 Mon Aug 10 18:40:47 PDT 1992 (patchlevel 23) mann@src.dec.com
10223
10224 * Added code so parser can handle fully qualified algebraic, e.g.,
10225 Ng1-f3, N/g1-f3, Ng1f3, or even Pe2-e4.  The "P" and "/" work only for
10226 fully qualified moves, not generally.
10227
10228 * Fixed parser bugs in handling moves with rank or file disambiguator,
10229 e.g. N1f3 or Ngf3.
10230
10231 Mon Jul  6 17:55:32 PDT 1992 (patchlevel 22) mann@src.dec.com
10232
10233 * AIXV3 patch from Tom McConnell; thanks!
10234
10235 * After hitting the Backward button we see the last move made instead of
10236 the word "Pausing" displayed.
10237
10238 * Fixed a couple of problems compiling on IRIX; thanks to Michel Arsenault
10239 and Alan Walsh for bug reports and help with fixes.
10240
10241 * Added optional display of algebraic notation coordinates along left and
10242 bottom edges of board.  This was inspired by some code from Jean-Christophe
10243 Engel; thanks!
10244
10245 * Swapped EditPosition and Pause buttons to reduce danger of losing the
10246 game in progress by hitting EditPosition when you wanted Backward.  Thanks
10247 to Ove Lundberg for complaining (though it bugged me too).
10248
10249 * Despite one complaint, I kept the feature of changing both clocks when black
10250 makes time control, rather than changing each individually when the player
10251 involved makes it.  This is to avoid having it look like White is way ahead on
10252 time while Black is thinking about the last move of the time control period
10253 (i.e., when White has made time control but Black hasn't yet).
10254
10255 * Corrected clocks to work as in real tournaments.  Time is *added* when you
10256 reach time control; previously the clocks were simply set to the length of the
10257 new time period.  Also, when a player's flag falls, he still does not receive a
10258 new time allotment at the next time control, but his opponent does still
10259 receive more time if *his* flag has not fallen; previously, time controls were
10260 ignored for both players if either flag fell.  I forget who reported this bug.
10261
10262 * Added a small ESIX patch from Kayvan Sylvan.
10263
10264 Mon Jun 22 13:24:38 PDT 1992 (patchlevel 21)
10265
10266 * Added some SVR4 support code from Ronald Cole.  It's Greek to me.
10267
10268 * Note:  Stephen Meatheringham reports a bug causing xboard to crash with an
10269 error from the X server when run on a Sun Sparcstation IPX with Solaris 1.0.1
10270 and OpenWindows 3.0.  This bug has not been tracked down yet.
10271
10272 * Fixed a problem with ATTENTION code.  On some operating systems, you have to
10273 be even more cautious about when you send a SIGINT to gnuchess, because the
10274 signal handler gets deinstalled each time it is used, and gnuchess does not
10275 reinstall it immediately.  In particular, if you send a SIGINT and make an
10276 illegal move or ask for a hint, gnuchess does not reinstall the handler until
10277 *after* you make your next move, so you had better not send a SIGINT before
10278 it.  I put a workaround for this case into xboard; I hope there are no more.
10279
10280 * The ATTENTION code is needed when compiling for the ESIX operating system,
10281 because ESIX has a bug in the FIONREAD ioctl, so the code in gnuchess that
10282 lets you interrupt its thinking on your time just by typing in your move does
10283 not work.  Perhaps gnuchess will have a workaround for this eventually.
10284
10285 * Fixed yet another bug in using XtGetValues; code to inhibit shell resizing
10286 was leaving a null pointer as the place to store the current sizes.
10287
10288 * Man page fixes: corrected -sl to -sd, updated LIMITATIONS.
10289
10290 * Added include of <sys/time.h> conditional on HAS_GETTIMEOFDAY.  I hope this
10291 works for all systems; on mine, <time.h> and <sys/time.h> are the same file,
10292 but with an #ifndef that makes it harmless to include both.
10293
10294 * Thanks for reports from Mike Pearlman, Stephen Meatheringham, Kayvan Sylvan,
10295 d87-mal@nada.kth.se, Urban Koistinen, and Ronald Cole.
10296
10297 Mon Jun  8 11:39:18 PDT 1992 (patchlevel 20)
10298
10299 * Documented default value of initString and explained what it means.  This
10300 paragraph also serves to inform the user that xboard by default will tell
10301 gnuchess to think on his time, something one user apparently didn't understand.
10302
10303 * Redid -searchDepth (formerly -searchLevel) and -searchTime code.  They both
10304 work correctly with gnuchess 3.1 now.  The -searchDepth option also works
10305 correctly with gnuchess 4.0.  The -searchTime option does not work with
10306 gnuchess 4.0.pl50 or earlier because those gnuchess versions do not have a
10307 working searchTime feature.  Instead of having xboard do a half-baked emulation
10308 of this feature by using a 1-move time control, I will be submitting a patch to
10309 the gnuchess folks to restore the feature as in 3.1.
10310
10311 * Improved clock code.  It now keeps accurate track of fractional seconds of
10312 clock running time, if your system has gettimeofday(); if not, it is generous
10313 about them---if a clock has been going for n.m seconds when it is stopped, only
10314 n seconds are charged.  Previously, xboard would charge one second immediately
10315 when a clock was started, so if n.m had elapsed when it was stopped, n+1 would
10316 be charged.  This should stop xboard from thinking gnuchess has let its flag
10317 fall on the last move of a time control, as it often did before.  I also
10318 improved the comments and condensed the code a little.  I hope there are no
10319 systems that have X11 and don't have gettimeofday(), but if there are, I'd like
10320 to know what to replace it with.
10321
10322 * "Flag dropped" messages now show up on the top line, beside the clocks, so
10323 that they don't obscure more interesting messages on the second line.
10324
10325 * Fixed confusion of NULL and '\000'.
10326
10327 * Include time.h to get ctime() declaration.
10328
10329 * Fix to "parser bug" messages in parser.l.
10330
10331 * Changed code to work with old-fashioned tolower() macro that requires its
10332 argument to be an uppercase letter.
10333
10334 * Minor fix to some usage error messages; was reversing program name and
10335 erroneous argument value.
10336
10337 * Thanks to Mitch Wright, Ranier Orth, and Henrik Schmiediche for bug reports.
10338
10339 Fri Jun  5 13:06:08 PDT 1992 (patchlevel 19)
10340
10341 * Note: xboard does not seem to work when compiled with gcc 1.40 on a
10342 PS/2 running AIX.  It crashes at the sscanf in line 768 of xboard.c.
10343 You can work around the problem by specifying the -timeControl option
10344 on the command line instead of defaulting it.  This does not seem to
10345 be a bug in xboard itself; it runs okay on PS/2 AIX when compiled with
10346 MetaWare High C.  [But see 2.1.pl8 above.]
10347
10348 * Removed bogus files from distribution.
10349
10350 * Changed variable name that conflicted with SVR4 ttyname function.
10351
10352 * Thanks to Christoph Strozyk for another bug report, and to several
10353 of the folks mentioned under patchlevel 18 for testing it.
10354
10355 Wed Jun  3 17:50:37 PDT 1992 (patchlevel 18) mann@src.dec.com
10356
10357 * Added an include of sys/fcntl.h to pick up the definition of O_RDWR for
10358 System V users.
10359
10360 * Fixed a bug in CatchPipeSignal; was testing the wrong variable to determine
10361 which chess program got the signal.
10362
10363 * Removed the declaration of strrchr, which was causing problems for some
10364 people, and added an include of <string.h> or <strings.h> instead.
10365
10366 * Fixed a bunch of type errors uncovered by compilers that check more carefully
10367 than the one I was using.  I just patched many of them with casts---typically
10368 cases where a function didn't take the same number and type of arguments as the
10369 X header file prototype said it should---because I didn't see any other way to
10370 fix them.  The versions of the X header files that I have don't actually have
10371 full prototypes for these function types; they declare only the return type and
10372 just give the argument types as comments.
10373
10374 * InitChessProgram returns immediately if chess program died while we were
10375 waiting for it to say "Chess".  I think this fixes a bug that could make xboard
10376 crash or go into an infinite loop printing "Warning: Select failed; error code
10377 9" if gnuchess crashed there.
10378
10379 * Removed code that tries to put the file descriptor used to read messages from
10380 gnuchess into nonblocking mode.  I don't see how this kludge could ever have
10381 fixed the problem it was intended to (see below), and it seemed to be causing
10382 a race condition when we were waiting for the initial message from gnuchess
10383 after it started up.
10384
10385 * Thanks to Richard K. Lloyd, Konstantinos Konstantinides, Mark
10386 Seiden, Erik Schoenfelder, Andreas Stolcke, Rainer Orth, Henry Thomas,
10387 and Kris Van Hees for bug reports and help with fixes.
10388
10389 Sun May 31 08:00:00 PDT 1992 (patchlevel 17) Bart Massey bart@cs.uoregon.edu
10390
10391 *  'xboard' suffered from a couple of serious bugs.  An initial
10392    size needed to be given to the message label to avoid a race
10393    condition (!) so I gave it some text (otherwise occasionally
10394    xboard would fail because the message widget was 0 width under
10395    MIT X11R4).  The sizes needed to be Dimension, not int, because
10396    they were written in by Xt -- on my big-endian box Dimension
10397    is short, causing chaos.  Also, I hacked a declaration in for
10398    strrchr() to shut the compiler up -- this is arguably a kludge,
10399    but I couldn't think of anything better; maybe you can.
10400
10401 Fri May 22 13:40:50 PDT 1992 (patchlevel 16)
10402
10403 * First real (non-beta) release of version 2.0.
10404
10405 * Added GNU copyleft notices covering version 2.0 enhancements.
10406
10407 Thu May 21 12:30:09 PDT 1992 (patchlevel 15)
10408
10409 * Removed -g from Imakefile.
10410
10411 * Added casts in parser.l to prevent warning messages from some C compilers.
10412
10413 * Bugfix: code to exit if chess program couldn't be started had bug in error
10414 message printing.
10415
10416 Tue May 19 11:58:06 PDT 1992 (patchlevel 14)
10417
10418 * Fixes one small bug: If LoadGame does not find a game in the file, it resets
10419 xboard to BeginningOfGame mode (as if the Reset button was pressed), instead of
10420 leaving it in LoadGame mode.
10421
10422 Mon Apr 13 18:32:27 PDT 1992 (patchlevel 13)
10423
10424 * Improved error handling when gnuchessx crashes.  Now displays a message and
10425 enters EndOfGame state without exiting.  This should help with diagnosing
10426 gnuchessx problems, since the position and move history are not lost.
10427
10428 * Debugged man page.
10429
10430 Version 2.0 -- Thu Apr  2 16:04:54 PST 1992 (patchlevel 12)
10431
10432 * Added small 40x40 pixel pieces; board size now specified as small, medium, or
10433 large.
10434
10435 * Improved man page.
10436
10437 * Saved position files now say "white to play" if it's white's move.
10438
10439 * SavePosition while in EditPosition mode now gets side to play right.
10440
10441 * Made "Pawn" the default on edit position menus.
10442
10443 * Removed "To play" from edit position menus, since it's redundant.  Left
10444 support code in so it can be restored if someone wants it.
10445
10446 * Tightened parser's definition of a move number to help further with skipping
10447 over stuff before the first move.
10448
10449 * Put back feature of skipping over stuff in game files before a start of game
10450 marker.  This helps when loading electronic mail messages that have things
10451 like "00" in the header (looks like castling), or that talk about moves in
10452 running text before the actual game score.  Tradeoff is that we can't load
10453 games that don't either have move numbers or say "gnuchess game" just before
10454 the moves.
10455
10456 * Changed version number to 2.0 because others have used "1.3" for patched
10457 versions of 1.2.  Display version number and patchlevel at startup.
10458
10459 Thu Apr  2 15:30:22 PST 1992 (patchlevel 11)
10460
10461 * Bugfix:  Match started with TwoMachines button now handles the case where
10462 user loaded/edited a position *and* forced some moves.
10463
10464 * added error message feedback to many cases where the user's button press is
10465 rejected because it isn't allowed in the current mode.
10466
10467 * added -noChessProgram option to allow use as a passive chessboard without
10468 gnuchess, replacing old buggy scheme that tried to do this automatically when
10469 gnuchess was not found on the search path.
10470
10471 * parser accepts "=" in front of promotion piece
10472
10473 * parser accepts ":" notation for captures
10474
10475 * Removed SwitchSides button to make room for EditPosition.  Left code in
10476 place, ifdef'ed out.
10477
10478 * Added EditPosition mode.
10479
10480 * Reformatted xboard.c to eliminate long lines.
10481
10482 * Promotion popup now appears near rank to which pawn is moving.
10483
10484 * UI improvement: Button representing current program mode is kept highlighted.
10485
10486 * Bug fix:  Hint button is now disabled when machine is on move.
10487
10488 Sat Mar 21 14:57:37 PST 1992 (patchlevel 10)
10489
10490 * TwoMachines now works from MachineWhite or MachineBlack mode.
10491
10492 * ForceMoves and Backward/Forward now work at the end of a game started by
10493 the TwoMachines button.
10494
10495 * Sends o-o or o-o-o to gnuchess instead of O-O or O-O-O.
10496
10497 * Bug fix:  SwitchSides button is now disabled when machine is on move.
10498
10499 * Added -searchLevel option and corrected handling of -searchTime to reflect
10500 the way gnuchess really handles command line options instead of what the
10501 documentation used to say.  Allowed optional ":seconds" on times.
10502
10503 Tue Mar 17 21:00:35 PST 1992 (patchlevel 9)
10504
10505 * Removed non-working code that tried to recover when a remote chess program
10506 could not be started; now exits with a message instead.
10507
10508 * Now waits for chess program to print its first message (normally "Chess")
10509 before sending it any commands.
10510
10511 * Matches between two machines can now start from a black-to-play position or
10512 black-to-play opening.
10513
10514 * Bug fix: The program would sometimes lose track of the board position after
10515 the end of the game, drawing a board full of white pawns next time it got an X
10516 redraw request.  Now fixed.
10517
10518 * Cleaned up handling of illegal moves in game files.  Now we just stop reading
10519 and go into ForceMoves mode.
10520
10521 * Saved games against gnuchess indicate who won (restored and debugged 1.2
10522 feature).
10523
10524 * Setting -searchTime turns off -clockMode.
10525
10526 * My trick for setting up a black-to-play position broke in the transition from
10527 gnuchess 3.1+ to 4.0.  Installed a different trick that works with both.
10528
10529 * Bug fix: Was clobbering memory by mallocing one byte too few for the file
10530 name in SetupPositionFromFileProc.  This usually resulted in a crash on the
10531 second attempt to load a position from a file.
10532
10533 Mon Mar 16 16:49:00 PST 1992 (patchlevel 8)
10534
10535 * Game and position files are saved in CHESSDIR as well as loaded from there.
10536 We actually chdir there, so gnuchess listing files also wind up there.
10537
10538 * Underpromotion moves from gnuchess really work now.
10539
10540 Sat Mar 14 14:55:24 PST 1992 (patchlevel 7)
10541
10542 * Cleaned up lots of bugs and kruft in parser.l.  It's a wonder the old version
10543 worked at all.  Improved rejection of random text interspersed with the moves.
10544
10545 * Relabeled buttons to reduce confusion (Play From File --> Load Game;
10546 Setup From File --> Load Position).
10547
10548 * Bug fix:  Doesn't exit at the end of a game that was started by pressing
10549 the Two Machines button.
10550
10551 * Bug fix:  Doesn't get confused if you hit Machine Black (White) while
10552 the machine is already playing black (white) and is on move.
10553
10554 * Prints "White to play" or "Black to play" after loading a position file.
10555
10556 * Bug fix:  No longer hangs if no start-of-game is found in a game file.
10557
10558 * More permissive about game file format.  The first line is not assumed
10559 to be a header comment unless it starts with "#".  We don't insist on
10560 seeing a "1." before the first move.
10561
10562 * Added pop-up dialog to allow underpromotion.  Moving a pawn to the last rank
10563 pops up a dialog to let you select what piece to promote to.  Also added code
10564 to handle underpromotion moves from gnuchess or from a game file correctly.
10565
10566 * Added code to send SIGINT to gnuchess before trying to move, if gnuchess
10567 might be busy thinking on our time.  The code is ifdef'ed out because it's
10568 not necessary; only beta-test versions of gnuchess 4.0 at patchlevel 19 or
10569 below require it.
10570
10571 Mon Feb 24 20:10:22 PST 1992
10572
10573 * Merged fixes received from Stuart Cracraft and Mike McGann, to iconic mode
10574 and to ShutdownChessPrograms.  (They both sent the same fixes.)  I did not
10575 install the change that removed "easy" from the initialization string, so
10576 xboard will still try to run gnuchessx in "hard" mode (thinking on opponent's
10577 time) by sending this command.
10578
10579 Version 1.3 -- Thu Dec 19 18:19:00 PST 1991  mann@src.dec.com (Tim Mann)
10580
10581 * I've fixed a slew of bugs in this version of xboard:
10582
10583 * You can now back up from the end of a game, even if gnuchess was playing
10584 against you.  Since gnuchess exits upon mate or draw (when it's not in force
10585 mode), this feature works by starting up a new copy of gnuchess and feeding it
10586 the saved starting position and moves.  Drawback: the new gnuchess starts with
10587 clocks at the beginning of a fresh time control.
10588
10589 * Note: the "force" command to gnuchess is a toggle.  I fixed a couple of
10590 places in xboard where "force" was being issued when gnuchess was already in
10591 force mode, which resulted in chaos.  I don't know if they were in 1.2 or if I
10592 added them myself in the course of putting in new features.
10593
10594 * ForceMoves button is now legal in PlayFromFile mode.  It closes the game file
10595 and lets you force moves (or go Backward) from whatever position you've
10596 reached.
10597
10598 * The parser now recognizes "white resigns" and "black resigns" (in any
10599 combination of upper and lower case, with or without the closing "s").  These
10600 used to be misinterpreted as meaning "white wins" or "black wins" respectively!
10601 Added "1 - 0" and "0 - 1" as equivalents for "1-0" and "0-1".
10602
10603 * I removed the parser feature of considering "!" as a comment delimiter.
10604 "!" is so common as an annotation in game scores that this feature seems like a
10605 very bad idea.
10606
10607 * Added a wait() after each successful call to kill() to avoid leaving zombie
10608 processes around.
10609
10610 * Removed the feature of putting an indication of how the game ended into the
10611 internal move list when playing from a file.  The only benefit of this was that
10612 it would get written back out if you saved the game at that point.  This
10613 feature doesn't seem too useful, since you are unlikely to save a game you've
10614 read in without making any changes, and it caused a lot of problems in the code
10615 and user interface.  The end condition is still displayed as a message when
10616 it's first read in from the file.  End conditions when playing against gnuchess
10617 are still saved, too.
10618
10619 * programName is now the last file name component of argv[0], not all of it.
10620
10621 * xboard.c got three compiler warnings due to arguments that didn't match the
10622 prototypes on X toolkit functions.  I got rid of them by adding some casts, and
10623 adding extra unused arguments to the ReceiveFromProgram function.
10624
10625 * As I received it, the distribution had an extra period glued on the front
10626 of every line that started with a period.  This broke the manpage in an
10627 obvious way.  It also broke parser.l in a nonobvious way that stopped
10628 PlayFromFile from working.
10629
10630 * Fixed one or two bugs where the clock was started when it shouldn't have
10631 been.  I think one example was if you tried an illegal move in ForceMoves mode.
10632
10633 * Now starts the machine's clock if you hit MachineWhite when white is on move
10634 or MachineBlack when black is on move.
10635
10636 * Now updates the to-move indicator (highlight on clock display) when you use
10637 Forward/Backward or ForceMoves.
10638
10639 * gnuchess 3.1+ has a bug that makes it try to think on its opponent's time
10640 even when in force mode; this causes problems with xboard's SetupFromFile
10641 command because gnuchess's saved hint move is garbage after the new position is
10642 loaded, so gnuchess prints out an error message when it tries to think about
10643 what it would do if the user made this move.  Here is a patch for gnuchess
10644 3.1+:
10645
10646 *** nondsp.c~   Mon Dec  2 12:37:18 1991
10647 *-- nondsp.c    Thu Dec 19 15:36:06 1991
10648 ***************
10649 *** 1223,1229 ****
10650     ok = flag.quit = false;
10651     player = opponent;
10652     ft = 0;
10653 !   if (hint > 0 && !flag.easy && Book == NULL)
10654       {
10655         fflush (stdout);
10656         time0 = time ((long *) 0);
10657 *-- 1223,1229 ----
10658     ok = flag.quit = false;
10659     player = opponent;
10660     ft = 0;
10661 !   if (hint > 0 && !flag.easy && Book == NULL && !flag.force)
10662       {
10663         fflush (stdout);
10664         time0 = time ((long *) 0);
10665
10666 * SavePosition/SetupFromFile now handle black-to-play positions.  If it's
10667 black's move in a saved position, the line "black to play" is printed
10668 immediately after the board display.  Upon loading a position, xboard
10669 looks for "black" at the beginning of this line to determine whether it's
10670 black's move.
10671
10672 * SetupFromFile now leaves you (effectively) in ForceMoves mode.  This
10673 eliminates some cases where the program would get into an inconsistent state,
10674 and hopefully is more intuitive for the user, too.
10675
10676 * PlayFromFile now leaves xboard in ForceMoves mode after playing through all
10677 the moves in the file.  You can use Backward/Forward, make moves, get gnuchess
10678 to join the game with MachineWhite or MachineBlack, etc.  The game file can end
10679 with either white or black to play.
10680
10681 * Backward/Forward now seem to work in all cases.  Previously using these
10682 buttons during a game against the machine would get xboard out of sync with
10683 gnuchess's idea of what was going on, resulting in chaos.  Now using these
10684 buttons puts xboard in ForceMoves mode; you can bring gnuchess back into the
10685 game using the MachineWhite or MachineBlack buttons.
10686
10687 Thu Jun 27 15:06:25 PDT 1991
10688
10689   * Remove comment popups during a reset.
10690
10691   * Bug in my forward move fix.  Didn't work for playgamefile mode.
10692
10693 Thu Jun 20 15:04:06 PDT 1991
10694
10695   * Can't do a backward move when it isn't your turn because gnuchess
10696     gets confused.  Similar bug for forward move.  Do a bunch of moves,
10697     back up move and go forward.  These get filtered out now.
10698
10699   * Put easy back into the initString.  This DISABLES easy mode which by
10700     default is ON.
10701
10702   * New-line wasn't always being added to forward move strings sent to gnuchess.
10703
10704   * Parsed comments as [ ..............text follows ] into d7d5
10705
10706   * Long game file comments cause core dumps on HP systems.
10707
10708   * Multiple uses of the get positition file button got confused
10709     on the second click.
10710
10711   Minor fixes to the 1.2 release
10712
10713 Version 1.2 -- Tue Jun 11 17:14:12 PDT 1991
10714
10715   * For version 1.2, Jeff Kenton, Richard LLoyd, David Jensen, Martin D.,
10716     Bill Schmidt, Scott Hemphill, Paul Vaughan and Bill Shauck all found
10717     a lot of bugs that we put into xboard just to see if they were paying
10718     attention.  They were.
10719
10720   * Changed the protocol that xboard uses to work with the new version of
10721     gnuchessr.
10722
10723   * There was an off by one error with the clock resetting code.  Also,
10724     the clock display highliting was wrong.  Thanks to Bill Shauck for
10725     pointing these out.
10726
10727   * enumerations are not really integers on some C compilers.  I added casting.
10728     The new version of gnuchess expects the "go" command for two machine
10729     and machine plays white cases.  The whiteString resource is for
10730     compatibility with previous gnuchess versions which get confused by go.
10731     Thanks to Martin D. for catching these.
10732
10733   * Fixed a bug where the checkmate message wasn't being parsed and xboard
10734     kept playing.  Also, the message was added to game file if saved.
10735     Thanks to Scott Hemhill for pointing this out.
10736
10737   * Fixed a bug where saving a long game, resetting and saving a short game
10738     resulted in appending the end of the long game to the short one.
10739     If a game is just being played out and there is no reason for gnuchessr
10740     to be used, ignore pipe signals.  This allows people to use xboard
10741     as a chess board without need for gnuchess.  Also, trivially bad moves
10742     such as e2e2 are not passed on to gnuchessr but instead ignored out of
10743     hand.  This allows people using xboard as a chessboard with gnuchessr
10744     to pick a piece up, think and put it back down without making a move.
10745     Thanks to Jeff Kenton for pointing these out.
10746
10747   * Added the CHESSDIR environment variable.  Game and position files are
10748     found in this directory.  If this variable is not declared, then the
10749     current directory is used.  File names starting with / are treated
10750     specially.
10751
10752   * The bitmap file names were changed so that none exceeded 14 characters.
10753     This is necessary for R5.
10754
10755         fcntl(from_prog[0], F_SETFL, O_NDELAY);
10756
10757     The xboard fix was to set non-blocking i/o on the read pipe for gnuchessr
10758
10759         printz ("Illegal move (no matching move generated)");
10760
10761   * fixed a problem with the new version of gnuchessr where xboard wasn't
10762     getting gnuchessr error messages for illegal moves.  The problem seems
10763     to be fixed *without* any gnuchess changes but this is likely to be
10764     highly system dependant.  There should be a new line on line 246 of nondsp.c
10765
10766   * -iconic doesn't work at all now.  The Iconify() does work.  This was
10767     a tradeoff and it is really an Xt bug.
10768
10769   * Fixed a compiler warning for gcc and an error for the IBM RT compilers.
10770     This is the VOID_PROC macro in xboard.h.  Thanks to David Jensen for this.
10771
10772   * If the DisplayWidth or DisplayHeight is less than 800, use small size mode.
10773     Also the size of the name widget was reduced from 500 pixels to 400 pixels
10774     because in small size mode there was a gap on the right.
10775     Changed the default font from fixed to helvetica_oblique14 to:
10776         **-helvetica-bold-r-normal--14-*-*-*-*-*-*-*
10777     helvetica_oblique14 is a font alias not on all R4 systems.
10778     Curiously enough, the 17 point is not available on 75dpi systems
10779     and the 18 point font is not available on 100dpi systems.
10780     Thanks to Richard K. Lloyd for pointing these out.
10781
10782   * Minor hacks to work with R5 alpha.  Had to add an event handler to the
10783     boardWidget to get translations to work.  This may go away with the real R5.
10784     Added <Message>WM_PROTOCOLS: QuitProc() for R5 ICCCM compatibility.
10785
10786   * If the first character of the file is not `1' then the first line
10787     of a game or position file is displayed as the name in a label widget.
10788
10789   * Added a PopUp dialog for getting file names.
10790
10791   * Modified the code to use the R4 routines rather than R3 compatibility.
10792
10793   * Changed the forwards/backwards/readgamefile code to allow a play to step
10794     back and forth in a game.  If he steps all the way to the beginning
10795     he has to restart the game.  If he gets into a mated position, same problem.
10796
10797   * Moved the man page from xboard.1 to xboard.man.  This makes imake man page
10798     installs work correctly.  Thanks to Richard K. Lloyd for pointing this out.
10799
10800   * Corrected the queening code.  XBoard was sending the wrong syntax.
10801     It was sending for example h8(Q) when it should have been sending h8q.
10802     Thanks to Paul Vaughan and Mike McGann for pointing this out.
10803
10804   * Added a lex parser for algebraic games.  It should be easy to use the parser
10805     for other interfaces such as the Microsoft Windows version.
10806     It parses comments of the form [anything] and ! to the end of a line.
10807
10808 Version 1.1 -- Mon Jan  7 14:46:03 PST 1991
10809
10810   * Roger Dubar, Konstantinos Konstantinides, Wolfgang S. Rupprecht,
10811     Paul Scowen, Mvh Smidt and Kayvan Sylvan all helped immensely during
10812     beta-testing.
10813
10814   * older non-ANSI versions of Sun compilers complain vociferously.
10815
10816   * the remoteShell resource was added for HP-UX systems
10817     and other systems where the remoteShell isn't rsh.
10818
10819   * -iconic doesn't work properly.  If XBoard is opened iconic then
10820     iconifying it later with a keystroke doesn't work.  I think
10821     this is an Xt bug.
10822
10823   * For systems with smaller screens, XBoard can use smaller pieces,
10824     and a smaller board.  -bigSizeMode False uses a smaller set of pieces.
10825     These are scaled versions of the large pieces.  They look ok but could
10826     be improved.
10827
10828   * getlogin() does not work in all cases.
10829     It was replaced by getpwuid(getuid())->pw_name).
10830
10831   * Warning messages get displayed in the message box.
10832
10833   * Any button restarts a paused game.
10834
10835   * Kayvan Sylvan contributed a patch for ESIX.
10836     It seems that select() on pipes is broken on his system.  We declined
10837     to incorporate his patch though, because it was a work-around for
10838     something that was broken on one system, and selfishly, that system
10839     was not my own.  Nevertheless, it is likely that other System V users
10840     on PC's may need to use this patch and it is is included as the file
10841     ESIX.patch.  To use it, type
10842
10843         patch xboard.c ESIX.patch
10844
10845   * Fixed a bug where hint didn't work.  The local version of gnuchessr
10846     had been hacked.  The fix was to clone stderr and stdout for gnuchessr.
10847
10848   * Fixed a bug where a player could play after a game had been finished.
10849
10850   * The bitmaps have been pushed into the bitmaps directory.
10851
10852   * Substantially rewrote and simplified the Two Machine code.
10853
10854   * Added StrStr() because many systems don't have this ANSI function.
10855
10856   * Added keyboard equivalents.  Added an iconify keystroke, C or c.
10857
10858   * Works with gcc now.  gcc complained about casting float constants
10859     as XtPointers.
10860
10861   * Detect if the visual doesn't support color.  If so, run in monoMode.
10862     An alternative would be to detect grayscale visual and use a collection
10863     of gray user interface colors.
10864
10865         XBoard.clockMode:    False
10866
10867   * For people who don't like or use chess clocks a clockMode switch
10868     has been added.  It is on by default.  It can be turned off in the
10869     .Xdefaults file with
10870
10871   * Added a declaration, xtVersion, which will quickly break on R3 Intrinsics.
10872
10873   * Hal Peterson contributed a new Imakefile.
10874
10875   * Rewrote DisplayClocks().
10876
10877   * Rewrote TwoMachinesPlay mode.
10878
10879   * Konstantinos Konstantinides added the -searchTime option.
10880
10881   * Substantially rewrote and simplified the clock code.  If a game was paused
10882     and then resumed, the clocks were out of sync.
10883
10884   * Fixed a bug in HandleUserMove() where the user could make a move while the
10885     machine was thinking.  The fix detects and ignores these moves.  onMove
10886     was not being used and was removed.