X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=bindings%2Fruby%2Fquery.c;h=f87700a49a5da5fe68e2252db060c82fc1500797;hp=e5ba1b7ab7b567027f6037304d9e994ca443c816;hb=516e196fa12a71982ee4feb4ef6ff52f48b1805b;hpb=a8e010962f257aaba0218392542cbfb1d14eddfd diff --git a/bindings/ruby/query.c b/bindings/ruby/query.c index e5ba1b7a..f87700a4 100644 --- a/bindings/ruby/query.c +++ b/bindings/ruby/query.c @@ -173,12 +173,35 @@ VALUE notmuch_rb_query_count_messages (VALUE self) { notmuch_query_t *query; + notmuch_status_t status; + unsigned int count; Data_Get_Notmuch_Query (self, query); - /* Xapian exceptions are not handled properly. - * (function may return 0 after printing a message) - * Thus there is nothing we can do here... - */ - return UINT2FIX(notmuch_query_count_messages(query)); + status = notmuch_query_count_messages_st (query, &count); + if (status) + notmuch_rb_status_raise (status); + + return UINT2NUM(count); +} + +/* + * call-seq: QUERY.count_threads => Fixnum + * + * Return an estimate of the number of threads matching a search + */ +VALUE +notmuch_rb_query_count_threads (VALUE self) +{ + notmuch_query_t *query; + notmuch_status_t status; + unsigned int count; + + Data_Get_Notmuch_Query (self, query); + + status = notmuch_query_count_threads_st (query, &count); + if (status) + notmuch_rb_status_raise (status); + + return UINT2NUM(count); }