diff options
author | Jeremy Allison <jra@samba.org> | 2009-10-16 16:37:20 -0700 |
---|---|---|
committer | Jeremy Allison <jra@samba.org> | 2009-10-16 16:38:59 -0700 |
commit | 010dfbf1fd26718ad197e3428ed0b03111f6c9e5 (patch) | |
tree | adc082fb10c9b5ed062c2d7e8612e0cffcca2f93 /source3/modules | |
parent | 7655282ede0375a0de4102c2b8f27cf8985bd71c (diff) | |
download | samba-010dfbf1fd26718ad197e3428ed0b03111f6c9e5.tar.gz samba-010dfbf1fd26718ad197e3428ed0b03111f6c9e5.tar.bz2 samba-010dfbf1fd26718ad197e3428ed0b03111f6c9e5.zip |
Fix one missing STAT -> LSTAT with POSIX pathnames in vfs_xattr_tdb.c. Caught by the torture tester. I love unit tests :-). Jeremy.
Diffstat (limited to 'source3/modules')
-rw-r--r-- | source3/modules/vfs_xattr_tdb.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/source3/modules/vfs_xattr_tdb.c b/source3/modules/vfs_xattr_tdb.c index 55fb1417b7..f7fbfce4cb 100644 --- a/source3/modules/vfs_xattr_tdb.c +++ b/source3/modules/vfs_xattr_tdb.c @@ -630,9 +630,15 @@ static int xattr_tdb_unlink(vfs_handle_struct *handle, return -1; } - if (SMB_VFS_STAT(handle->conn, smb_fname_tmp) == -1) { + if (lp_posix_pathnames()) { + ret = SMB_VFS_LSTAT(handle->conn, smb_fname_tmp); + } else { + ret = SMB_VFS_STAT(handle->conn, smb_fname_tmp); + } + if (ret == -1) { goto out; } + if (smb_fname_tmp->st.st_ex_nlink == 1) { /* Only remove record on last link to file. */ remove_record = true; |