src/server/daemon/vfs.h

changeset 56
c6cf20b09043
parent 55
b7908bf38f9f
child 58
66c22e54aa90
--- 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
 }

mercurial