]> granicus.if.org Git - vim/commitdiff
patch 8.0.0010 v8.0.0010
authorBram Moolenaar <Bram@vim.org>
Sun, 25 Sep 2016 18:54:11 +0000 (20:54 +0200)
committerBram Moolenaar <Bram@vim.org>
Sun, 25 Sep 2016 18:54:11 +0000 (20:54 +0200)
Problem:    Crash when editing file that starts with crypt yeader. (igor2x)
Solution:   Check for length of text. (Christian Brabandt) Add a test.

src/Makefile
src/fileio.c
src/testdir/Make_all.mak
src/testdir/test_crypt.vim [new file with mode: 0644]
src/version.c

index 864f54b25887b04852d5e7d9e8ad907a3fa84c6e..61c5919d07151266fc297fcf31f7e35d64281036 100644 (file)
@@ -2066,6 +2066,7 @@ test_arglist \
        test_channel \
        test_charsearch \
        test_cmdline \
+       test_crypt \
        test_cscope \
        test_cursor_func \
        test_delete \
index ea1f338f587744038f3a74c225951cff43338ebe..bcb8fef8b1a90ae433d8256e0302fdbcc8efe247 100644 (file)
@@ -3011,6 +3011,9 @@ check_for_cryptkey(
 
            /* Remove cryptmethod specific header from the text. */
            header_len = crypt_get_header_len(method);
+           if (*sizep <= header_len)
+               /* invalid header, buffer can't be encrypted */
+               return NULL;
            *filesizep += header_len;
            *sizep -= header_len;
            mch_memmove(ptr, ptr + header_len, (size_t)*sizep);
index 65ad3ee12f6bdcdbc9b0cfffcf4180cb57523e54..999f519abf376229a47a33869c1ae83b59d5ab5a 100644 (file)
@@ -149,6 +149,7 @@ NEW_TESTS = test_arglist.res \
            test_channel.res \
            test_charsearch.res \
            test_cmdline.res \
+           test_crypt.res \
            test_cscope.res \
            test_diffmode.res \
            test_digraph.res \
diff --git a/src/testdir/test_crypt.vim b/src/testdir/test_crypt.vim
new file mode 100644 (file)
index 0000000..10979dd
--- /dev/null
@@ -0,0 +1,42 @@
+" Tests for encryption.
+" TODO: include tests from test71.
+
+func Common_head_only(text)
+  " This was crashing Vim
+  split Xtest.txt
+  call setline(1, a:text)
+  wq
+  call feedkeys(":split Xtest.txt\<CR>foobar\<CR>", "tx")
+  call delete('Xtest.txt')
+  call assert_match('VimCrypt', getline(1))
+  bwipe!
+endfunc
+
+func Test_head_only_2()
+  call Common_head_only('VimCrypt~02!abc')
+endfunc
+
+func Test_head_only_3()
+  call Common_head_only('VimCrypt~03!abc')
+endfunc
+" Tests for encryption.
+" TODO: include tests from test71.
+
+func Common_head_only(text)
+  " This was crashing Vim
+  split Xtest.txt
+  call setline(1, a:text)
+  wq
+  call feedkeys(":split Xtest.txt\<CR>foobar\<CR>", "tx")
+  call delete('Xtest.txt')
+  call assert_match('VimCrypt', getline(1))
+  bwipe!
+endfunc
+
+func Test_head_only_2()
+  call Common_head_only('VimCrypt~02!abc')
+endfunc
+
+func Test_head_only_3()
+  call Common_head_only('VimCrypt~03!abc')
+endfunc
index cf986e4c3e4e0a95de739725c74dd3aa863c1855..2a60f8b7b2342023e062f661939a5510b14158b4 100644 (file)
@@ -764,6 +764,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    10,
 /**/
     9,
 /**/