12 years agoAlso exempt variant seirawan from eval-scale doubling
H.G. Muller [Wed, 1 Dec 2010 17:57:57 +0000 (18:57 +0100)]
Also exempt variant seirawan from eval-scale doubling

It is not really a drop game, so a scale from -7 to 7 in the eval graph
is good enough (like variants great and super).

12 years agoConfigure EGTB cache size in adapterCommand
H.G. Muller [Wed, 1 Dec 2010 09:33:13 +0000 (10:33 +0100)]
Configure EGTB cache size in adapterCommand

The hash size, nr of CPUs and EGTB path are transferred through the WB
protocol interface commands memory, cores and egtpath. But there is no
WB command for detailing the EGTB cache size. So the value of the
command-line option -defaultCacheSizeEGTB has to be sent to Polyglot
through its startup command to make it known to UCI engines.

12 years agoMove Hint and Book items to Engine menu in XBoard
H.G. Muller [Tue, 30 Nov 2010 21:46:16 +0000 (22:46 +0100)]
Move Hint and Book items to Engine menu in XBoard

12 years agoCorrect the key bindings fo view menu in texi file
H.G. Muller [Tue, 30 Nov 2010 21:17:24 +0000 (22:17 +0100)]
Correct the key bindings fo view menu in texi file

The mentioned bindings for Game List and Eval Graph were wrong.

12 years agoFix sub-variation display with negative score
H.G. Muller [Tue, 30 Nov 2010 20:25:07 +0000 (21:25 +0100)]
Fix sub-variation display with negative score

The test if the displayed score was the pvInfo score failed for negative
scores, because floats are truncated towards zero. So the previous fix
of spurious score/depth info was not working when the score was

12 years agoPeel PV out of comment
H.G. Muller [Tue, 30 Nov 2010 17:27:52 +0000 (18:27 +0100)]
Peel PV out of comment

Arena stores engine PVs not in variation format, but within both braces
and parentheses, before the score/depth info. This caused XBoard to
overlook the score/depth info, (frustrating, e.g., the eval graph),
while the PV would not be accessible for walking it as a variation.
The routine that extracts the score/depth from a comment now has
been made more clever, to recognize a leadin PV in the comment, and then
place it in front of the comment as variation (by moving the opening
brace to behind it). For some reason it does not work if the PV and
score/depth were separated by a newline, but this happens quite rarely.

12 years agoAllow line-straddling result comments
H.G. Muller [Tue, 30 Nov 2010 17:23:12 +0000 (18:23 +0100)]
Allow line-straddling result comments

Some GUIs (in particular Arena) do not have the decency to keep the
result comment on a single line. In this case the parser rules would not
recognize it, and treat it as a normal comment, plus an undetailed PGN
result. The rules are now fixed to allow linefeeds in the comment, and
between comment and PGN result. To correctly process the comment further
(e.g. in game-list lines) the linefeeds are replaced by spaces in the
back-end routines that do use the result comment.

12 years agoWrite key bindings in XBoard menus
H.G. Muller [Tue, 30 Nov 2010 11:22:32 +0000 (12:22 +0100)]
Write key bindings in XBoard menus

Unfortunately tabs are not understood in menu texts, so fine-tuning
through spaces is necessary to get some sort of ragged alignment.

12 years agoConfigure XBoard to use wood board texture by default
H.G. Muller [Mon, 29 Nov 2010 17:01:38 +0000 (18:01 +0100)]
Configure XBoard to use wood board texture by default

The texture pixmaps are sought in /usr/share/games/xboard, with names
wood_l.pm and wood_d.xpm. I guess the " make install" should be adapted
to put them there. XBoard is resitent to non-existence of the files,
btw. It simply ignores the arguments in that case.

12 years agoConfigure -inc as volatile option in XBoard
H.G. Muller [Mon, 29 Nov 2010 16:48:48 +0000 (17:48 +0100)]
Configure -inc as volatile option in XBoard

XBoard users are not used to options being persistent, and thus have
many scripts assuming the timeIncrement is -1 when they don't specify it
on the command line, and want to specify -mps. But a persistent -inc of
0 fom a preious session would then force their -mps to zero, causing
big-time confusion.

12 years agoMake WinBoard clocks translation-proof
H.G. Muller [Mon, 29 Nov 2010 16:36:33 +0000 (17:36 +0100)]
Make WinBoard clocks translation-proof

With logos on, the splitting of the clock over two lines assumed the
lengths of the words "white" and "black" would always be 5. Used strlen.

12 years agoImprove drawing of highlight arrow
H.G. Muller [Mon, 29 Nov 2010 13:57:00 +0000 (14:57 +0100)]
Improve drawing of highlight arrow

