react-native-stockfish-android
TypeScript icon, indicating that this package has built-in type declarations

0.3.0 • Public • Published

react-native-stockfish-chess-engine

Use stockfish chess engine 15 in your project (Only for Android).

Prerequesites

In Android Studio settings, go to Android Sdk tools, and install :

  • Android SDK build tool
  • Android SDK Command line tool

Installation

npm install react-native-stockfish-android

Usage

// Notice that all methods are asynchronous.
import { mainLoop, shutdownStockfish, sendCommand } from 'react-native-stockfish-android';
import { NativeEventEmitter, NativeModules } from 'react-native'; // in order to read Stockfish output.

// In startup hook
const eventEmitter = new NativeEventEmitter(NativeModules.ReactNativeStockfishChessEngine);
// Also you need to listen to the event 'stockfish-output' in order to get output lines from Stockfish.
const eventListener = eventEmitter.addListener('stockfish-output', (line) => {
      console.log("Stockfish output: "+line);
});
await mainLoop(); // starts the engine process.

// When you need to send a command (e.g) : don't forget the newline character :
await sendCommand("position start\n");

// In will destroy hook
await shutdownStockfish(); // dispose the engine process
eventListener.remove(); // dispose the Stockfish output reader process.

Important notes :

  • You will need to check that the position you set up is valid before sending the command "go" and its variations. Because if the position is illegal, it will crash. The same will happen if it is already mate/stalemate. You can use a package like chess.ts for checking those states. Please also notice that chess.ts (based on chess.js) does not check everything at the time this plugin has been released, in particular :
  • if they are exactly one king for each side
  • if the other side is not in check You will have to check those yourself, as in the example if you want.
  • In order to run the example, refreshing the metro packager is not enough for the application to run correctly : you will need to run the command npx react-native run-android again. And it may be the same for your next application using this plugin.

Developers

Changing the downloaded NNUE file

  1. Go to Stockfish NNUE files page and select a reference from the list.
  2. Modify CMakeLists.txt, by replacing line starting by set (NNUE_NAME ) by setting your reference name, without any quote.
  3. Modify the reference name in evaluate.h in the line containing #define EvalFileDefaultName , by setting your nnue file name, with the quotes of course.

Updating Stockfish version

Just change the folder /cpp/stockfish with the sources of the new version, and also adjust the referenced NNUE file, as described above.

If necessary, import the code inside main() function in main.cpp of stockfish source file, into the main() function in cpp/bridge/stockfish.cpp. But anyway do not forget to delete the main.cpp from Stockfish sources folder afterwards.

License

MIT

Included code from Stockfish.

Dependencies (0)

    Dev Dependencies (20)

    Package Sidebar

    Install

    npm i react-native-stockfish-android

    Weekly Downloads

    11

    Version

    0.3.0

    License

    MIT

    Unpacked Size

    47.7 MB

    Total Files

    80

    Last publish

    Collaborators

    • loloof64