LTe / pgn-parser

Javascript library to allow reading of a PGN (Portable Game Notation) chess game notation, and providing the result as JSON.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

pgn-parser

GitHub Workflow Status Libraries.io dependency status for GitHub repo GitHub package.json version npm GitHub

Javascript library to allow reading of a PGN (Portable Game Notation) chess game notation, and providing the result as JSON.

What is it?

PGN is a shortcut for portable game notation. It was developed in 1993. It helps standardize how chess games were notated, so that computer programs like the PgnViewerJS could be developed. PGN is the standard to keep chess games forever. There are huge databases available like those from https://lichess.org.

Who needs it?

Everyone that wants to implement chess software and has to read PGN notation. The library is a runtime component to be included in the usual way.

import parser from '@mliebelt/pgn-parser'

How to install it?

npm i @mliebelt/pgn-parser --save

How to use it?

Look at the many test cases that show how to use it. Here is an example:

import parser from '@mliebelt/pgn-parser'
let moves = parser.parse("1. {first move} e4! {my favorite} e5 (1... c5!?)")
moves[0].moveNumber

It does not have an API, just a JSON structure that has to be read then. You have 3 top level rules to use the parser:

  • games: Reads many games from the string given, returns an array of games (object with keys tags and moves).
  • game: Reads a complete game, and returns an object with keys tags and moves.
  • tags: Reads only the tags from the given input. The input must not contain any moves.
  • pgn: Reads only the moves of the game (as array).

A code example to read a complete game then looks like:

import parser from '@mliebelt/pgn-parser'
let game = parser.parse('[White "Me"] [Black "Magnus"] 1. f4 e5 2. g4 Qh4#', {startRule: "game"})
console.log(JSON.stringify(res, null, 2))
==>
JSON.stringify(res, null, 2)
{
  "tags": {
    "White": "Me",
    "Black": "Magnus"
  },
  "moves": [
    {
      "turn": "w",
      "moveNumber": 1,
    ...
    },
    {...},
    ...
  ]
}

How to use it in the browser?

If you want to use the library in the browser, the above method will not work. In the ticket 22, Bebul explained how to do it. Here is the complete recipe:

  1. Install Browserify.

  2. Store the parse function as window property

     File: parsePgn.js
     ----
     const parser =  require('./pgn-parser.js')
     window.parsePgn = parser.parse
    
  3. Process newly created parsePgn.js through Browserify.

    browserify parsePgn.js -o pgn-bundle.js
    
  4. In the index.html then use:

     <script type="text/javascript" src="pgn/pgn-bundle.js"></script>
    
  5. And the parsePgn is now available:

      let gameList = parsePgn('[White "Me"] [Black "Magnus"] 1. f4 e5 2. g4 Qh4#', {startRule: "game"});        
    

References

  • pegjs Parser Generator implemented in Javascript. Used for regenerating the javascript library completely by an automatic build.
  • PGN Specification: PGN (Portable Game Notation) specification, there the section 8.2. This parser currently does not implement the section 8.1, the tags.
  • NAG Specification Definition of the NAGs (Numeric Annotation Glyphs)

About

Javascript library to allow reading of a PGN (Portable Game Notation) chess game notation, and providing the result as JSON.

License:Apache License 2.0


Languages

Language:JavaScript 100.0%