Mercurial > vim
view src/libvterm/tbl2inc_c.pl @ 15742:916c13256877 v8.1.0878
patch 8.1.0878: test for has('bsd') fails on some BSD systems
commit https://github.com/vim/vim/commit/a02e3f65c52a2c8c987e7dcac5df1f8db9a7b0de
Author: Bram Moolenaar <Bram@vim.org>
Date: Thu Feb 7 21:27:14 2019 +0100
patch 8.1.0878: test for has('bsd') fails on some BSD systems
Problem: Test for has('bsd') fails on some BSD systems.
Solution: Adjust the uname match. (James McCoy, closes https://github.com/vim/vim/issues/3909)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Thu, 07 Feb 2019 21:30:06 +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