react-native-stockfish-chess-engine
v0.1.5
Published
Use stockfish chess engine in your project (Android only).
Downloads
135
Readme
react-native-stockfish-chess-engine
Use stockfish chess engine 14 in your project (Only for Android).
Installation
npm install react-native-stockfish-chess-engine
Usage
import { mainLoop, shutdownStockfish, sendCommand } from 'react-native-stockfish-chess-engine';
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);
});
mainLoop(); // starts the engine process.
// When you want to read next output line :
readNextOutput();
// When you need to send a command (e.g) :
sendCommand("position start");
// In will destroy hook
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.
Contributing
See the contributing guide to learn how to contribute to the repository and the development workflow.
License
MIT
Included code from Stockfish.