else
Search::Limits.ponder = false;
}
- else if (token == "perft" && (is >> token)) // Read perft depth
+ else if (token == "perft" || token == "divide")
{
+ int depth;
stringstream ss;
+ is >> depth;
ss << Options["Hash"] << " "
- << Options["Threads"] << " " << token << " current perft";
+ << Options["Threads"] << " " << depth << " current " << token;
benchmark(pos, ss);
}
<< "position key: " << setw(16) << pos.key()
<< "\nmaterial key: " << setw(16) << pos.material_key()
<< "\npawn key: " << setw(16) << pos.pawn_key()
- << dec << sync_endl;
+ << dec << nouppercase << setfill(' ') << sync_endl;
else if (token == "uci")
sync_cout << "id name " << engine_info(true)
<< "\n" << Options
<< "\nuciok" << sync_endl;
- else if (token == "eval")
- {
- Search::RootColor = pos.side_to_move(); // Ensure it is set
- sync_cout << Eval::trace(pos) << sync_endl;
- }
else if (token == "ucinewgame") TT.clear();
else if (token == "go") go(pos, is);
else if (token == "position") position(pos, is);
else if (token == "bench") benchmark(pos, is);
else if (token == "d") sync_cout << pos.pretty() << sync_endl;
else if (token == "isready") sync_cout << "readyok" << sync_endl;
+ else if (token == "eval") sync_cout << Eval::trace(pos) << sync_endl;
else
sync_cout << "Unknown command: " << cmd << sync_endl;