A diagonal arrow sometimes had a notch in the shaft because of
independent rounding of the starting and ending point coordinates.
Furthermore the width of the shaft was unnecessary variable(as a
function of direction) because half the width was rounded and then used
twice. Now rounding of end-points is always done towards a fixed grid
of square centers, which keeps diagonals purely diagonal, and one side
of the shaft is drawn relative to the other side, after the
position of the latter has been rounded, so any rounding error affects
the shaft width only once.

12 years agoAlter descriptionof Analyze File menu item
H.G. Muller [Mon, 29 Nov 2010 09:25:50 +0000 (10:25 +0100)]
Alter descriptionof Analyze File menu item

This menu item has been given a new function, so a new description was

12 years agoAdd description of Game List Options in texi file
H.G. Muller [Mon, 29 Nov 2010 09:15:39 +0000 (10:15 +0100)]
Add description of Game List Options in texi file

12 years agoUpdate texi file for new menu organization
H.G. Muller [Mon, 29 Nov 2010 08:58:00 +0000 (09:58 +0100)]
Update texi file for new menu organization

The descriptions are shuffled around and organized into sections
corresponding to the new main menus. Where necessary the name of the
items was changed to their new names. The items removed from the File
menu (the next/previous/same stuff) are nowmoved to the section "other
shortcut keys", as the key bindings for some of them are still active.

12 years agoUpdate info on key bindings in texi file
H.G. Muller [Mon, 29 Nov 2010 08:06:14 +0000 (09:06 +0100)]
Update info on key bindings in texi file

The texi file was still listing the old XBoard key bindings. Where
necessary this is now changed to the new (WinBoard) bindings, and all
the new bindings were added.

12 years agoAdd XBoard key bindings for Revert and Truncate
H.G. Muller [Mon, 29 Nov 2010 08:04:53 +0000 (09:04 +0100)]
Add XBoard key bindings for Revert and Truncate

Use Home key as accelerator for Revert, End for Truncate, as in WinBoard.

12 years agoDivorce the Edit and Show Tags/Comment menu items
H.G. Muller [Sun, 28 Nov 2010 22:12:14 +0000 (23:12 +0100)]
Divorce the Edit and Show Tags/Comment menu items

In WinBoard the items in the Edit and View menu for Tags and Comment now
have different IDs, so they can be independently controlled. Only the
items in the View menu are check-marked. The items still do the same.

12 years agoAlter WinBoard menu text
H.G. Muller [Sun, 28 Nov 2010 22:08:26 +0000 (23:08 +0100)]
Alter WinBoard menu text

The texts are slightly adapted, mostly by choosing more convenient
tabbing characters for the new menu organization. The translation
template is updated accordingly.

12 years agoLet move-history window scroll to bottom after adding move
H.G. Muller [Sun, 28 Nov 2010 19:24:46 +0000 (20:24 +0100)]
Let move-history window scroll to bottom after adding move

By activating the scrollbar of the viewport through XtCallActionProc
the move-history window is scrolled to the bottom.

12 years agoFix Shogi promotion popup
H.G. Muller [Sat, 27 Nov 2010 13:38:14 +0000 (14:38 +0100)]
Fix Shogi promotion popup

The texts were adapted to shogi by printing new text items over the
Queen and Knight buttons, but these did not alwys cover it. Now the text
on the buttons is changed as it should be. Also the window title is

12 years agoApply gettext macros to menu texts
H.G. Muller [Fri, 26 Nov 2010 10:22:06 +0000 (11:22 +0100)]
Apply gettext macros to menu texts

