view src/libvterm/tbl2inc_c.pl @ 27199:d4f254d02d7c v8.2.4128

patch 8.2.4128: crash when method cannot be found Commit: https://github.com/vim/vim/commit/64283d5e1f5487e2dbaa17d478e6eae040daa064 Author: Bram Moolenaar <Bram@vim.org> Date: Tue Jan 18 10:37:29 2022 +0000 patch 8.2.4128: crash when method cannot be found Problem: Crash when method cannot be found. (Christian J. Robinson) Solution: Don't mix up pointer names.
author Bram Moolenaar <Bram@vim.org>
date Tue, 18 Jan 2022 11:45:04 +0100
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