diff options
author | Richard Jones <rjones@trick.home.annexia.org> | 2009-05-19 12:05:43 +0100 |
---|---|---|
committer | Richard Jones <rjones@trick.home.annexia.org> | 2009-05-19 12:05:43 +0100 |
commit | 1fc41b39dac877ccec1284da8bb14baa4df368b8 (patch) | |
tree | 74d0693b6d97d796b75847ace4815109c17b3198 /daemon | |
parent | d1df2f342489bbbba086cae2bb95971c8e404cad (diff) | |
download | libguestfs-1fc41b39dac877ccec1284da8bb14baa4df368b8.tar.gz libguestfs-1fc41b39dac877ccec1284da8bb14baa4df368b8.tar.xz libguestfs-1fc41b39dac877ccec1284da8bb14baa4df368b8.zip |
Generated code for 'find' command.
Diffstat (limited to 'daemon')
-rw-r--r-- | daemon/actions.h | 1 | ||||
-rw-r--r-- | daemon/stubs.c | 31 |
2 files changed, 32 insertions, 0 deletions
diff --git a/daemon/actions.h b/daemon/actions.h index 79ec62aa..8aed57c1 100644 --- a/daemon/actions.h +++ b/daemon/actions.h @@ -127,3 +127,4 @@ extern int do_vg_activate_all (int activate); extern int do_vg_activate (int activate, char * const* const volgroups); extern int do_lvresize (const char *device, int mbytes); extern int do_resize2fs (const char *device); +extern char **do_find (const char *directory); diff --git a/daemon/stubs.c b/daemon/stubs.c index 2fdd5c16..2df8bbac 100644 --- a/daemon/stubs.c +++ b/daemon/stubs.c @@ -2667,6 +2667,34 @@ done: xdr_free ((xdrproc_t) xdr_guestfs_resize2fs_args, (char *) &args); } +static void find_stub (XDR *xdr_in) +{ + char **r; + struct guestfs_find_args args; + const char *directory; + + memset (&args, 0, sizeof args); + + if (!xdr_guestfs_find_args (xdr_in, &args)) { + reply_with_error ("%s: daemon failed to decode procedure arguments", "find"); + return; + } + directory = args.directory; + + r = do_find (directory); + if (r == NULL) + /* do_find has already called reply_with_error */ + goto done; + + struct guestfs_find_ret ret; + ret.names.names_len = count_strings (r); + ret.names.names_val = r; + reply ((xdrproc_t) &xdr_guestfs_find_ret, (char *) &ret); + free_strings (r); +done: + xdr_free ((xdrproc_t) xdr_guestfs_find_args, (char *) &args); +} + void dispatch_incoming_message (XDR *xdr_in) { switch (proc_nr) { @@ -2988,6 +3016,9 @@ void dispatch_incoming_message (XDR *xdr_in) case GUESTFS_PROC_RESIZE2FS: resize2fs_stub (xdr_in); break; + case GUESTFS_PROC_FIND: + find_stub (xdr_in); + break; default: reply_with_error ("dispatch_incoming_message: unknown procedure number %d", proc_nr); } |