]> granicus.if.org Git - vim/commitdiff
patch 8.1.0760: no proper test for using 'termencoding' v8.1.0760
authorBram Moolenaar <Bram@vim.org>
Thu, 17 Jan 2019 12:04:30 +0000 (13:04 +0100)
committerBram Moolenaar <Bram@vim.org>
Thu, 17 Jan 2019 12:04:30 +0000 (13:04 +0100)
Problem:    No proper test for using 'termencoding'.
Solution:   Add a screendump test.  Fix using double width characters in a
            screendump.

src/terminal.c
src/testdir/Make_all.mak
src/testdir/dumps/Test_tenc_euc_jp_01.dump [new file with mode: 0644]
src/testdir/test_termencoding.vim [new file with mode: 0644]
src/version.c

index dbb8f2cb1c14be4336ba4c899a5d07009fbdb011..09b60726991ba4e3cbd5d6299664f3fb022443cf 100644 (file)
@@ -4031,7 +4031,6 @@ f_term_dumpwrite(typval_T *argvars, typval_T *rettv UNUSED)
                    if (cell.width == 2)
                    {
                        fputs("*", fd);
-                       ++pos.col;
                    }
                    else
                        fputs("+", fd);
@@ -4062,6 +4061,9 @@ f_term_dumpwrite(typval_T *argvars, typval_T *rettv UNUSED)
 
                prev_cell = cell;
            }
+
+           if (cell.width == 2)
+               ++pos.col;
        }
        if (repeat > 0)
            fprintf(fd, "@%d", repeat);
@@ -4103,6 +4105,7 @@ read_dump_file(FILE *fd, VTermPos *cursor_pos)
     char_u         *prev_char = NULL;
     int                    attr = 0;
     cellattr_T     cell;
+    cellattr_T     empty_cell;
     term_T         *term = curbuf->b_term;
     int                    max_cells = 0;
     int                    start_row = term->tl_scrollback.ga_len;
@@ -4110,6 +4113,7 @@ read_dump_file(FILE *fd, VTermPos *cursor_pos)
     ga_init2(&ga_text, 1, 90);
     ga_init2(&ga_cell, sizeof(cellattr_T), 90);
     vim_memset(&cell, 0, sizeof(cell));
+    vim_memset(&empty_cell, 0, sizeof(empty_cell));
     cursor_pos->row = -1;
     cursor_pos->col = -1;
 
@@ -4208,66 +4212,68 @@ read_dump_file(FILE *fd, VTermPos *cursor_pos)
                        c = fgetc(fd);
                    }
                    hl2vtermAttr(attr, &cell);
-               }
-               else
-                   dump_is_corrupt(&ga_text);
 
-               /* is_bg == 0: fg, is_bg == 1: bg */
-               for (is_bg = 0; is_bg <= 1; ++is_bg)
-               {
-                   if (c == '&')
-                   {
-                       /* use same color as previous cell */
-                       c = fgetc(fd);
-                   }
-                   else if (c == '#')
+                   /* is_bg == 0: fg, is_bg == 1: bg */
+                   for (is_bg = 0; is_bg <= 1; ++is_bg)
                    {
-                       int red, green, blue, index = 0;
-
-                       c = fgetc(fd);
-                       red = hex2nr(c);
-                       c = fgetc(fd);
-                       red = (red << 4) + hex2nr(c);
-                       c = fgetc(fd);
-                       green = hex2nr(c);
-                       c = fgetc(fd);
-                       green = (green << 4) + hex2nr(c);
-                       c = fgetc(fd);
-                       blue = hex2nr(c);
-                       c = fgetc(fd);
-                       blue = (blue << 4) + hex2nr(c);
-                       c = fgetc(fd);
-                       if (!isdigit(c))
-                           dump_is_corrupt(&ga_text);
-                       while (isdigit(c))
+                       if (c == '&')
                        {
-                           index = index * 10 + (c - '0');
+                           /* use same color as previous cell */
                            c = fgetc(fd);
                        }
-
-                       if (is_bg)
+                       else if (c == '#')
                        {
-                           cell.bg.red = red;
-                           cell.bg.green = green;
-                           cell.bg.blue = blue;
-                           cell.bg.ansi_index = index;
+                           int red, green, blue, index = 0;
+
+                           c = fgetc(fd);
+                           red = hex2nr(c);
+                           c = fgetc(fd);
+                           red = (red << 4) + hex2nr(c);
+                           c = fgetc(fd);
+                           green = hex2nr(c);
+                           c = fgetc(fd);
+                           green = (green << 4) + hex2nr(c);
+                           c = fgetc(fd);
+                           blue = hex2nr(c);
+                           c = fgetc(fd);
+                           blue = (blue << 4) + hex2nr(c);
+                           c = fgetc(fd);
+                           if (!isdigit(c))
+                               dump_is_corrupt(&ga_text);
+                           while (isdigit(c))
+                           {
+                               index = index * 10 + (c - '0');
+                               c = fgetc(fd);
+                           }
+
+                           if (is_bg)
+                           {
+                               cell.bg.red = red;
+                               cell.bg.green = green;
+                               cell.bg.blue = blue;
+                               cell.bg.ansi_index = index;
+                           }
+                           else
+                           {
+                               cell.fg.red = red;
+                               cell.fg.green = green;
+                               cell.fg.blue = blue;
+                               cell.fg.ansi_index = index;
+                           }
                        }
                        else
-                       {
-                           cell.fg.red = red;
-                           cell.fg.green = green;
-                           cell.fg.blue = blue;
-                           cell.fg.ansi_index = index;
-                       }
+                           dump_is_corrupt(&ga_text);
                    }
-                   else
-                       dump_is_corrupt(&ga_text);
                }
