unofficial mirror of notmuch@notmuchmail.org
 help / color / mirror / code / Atom feed
From: Austin Clements <amdragon@MIT.EDU>
To: Adrien Bustany <adrien@bustany.org>
Cc: notmuch@notmuchmail.org
Subject: Re: [PATCH 7/7] go: Bind notmuch_thread_t functions
Date: Wed, 18 Jul 2012 16:50:28 -0400	[thread overview]
Message-ID: <20120718205028.GV31670@mit.edu> (raw)
In-Reply-To: <1342636475-16057-8-git-send-email-adrien@bustany.org>

Quoth Adrien Bustany on Jul 18 at  9:34 pm:
> ---
>  bindings/go/src/notmuch/notmuch.go |  253 +++++++++++++++++++++++++++++++++++-
>  1 files changed, 252 insertions(+), 1 deletions(-)
> 
> diff --git a/bindings/go/src/notmuch/notmuch.go b/bindings/go/src/notmuch/notmuch.go
> index be4cb8c..f667dbb 100644
> --- a/bindings/go/src/notmuch/notmuch.go
> +++ b/bindings/go/src/notmuch/notmuch.go
> @@ -12,6 +12,8 @@ package notmuch
>  */
>  import "C"
>  import "runtime"
> +import "strings"
> +import "time"
>  import "unsafe"
>  
>  // Status codes used for the return values of most functions
> @@ -700,7 +702,20 @@ func (self *Query) CountMessages() uint {
>  	return uint(C.notmuch_query_count_messages(self.query))
>  }
>  
> -// TODO: wrap threads and thread
> +/* Return the number of threads matching a search.
> + *
> + * This function performs a search and returns the number of unique thread IDs
> + * in the matching messages. This is the same as number of threads matching a
> + * search.
> + *
> + * Note that this is a significantly heavier operation than
> + * notmuch_query_count_messages().
> + *
> + * If an error occurs, this function may return 0.
> + */
> +func (self *Query) CountThreads() uint {
> +	return uint(C.notmuch_query_count_threads(self.query))
> +}
>  
>  /* Is the given 'threads' iterator pointing at a valid thread.
>   *
> @@ -722,6 +737,45 @@ func (self *Threads) Valid() bool {
>  	return true
>  }
>  
> +/* Get the current thread from 'threads' as a notmuch_thread_t.
> + *
> + * Note: The returned thread belongs to 'threads' and has a lifetime
> + * identical to it (and the query to which it belongs).
> + *
> + * See the documentation of notmuch_query_search_threads for example
> + * code showing how to iterate over a notmuch_threads_t object.
> + *
> + * If an out-of-memory situation occurs, this function will return
> + * NULL.
> + */
> +func (self *Threads) Get() *Thread {
> +	if self.threads == nil {
> +		return nil
> +	}
> +	thread := C.notmuch_threads_get(self.threads)
> +	if thread == nil {
> +		return nil
> +	}
> +	return createThread(thread, self)
> +}
> +
> +/* Move the 'threads' iterator to the next thread.
> + *
> + * If 'threads' is already pointing at the last thread then the
> + * iterator will be moved to a point just beyond that last thread,
> + * (where notmuch_threads_valid will return FALSE and
> + * notmuch_threads_get will return NULL).
> + *
> + * See the documentation of notmuch_query_search_threads for example
> + * code showing how to iterate over a notmuch_threads_t object.
> + */
> +func (self *Threads) MoveToNext() {
> +	if self.threads == nil {
> +		return
> +	}
> +	C.notmuch_threads_move_to_next(self.threads)
> +}
> +
>  /* Destroy a notmuch_threads_t object.
>   *
>   * It's not strictly necessary to call this function. All memory from
> @@ -735,6 +789,203 @@ func (self *Threads) Destroy() {
>  	}
>  }
>  
> +/* Get the thread ID of 'thread'.
> + *
> + * The returned string belongs to 'thread' and as such, should not be
> + * modified by the caller and will only be valid for as long as the
> + * thread is valid, (which is until notmuch_thread_destroy or until
> + * the query from which it derived is destroyed).
> + */
> +func (self *Thread) GetThreadId() string {
> +	if self.thread == nil {
> +		return ""
> +	}
> +	id := C.notmuch_thread_get_thread_id(self.thread)
> +
> +	if id == nil {
> +		return ""
> +	}
> +
> +	return C.GoString(id)
> +}
> +
> +/* Get the total number of messages in 'thread'.
> + *
> + * This count consists of all messages in the database belonging to
> + * this thread. Contrast with notmuch_thread_get_matched_messages() .
> + */
> +func (self *Thread) GetTotalMessages() int {
> +	if self.thread == nil {
> +		return 0
> +	}
> +	return int(C.notmuch_thread_get_total_messages(self.thread))
> +}
> +
> +/* Get a notmuch_messages_t iterator for the top-level messages in
> + * 'thread'.
> + *
> + * This iterator will not necessarily iterate over all of the messages
> + * in the thread. It will only iterate over the messages in the thread
> + * which are not replies to other messages in the thread.
> + *
> + * To iterate over all messages in the thread, the caller will need to
> + * iterate over the result of notmuch_message_get_replies for each
> + * top-level message (and do that recursively for the resulting
> + * messages, etc.).
> + */
> +func (self *Thread) GetToplevelMessages() *Messages {
> +	if self.thread == nil {
> +		return nil
> +	}
> +	msgs := C.notmuch_thread_get_toplevel_messages(self.thread)
> +	if msgs == nil {
> +		return nil
> +	}
> +	return createMessages(msgs, self)
> +}
> +
> +/* Get a notmuch_messages_t iterator for the top-level messages in
> + * 'thread'.
> + *
> + * This iterator will not necessarily iterate over all of the messages
> + * in the thread. It will only iterate over the messages in the thread
> + * which are not replies to other messages in the thread.
> + *
> + * To iterate over all messages in the thread, the caller will need to
> + * iterate over the result of notmuch_message_get_replies for each
> + * top-level message (and do that recursively for the resulting
> + * messages, etc.).
> + */

