X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=bindings%2Fruby%2Fquery.c;h=f87700a49a5da5fe68e2252db060c82fc1500797;hp=1658edee4dac046e7bcc9f95e751ef77f9cee9da;hb=516e196fa12a71982ee4feb4ef6ff52f48b1805b;hpb=f0dfda5c7797f9db81ce35d270fe0ac406c7fca1 diff --git a/bindings/ruby/query.c b/bindings/ruby/query.c index 1658edee..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 UINT2NUM(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); }