Skip to content

bodop/tip-toi-reveng

 
 

Repository files navigation

tip-toi-reveng

The goal of this project is to understand the file and paper format for the Ravensburger TipToi pen. The ultimate goal is that everyone can create their own books, with their own sounds.

The current status is that we understood most of the file format (see the GME file format specification). We provide a tool that allows you to dissect these files.

The tool can also be used to generate completely new files from scratch; see below for details.

If you want to learn more, here are some relevant links:

The tttool tool

Use the tool tttool.hs to investigate the gme files and build new ones. It supports various subcommands:

Usage: tttool [options] command

Options:
    -t <transcriptfile>
       replaces media file indices by a transscript

Commands:
    info <file.gme>...
       general information
    media [-d dir] <file.gme>...
       dumps all audio samples to the given directory (default: media/)
    scripts <file.gme>...
       prints the decoded scripts for each OID
    script <file.gme> <n>
       prints the decoded scripts for the given OID
    raw-scripts <file.gme>...
       prints the scripts for each OID, in their raw form
    raw-script <file.gme> <n>
       prints the scripts for the given OID, in their raw form
    games <file.gme>...
       prints the decoded games
    lint <file.gme>
       checks for errors in the file or in this program
    segments <file.gme>...
       lists all known parts of the file, with description.
    segment <file.gme> <pos>
       which segment contains the given position.
    holes <file.gme>...
       lists all unknown parts of the file.
    explain <file.gme>...
       lists all parts of the file, with description and hexdum and hexdumpp.
    play <file.gme>
       interactively play: Enter OIDs, and see what happens.
    rewrite <infile.gme> <outfile.gme>
       parses the file and serializes it again (for debugging).
    create-debug <outfile.gme> <productid>
       creates a special Debug.gme file for that productid
    export <infile.gme> [<outfile.yaml>]
       dumps the file in the human-readable yaml format
    assemble <infile.yaml> <outfile.gme>
       creates a gme file from the given source

A transscript is simply a ;-separated table of OIDs and some text, see for example transcript/WWW_Bauernhof.csv.

Installation

This program is written in Haskell and can be installed on Windows, MacOS or Linux.

For Windows users, we create zipfile containing tttool, you can find them in the releases section of the github project.

Otherwise, installation from source is not difficult either:

  1. First install the Haskell platform, see http://www.haskell.org/platform/ for details for your system. Users of Debian or Ubuntu simply run apt-get install haskell-platform.

  2. Install the dependencies. The Haskell platform comes with a tool called cabal, and you should run the two commands

    cabal update
    cabal install yaml
    
  3. Now you can build the program using

    make
    
  4. At this point, tttool should be ready to go. If you run

    ./tttool
    

    you should see the list of commands shown above.

If you have any problems, you can report an issue via GitHub.

Building your own gme files

Once you have installed tttool, you can create your own .gme files. The process is as follows

  1. Record the audio samples you want to include, as Ogg Vorbis files, mono, 22050Hz. I use

    arecord -r 22050 foo.wav oggenc foo.wav rm foo.wav

  2. Write a my-book.yaml file containing some general information, and especially the scripts (i.e. what to do) for each OIDs (i.e. the various fields of a book). You can use the example.yaml file as a starting point; it contains more information in its comments.

  3. Run ./tttool assemble my-book.yaml, and make sure it reports no error, i.e. finishes silently.

  4. Copy the now generated my-book.gme to your TipToi pen and enjoy!

If you need to find out what OID code corresponds to what part of the book, you can generate a debug gme file using ./tttool create-debug and load that on your pen. It will then read out the codes, as a sequence of english digits.

We are also collecting template files, where the OIDs are commented; these can be found in the ./templates directory. Please improve and contribute!

Again, please let us know if you have problems, but also tell us what fun things you did if you succeded.

TODO

  • What are all the header fields? (See wip/Header.md)
  • Finish decoding the games. (See wip/games.txt)
  • What is the purpose of the additional script table?
  • Find a DIY way to print in a TipToi compatible way.

Other resources in this repository

  • oid-decoder.html allows you to manually decode an OID image.
  • scripts/updates.sh downloads all gme files from the Ravensburger server.
  • gameanalyse.c and libtiptoi.c is an alternative tool to investigate gme files. It can also replace audio files in gme files; compile and run it for diagnostic output.
  • Audio/ contains some audio files, such as digits read out.
  • docs/ collects information about TipToi found elsewhere.
  • matlab/ contains scripts to analyse gme files in Matlab
  • wip/ (work in progess) contains notes about the parts of the gme files that are not fully understood yet.

About

Trying to understand the file format of Tip Toi

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 45.4%
  • Haskell 24.4%
  • Yacc 14.4%
  • HTML 9.8%
  • MATLAB 3.0%
  • Shell 1.1%
  • Other 1.9%