diff options
author | Andrew Tridgell <tridge@samba.org> | 2001-04-28 12:43:15 +0000 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2001-04-28 12:43:15 +0000 |
commit | 944aeb7de472e0654561f7d8f37a5703487a973e (patch) | |
tree | 2f181621cdb9482eee0d40f6ad06bac8a94f2e22 | |
parent | fd5c6d72d333a967480be834abb611120c1ae0b6 (diff) | |
download | samba-944aeb7de472e0654561f7d8f37a5703487a973e.tar.gz samba-944aeb7de472e0654561f7d8f37a5703487a973e.tar.bz2 samba-944aeb7de472e0654561f7d8f37a5703487a973e.zip |
use asprintf for hideunreadable option
(This used to be commit 338d5ca8addb3079e0ab4a68338596d6e3b17ddb)
-rw-r--r-- | source3/smbd/dir.c | 22 |
1 files changed, 8 insertions, 14 deletions
diff --git a/source3/smbd/dir.c b/source3/smbd/dir.c index 1d497574a6..fa9cbdc4a2 100644 --- a/source3/smbd/dir.c +++ b/source3/smbd/dir.c @@ -727,21 +727,15 @@ void *OpenDir(connection_struct *conn, char *name, BOOL use_veto) if (use_veto && conn && IS_VETO_PATH(conn, n)) continue; /* Honour _hide unreadable_ option */ - if (conn && lp_hideunreadable(SNUM(conn))) - { - char *entry; - int ret; + if (conn && lp_hideunreadable(SNUM(conn))) { + char *entry; + int ret=0; - entry = (char *)malloc(PATH_MAX); - if (!entry) { - DEBUG(0,("Out of memory in OpenDir\n")); - conn->vfs_ops.closedir(conn,p); - return(NULL); - } - slprintf(entry, PATH_MAX, "%s/%s/%s", conn->origpath, name, n); - ret = user_can_read_file(conn, entry); - free(entry); - if (!ret) continue; + if (asprintf(&entry, "%s/%s/%s", conn->origpath, name, n) > 0) { + ret = user_can_read_file(conn, entry); + free(entry); + } + if (!ret) continue; } if (used + l > dirp->mallocsize) { |