Mercurial > vim
view src/libvterm/tbl2inc_c.pl @ 12572:31737ff54115 v8.0.1164
patch 8.0.1164: changing StatusLine highlight does not always work
commit https://github.com/vim/vim/commit/65ed136844fbaffdd473903ed841c944600234dc
Author: Bram Moolenaar <Bram@vim.org>
Date: Sat Sep 30 16:00:14 2017 +0200
patch 8.0.1164: changing StatusLine highlight does not always work
Problem: Changing StatusLine highlight while evaluating 'statusline' may
not change the status line color.
Solution: When changing highlighting while redrawing don't cause another
redraw. (suggested by Ozaki Kiichi, closes #2171, closes #2120)
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Sat, 30 Sep 2017 16:15: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