Skip to content

Latest commit

 

History

History
99 lines (91 loc) · 3.8 KB

README.md

File metadata and controls

99 lines (91 loc) · 3.8 KB

Scid File Format Specification Version 4

Scid is a popular free chess database program. It stores games in it's own binary format. Whereas Scid is open source, there is no single clear file format specification, and one has to resort to deep study of it's C++ source code to understand the format. This document attempts to provide a technical specification of the format in order to facilitate the implementation of the format by programs other than direct forks of the SCID source base.

A Scid database consists of three files:

  • An Index File (.si4) containing meta-information for each game
  • A file containing the actual game data (.sg4)
  • A file containing player names, tournament names and other textual information (.sn4)

The Index File

The Index file starts with a header of 182 byte. After that index records follow. There is one index record for each stored game. Each index record has a length of 47 byte.

Data Length (Byte) Description
Magic Header 8

53 63 69 64 2E 73 69 00 in Hex

i.e. Scid.si\NUL in Ascci

Version Number 2 01 90 (i.e. 400 in decimal). All existing SCID forks support (and write) according to this standard
Type of Database 4

00 00 00 00

A byte sequence that describes the type of the database, e.g. tournament, theory, etc. All existing SCID forks seem to set this to a sequence of four zero bytes. In KingbaseLite this is set to 00 00 00 05

Number of Stored Games 3

Interpreted as an unsigned int. This theoretically limits the number of stored games in a database to 16777215.

Example 11 8F 32 denotes that there are 1150770 games in the database.

Auto Load Game 3

This entry denotes which game to automatically load on opening the database. The encoding is as follows:

00 00 00: The first game should be loaded

00 00 01: It is not defined which game to load

If none of the above, the encoding is: Let the three bytes denote an integer N. Load the game N – 1.

E.g. 00 00 02: load the first game (this is redundant but due to backward compatibility to .si3).

00 00 03: load the second game.

Etc.

Database Info 108

This contains a general description of the database and it‘s contents. The last byte MUST be set to 00.

With the usual SCID forks, this is just a sequence of 128 zero-bytes.

Custom Flags 54 There are six custom flag entries. Each entry is nine byte long and consists of a zero-terminated ASCII string (last charachter is NUL, i.e. a zero byte). Within each entry, any byte following a zero byte must be ignored.
Overall Length 182

After the fixed length header, index entries follows. Each index entry has a length of 47 byte, and describes general information about a game, as well as offsets into other files (e.g. for the actual encoded sequence of moves, or for the player names).

Data Length (Byte) Description
Overall Length 47