--- a/src/server/daemon/vfs.h Sun Mar 17 12:47:59 2013 +0100 +++ b/src/server/daemon/vfs.h Sun Mar 17 17:54:20 2013 +0100 @@ -50,6 +50,8 @@ int (*stat)(VFSContext *ctx, char *path, struct stat *buf); int (*fstat)(VFSContext *ctx, SYS_FILE fd, struct stat *buf); VFS_DIR (*opendir)(VFSContext *ctx, char *path); + int (*mkdir)(VFSContext *ctx, char *path); + int (*unlink)(VFSContext *ctx, char *path); }; struct VFSContext { @@ -111,8 +113,13 @@ int vfs_readdir(VFS_DIR dir, VFS_ENTRY *entry); int vfs_readdir_stat(VFS_DIR dir, VFS_ENTRY *entry); void vfs_closedir(VFS_DIR dir); +int vfs_mkdir(VFSContext *ctx, char *path); +int vfs_unlink(VFSContext *ctx, char *path); // private +typedef int(*vfs_op_f)(VFSContext *, char *); +int vfs_path_op(VFSContext *ctx, char *path, vfs_op_f op, uint32_t access); + int sys_acl_check(VFSContext *ctx, uint32_t acm, uid_t *uid, gid_t *gid); void sys_set_error_status(VFSContext *ctx); ssize_t sys_file_read(SYS_FILE fd, void *buf, size_t nbyte); @@ -120,6 +127,8 @@ void sys_file_close(SYS_FILE fd); int sys_dir_read(VFS_DIR dir, VFS_ENTRY *entry, int getstat); void sys_dir_close(VFS_DIR dir); +int sys_mkdir(VFSContext *ctx, char *path); +int sys_unlink(VFSContext *ctx, char *path); #ifdef __cplusplus }