+               else
+                   dump_is_corrupt(&ga_text);
            }
            else
                dump_is_corrupt(&ga_text);
 
            append_cell(&ga_cell, &cell);
+           if (cell.width == 2)
+               append_cell(&ga_cell, &empty_cell);
        }
        else if (c == '@')
        {
index 6ea0c4518a90e98672c2645a6e3dc311df23061e..8ed4642298cc3031deaee54ed551ba3c73692dfe 100644 (file)
@@ -243,6 +243,7 @@ NEW_TESTS = \
        test_tagjump \
        test_taglist \
        test_tcl \
+       test_termencoding \
        test_terminal \
        test_terminal_fail \
        test_textformat \
@@ -389,6 +390,7 @@ NEW_TESTS_RES = \
        test_system.res \
        test_tab.res \
        test_tcl.res \
+       test_termencoding.res \
        test_terminal.res \
        test_terminal_fail.res \
        test_textformat.res \
diff --git a/src/testdir/dumps/Test_tenc_euc_jp_01.dump b/src/testdir/dumps/Test_tenc_euc_jp_01.dump
new file mode 100644 (file)
index 0000000..14a4313
--- /dev/null
@@ -0,0 +1,10 @@
+>E+0&#ffffff0|8|9|:| |バ*&|ッ|フ|ァ| +&|%|l|d| |の*&|変|更|は|保|存|さ|れ|て|い|ま|せ|ん| +&|(|!| |で*&|変|更|を|破|棄|)+&| @13
+|~+0#4040ff13&| @73
+|~| @73
+|~| @73
+|X+3#0000000&|e|u|c|_|j|p|.|t|x|t| @45|1|,|1| @11|A|l@1
+|E+0&&|8|3|:| |バ*&|ッ|フ|ァ|を|作|成|で|き|な|い|の|で|、|他|の|を|使|用|し|ま|す|.+&@2| @22
+|~+0#4040ff13&| @73
+|~| @73
+|[+1#0000000&|N|o| |N|a|m|e|]| |[|+|]| @43|1|,|5|2| @10|A|l@1
+| +0&&@74
diff --git a/src/testdir/test_termencoding.vim b/src/testdir/test_termencoding.vim
new file mode 100644 (file)
index 0000000..6192dcf
--- /dev/null
@@ -0,0 +1,37 @@
+" Test for setting 'encoding' to something else than the terminal uses, then
+" setting 'termencoding' to make it work.
+
+" This only works with "iconv".
+if !has('multi_byte') || !has('iconv')
+  finish
+endif
+
+source screendump.vim
+if !CanRunVimInTerminal()
+  finish
+endif
+
+" This Vim is running with 'encoding' "utf-8", the Vim in the terminal is
+" running with 'encoding' "euc-jp".  We need to make sure the text is in the
+" right encoding, this is a bit tricky.
+func Test_termencoding_euc_jp()
+  new
+  call setline(1, 'E89: バッファ %ld の変更は保存されていません (! で変更を破棄)')
+  write ++enc=euc-jp Xeuc_jp.txt
+  quit
+
+  call writefile([
+       \ 'set encoding=euc-jp',
+       \ 'set termencoding=utf-8',
+       \ 'scriptencoding utf-8',
+       \ 'exe "normal aE83: バッファを作成できないので、他のを使用します...\<Esc>"',
+       \ 'split Xeuc_jp.txt',
+       \ ], 'XTest_tenc_euc_jp')
+  let buf = RunVimInTerminal('-S XTest_tenc_euc_jp', {'rows': 10})
+  call VerifyScreenDump(buf, 'Test_tenc_euc_jp_01', {})
+
+  " clean up
+  call StopVimInTerminal(buf)
+  call delete('Xeuc_jp.txt')
+  call delete('XTest_tenc_euc_jp')
+endfunc
index c4c596956843d98b61ea2e09d2d185c8ed1c5455..40e4bf3002ffee68be38443c7af6026e978a7657 100644 (file)
@@ -795,6 +795,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    760,
 /**/
     759,
 /**/