diff options
author | Jeremy Allison <jra@samba.org> | 1998-10-23 03:41:11 +0000 |
---|---|---|
committer | Jeremy Allison <jra@samba.org> | 1998-10-23 03:41:11 +0000 |
commit | 269bca2b3bbf5cae9fdf05d0405bfd80272da5d1 (patch) | |
tree | 40f9c014f36f5215a601bf6ad764fd8bab1972b2 /source/smbd/trans2.c | |
parent | 5e6a7cd99d29d1cf068fc517272559c1cf47ea3a (diff) | |
download | samba-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.c | 7 |
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)); |