X-Git-Url: https://git.notmuchmail.org/git?a=blobdiff_plain;f=bindings%2Fruby%2Ffilenames.c;h=e27859038697a5ecc07e634cf1e5711742df9376;hb=e8a828b30d099b929d2feab0154e98d06786e92e;hp=44a16522feb7567b6ab1b8baa515396cb9f6ebcb;hpb=06bf04500ba282052d38adf428219968ae62bb54;p=notmuch diff --git a/bindings/ruby/filenames.c b/bindings/ruby/filenames.c index 44a16522..e2785903 100644 --- a/bindings/ruby/filenames.c +++ b/bindings/ruby/filenames.c @@ -20,6 +20,24 @@ #include "defs.h" +/* + * call-seq: FILENAMES.destroy! => nil + * + * Destroys the filenames, freeing all resources allocated for it. + */ +VALUE +notmuch_rb_filenames_destroy (VALUE self) +{ + notmuch_filenames_t *fnames; + + Data_Get_Notmuch_FileNames (self, fnames); + + notmuch_filenames_destroy (fnames); + DATA_PTR (self) = NULL; + + return Qnil; +} + /* * call-seq: FILENAMES.each {|item| block } => FILENAMES * @@ -27,17 +45,14 @@ * parameter. */ VALUE -notmuch_rb_filenames_each(VALUE self) +notmuch_rb_filenames_each (VALUE self) { - notmuch_rb_filenames_t *flist; + notmuch_filenames_t *fnames; - Data_Get_Struct(self, notmuch_rb_filenames_t, flist); - if (!flist->nm_flist) - return self; + Data_Get_Notmuch_FileNames (self, fnames); - for (; notmuch_filenames_valid(flist->nm_flist); - notmuch_filenames_move_to_next(flist->nm_flist)) - rb_yield(rb_str_new2(notmuch_filenames_get(flist->nm_flist))); + for (; notmuch_filenames_valid (fnames); notmuch_filenames_move_to_next (fnames)) + rb_yield (rb_str_new2 (notmuch_filenames_get (fnames))); return self; }