summaryrefslogtreecommitdiffstats
path: root/daemon
diff options
context:
space:
mode:
authorRichard W.M. Jones <rjones@redhat.com>2009-06-23 15:53:44 +0100
committerRichard W.M. Jones <rjones@redhat.com>2009-06-23 15:53:44 +0100
commitbcb3fc0c3336c05e9ecbbfb25c7c31b42bd3e32e (patch)
tree80042c722c65911c3a3b55a275daefff96220e7f /daemon
parentda7cf3670fe60301beeb175ff6c284b737d5b7f4 (diff)
downloadlibguestfs-bcb3fc0c3336c05e9ecbbfb25c7c31b42bd3e32e.tar.gz
libguestfs-bcb3fc0c3336c05e9ecbbfb25c7c31b42bd3e32e.tar.xz
libguestfs-bcb3fc0c3336c05e9ecbbfb25c7c31b42bd3e32e.zip
Generated code for 'scrub-*' commands.
Diffstat (limited to 'daemon')
-rw-r--r--daemon/actions.h3
-rw-r--r--daemon/stubs.c81
2 files changed, 84 insertions, 0 deletions
diff --git a/daemon/actions.h b/daemon/actions.h
index cc8bc787..17ec338c 100644
--- a/daemon/actions.h
+++ b/daemon/actions.h
@@ -134,3 +134,6 @@ extern int do_ntfs_3g_probe (int rw, char *device);
extern char *do_sh (char *command);
extern char **do_sh_lines (char *command);
extern char **do_glob_expand (char *pattern);
+extern int do_scrub_device (char *device);
+extern int do_scrub_file (char *file);
+extern int do_scrub_freespace (char *dir);
diff --git a/daemon/stubs.c b/daemon/stubs.c
index af87a994..be97a863 100644
--- a/daemon/stubs.c
+++ b/daemon/stubs.c
@@ -2854,6 +2854,78 @@ done:
xdr_free ((xdrproc_t) xdr_guestfs_glob_expand_args, (char *) &args);
}
+static void scrub_device_stub (XDR *xdr_in)
+{
+ int r;
+ struct guestfs_scrub_device_args args;
+ char *device;
+
+ memset (&args, 0, sizeof args);
+
+ if (!xdr_guestfs_scrub_device_args (xdr_in, &args)) {
+ reply_with_error ("%s: daemon failed to decode procedure arguments", "scrub_device");
+ return;
+ }
+ device = args.device;
+
+ r = do_scrub_device (device);
+ if (r == -1)
+ /* do_scrub_device has already called reply_with_error */
+ goto done;
+
+ reply (NULL, NULL);
+done:
+ xdr_free ((xdrproc_t) xdr_guestfs_scrub_device_args, (char *) &args);
+}
+
+static void scrub_file_stub (XDR *xdr_in)
+{
+ int r;
+ struct guestfs_scrub_file_args args;
+ char *file;
+
+ memset (&args, 0, sizeof args);
+
+ if (!xdr_guestfs_scrub_file_args (xdr_in, &args)) {
+ reply_with_error ("%s: daemon failed to decode procedure arguments", "scrub_file");
+ return;
+ }
+ file = args.file;
+
+ r = do_scrub_file (file);
+ if (r == -1)
+ /* do_scrub_file has already called reply_with_error */
+ goto done;
+
+ reply (NULL, NULL);
+done:
+ xdr_free ((xdrproc_t) xdr_guestfs_scrub_file_args, (char *) &args);
+}
+
+static void scrub_freespace_stub (XDR *xdr_in)
+{
+ int r;
+ struct guestfs_scrub_freespace_args args;
+ char *dir;
+
+ memset (&args, 0, sizeof args);
+
+ if (!xdr_guestfs_scrub_freespace_args (xdr_in, &args)) {
+ reply_with_error ("%s: daemon failed to decode procedure arguments", "scrub_freespace");
+ return;
+ }
+ dir = args.dir;
+
+ r = do_scrub_freespace (dir);
+ if (r == -1)
+ /* do_scrub_freespace has already called reply_with_error */
+ goto done;
+
+ reply (NULL, NULL);
+done:
+ xdr_free ((xdrproc_t) xdr_guestfs_scrub_freespace_args, (char *) &args);
+}
+
void dispatch_incoming_message (XDR *xdr_in)
{
switch (proc_nr) {
@@ -3196,6 +3268,15 @@ void dispatch_incoming_message (XDR *xdr_in)
case GUESTFS_PROC_GLOB_EXPAND:
glob_expand_stub (xdr_in);
break;
+ case GUESTFS_PROC_SCRUB_DEVICE:
+ scrub_device_stub (xdr_in);
+ break;
+ case GUESTFS_PROC_SCRUB_FILE:
+ scrub_file_stub (xdr_in);
+ break;
+ case GUESTFS_PROC_SCRUB_FREESPACE:
+ scrub_freespace_stub (xdr_in);
+ break;
default:
reply_with_error ("dispatch_incoming_message: unknown procedure number %d, set LIBGUESTFS_PATH to point to the matching libguestfs appliance directory", proc_nr);
}