summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--games/exchess/distinfo9
-rw-r--r--games/exchess/patches/patch-ad15
-rw-r--r--games/exchess/patches/patch-af13
-rw-r--r--games/exchess/patches/patch-ag29
-rw-r--r--games/exchess/patches/patch-ah16
-rw-r--r--games/exchess/patches/patch-ai130
-rw-r--r--games/exchess/patches/patch-aj42
7 files changed, 249 insertions, 5 deletions
diff --git a/games/exchess/distinfo b/games/exchess/distinfo
index d8bbc23d8b0..2a493fb884c 100644
--- a/games/exchess/distinfo
+++ b/games/exchess/distinfo
@@ -1,9 +1,14 @@
-$NetBSD: distinfo,v 1.3 2002/07/16 13:39:03 agc Exp $
+$NetBSD: distinfo,v 1.4 2004/02/14 04:31:56 kristerw Exp $
SHA1 (EXCH314S.zip) = 7d8ffbd94dc86a97512826e611048a691c8c646d
Size (EXCH314S.zip) = 110676 bytes
SHA1 (patch-aa) = 40e90ccef0f2f1cd56ab8545ab73f93ccdb04017
SHA1 (patch-ab) = a9385051ed9d482e02bbeff40b5d9552ebc56c9f
SHA1 (patch-ac) = cfc1beff8ae3b2e4c9620e8d49852ce80d848ad6
-SHA1 (patch-ad) = 021dbe949c3c5865d9de8a095a2c40a66e41f658
+SHA1 (patch-ad) = ea2c66248a07d21db498bb093be284327838ccaa
SHA1 (patch-ae) = 9d374b888a6f431604f41c4421baa23d8ca775a1
+SHA1 (patch-af) = 7eb0c780dea41b5d17a532f82a76b984eeefda2d
+SHA1 (patch-ag) = 00bb9750c823aecd7fa44aacc1cf539e062055a9
+SHA1 (patch-ah) = 872b0b7c62f95075f0ce7360464fa51215619ee3
+SHA1 (patch-ai) = 5aaa3e15304c8f19282770d126623d71bf747dbe
+SHA1 (patch-aj) = 83f69a5deb3198877a7c8309f34ed9f1189b355a
diff --git a/games/exchess/patches/patch-ad b/games/exchess/patches/patch-ad
index c5b4672d1ea..a2c086cfbe5 100644
--- a/games/exchess/patches/patch-ad
+++ b/games/exchess/patches/patch-ad
@@ -1,7 +1,7 @@
-$NetBSD: patch-ad,v 1.1.1.1 2000/10/25 08:40:00 jlam Exp $
+$NetBSD: patch-ad,v 1.2 2004/02/14 04:31:56 kristerw Exp $
---- main.cpp.orig Sat Apr 1 07:46:20 2000
-+++ main.cpp
+--- main.cpp.orig 2000-04-01 07:46:20.000000000 +0200
++++ main.cpp 2004-02-14 04:58:19.000000000 +0100
@@ -17,6 +17,7 @@
#if UNIX
#include <sys/types.h>
@@ -37,3 +37,12 @@ $NetBSD: patch-ad,v 1.1.1.1 2000/10/25 08:40:00 jlam Exp $
/* initializing hash tables, check tables, scoring parameters,
and the random number seed and tablebases */
+@@ -117,7 +109,7 @@
+ if(li < 10) sprintf(lfile, "run_log.00%i", li);
+ else if(li < 100) sprintf(lfile, "run_log.0%i", li);
+ else sprintf(lfile, "run_log.%i", li);
+- logfile.open(lfile, ios::noreplace | ios::out);
++ logfile.open(lfile, ios::out);
+ if(logfile) break;
+ }
+ if(!logfile) {
diff --git a/games/exchess/patches/patch-af b/games/exchess/patches/patch-af
new file mode 100644
index 00000000000..1ee862ab31f
--- /dev/null
+++ b/games/exchess/patches/patch-af
@@ -0,0 +1,13 @@
+$NetBSD: patch-af,v 1.1 2004/02/14 04:31:56 kristerw Exp $
+
+--- hash.h.orig Sat Feb 14 04:16:19 2004
++++ hash.h Sat Feb 14 04:16:36 2004
+@@ -54,6 +54,6 @@
+ float ran(long *idum);
+
+ /* Macro for or'ing two hash codes */
+-#define or(A, B) A.address ^= B.address; A.key ^= B.key
++#define hash_or(A, B) A.address ^= B.address; A.key ^= B.key
+
+-#endif HASH_H
++#endif // HASH_H
diff --git a/games/exchess/patches/patch-ag b/games/exchess/patches/patch-ag
new file mode 100644
index 00000000000..5a84edd84b9
--- /dev/null
+++ b/games/exchess/patches/patch-ag
@@ -0,0 +1,29 @@
+$NetBSD: patch-ag,v 1.1 2004/02/14 04:31:56 kristerw Exp $
+
+--- hash.cpp.orig Sat Feb 14 04:23:02 2004
++++ hash.cpp Sat Feb 14 04:24:05 2004
+@@ -210,7 +210,7 @@
+ }
+
+ for(i = 0; i < 64; i++) {
+- or(temp_rec, hval[ID(p->sq[i])][i]);
++ hash_or(temp_rec, hval[ID(p->sq[i])][i]);
+ if(p->sq[i].side == p->wtm) p->material += value[p->sq[i].type];
+ else p->material -= value[p->sq[i].type];
+ if(p->sq[i].type > PAWN) p->pieces[p->sq[i].side]++;
+@@ -220,11 +220,11 @@
+ }
+ }
+
+- if(p->wtm) { or(temp_rec, wtm); }
+- else { or(temp_rec, btm); }
++ if(p->wtm) { hash_or(temp_rec, wtm); }
++ else { hash_or(temp_rec, btm); }
+
+- or(temp_rec, castle_code[p->castle]);
+- or(temp_rec, ep_code[p->ep]);
++ hash_or(temp_rec, castle_code[p->castle]);
++ hash_or(temp_rec, ep_code[p->ep]);
+
+ return temp_rec;
+ }
diff --git a/games/exchess/patches/patch-ah b/games/exchess/patches/patch-ah
new file mode 100644
index 00000000000..7ef7cdcd375
--- /dev/null
+++ b/games/exchess/patches/patch-ah
@@ -0,0 +1,16 @@
+$NetBSD: patch-ah,v 1.1 2004/02/14 04:31:56 kristerw Exp $
+
+--- score.cpp.orig Sat Feb 14 04:22:38 2004
++++ score.cpp Sat Feb 14 04:30:18 2004
+@@ -99,9 +99,9 @@
+ +++++++++++++++++++++++++++++++++*/
+ pcode = stage_code[stage];
+ for(i=1;i<=p->plist[WHITE][PAWN][0];i++)
+- or(pcode, hval[WPAWN][p->plist[WHITE][PAWN][i]]);
++ hash_or(pcode, hval[WPAWN][p->plist[WHITE][PAWN][i]]);
+ for(i=1;i<=p->plist[BLACK][PAWN][0];i++)
+- or(pcode, hval[BPAWN][p->plist[BLACK][PAWN][i]]);
++ hash_or(pcode, hval[BPAWN][p->plist[BLACK][PAWN][i]]);
+
+ /*+++++++++++++++++++++++++++++++
+ |
diff --git a/games/exchess/patches/patch-ai b/games/exchess/patches/patch-ai
new file mode 100644
index 00000000000..30aec137df7
--- /dev/null
+++ b/games/exchess/patches/patch-ai
@@ -0,0 +1,130 @@
+$NetBSD: patch-ai,v 1.1 2004/02/14 04:31:56 kristerw Exp $
+
+--- exmove.cpp.orig Sat Feb 14 04:16:56 2004
++++ exmove.cpp Sat Feb 14 04:19:15 2004
+@@ -52,8 +52,8 @@
+ { return 0; }
+ p->sq[5] = p->sq[7];
+ p->sq[7] = empty;
+- or(p->hcode, hval[WROOK][5]);
+- or(p->hcode, hval[WROOK][7]);
++ hash_or(p->hcode, hval[WROOK][5]);
++ hash_or(p->hcode, hval[WROOK][7]);
+ p->has_castled[1] = 1;
+ /* update piece list */
+ for(pi=1;pi<=p->plist[p->wtm][ROOK][0];pi++)
+@@ -69,8 +69,8 @@
+ { return 0; }
+ p->sq[3] = p->sq[0];
+ p->sq[0] = empty;
+- or(p->hcode, hval[WROOK][3]);
+- or(p->hcode, hval[WROOK][0]);
++ hash_or(p->hcode, hval[WROOK][3]);
++ hash_or(p->hcode, hval[WROOK][0]);
+ p->has_castled[1] = 1;
+ /* update piece list */
+ for(pi=1;pi<=p->plist[p->wtm][ROOK][0];pi++)
+@@ -86,8 +86,8 @@
+ { return 0; }
+ p->sq[61] = p->sq[63];
+ p->sq[63] = empty;
+- or(p->hcode, hval[BROOK][61]);
+- or(p->hcode, hval[BROOK][63]);
++ hash_or(p->hcode, hval[BROOK][61]);
++ hash_or(p->hcode, hval[BROOK][63]);
+ p->has_castled[0] = 1;
+ /* update piece list */
+ for(pi=1;pi<=p->plist[p->wtm][ROOK][0];pi++)
+@@ -103,8 +103,8 @@
+ { return 0; }
+ p->sq[59] = p->sq[56];
+ p->sq[56] = empty;
+- or(p->hcode, hval[BROOK][59]);
+- or(p->hcode, hval[BROOK][56]);
++ hash_or(p->hcode, hval[BROOK][59]);
++ hash_or(p->hcode, hval[BROOK][56]);
+ p->has_castled[0] = 1;
+ /* update piece list */
+ for(pi=1;pi<=p->plist[p->wtm][ROOK][0];pi++)
+@@ -125,7 +125,7 @@
+
+ if(p->sq[emove.b.to].type) {
+ // Remove hashcode for the target square
+- or(p->hcode, hval[ID(p->sq[emove.b.to])][emove.b.to]);
++ hash_or(p->hcode, hval[ID(p->sq[emove.b.to])][emove.b.to]);
+ // Remove piece from piece list
+ for(pi=1;pi<=p->plist[p->wtm^1][p->sq[emove.b.to].type][0];pi++)
+ if(p->plist[p->wtm^1][p->sq[emove.b.to].type][pi] == emove.b.to) {
+@@ -143,8 +143,8 @@
+ // Move the new piece to the target square
+ p->sq[emove.b.to] = p->sq[emove.b.from];
+ // Update the hash code to reflect the move
+- or(p->hcode, hval[ID(p->sq[emove.b.from])][emove.b.from]);
+- or(p->hcode, hval[ID(p->sq[emove.b.from])][emove.b.to]);
++ hash_or(p->hcode, hval[ID(p->sq[emove.b.from])][emove.b.from]);
++ hash_or(p->hcode, hval[ID(p->sq[emove.b.from])][emove.b.to]);
+ // Original square is now empty
+ p->sq[emove.b.from] = empty;
+
+@@ -152,7 +152,7 @@
+ if(emove.b.type&EP) {
+ if(p->wtm) {
+ p->sq[emove.b.to-8] = empty;
+- or(p->hcode, hval[BPAWN][emove.b.to-8]);
++ hash_or(p->hcode, hval[BPAWN][emove.b.to-8]);
+ // Update piece lists
+ for(pi=1;pi<=p->plist[p->wtm^1][PAWN][0];pi++)
+ if(p->plist[BLACK][PAWN][pi] == emove.b.to-8) {
+@@ -163,7 +163,7 @@
+ }
+ } else {
+ p->sq[emove.b.to+8] = empty;
+- or(p->hcode, hval[WPAWN][emove.b.to+8]);
++ hash_or(p->hcode, hval[WPAWN][emove.b.to+8]);
+ // Update piece lists
+ for(pi=1;pi<=p->plist[p->wtm^1][PAWN][0];pi++)
+ if(p->plist[WHITE][PAWN][pi] == emove.b.to+8) {
+@@ -189,7 +189,7 @@
+ // if the move is a promotion, promote it
+ if(emove.b.type&PROMOTE) {
+ // Remove the pawn from the hash code
+- or(p->hcode, hval[ID(p->sq[emove.b.to])][emove.b.to]);
++ hash_or(p->hcode, hval[ID(p->sq[emove.b.to])][emove.b.to]);
+ // Change the piece type to the promoted piece
+ p->sq[emove.b.to].type = emove.b.promote;
+ // Add the new piece to the piece lists
+@@ -206,7 +206,7 @@
+ // adjust material score
+ p->material += value[emove.b.promote] - value[PAWN];
+ // add piece to hash code
+- or(p->hcode, hval[ID(p->sq[emove.b.to])][emove.b.to]);
++ hash_or(p->hcode, hval[ID(p->sq[emove.b.to])][emove.b.to]);
+ // adjust total piece count
+ p->pieces[p->wtm]++;
+ }
+@@ -214,11 +214,11 @@
+ // update position characteristics
+ p->wtm = p->wtm^1;
+ p->material = -p->material;
+- or(p->hcode, btm); or(p->hcode, wtm);
++ hash_or(p->hcode, btm); hash_or(p->hcode, wtm);
+
+ // undo hash code for en-passant and castling status
+- or(p->hcode, ep_code[p->ep]);
+- or(p->hcode, castle_code[p->castle]);
++ hash_or(p->hcode, ep_code[p->ep]);
++ hash_or(p->hcode, castle_code[p->castle]);
+
+ // if move is a pawn push 2 spaces, set en passant flag
+ if((emove.b.type&PAWN_PUSH2) &&
+@@ -235,8 +235,8 @@
+ p->last = emove;
+
+ // update hash code for en-passant and castling status
+- or(p->hcode, ep_code[p->ep]);
+- or(p->hcode, castle_code[p->castle]);
++ hash_or(p->hcode, ep_code[p->ep]);
++ hash_or(p->hcode, castle_code[p->castle]);
+
+ // check whether other side is placed in check
+ int ptype = p->sq[emove.b.to].type;
diff --git a/games/exchess/patches/patch-aj b/games/exchess/patches/patch-aj
new file mode 100644
index 00000000000..19296e7918f
--- /dev/null
+++ b/games/exchess/patches/patch-aj
@@ -0,0 +1,42 @@
+$NetBSD: patch-aj,v 1.1 2004/02/14 04:31:56 kristerw Exp $
+
+--- search.cpp.orig Sat Feb 14 04:30:46 2004
++++ search.cpp Sat Feb 14 04:32:41 2004
+@@ -181,7 +181,7 @@
+ last_depth = 1;
+
+ // adjusting hash code for game stage
+- or(p.hcode, stage_code[stage]);
++ hash_or(p.hcode, stage_code[stage]);
+
+ // initialize history table
+ for(int i = 0; i < 64; i++)
+@@ -261,7 +261,7 @@
+ }
+
+ // adjusting hash code for game stage
+- or(p.hcode, stage_code[stage]);
++ hash_or(p.hcode, stage_code[stage]);
+
+ if(!xboard && !ALLEG && post) {
+ cout << "\nnode_count = " << node_count
+@@ -423,7 +423,7 @@
+ if(ply) {
+ // add hash code for this position to position list
+ p_list[turn+ply-1] = sp[ply].hcode;
+- or(p_list[turn+ply-1], stage_code[stage]);
++ hash_or(p_list[turn+ply-1], stage_code[stage]);
+
+ // fifty move rule
+ if(sp[ply].fifty >= 100) return(0);
+@@ -470,8 +470,8 @@
+ {
+ node_count++;
+ sp[ply+1] = sp[ply]; sp[ply+1].wtm ^= 1;
+- or(sp[ply+1].hcode,wtm);
+- or(sp[ply+1].hcode,btm);
++ hash_or(sp[ply+1].hcode,wtm);
++ hash_or(sp[ply+1].hcode,btm);
+ sp[ply+1].last.t = NOMOVE; sp[ply+1].ep = 0;
+ sp[ply+1].material = -sp[ply+1].material;
+ sp[ply+1].fifty = 0;