X-Git-Url: http://winboard.nl/cgi-bin?a=blobdiff_plain;f=gnushogi%2Fsearch.c;h=1491057231e2cbb93ee27875a7a20fb6f8a9b1bd;hb=74ba6a1c63855ebd51dbe316582a16e7ca95c0a4;hp=2cfff174703854fc4fcd821aead631ae07bd1a84;hpb=389702a9b4201dd03f756606f41eb58516997272;p=gnushogi.git diff --git a/gnushogi/search.c b/gnushogi/search.c index 2cfff17..1491057 100644 --- a/gnushogi/search.c +++ b/gnushogi/search.c @@ -30,6 +30,8 @@ */ #include "gnushogi.h" +#include +#include #if !defined OLDTIME && defined HAVE_GETTIMEOFDAY double pow(double x, double y); @@ -176,6 +178,7 @@ SelectMove(short side, SelectMove_mode iop) } else { + background = false; /* [HGM] with ponder on we did not switch back to foreground mode??? */ player = side; SetResponseTime(side); } @@ -529,6 +532,8 @@ search(short side, short best = -(SCORE_LIMIT + 3000); short bestwidth = 0; short mustcut; + static struct pollfd pollfds[1] = { /* [0] = */ { /* .fd = */ STDIN_FILENO, + /* .events = */ POLLIN } }; #ifdef NULLMOVE short PVsave; @@ -546,6 +551,19 @@ search(short side, { ElapsedTime(COMPUTE_MODE); + if(background) { + int cnt = poll(pollfds, sizeof(pollfds)/sizeof(pollfds[0]), 0); + if (cnt < 0) { + perror("polling standard input"); + ExitShogi(); + } + if (cnt) { /* if anything to read, or error occured */ + if (!flag.timeout) + flag.back = true; /* previous: flag.timeout = true; */ + flag.bothsides = false; + } + } + if (flag.back) { flag.back = false;