From 06c7ec8485c449dbcff7ea4f24ecce068fdab44c Mon Sep 17 00:00:00 2001 From: Tim Potter Date: Thu, 8 Apr 1999 03:01:18 +0000 Subject: Forgot about closedir() function for VFS. Hoo embarassing. (This used to be commit c1cbe07c0391c36066b068fdd42bf1aa40259a5c) --- source3/smbd/dir.c | 4 ++-- source3/smbd/vfs-wrap.c | 8 ++++++++ source3/smbd/vfs.c | 2 ++ 3 files changed, 12 insertions(+), 2 deletions(-) (limited to 'source3/smbd') diff --git a/source3/smbd/dir.c b/source3/smbd/dir.c index 52d271e284..b7ae2af47c 100644 --- a/source3/smbd/dir.c +++ b/source3/smbd/dir.c @@ -524,7 +524,7 @@ void *OpenDir(connection_struct *conn, char *name, BOOL use_veto) if (!p) return(NULL); dirp = (Dir *)malloc(sizeof(Dir)); if (!dirp) { - closedir(p); + conn->vfs_ops.closedir(p); return(NULL); } dirp->pos = dirp->numentries = dirp->mallocsize = 0; @@ -554,7 +554,7 @@ void *OpenDir(connection_struct *conn, char *name, BOOL use_veto) dirp->numentries++; } - closedir(p); + conn->vfs_ops.closedir(p); return((void *)dirp); } diff --git a/source3/smbd/vfs-wrap.c b/source3/smbd/vfs-wrap.c index b3d1a35329..da69b3f006 100644 --- a/source3/smbd/vfs-wrap.c +++ b/source3/smbd/vfs-wrap.c @@ -66,6 +66,14 @@ int vfswrap_rmdir(char *path) return result; } +int vfswrap_closedir(DIR *dirp) +{ + int result; + + result = closedir(path); + return result; +} + /* File operations */ int vfswrap_open(char *fname, int flags, mode_t mode) diff --git a/source3/smbd/vfs.c b/source3/smbd/vfs.c index 59e7bb4935..fdff87496b 100644 --- a/source3/smbd/vfs.c +++ b/source3/smbd/vfs.c @@ -53,6 +53,7 @@ struct vfs_syminfo vfs_syminfo[] = { {"vfs_readdir", &dl_ops.readdir}, {"vfs_mkdir", &dl_ops.mkdir}, {"vfs_rmdir", &dl_ops.rmdir}, + {"vfs_closedir", &dl_ops.closedir}, /* File operations */ @@ -95,6 +96,7 @@ struct vfs_ops default_vfs_ops = { vfswrap_readdir, vfswrap_mkdir, vfswrap_rmdir, + vfswrap_closedir, /* File operations */ -- cgit