From: Bram Moolenaar Date: Sat, 19 Dec 2015 14:28:18 +0000 (+0100) Subject: patch 7.4.979 X-Git-Tag: v7.4.979 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=4a8c2cfc56b9affc36934aa0f20d8cfd2b1511c8;p=vim patch 7.4.979 Problem: When changing the crypt key the blocks read from disk are not decrypted. Solution: Also call ml_decrypt_data() when mf_old_key is set. (Ken Takata) --- diff --git a/src/memfile.c b/src/memfile.c index a21b7076a..5b13d510e 100644 --- a/src/memfile.c +++ b/src/memfile.c @@ -1032,8 +1032,9 @@ mf_read(mfp, hp) } #ifdef FEAT_CRYPT - /* Decrypt if 'key' is set and this is a data block. */ - if (*mfp->mf_buffer->b_p_key != NUL) + /* Decrypt if 'key' is set and this is a data block. And when changing the + * key. */ + if (*mfp->mf_buffer->b_p_key != NUL || mfp->mf_old_key != NULL) ml_decrypt_data(mfp, hp->bh_data, offset, size); #endif diff --git a/src/version.c b/src/version.c index f1bf8733e..f949e6427 100644 --- a/src/version.c +++ b/src/version.c @@ -741,6 +741,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 979, /**/ 978, /**/