From: Volker Lendecke Date: Mon, 5 Mar 2007 20:09:27 +0000 (+0000) Subject: r21706: get_delete_on_close_flag() is the perfect candidate for tdb_parse_record() X-Git-Tag: samba-misc-tags/initial-v3-0-unstable~999 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=b73685d20751ac343faab79332552cd7ee92d831;p=thirdparty%2Fsamba.git r21706: get_delete_on_close_flag() is the perfect candidate for tdb_parse_record() --- diff --git a/source/locking/locking.c b/source/locking/locking.c index ffac43aff59..7326ea08c09 100644 --- a/source/locking/locking.c +++ b/source/locking/locking.c @@ -858,15 +858,29 @@ BOOL rename_share_filename(struct share_mode_lock *lck, return True; } -BOOL get_delete_on_close_flag(SMB_DEV_T dev, SMB_INO_T inode) +static int pull_delete_on_close_flag(TDB_DATA key, TDB_DATA dbuf, + void *private_data) { - BOOL result; - struct share_mode_lock *lck = get_share_mode_lock(NULL, dev, inode, NULL, NULL); - if (!lck) { - return False; + BOOL *result = (BOOL *)private_data; + struct locking_data *data; + + if (dbuf.dsize < sizeof(struct locking_data)) { + smb_panic("PANIC: parse_share_modes: buffer too short.\n"); } - result = lck->delete_on_close; - TALLOC_FREE(lck); + + data = (struct locking_data *)dbuf.dptr; + + *result = data->u.s.delete_on_close; + return 0; +} + +BOOL get_delete_on_close_flag(SMB_DEV_T dev, SMB_INO_T inode) +{ + TDB_DATA key = locking_key(dev, inode); + BOOL result = False; + + tdb_parse_record(tdb, key, pull_delete_on_close_flag, + (void *)&result); return result; }