Mercurial > vim
view src/libvterm/tbl2inc_c.pl @ 23869:5a4f9c5c1b99 v8.2.2476
patch 8.2.2476: using freed memory when splitting window while closing buffer
Commit: https://github.com/vim/vim/commit/983d83ff1cd796ff321074335fa53fbe7ac45a46
Author: Bram Moolenaar <Bram@vim.org>
Date: Sun Feb 7 12:12:43 2021 +0100
patch 8.2.2476: using freed memory when splitting window while closing buffer
Problem: Using freed memory when using an autocommand to split a window
while a buffer is being closed.
Solution: Disallow splitting when the buffer has b_locked_split set.
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Sun, 07 Feb 2021 12:15:03 +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