#!/usr/bin/perl
print <<'EOF';
/*
 * This file is part of the Trezor project, https://trezor.io/
 *
 * Copyright (C) 2016 Jochen Hoenicke <hoenicke@gmail.com>
 *
 * This library is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this library.  If not, see <http://www.gnu.org/licenses/>.
 */

EOF

my @arr1;
my @arr2;
my $x = 0;
my $l = "00";
my @words;
while (<>) {
    $_ =~ /([1-9]{2})[1-9] ([1-6]):(.*)/;
    my $n = $1;
    my $c = $2;
    my @nw = split(",", $3);
    die if $c != @nw;
    die if $c > 6;
    push @words, @nw;
    if ($n ne $l) {
        $len = @arr2;
        die if $len - $arr1[-1] > 9;
        push @arr1, $len;
    }
    push @arr2, $x;
    $x += $c;
    $l = $n;
}
$len = @arr2;
push @arr1, $len;
push @arr2, $x;

sub computerange($$$) {
    my ($i1, $i2, $entries) = @_;
    $prev = $i1 == 0 ? "_" : $words[$i1 - 1];
    $first = $words[$i1];
    $last = $words[$i2-1];
    $next = $i2 == @words ? "_" : $words[$i2];
    my $j;
    for ($j = 0; $j < 5; $j++) {
        last if substr($first, 0, $j+1) ne substr($last, 0, $j+1);
        last if substr($prev, 0, $j) ne substr($first, 0, $j)
             && substr($next, 0, $j) ne substr($last, 0, $j);
    }
    $prefix = substr($first, 0, $j);
    $range = "";
    $rng = 0;
    if (substr($prev, 0, $j) eq substr($first, 0, $j)
        || substr($last, 0, $j) eq substr($next, 0, $j)) {
        $range = "[".substr($first, $j, 1) . "-". substr($last, $j, 1)."]";
        $rng++;
        if ($j <= 1) {
            $range = substr($first,0, $j+1)."-".substr($last,0,$j+1);
            $prefix= "";
        }
    }
    if (substr($prev, 0, $j+1) eq substr($first, 0, $j+1)
        || substr($last, 0, $j+1) eq substr($next, 0, $j+1)) {
        $j = 0; $rng = 2;
    }
    #printf STDERR "  # %1d: %9s - %9s = \U$prefix$range\E\n", $entries, $first, $last;
    return $j + $rng;
}

print << 'EOF';
/* DO NOT EDIT: This file is automatically generated by
 * cd ../gen/wordlist
 * perl build-recoverytable.pl recovery_english.txt
 */

EOF

$len = @arr1;
print "static const uint16_t word_table1[$len] =\n";
print "{";
for ($i = 0; $i< @arr1; $i++) {
    print "\n   " if ($i % 9 == 0);
    $prefixlen = computerange($arr2[$arr1[$i]], $arr2[$arr1[$i+1]], $arr1[$i+1]-$arr1[$i]);
    $prefixlen = 0 if ($i == @arr1 - 1);
    printf(" %5d,", $arr1[$i] + 4096 * $prefixlen);
}
print "\n};\n\n";

$len = @arr2;
print "static const uint16_t word_table2[$len] =\n";
print "{";
for ($i = 0; $i< @arr2; $i++) {
    print "\n   " if ($i % 9 == 0);
    $prefixlen = computerange($arr2[$i], $arr2[$i+1], $arr2[$i+1]-$arr2[$i]);
    $prefixlen = 0 if ($i == @arr2 - 1);
    printf(" %5d,", $arr2[$i] + 4096 * $prefixlen);
}
print "\n};\n";