Now texts and references are separated, the texts in the tables can be
decorated with the N_() macro, so that the _() macro no longer has to be
applied when they are used. (This makes the texts appear in the .po

12 years agoAdapt some XBoard menu texts
H.G. Muller [Fri, 26 Nov 2010 10:12:58 +0000 (11:12 +0100)]
Adapt some XBoard menu texts

The "Show" prefix is removed from the "View" menu items, as this seems
implied. An ellipsis is added to the Engine #N Settings items, which
could not be there before, because periods in a menu name would break
any reference to it. For some other names the ellipsis was deleted.
(These were not refered to, but who knows what we will do in the future.)

12 years agoSeparate menu text from menu name in XBoard
H.G. Muller [Fri, 26 Nov 2010 10:03:35 +0000 (11:03 +0100)]
Separate menu text from menu name in XBoard

The text string in the menu-definition tables was used both for the menu
text, as well as for referencing the items from the code (for enabing or
checkmarking). Now these can be defined separately, so that altering the
menu texts is possible without breaing any references to the item.
(Moving them to another menu would still break XBoard, though!)
Currently the texts and names are still the same.

12 years agoBugfix XBoard menu translation
H.G. Muller [Fri, 26 Nov 2010 09:48:54 +0000 (10:48 +0100)]
Bugfix XBoard menu translation

The gettext macro N_() was applied to the menu definition tables, but
this would break any translation, as these items are both used as menu
texts as well as reference for enabling and checkmarking. The routines
that create the menus already apply _() dynamically to these items when
they are used as menu texts.

12 years agoRestrict drops in variant seirawan to back rank
H.G. Muller [Fri, 26 Nov 2010 09:10:55 +0000 (10:10 +0100)]
Restrict drops in variant seirawan to back rank

Drops aren't really llowed at all in Seirawan Ches, but there exists an
engine that supports a variant where drops on the back-rank are allowed.

12 years agoLet Analyze File annotate the loaded game
H.G. Muller [Thu, 25 Nov 2010 18:44:37 +0000 (19:44 +0100)]
Let Analyze File annotate the loaded game

By not suppressing the auto-play loop in AnalyzeFle mode, we step
through the game while the engine is analyzing, and store the PV info
that the engine produces, as well as the full PV (as variation comment)
with each move.

12 years agoRevive Analyze File menu item in WB
H.G. Muller [Thu, 25 Nov 2010 18:41:05 +0000 (19:41 +0100)]
Revive Analyze File menu item in WB

We will keep this menu after all, becase it can be given a new meaning.

12 years agoFix spurious scores in comments
H.G. Muller [Thu, 25 Nov 2010 18:31:52 +0000 (19:31 +0100)]
Fix spurious scores in comments

The comment popup is also used to display engine PV info, but when the
contents of the window is written back when we select a variation,
it was treated as a real comment. This is fixed now by checing in
ReplaceComment() if the comment starts with the PV info, and if so,
ignore the latter. This solves the problem, but I guess the real bug is
that selecting a variation tries to write the comment even if it did not

12 years agoDisplay error for wrong use of Machine Match
H.G. Muller [Thu, 25 Nov 2010 18:26:34 +0000 (19:26 +0100)]
Display error for wrong use of Machine Match

12 years agoReorganize XBoard menus
H.G. Muller [Wed, 24 Nov 2010 12:30:08 +0000 (13:30 +0100)]
Reorganize XBoard menus

12 years agoReorganize WinBoard menus
H.G. Muller [Wed, 24 Nov 2010 10:02:19 +0000 (11:02 +0100)]
Reorganize WinBoard menus

New main menus Edit, View and Engine are added; the step menu
disappears. The menu items are redistributed over the new menus.
Sometimes duplicates are created. No adaptation of short-cut characters
as made yet (as this affects translation).

12 years agoremoved trailing whitespaces from NEWS
Arun Persaud [Sun, 21 Nov 2010 04:20:27 +0000 (20:20 -0800)]
removed trailing whitespaces from NEWS

12 years agomerged readme_HGM.txt into the NEWS file
Arun Persaud [Sun, 21 Nov 2010 04:19:30 +0000 (20:19 -0800)]
merged readme_HGM.txt into the NEWS file

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.

12 years agotypo in date of developer release
Arun Persaud [Sun, 21 Nov 2010 02:24:19 +0000 (18:24 -0800)]
typo in date of developer release

but will leave the tagged version as it is, since it's still a unique version number

12 years agonew developer release
Arun Persaud [Sun, 21 Nov 2010 02:11:01 +0000 (18:11 -0800)]
new developer release

12 years agoadded latest version of parser.c
Arun Persaud [Sun, 21 Nov 2010 02:12:41 +0000 (18:12 -0800)]
added latest version of parser.c

12 years agoupdated Changelog, etc for developer release
Arun Persaud [Sun, 21 Nov 2010 02:05:56 +0000 (18:05 -0800)]
updated Changelog, etc for developer release

12 years agoRevert "adding gnu-readline support"
Arun Persaud [Sun, 21 Nov 2010 00:22:00 +0000 (16:22 -0800)]
Revert "adding gnu-readline support"

This reverts commit c95ef32a700132a134f335f857ca6f1b6f3c169f.


better to use the (relatively) new ICS input box then add readline support.

12 years agoRevert "bugfix: fixed readline support with icslogon option"
Arun Persaud [Sun, 21 Nov 2010 00:19:32 +0000 (16:19 -0800)]
Revert "bugfix: fixed readline support with icslogon option"

This reverts commit b9cdd7422ad1037d7376bce4f8f2db2669396e83.


better to use the (relatively) new ICS input box then add readline support.

12 years agoMake Hoplite moves irreversible in Spartan Chess
H.G. Muller [Fri, 19 Nov 2010 22:10:35 +0000 (23:10 +0100)]
Make Hoplite moves irreversible in Spartan Chess

Consider Lance moves in variant Fairy (where the Lance represents the
Spartan Hoplite Pawn) as Pawn moves, so they reset the 50-move counter.

12 years agoGive Lance moves of Amazon in variant super
H.G. Muller [Fri, 19 Nov 2010 20:09:24 +0000 (21:09 +0100)]
Give Lance moves of Amazon in variant super

Now that Lance is no longer a wild-card piece the moves of Amazon must
be programmed explicitly, to keep the possibbilty to play Superchess
with legality testing on.

12 years agoChange representation of Bede in variant fairy initial position
H.G. Muller [Fri, 19 Nov 2010 17:32:16 +0000 (18:32 +0100)]
Change representation of Bede in variant fairy initial position

This used to be Lance, but the promoted Bishop (Dragon Horse)
is more applicable. Especially now that Lance is supposed to move like a
Berolina Pawn.

12 years agoMake yyskipmoves also suppress examining of drop moves
H.G. Muller [Fri, 19 Nov 2010 17:28:19 +0000 (18:28 +0100)]
Make yyskipmoves also suppress examining of drop moves

Not sure if this does any good, but it seemed illogical that this would
happen in all other moves, but not drops.

12 years agoDefine moves for Dragon Horse outside Shogi
H.G. Muller [Fri, 19 Nov 2010 17:23:05 +0000 (18:23 +0100)]
Define moves for Dragon Horse outside Shogi

Let it move like Bishop + Wazir + Dababba.

12 years agoFix safety crash when appending comments
H.G. Muller [Wed, 17 Nov 2010 12:40:20 +0000 (13:40 +0100)]
Fix safety crash when appending comments

The length limit imposed on safeStrCpy was one too short when copying
an existing comment to the space allocated for the longer (concatenated)
one. It allowed no space for the terminating '\0'.

12 years agoFix safeStrCpy
H.G. Muller [Wed, 17 Nov 2010 12:38:00 +0000 (13:38 +0100)]
Fix safeStrCpy

The test for when to terminate a non-fiting string was one off, and the
debug message was written stdoutin stead of debugFP.

12 years agoFix default holdings size for variant seirawan
H.G. Muller [Tue, 16 Nov 2010 11:40:31 +0000 (12:40 +0100)]
Fix default holdings size for variant seirawan

The holdings for 7 pieces werealways considered an overrule, so that the
variant name was prefixed with "8x8+7_".

12 years agoFix home-dir crash
H.G. Muller [Mon, 15 Nov 2010 10:36:21 +0000 (11:36 +0100)]
Fix home-dir crash

When confronted with a path name starting with ~ and not containing a /
XBoard would segfault.

12 years agoFix one-click moving on up-click
H.G. Muller [Sun, 14 Nov 2010 20:45:55 +0000 (21:45 +0100)]
Fix one-click moving on up-click

(First) up-clicks were not always ignored: in Edit-Game mode with
one-click moving enabled this could lead to a capture being made on
the down-click, and the recapture on the correspoding up-click.
This has now been corrected, and only the down-click of a first click
can lead to selecting a piece or a one-click move.

12 years agofixed buffer size for snprintf
Arun Persaud [Tue, 16 Nov 2010 02:15:40 +0000 (18:15 -0800)]
fixed buffer size for snprintf

12 years agoAccept Seirawan-style gating suffixes
H.G. Muller [Sat, 13 Nov 2010 22:04:14 +0000 (23:04 +0100)]
Accept Seirawan-style gating suffixes

The parser rules were extended to accept / as an equivalent of = in
promotion-suffix notation (e.g. Nf3/H in stead of Nf3=H).

12 years agoUse Falcon and Alfil as built-ins for Seirawan chess
H.G. Muller [Sat, 13 Nov 2010 21:55:32 +0000 (22:55 +0100)]
Use Falcon and Alfil as built-ins for Seirawan chess

Where available (size 49 and 72) we use Falcon for Archbishop and Alfil
for Chancelor, to better conform to the Seirawan names Hawk and Elephant.

12 years agoImplement entering gating moves with mouse
H.G. Muller [Sat, 13 Nov 2010 19:02:31 +0000 (20:02 +0100)]
Implement entering gating moves with mouse

A move with a back-rank piece that starts when a piece in the holdings
is selected will be interpreted as a gating move in variant seirawan.
The front-end uses a 'gatingPiece' selected this way todisplay it on the
from square during animate dragging.

12 years agoImplement variant seirawan
H.G. Muller [Sat, 13 Nov 2010 17:56:15 +0000 (18:56 +0100)]
Implement variant seirawan

Set upthe position, including Hawk and Elephant in holdings, in
InitPostion(). Suppress putting captured pieces in holding. Let
promoChar indicate gating in ApplyMove(). Remove gated pieces from
the holdings there. Let GenLegal() generate RxK-type castlings to act as
base for gating on Rook square. Gatings are tested for legality
based on the holdings content and whether they occur on the back
rank. Disambiguate() also tests this. Make sure the gated pieces are
printed as move suffixes in CoordsToAlgebraic().

12 years agoAdd -variant seirawan to menu
H.G. Muller [Sat, 13 Nov 2010 17:42:27 +0000 (18:42 +0100)]
Add -variant seirawan to menu

12 years agoFix acceptance of null-move with legality testing off
H.G. Muller [Sat, 13 Nov 2010 21:52:09 +0000 (22:52 +0100)]
Fix acceptance of null-move with legality testing off

A second click on the same piece was interpreted as a to-square rather
than deselection of the piece.

12 years agoFix one-click bug
H.G. Muller [Sat, 13 Nov 2010 21:49:43 +0000 (22:49 +0100)]
Fix one-click bug

Disambiguate was imagining captures, so an only capture by double
clicking your own piece did not always work.

12 years agoFix mouse-driver buglet
H.G. Muller [Sat, 13 Nov 2010 19:08:32 +0000 (20:08 +0100)]
Fix mouse-driver buglet

The highlights were not cleared on moves that went vertically off board.

12 years agoList some undocumented commands as compliant
H.G. Muller [Fri, 12 Nov 2010 16:17:41 +0000 (17:17 +0100)]
List some undocumented commands as compliant

The engine->GUI commands setboard and setup are now always printed in
the debug file as well.

12 years agoList Hint with compliant commands
H.G. Muller [Fri, 12 Nov 2010 16:05:22 +0000 (17:05 +0100)]
List Hint with compliant commands

This command was omitted, so that in some -engineDebugOutput modes it
would not appear in the debug file.

12 years agoRestrict use of escape expansion
H.G. Muller [Fri, 12 Nov 2010 16:02:53 +0000 (17:02 +0100)]
Restrict use of escape expansion

Only expand escape sequences like \n and \t in telluser(error) comamnds
that ask for it by preficing the messages by double backslash. Otherwise
backward copatiblity is too severely broken for messages that display
DOS-style filenames.

12 years agoMake safeStrCpy safe
H.G. Muller [Fri, 12 Nov 2010 12:56:33 +0000 (13:56 +0100)]
Make safeStrCpy safe

SafeStrCpy was causing a lot of out-of-bound write accesses, as it was
always writing the character at the length limit of the destination.
Now no memory is accessed that is is not needed to hold the copy.

12 years agoAllow clicked name internal to the icsMenu command string
H.G. Muller [Sun, 7 Nov 2010 20:37:10 +0000 (21:37 +0100)]
Allow clicked name internal to the icsMenu command string

A command in the /icsMenu that was specified to contain the selected
text or clicked word always appended this word at the end. Now the user
can also configure it to appear in the middle, by putting a %s in the
command string where he wants it to appear.

12 years agoLet Engine #2 Settings start second engine
H.G. Muller [Sun, 7 Nov 2010 20:33:19 +0000 (21:33 +0100)]
Let Engine #2 Settings start second engine

If the second engine is not yet running, it would be impossible to use
the settings dialog for it, as the features have not been received and
the dialog will be empty. So the user could not adjust the engine
parameters before starting a match. Using this menu now automatically
starts the engine, and delays the appearence of the popup untill the
features are received, using a similar mechanism as in

12 years agoNewly lexed parser.c
H.G. Muller [Mon, 1 Nov 2010 18:40:26 +0000 (19:40 +0100)]
Newly lexed parser.c

12 years agoFix bug in parsing illegal Pawn captures
H.G. Muller [Sat, 6 Nov 2010 18:55:31 +0000 (19:55 +0100)]
Fix bug in parsing illegal Pawn captures

When a pawn move of type exf5 was illegal, the parser made an attempt to
interpret it as e.p. capture of f5. This, however, messed up the move,
so that it was now permanently mistaken for e5xf6. Even in cases with
legality testing off, where you would want the original move to be
accepted despite the fact that it was illegal.

12 years agoKeep last PV while clearing engine-output display
H.G. Muller [Sat, 6 Nov 2010 18:49:45 +0000 (19:49 +0100)]
Keep last PV while clearing engine-output display

When ponder is on, the display is cleared immediately when the last line
of thinking output appears by the appearing ponder output. So you would
never get the chance to see it. This line is now re-written after
clearing, so it appears at the bottom of the output for the next search.

12 years agoGive Lance moves of Berolina Pawn
H.G. Muller [Sat, 6 Nov 2010 18:45:18 +0000 (19:45 +0100)]
Give Lance moves of Berolina Pawn

In stead of using it as a wildcard piece, the Lance gets the moves of
the Berolina Pawn (straight capture, diagonal move). The initial double
osh can be a ump, though. (So it is really a Hoplite Pawn from Spartan

12 years agoUse SAN even on illegal moves
H.G. Muller [Sat, 6 Nov 2010 18:42:16 +0000 (19:42 +0100)]
Use SAN even on illegal moves

If there is only one piece of type T, moves like Ta1 or Txa1 are never
ambiguous, so adding the from square is just cumbersome.

12 years agoUse normal SAN for wildcard pieces
H.G. Muller [Sat, 6 Nov 2010 18:34:53 +0000 (19:34 +0100)]
Use normal SAN for wildcard pieces

SAN often can also be used with pieces we don't know the moves of, e.g.
if there is only one of that type. We just always get rank or file
disambiguators if there are more (even when they might be unnecessary).

12 years agoFix some warnings
H.G. Muller [Sat, 6 Nov 2010 13:52:12 +0000 (14:52 +0100)]
Fix some warnings

Unused variables were removed from parser.l

12 years agoAllow arbitrary nesting of sub-variations in PGN input
H.G. Muller [Sat, 6 Nov 2010 13:43:54 +0000 (14:43 +0100)]
Allow arbitrary nesting of sub-variations in PGN input

The parsing of subvariations is moved out of the state-machine parsing,
to allow arbitrary nesting. In stead of the entire sub-variation being
parsed by lex as Comment, it now returns Open and Close for the
corresponding parentheses, which are then handled in a wrapper routine
for yylex(): Myylex(). Problem was that yy_text is supposed to return
the entire parsed text of the returned symbol, which thus has to be
collected. To make this possible, yylex has to return everything that it
parses, (even white space!), and a symbol "Nothing" was added to return
in parsing rules that before just ate away irrelevant text without
returning anything.

12 years agoImplement setup (engine-GUI) command
H.G. Muller [Sat, 6 Nov 2010 20:48:47 +0000 (21:48 +0100)]
Implement setup (engine-GUI) command

This allows the frst engine (when legality testing is off) to overrule
the default opening position, in reply to the variant command. Syntax is
where the FEN string is interpreted in the context of the given
pieceToCharTable (which is optional, and only delimeted by parethesis if
it is present).
Sendng the position to the second engine is delayed until the first
engine has responded to the ping after the new-game sequence, to make
sure it gets the chance to alter the position before it is sent to the
second engine. This feature is useful for playing variants that WinBoard
does not even know the opening positon for, and can be used even if they
are shuffle variants.

12 years agoRestrict use of a2a3 kludge
H.G. Muller [Sat, 6 Nov 2010 13:19:56 +0000 (14:19 +0100)]
Restrict use of a2a3 kludge

The kudge to send "a2a3" in stead of "black" to get black to move is
fatally flawed in varants that have no Pawn on a2. So in that case we
revert to use of the deprecated "black" command.

12 years agoRemember values set by -firstOptions, -secondOptions
H.G. Muller [Tue, 2 Nov 2010 12:06:58 +0000 (13:06 +0100)]
Remember values set by -firstOptions, -secondOptions

When an engine announces its option features, and the option name
matches that of a setting given in -first/secondOptions, the engine is
sent hte specified value, but this value was not remembered as current
value (but the latter  was left at the engine-announced default),
leading to inconsistent behavior in the Engine #N Settings dialog.

12 years agoMake test for valid promotion piece color-dependent
H.G. Muller [Mon, 1 Nov 2010 18:26:19 +0000 (19:26 +0100)]
Make test for valid promotion piece color-dependent

This is needed to make it work in variants where white and black have
different armies; quite likely white will promote to pieces that do not
exist in the black army, so we really have to make sure we test if the
white (upper-case) piece exists in this case.

12 years agoRemove validity test on promochar from parser
H.G. Muller [Mon, 1 Nov 2010 18:23:43 +0000 (19:23 +0100)]
Remove validity test on promochar from parser

The backend routines Disambiguate() and LegalityTest() will catch
invalid promotions, so no need to do it here.

12 years agoAdd the actual size-33 Shogi bitmaps
H.G. Muller [Sun, 31 Oct 2010 22:37:06 +0000 (23:37 +0100)]
Add the actual size-33 Shogi bitmaps

These were forgotten in the original commit that fixed the .rc file.

12 years agoDelete some stale promotion code
H.G. Muller [Sun, 31 Oct 2010 12:20:08 +0000 (13:20 +0100)]
Delete some stale promotion code

The correction of the promotion piece to Ferz in Shatran-like variants
in ApplyMove() was no longer needed, as the new promotion code already
does this in the move parser.

12 years agoAugment moves of some fairy pieces
H.G. Muller [Sun, 31 Oct 2010 12:08:52 +0000 (13:08 +0100)]
Augment moves of some fairy pieces

To get better disambiguation in variants that have to be played with
legality testing off, the Elephant is given also one-step moves (making
it a so-called Modern Elephant) in -variant fairy and great. The Dragon
King (Crowned Rook), which had no moves defined for it outside Shogi at
all, has been given Rook moves plus an orthogonal 2-jump, so that it
can get SAN moves when used as Dababba or Short Rook. (Illegal moves
currently aways force long algebraic notation...)

12 years agoBugfix safeStrCpy patch, WinBoard
H.G. Muller [Mon, 8 Nov 2010 21:57:56 +0000 (22:57 +0100)]
Bugfix safeStrCpy patch, WinBoard

The use of sizeof on pointers was detected through the same method as
the previous patches, this time while compiling WinBoard. A typo in
jaws.c was fixed as well.

12 years agoBugfix for safeStrCpy patch for XBoard
H.G. Muller [Mon, 8 Nov 2010 22:03:13 +0000 (23:03 +0100)]
Bugfix for safeStrCpy patch for XBoard

By a trick (temporarily redefining safeStrCpy in common.h as
((char*) (a=1/(4-3rdArgument))) ) a compile-time warning (division by 0)
could be generated for every occurrence where the size argument was equal
to 4, i.e. where the 1st argument was likely a pointer rather than an
array. These cases are now fixed. The file xoptions.c, which is the
only ne that does not #include common.h had to be fixed by making
the #define in the file itself.

12 years agoFix spurious promotions with legality testing off
H.G. Muller [Sun, 31 Oct 2010 12:16:01 +0000 (13:16 +0100)]
Fix spurious promotions with legality testing off

The recent promotion patch had broken playing without legality testing
completely: without legality testing one always gets the piece that was
asked for, but a NULLCHAR should not be taken as a request for a piece!
But it was, and this resulted in any moved piece turning into a white
Pawn! For true promotions the piece was always black, which was also not
very useful.

Also revert to the use of '+' as internal Shogi promoChar, because
pre-processing turns out not to be possible when reading a game file.
In stead parse any trailing '+' on moves as promoChar. Downside: '++'
can no longer be recognized as checkmate symbol.

12 years agoMake deferral default in Shogi promotions
H.G. Muller [Fri, 29 Oct 2010 20:54:18 +0000 (22:54 +0200)]
Make deferral default in Shogi promotions

Because '+' is intercepted by the parser as check indicator, Shogi moves
are pre-processed to change a trailing '+' into an internally used
alternative '^'. The testing if a promotion character is OK is now done
in LegalityTest() and Disambiguate(), which return ImpossibleMove when
the character does not correspond to any piece, and IllegalMove when in
Shogi anything other than '^' or '=' is used. (Except for the ICS
notations.) On output, in CoordsToComputerAlgebraic() and
CoordsToAlgebraic(), the '^' is translated back to '+'.

12 years agoAnimate piece explosions in drag-drop moves and in XB
H.G. Muller [Thu, 28 Oct 2010 15:51:34 +0000 (17:51 +0200)]
Animate piece explosions in drag-drop moves and in XB

This required some code restructuring: the decision if an explosion is
needed is now taken in a new routine Explode() in the backend. This then
calls the front-end driver, and it returns the info if there was an
explosion or not, so the caller (AnimateMove() or the mouse driver) can
take action to repair the damage to the board caused by the blast wave.
A front-end driver for XBoard is provided as well, so that both
click-click (and replay, which is the same) and drag-drop atomic
captures are animated in XB as well as WB.
Explosions on rejected moves are suppressed.

12 years agoSuppress promotion popup if piece will explode
H.G. Muller [Thu, 28 Oct 2010 11:53:51 +0000 (13:53 +0200)]
Suppress promotion popup if piece will explode

In atomic, a Pawn capture to last rank is not really a promotion.
Fix choice to Queen.

12 years agoMake Knight hop first straight, then diagonal
H.G. Muller [Thu, 28 Oct 2010 16:42:25 +0000 (18:42 +0200)]
Make Knight hop first straight, then diagonal

It used to be the other way around, which looked pretty illogical in
Xiangqi: to see Horses, which are blockable pieces there, move over an
occupied square.

12 years agoLet -oneClickMove also work in EditGame mode
H.G. Muller [Wed, 27 Oct 2010 18:04:01 +0000 (20:04 +0200)]
Let -oneClickMove also work in EditGame mode

There is really no reason why people that lke one-clcik moves enough to
switch them on would not want to use them too when editing a game.
This solves a nast inconsistency, as before it used to work in -ncp mode
on the _first_ move, as the mode is then BeginningOfGame, and not yet
EditGame, and we do want it to work for BeginningOfGame, as this is
also the game mode when you start playing as white.

12 years agoMake -flipBlack and -allWhite option volatile
H.G. Muller [Wed, 27 Oct 2010 17:40:22 +0000 (19:40 +0200)]
Make -flipBlack and -allWhite option volatile

As these options are very Shogi specific, and the variant is volatile,
it seems logical to make them also volatile. Not completely sure about
-allWhite, though. It cold be useful if you want, for example, to play
wth dark-brown pieces for black, as any color but black looks much
better with outline pieces than with solid pieces.

12 years agoProvide some sample board-texture pixmaps
H.G. Muller [Wed, 27 Oct 2010 17:33:44 +0000 (19:33 +0200)]
Provide some sample board-texture pixmaps

Wood and marble themes are provided as textures for light and dark
squares, plus two complete Xiangqi boards (wood and evenly colored).
These should probably not goint the distro tar ball.

12 years agoThe -overrideLineGap option is made to work in XBoard
H.G. Muller [Wed, 27 Oct 2010 17:25:56 +0000 (19:25 +0200)]
The -overrideLineGap option is made to work in XBoard

Although XBoard already allowed this in the -boardSize specification,
it is still seful to globally disable grid lines, e.g. for an
oriental Xiangqi board. And it converges XB and WB.

12 years agoImplement board textures in XBoard
H.G. Muller [Wed, 27 Oct 2010 17:18:41 +0000 (19:18 +0200)]
Implement board textures in XBoard

The -darkBackTextureFile and -liteBackTextureFile options now wrk in
XBoard too, for loading a pixmap that will be used to cut out the dark
and light square backgrounds. The cutting algorithm is such that the
pixmap image is completely restored if the size was that of the total
board (e.g. a drawing of a Xiangqi board).

12 years agoComplete WB (western) bitmaps for Shogi at size 33
H.G. Muller [Wed, 27 Oct 2010 10:11:02 +0000 (12:11 +0200)]
Complete WB (western) bitmaps for Shogi at size 33

The Lance was not replacing Queen in some sizes where the bitmaps were
already available, and new bitmaps for the promotion Golds were added.

12 years agoMake starting new variation dependent on shift key
H.G. Muller [Fri, 22 Oct 2010 18:30:06 +0000 (20:30 +0200)]
Make starting new variation dependent on shift key

The shift key is read during mouse events, and posted in a global
variable, which can then be used by the back-end. The decision to start
a new variation (pushing the game tail rather than clipping it off) when
entring a move in Edit Game or Analyze mode is made dependent on this.
The move-typein also records the shift-key state.

12 years agoFix merging bug
H.G. Muller [Fri, 22 Oct 2010 18:25:06 +0000 (20:25 +0200)]
Fix merging bug

A %g format was used to print an int in sending the level command,
because decimal points were dropped when merging patches. Also an unused
variable was removed to suppress a warning.

12 years agoAdd set of shogi pixmaps for XBoard
H.G. Muller [Mon, 18 Oct 2010 17:50:09 +0000 (19:50 +0200)]
Add set of shogi pixmaps for XBoard

The -size 64 pieces from gShogi (and originally XShogi) are made
suitable for loading by XBoard, through redefining the transparent
background color as either light or dark square color. These bitmaps are
not included in the XBoard build, and perhaps should not even be
included in the source distribution, but made available in a separate

12 years agoImplement -flipBlack in XBoard
H.G. Muller [Mon, 18 Oct 2010 17:46:33 +0000 (19:46 +0200)]
Implement -flipBlack in XBoard

When -flipBlack is true, the white and back piece pixmaps are swapped in
flipView. The idea is that the black pieces are upside-down versions of
the white (Shogi) pieces, so that swapping white and black in effect
turns all pieces upside down, which is what should happen in flipView.

12 years agoDisable some very verbose debug printing
H.G. Muller [Mon, 11 Oct 2010 19:06:41 +0000 (21:06 +0200)]
Disable some very verbose debug printing

The internationalization seems debugged enough to do without them.

12 years agoAdd option -variations to control variation-tree walking
H.G. Muller [Mon, 11 Oct 2010 18:52:10 +0000 (20:52 +0200)]
Add option -variations to control variation-tree walking

Just so that users can switch it off if the find it annoying.