X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=ruby%2Fext%2Fguestfs%2F_guestfs.c;h=4fb6ce713fb58e1a9d0211efa1f67e93b21e35f2;hb=d901cc916102f1aaccfb73396b48aa303e5b8cd7;hp=0c20703d429e1a0d9f0fdb60721ec6286bb0715a;hpb=e8ecc08f663b44f3d79517affe52f137858dfe00;p=libguestfs.git diff --git a/ruby/ext/guestfs/_guestfs.c b/ruby/ext/guestfs/_guestfs.c index 0c20703..4fb6ce7 100644 --- a/ruby/ext/guestfs/_guestfs.c +++ b/ruby/ext/guestfs/_guestfs.c @@ -2885,6 +2885,27 @@ static VALUE ruby_guestfs_hexdump (VALUE gv, VALUE pathv) return rv; } +static VALUE ruby_guestfs_zerofree (VALUE gv, VALUE devicev) +{ + guestfs_h *g; + Data_Get_Struct (gv, guestfs_h, g); + if (!g) + rb_raise (rb_eArgError, "%s: used handle after closing it", "zerofree"); + + const char *device = StringValueCStr (devicev); + if (!device) + rb_raise (rb_eTypeError, "expected string for parameter %s of %s", + "device", "zerofree"); + + int r; + + r = guestfs_zerofree (g, device); + if (r == -1) + rb_raise (e_Error, "%s", guestfs_last_error (g)); + + return Qnil; +} + /* Initialize the module. */ void Init__guestfs () { @@ -3135,4 +3156,6 @@ void Init__guestfs () ruby_guestfs_strings_e, 2); rb_define_method (c_guestfs, "hexdump", ruby_guestfs_hexdump, 1); + rb_define_method (c_guestfs, "zerofree", + ruby_guestfs_zerofree, 1); }