summaryrefslogtreecommitdiffstats
path: root/daemon/stubs.c
diff options
context:
space:
mode:
Diffstat (limited to 'daemon/stubs.c')
-rw-r--r--daemon/stubs.c85
1 files changed, 85 insertions, 0 deletions
diff --git a/daemon/stubs.c b/daemon/stubs.c
index 54fa8e00..4eccfb5b 100644
--- a/daemon/stubs.c
+++ b/daemon/stubs.c
@@ -25,6 +25,82 @@
#include "../src/guestfs_protocol.h"
#include "actions.h"
+static void cat_stub (XDR *xdr_in)
+{
+ char *r;
+ struct guestfs_cat_args args;
+ const char *path;
+
+ memset (&args, 0, sizeof args);
+
+ if (!xdr_guestfs_cat_args (xdr_in, &args)) {
+ reply_with_error ("cat: daemon failed to decode procedure arguments");
+ return;
+ }
+ path = args.path;
+
+ r = do_cat (path);
+ if (r == NULL)
+ /* do_cat has already called reply_with_error, so just return */
+ return;
+
+ struct guestfs_cat_ret ret;
+ ret.content = r;
+ reply ((xdrproc_t) &xdr_guestfs_cat_ret, (char *) &ret);
+ free (r);
+}
+
+static void ll_stub (XDR *xdr_in)
+{
+ char *r;
+ struct guestfs_ll_args args;
+ const char *directory;
+
+ memset (&args, 0, sizeof args);
+
+ if (!xdr_guestfs_ll_args (xdr_in, &args)) {
+ reply_with_error ("ll: daemon failed to decode procedure arguments");
+ return;
+ }
+ directory = args.directory;
+
+ r = do_ll (directory);
+ if (r == NULL)
+ /* do_ll has already called reply_with_error, so just return */
+ return;
+
+ struct guestfs_ll_ret ret;
+ ret.listing = r;
+ reply ((xdrproc_t) &xdr_guestfs_ll_ret, (char *) &ret);
+ free (r);
+}
+
+static void ls_stub (XDR *xdr_in)
+{
+ char **r;
+ struct guestfs_ls_args args;
+ const char *directory;
+
+ memset (&args, 0, sizeof args);
+
+ if (!xdr_guestfs_ls_args (xdr_in, &args)) {
+ reply_with_error ("ls: daemon failed to decode procedure arguments");
+ return;
+ }
+ directory = args.directory;
+
+ r = do_ls (directory);
+ if (r == NULL)
+ /* do_ls has already called reply_with_error, so just return */
+ return;
+
+ struct guestfs_ls_ret ret;
+ ret.listing.listing_len = count_strings (r);
+ ret.listing.listing_val = r;
+ reply ((xdrproc_t) &xdr_guestfs_ls_ret, (char *) &ret);
+ free_strings (r);
+}
+
static void mount_stub (XDR *xdr_in)
{
int r;
@@ -86,6 +162,15 @@ static void touch_stub (XDR *xdr_in)
void dispatch_incoming_message (XDR *xdr_in)
{
switch (proc_nr) {
+ case GUESTFS_PROC_CAT:
+ cat_stub (xdr_in);
+ break;
+ case GUESTFS_PROC_LL:
+ ll_stub (xdr_in);
+ break;
+ case GUESTFS_PROC_LS:
+ ls_stub (xdr_in);
+ break;
case GUESTFS_PROC_MOUNT:
mount_stub (xdr_in);
break;