diff options
author | zeertzjq <zeertzjq@outlook.com> | 2022-04-05 15:31:01 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2022-04-05 15:31:01 +0100 |
commit | 478700336d1c72e133b8ff6841e968c1bb1658ed (patch) | |
tree | 326bd148a82456b62d4a8464453add9fe06eaa4e | |
parent | beb0ef1ab2dbd9760345e3e03647b93914591d56 (diff) | |
download | vim-git-478700336d1c72e133b8ff6841e968c1bb1658ed.tar.gz |
patch 8.2.4696: delete() with "rf" argument does not report a failurev8.2.4696
Problem: delete() with "rf" argument does not report a failure.
Solution: Return -1 if the directory could not be removed. (closes #10078)
-rw-r--r-- | src/fileio.c | 5 | ||||
-rw-r--r-- | src/testdir/test_functions.vim | 9 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 15 insertions, 1 deletions
diff --git a/src/fileio.c b/src/fileio.c index 9ef2dbd3b..af915c665 100644 --- a/src/fileio.c +++ b/src/fileio.c @@ -5017,13 +5017,16 @@ delete_recursive(char_u *name) vim_snprintf((char *)NameBuff, MAXPATHL, "%s/%s", exp, ((char_u **)ga.ga_data)[i]); if (delete_recursive(NameBuff) != 0) + // Remember the failure but continue deleting any further + // entries. result = -1; } ga_clear_strings(&ga); + if (mch_rmdir(exp) != 0) + result = -1; } else result = -1; - (void)mch_rmdir(exp); vim_free(exp); } else diff --git a/src/testdir/test_functions.vim b/src/testdir/test_functions.vim index a19dd5271..a87ca3b58 100644 --- a/src/testdir/test_functions.vim +++ b/src/testdir/test_functions.vim @@ -2242,6 +2242,15 @@ func Test_delete_rf() call assert_equal(0, delete('Xdir', 'rf')) call assert_false(filereadable('Xdir/foo.txt')) call assert_false(filereadable('Xdir/[a-1]/foo.txt')) + + if has('unix') + call mkdir('Xdir/Xdir2', 'p') + silent !chmod 555 Xdir + call assert_equal(-1, delete('Xdir/Xdir2', 'rf')) + call assert_equal(-1, delete('Xdir', 'rf')) + silent !chmod 755 Xdir + call assert_equal(0, delete('Xdir', 'rf')) + endif endfunc func Test_call() diff --git a/src/version.c b/src/version.c index f4d300b39..0e42966d9 100644 --- a/src/version.c +++ b/src/version.c @@ -747,6 +747,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 4696, +/**/ 4695, /**/ 4694, |