diff options
author | Richard Jones <rjones@redhat.com> | 2009-04-15 10:45:01 +0100 |
---|---|---|
committer | Richard Jones <rjones@redhat.com> | 2009-04-15 10:45:01 +0100 |
commit | 6bcbe54b5785cb8c911ccf4b724ae6abfdf53ce4 (patch) | |
tree | 17dc6cbf4514f5808fbc204e592723bea95c4382 /daemon | |
parent | 212a55d483c2a20e61f42211c0c64aab3645cb09 (diff) | |
download | libguestfs-6bcbe54b5785cb8c911ccf4b724ae6abfdf53ce4.tar.gz libguestfs-6bcbe54b5785cb8c911ccf4b724ae6abfdf53ce4.tar.xz libguestfs-6bcbe54b5785cb8c911ccf4b724ae6abfdf53ce4.zip |
Generated code for stat/lstat/statvfs changes.
Diffstat (limited to 'daemon')
-rw-r--r-- | daemon/actions.h | 3 | ||||
-rw-r--r-- | daemon/stubs.c | 90 |
2 files changed, 93 insertions, 0 deletions
diff --git a/daemon/actions.h b/daemon/actions.h index 90aeb8d0..c0f41ce1 100644 --- a/daemon/actions.h +++ b/daemon/actions.h @@ -72,3 +72,6 @@ extern int do_lvm_remove_all (void); extern char *do_file (const char *path); extern char *do_command (char * const* const arguments); extern char **do_command_lines (char * const* const arguments); +extern guestfs_int_stat *do_stat (const char *path); +extern guestfs_int_stat *do_lstat (const char *path); +extern guestfs_int_statvfs *do_statvfs (const char *path); diff --git a/daemon/stubs.c b/daemon/stubs.c index 9a0dc912..9662de80 100644 --- a/daemon/stubs.c +++ b/daemon/stubs.c @@ -1223,6 +1223,87 @@ done: xdr_free ((xdrproc_t) xdr_guestfs_command_lines_args, (char *) &args); } +static void stat_stub (XDR *xdr_in) +{ + guestfs_int_stat *r; + struct guestfs_stat_args args; + const char *path; + + memset (&args, 0, sizeof args); + + if (!xdr_guestfs_stat_args (xdr_in, &args)) { + reply_with_error ("%s: daemon failed to decode procedure arguments", "stat"); + return; + } + path = args.path; + + r = do_stat (path); + if (r == NULL) + /* do_stat has already called reply_with_error */ + goto done; + + struct guestfs_stat_ret ret; + ret.statbuf = *r; + reply ((xdrproc_t) xdr_guestfs_stat_ret, (char *) &ret); + xdr_free ((xdrproc_t) xdr_guestfs_stat_ret, (char *) &ret); +done: + xdr_free ((xdrproc_t) xdr_guestfs_stat_args, (char *) &args); +} + +static void lstat_stub (XDR *xdr_in) +{ + guestfs_int_stat *r; + struct guestfs_lstat_args args; + const char *path; + + memset (&args, 0, sizeof args); + + if (!xdr_guestfs_lstat_args (xdr_in, &args)) { + reply_with_error ("%s: daemon failed to decode procedure arguments", "lstat"); + return; + } + path = args.path; + + r = do_lstat (path); + if (r == NULL) + /* do_lstat has already called reply_with_error */ + goto done; + + struct guestfs_lstat_ret ret; + ret.statbuf = *r; + reply ((xdrproc_t) xdr_guestfs_lstat_ret, (char *) &ret); + xdr_free ((xdrproc_t) xdr_guestfs_lstat_ret, (char *) &ret); +done: + xdr_free ((xdrproc_t) xdr_guestfs_lstat_args, (char *) &args); +} + +static void statvfs_stub (XDR *xdr_in) +{ + guestfs_int_statvfs *r; + struct guestfs_statvfs_args args; + const char *path; + + memset (&args, 0, sizeof args); + + if (!xdr_guestfs_statvfs_args (xdr_in, &args)) { + reply_with_error ("%s: daemon failed to decode procedure arguments", "statvfs"); + return; + } + path = args.path; + + r = do_statvfs (path); + if (r == NULL) + /* do_statvfs has already called reply_with_error */ + goto done; + + struct guestfs_statvfs_ret ret; + ret.statbuf = *r; + reply ((xdrproc_t) xdr_guestfs_statvfs_ret, (char *) &ret); + xdr_free ((xdrproc_t) xdr_guestfs_statvfs_ret, (char *) &ret); +done: + xdr_free ((xdrproc_t) xdr_guestfs_statvfs_args, (char *) &args); +} + void dispatch_incoming_message (XDR *xdr_in) { switch (proc_nr) { @@ -1379,6 +1460,15 @@ void dispatch_incoming_message (XDR *xdr_in) case GUESTFS_PROC_COMMAND_LINES: command_lines_stub (xdr_in); break; + case GUESTFS_PROC_STAT: + stat_stub (xdr_in); + break; + case GUESTFS_PROC_LSTAT: + lstat_stub (xdr_in); + break; + case GUESTFS_PROC_STATVFS: + statvfs_stub (xdr_in); + break; default: reply_with_error ("dispatch_incoming_message: unknown procedure number %d", proc_nr); } |