view src/libvterm/tbl2inc_c.pl @ 20443:e02d45e302a2 v8.2.0776

patch 8.2.0776: libvterm code lags behind the upstream version Commit: https://github.com/vim/vim/commit/e178ba36546ec7805020280910306331f1ef4ed0 Author: Bram Moolenaar <Bram@vim.org> Date: Sun May 17 14:59:47 2020 +0200 patch 8.2.0776: libvterm code lags behind the upstream version Problem: Libvterm code lags behind the upstream version. Solution: Include revision 719.
author Bram Moolenaar <Bram@vim.org>
date Sun, 17 May 2020 15:00:04 +0200
parents b8299e742f41
children
line wrap: on
line source

#!/usr/bin/perl

use strict;
use warnings;

my ( $encname ) = $ARGV[0] =~ m{/([^/.]+).tbl}
   or die "Cannot parse encoding name out of $ARGV[0]\n";

print <<"EOF";
static const struct StaticTableEncoding encoding_$encname = {
  {
    NULL, /* init */
    &decode_table /* decode */
  },
  {
EOF

my $row = 0;
while( <> ) {
   s/\s*#.*//; # strip comment

   if ($_ =~ m{^\d+/\d+}) {
     my ($up, $low) = ($_ =~ m{^(\d+)/(\d+)});
     my $thisrow = $up * 16 + $low;
     while ($row < $thisrow) {
	print "    0x0, /* $row */\n";
	++$row;
     }
   }

   s{^(\d+)/(\d+)}{""}e;                     # Remove 3/1
   s{ = }{""}e;                            # Remove " = "
   s{"(.)"}{sprintf "0x%04x", ord $1}e;      # Convert "A" to 0x41
   s{U\+}{0x};                               # Convert U+0041 to 0x0041

   s{$}{, /* $row */}; # append comma and index

   print "    $_";

   ++$row;
}

while ($row < 128) {
   print "    0x0, /* $row */\n";
   ++$row;
}

print <<"EOF";
  }
};
EOF