Mercurial > vim
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