Wrong comment.  (Same for the next two methods.)

> +func (self *Thread) GetMatchedMessages() int {
> +	if self.thread == nil {
> +		return 0
> +	}
> +	return int(C.notmuch_thread_get_matched_messages(self.thread))
> +}
> +
> +/* Get a notmuch_messages_t iterator for the top-level messages in
> + * 'thread'.
> + *
> + * This iterator will not necessarily iterate over all of the messages
> + * in the thread. It will only iterate over the messages in the thread
> + * which are not replies to other messages in the thread.
> + *
> + * To iterate over all messages in the thread, the caller will need to
> + * iterate over the result of notmuch_message_get_replies for each
> + * top-level message (and do that recursively for the resulting
> + * messages, etc.).
> + */
> +func (self *Thread) GetAuthors() []string {
> +	if self.thread == nil {
> +		return make([]string, 0)
> +	}
> +	authors_str := C.notmuch_thread_get_authors(self.thread)
> +
> +	if authors_str == nil {
> +		return make([]string, 0)
> +	}
> +
> +	return strings.Split(C.GoString(authors_str), ", ")
> +}
> +
> +/* Get the subject of 'thread'
> + *
> + * The subject is taken from the first message (according to the query
> + * order---see notmuch_query_set_sort) in the query results that
> + * belongs to this thread.
> + *
> + * The returned string belongs to 'thread' and as such, should not be
> + * modified by the caller and will only be valid for as long as the
> + * thread is valid, (which is until notmuch_thread_destroy or until
> + * the query from which it derived is destroyed).
> + */
> +func (self *Thread) GetSubject() string {
> +	if self.thread == nil {
> +		return ""
> +	}
> +	subject := C.notmuch_thread_get_subject(self.thread)
> +
> +	if subject == nil {
> +		return ""
> +	}
> +
> +	return C.GoString(subject)
> +}
> +
> +/* Get the date of the oldest message in 'thread' as a time_t value.
> + */
> +func (self *Thread) GetOldestDate() time.Time {
> +	if self.thread == nil {
> +		return time.Unix(0, 0)
> +	}
> +	return time.Unix(int64(C.notmuch_thread_get_oldest_date(self.thread)), 0)
> +}
> +
> +/* Get the date of the newest message in 'thread' as a time_t value.
> + */
> +func (self *Thread) GetNewestDate() time.Time {
> +	if self.thread == nil {
> +		return time.Unix(0, 0)
> +	}
> +	return time.Unix(int64(C.notmuch_thread_get_oldest_date(self.thread)), 0)
> +}
> +
> +/* Get the tags for 'thread', returning a notmuch_tags_t object which
> + * can be used to iterate over all tags.
> + *
> + * Note: In the Notmuch database, tags are stored on individual
> + * messages, not on threads. So the tags returned here will be all
> + * tags of the messages which matched the search and which belong to
> + * this thread.
> + *
> + * The tags object is owned by the thread and as such, will only be
> + * valid for as long as the thread is valid, (for example, until
> + * notmuch_thread_destroy or until the query from which it derived is
> + * destroyed).
> + *
> + * Typical usage might be:
> + *
> + *     notmuch_thread_t *thread;
> + *     notmuch_tags_t *tags;
> + *     const char *tag;
> + *
> + *     thread = notmuch_threads_get (threads);
> + *
> + *     for (tags = notmuch_thread_get_tags (thread);
> + *          notmuch_tags_valid (tags);
> + *          notmuch_result_move_to_next (tags))
> + *     {
> + *         tag = notmuch_tags_get (tags);
> + *         ....
> + *     }
> + *
> + *     notmuch_thread_destroy (thread);

I wonder if this example should be updated for Go?  OTOH, all of the
comments seem to be copied verbatim, to the point of referring to C
function names and status symbols.

> + *
> + * Note that there's no explicit destructor needed for the
> + * notmuch_tags_t object. (For consistency, we do provide a
> + * notmuch_tags_destroy function, but there's no good reason to call
> + * it if the message is about to be destroyed).
> + */
> +func (self *Thread) GetTags() *Tags {
> +	if self.thread == nil {
> +		return nil
> +	}
> +	tags := C.notmuch_thread_get_tags(self.thread)
> +	if tags == nil {
> +		return nil
> +	}
> +	return createTags(tags, self)
> +}
> +
> +/* Destroy a notmuch_thread_t object. */
> +func (self *Thread) Destroy() {
> +	if self.thread == nil {
> +		return
> +	}
> +	C.notmuch_thread_destroy(self.thread)
> +	self.thread = nil
> +}
> +
>  /* Is the given 'messages' iterator pointing at a valid message.
>   *
>   * When this function returns TRUE, notmuch_messages_get will return a

  reply	other threads:[~2012-07-18 20:50 UTC|newest]

Thread overview: 21+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-07-18 18:34 [PATCH 0/7] Various fixes for the Go bindings Adrien Bustany
2012-07-18 18:34 ` [PATCH 1/7] go: Use iota in enum bindings Adrien Bustany
2012-07-18 20:17   ` Austin Clements
2012-07-18 20:36     ` Sebastien Binet
2012-07-18 18:34 ` [PATCH 2/7] go: Add missing MESSAGE_FLAG_EXCLUDED in Flag enum Adrien Bustany
2012-07-18 18:34 ` [PATCH 3/7] go: Allow notmuch objects to be garbage collected Adrien Bustany
2012-07-18 20:40   ` Austin Clements
2012-07-19 18:25     ` Adrien Bustany
2012-07-20  3:23       ` Austin Clements
2012-07-23 22:03         ` Adrien Bustany
2012-08-04 19:28           ` Austin Clements
2012-10-19  3:55   ` Ethan Glasser-Camp
2012-10-25 18:41     ` Adrien Bustany
2012-07-18 18:34 ` [PATCH 4/7] go: Make Destroy functions safe to call several times Adrien Bustany
2012-07-18 18:34 ` [PATCH 5/7] go: Partially bind notmuch_database_upgrade Adrien Bustany
2012-07-18 20:41   ` Austin Clements
2012-07-18 18:34 ` [PATCH 6/7] go: Bind notmuch_database_find_message_by_filename Adrien Bustany
2012-07-18 18:34 ` [PATCH 7/7] go: Bind notmuch_thread_t functions Adrien Bustany
2012-07-18 20:50   ` Austin Clements [this message]
2012-07-18 20:51 ` [PATCH 0/7] Various fixes for the Go bindings Austin Clements
2012-07-19 18:29   ` Adrien Bustany

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://notmuchmail.org/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20120718205028.GV31670@mit.edu \
    --to=amdragon@mit.edu \
    --cc=adrien@bustany.org \
    --cc=notmuch@notmuchmail.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://yhetil.org/notmuch.git/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).