/***************************************************************************/\r
-/* fairy-Max, */\r
+/* Fairy-Max, */\r
/* Version of the sub-2KB (source) micro-Max Chess program, fused to a */\r
/* generic WinBoard interface, loading its move-generator tables from file */\r
/***************************************************************************/\r
\r
/*****************************************************************/\r
/* LICENCE NOTIFICATION */\r
- /* Fairy-Max 4.8 is free software, and you have my permission do */\r
- /* with it whatever you want, whether it is commercial or not. */\r
+ /* Fairy-Max 4.8 is free software, released in the public domain */\r
+ /* so that you have my permission do with it whatever you want, */\r
+ /* whether it is commercial or not, at your own risk. Those that */\r
+ /* are not comfortable with this, can also use or redistribute */\r
+ /* it under the GNU Public License or the MIT License. */\r
/* Note, however, that Fairy-Max can easily be configured through*/\r
/* its fmax.ini file to play Chess variants that are legally pro-*/\r
/* tected by patents, and that to do so would also require per- */\r
/*****************************************************************/\r
\r
#define MULTIPATH\r
-#define VERSION "4.8U"\r
+#define VERSION "4.8V"\r
\r
#include <stdio.h>\r
#include <stdlib.h>\r
int m, nr;\r
double cpuT;\r
\r
+ if(argc > 1 && !strcmp(argv[1], "-v")) argc++, argv--, printf("%s\n", VERSION), exit(0);\r
+\r
if(argc>1 && sscanf(argv[1], "%d", &m)==1)\r
{ U = (1<<m)-1; argc--; argv++; }\r
A = (struct _ *) calloc(U+1, sizeof(struct _));\r
signal(SIGINT, SIG_IGN);\r
printf("tellics say " NAME " " VERSION "\n");\r
printf("tellics say by H.G. Muller\n");\r
- printf("tellics say Gothic Chess is protected by U.S. patent #6,481,716 by Ed Trice.\n");\r
- printf("tellics say Falcon Chess is protected by U.S. patent #5,690,334 by George W. Duke\n");\r
InitEngine();\r
LoadGame(NULL);\r
InitGame();\r
if(tlim>TimeLeft/15) tlim = TimeLeft/15;\r
PromPiece = 0; /* Always promote to Queen ourselves */\r
for(N=K=0;K<S;K++)N+=b[K]?b[K]&16?S:1:0; /* count pieces for detecting bare King */\r
- if(w[3]<0&w[4]<0){if(N>>8<2)centr[4]=5;if(!(N&S-2))centr[3]=5;Z+=R>4;R=4;}\r
-printf("# %d+%d pieces, centr = (%d,%d)\n", N&63, N>>7, centr[3], centr[4]);\r
+ if(w[3]<0&w[4]<0){if(N<2*S)centr[4]=5,Z+=R>4,R=4;if(!(N&S-2))centr[3]=5,Z+=R>4,R=4;}\r
+printf("# %d+%d pieces, centr = (%d,%d) R=%d\n", N&63, N>>7, centr[3], centr[4], R);\r
N=0;K=I;\r
if(hill) centr[3] = R>20 ? 1 : 22-R;\r
if (D(Side,-I,I,Q,O,LL|S,3)==I) {\r