summaryrefslogtreecommitdiff
path: root/source/smbd/trans2.c
diff options
context:
space:
mode:
authorJeremy Allison <jra@samba.org>1998-10-23 03:41:11 +0000
committerJeremy Allison <jra@samba.org>1998-10-23 03:41:11 +0000
commit269bca2b3bbf5cae9fdf05d0405bfd80272da5d1 (patch)
tree40f9c014f36f5215a601bf6ad764fd8bab1972b2 /source/smbd/trans2.c
parent5e6a7cd99d29d1cf068fc517272559c1cf47ea3a (diff)
downloadsamba-269bca2b3bbf5cae9fdf05d0405bfd80272da5d1.tar.gz
Fixed bug in previous commit where I was overwriting share_mode from
one fsp with that of another. Not good :-). Jeremy.
Diffstat (limited to 'source/smbd/trans2.c')
-rw-r--r--source/smbd/trans2.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/source/smbd/trans2.c b/source/smbd/trans2.c
index 1c2bdb1ddfa..e19b3a94a8f 100644
--- a/source/smbd/trans2.c
+++ b/source/smbd/trans2.c
@@ -1681,9 +1681,6 @@ static int call_trans2setfilepathinfo(connection_struct *conn,
files_struct *iterate_fsp;
SMB_DEV_T dev = fsp->fd_ptr->dev;
SMB_INO_T inode = fsp->fd_ptr->inode;
- int new_share_mode = (delete_on_close ?
- (fsp->share_mode | DELETE_ON_CLOSE_FLAG) :
- (fsp->share_mode & ~DELETE_ON_CLOSE_FLAG) );
DEBUG(10,("call_trans2setfilepathinfo: %s delete on close flag for fnum = %d, file %s\n",
delete_on_close ? "Adding" : "Removing", fsp->fnum, fsp->fsp_name ));
@@ -1699,6 +1696,10 @@ static int call_trans2setfilepathinfo(connection_struct *conn,
for(iterate_fsp = file_find_di_first(dev, inode); iterate_fsp;
iterate_fsp = file_find_di_next(iterate_fsp))
{
+ int new_share_mode = (delete_on_close ?
+ (iterate_fsp->share_mode | DELETE_ON_CLOSE_FLAG) :
+ (iterate_fsp->share_mode & ~DELETE_ON_CLOSE_FLAG) );
+
if(modify_share_mode(token, iterate_fsp, new_share_mode)==False)
DEBUG(0,("call_trans2setfilepathinfo: failed to change delete on close for fnum %d, \
dev = %x, inode = %.0f\n", fsp->fnum, (unsigned int)dev, (double)inode));