From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from localhost (localhost [127.0.0.1]) by olra.theworths.org (Postfix) with ESMTP id E6B59429E21 for ; Mon, 3 Oct 2011 13:38:42 -0700 (PDT) X-Virus-Scanned: Debian amavisd-new at olra.theworths.org X-Spam-Flag: NO X-Spam-Score: 1.7 X-Spam-Level: * X-Spam-Status: No, score=1.7 tagged_above=-999 required=5 tests=[DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, FREEMAIL_FROM=0.001, FREEMAIL_REPLY=2.499, RCVD_IN_DNSWL_LOW=-0.7] autolearn=disabled Received: from olra.theworths.org ([127.0.0.1]) by localhost (olra.theworths.org [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id L-ZdWPooDdA8 for ; Mon, 3 Oct 2011 13:38:41 -0700 (PDT) Received: from mail-ey0-f181.google.com (mail-ey0-f181.google.com [209.85.215.181]) (using TLSv1 with cipher RC4-SHA (128/128 bits)) (No client certificate requested) by olra.theworths.org (Postfix) with ESMTPS id 08CE0431FB6 for ; Mon, 3 Oct 2011 13:38:40 -0700 (PDT) Received: by eyg5 with SMTP id 5so3728733eyg.26 for ; Mon, 03 Oct 2011 13:38:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=date:from:to:cc:subject:message-id:mail-followup-to:references :mime-version:content-type:content-disposition:in-reply-to :organization:user-agent; bh=98EE4NEyhIaFClWBhtIqthYjevVR+JXW8hqRvMQppn8=; b=RRrIdf4bgAdDmZy2smD2wIfWhFVI3/7KsDIug2ztHXdJrpH5sOEP0mJq7ED+xWjPlt EUJh7CN/X6SOYTCEZ8IDWtugJYJTGv7MaJmrHTqZ/zziWNYEPNmxgnl58udo46UfW1I9 e/Zm/AmWnMnmfeEvwXEI624IGleQLdPrQSB14= Received: by 10.223.53.146 with SMTP id m18mr476433fag.67.1317674318123; Mon, 03 Oct 2011 13:38:38 -0700 (PDT) Received: from localhost ([85.104.4.184]) by mx.google.com with ESMTPS id f25sm22627840faf.7.2011.10.03.13.38.35 (version=TLSv1/SSLv3 cipher=OTHER); Mon, 03 Oct 2011 13:38:36 -0700 (PDT) Date: Mon, 3 Oct 2011 23:38:37 +0300 From: Ali Polatel To: Austin Clements Subject: Re: [PATCH v1 1/1] lib: make find_message{, by_filename) report errors Message-ID: <20111003203837.GA22365@hayalet> Mail-Followup-To: Austin Clements , Notmuch Mailing List References: <1218582065f35bfcc5b84dfc1fbce21fc05034a6.1317660324.git.alip@exherbo.org> <20111003174308.GD17905@mit.edu> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha1; protocol="application/pgp-signature"; boundary="vtzGhvizbBRQ85DL" Content-Disposition: inline In-Reply-To: <20111003174308.GD17905@mit.edu> Organization: Pink Floyd User-Agent: Mutt/1.5.21 (2010-09-15) Cc: Notmuch Mailing List X-BeenThere: notmuch@notmuchmail.org X-Mailman-Version: 2.1.13 Precedence: list List-Id: "Use and development of the notmuch mail system." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 03 Oct 2011 20:38:43 -0000 --vtzGhvizbBRQ85DL Content-Type: text/plain; charset=utf-8; format=flowed Content-Disposition: inline Content-Transfer-Encoding: quoted-printable Austin Clements yazm=C4=B1=C5=9F: >All of the code looks good to me (and improving error handling is >always a good thing). Some style nits are inline below. Thanks for the review, comments below and a new set of patches follow... >The changes to _resolve_message_id_to_thread_id and >_notmuch_database_link_message_to_parents seem like just plain better >error handling and unrelated to the find_message API changes. Perhaps >these should be in a separate patch? I don't think this is wise considering the fact that the prototypes of the functions change. Separating this into two patches will leave the state of the tree broken between the two patches which is bad for git-bisect. In addition, considering the small size and compactness of the patch, I don't think it's worth the effort. >Quoth Ali Polatel on Oct 03 at 7:49 pm: >> Previously, the functions notmuch_database_find_message() and >> notmuch_database_find_message_by_filename() functions did not properly >> report error condition to the library user. >> >> For more information, read the thread on the notmuch mailing list >> starting with my mail "id:871uv2unfd.fsf@gmail.com" >> >> Make these functions accept a pointer to 'notmuch_message_t' as argument >> and return notmuch_status_t which may be used to check for any error >> condition. >> >> restore: Modify for the new notmuch_database_find_message() >> new: Modify for the new notmuch_database_find_message_by_filename() >> --- >> lib/database.cc | 90 ++++++++++++++++++++++++++++++++++------------= ------ >> lib/message.cc | 6 ++-- >> lib/notmuch.h | 61 +++++++++++++++++++++++++---------- >> notmuch-new.c | 4 ++- >> notmuch-restore.c | 11 ++++-- >> 5 files changed, 115 insertions(+), 57 deletions(-) >> >> diff --git a/lib/database.cc b/lib/database.cc >> index 9299c8d..1705232 100644 >> --- a/lib/database.cc >> +++ b/lib/database.cc >> @@ -360,13 +360,17 @@ _message_id_compressed (void *ctx, const char *mes= sage_id) >> return compressed; >> } >> >> -notmuch_message_t * >> +notmuch_status_t >> notmuch_database_find_message (notmuch_database_t *notmuch, >> - const char *message_id) >> + const char *message_id, >> + notmuch_message_t **message) > >Perhaps this should be message_ret to clearly distinguish it as an >out-argument? This crossed my mind while working on the initial patch but I guess I was just being lazy. Fixed. >> { >> notmuch_private_status_t status; >> unsigned int doc_id; >> >> + if (message =3D=3D NULL) >> + return NOTMUCH_STATUS_NULL_POINTER; >> + >> if (strlen (message_id) > NOTMUCH_MESSAGE_ID_MAX) >> message_id =3D _message_id_compressed (notmuch, message_id); >> >> @@ -375,14 +379,21 @@ notmuch_database_find_message (notmuch_database_t = *notmuch, >> message_id, &doc_id); >> >> if (status =3D=3D NOTMUCH_PRIVATE_STATUS_NO_DOCUMENT_FOUND) >> - return NULL; >> + *message =3D NULL; >> + else { >> + *message =3D _notmuch_message_create (notmuch, notmuch, doc_id, >> + NULL); >> + if (*message =3D=3D NULL) >> + return NOTMUCH_STATUS_OUT_OF_MEMORY; >> + } >> >> - return _notmuch_message_create (notmuch, notmuch, doc_id, NULL); >> + return NOTMUCH_STATUS_SUCCESS; >> } catch (const Xapian::Error &error) { >> fprintf (stderr, "A Xapian exception occurred finding message: %s.\n", >> error.get_msg().c_str()); >> notmuch->exception_reported =3D TRUE; >> - return NULL; >> + *message =3D NULL; >> + return NOTMUCH_STATUS_XAPIAN_EXCEPTION; >> } >> } >> >> @@ -1311,7 +1322,8 @@ _get_metadata_thread_id_key (void *ctx, const char= *message_id) >> >> /* Find the thread ID to which the message with 'message_id' belongs. >> * >> - * Always returns a newly talloced string belonging to 'ctx'. >> + * Note: 'thread_id' must not be NULL! >> + * On success '*thread_id' is set to a newly talloced string belonging = to 'ctx'. >> * >> * Note: If there is no message in the database with the given >> * 'message_id' then a new thread_id will be allocated for this >> @@ -1319,25 +1331,29 @@ _get_metadata_thread_id_key (void *ctx, const ch= ar *message_id) >> * thread ID can be looked up if the message is added to the database >> * later). >> */ >> -static const char * >> +static notmuch_status_t >> _resolve_message_id_to_thread_id (notmuch_database_t *notmuch, >> void *ctx, >> - const char *message_id) >> + const char *message_id, >> + const char **thread_id) > >thread_id_ret? Same as above, fixed. > >> { >> + notmuch_status_t status; >> notmuch_message_t *message; >> string thread_id_string; >> - const char *thread_id; >> char *metadata_key; >> Xapian::WritableDatabase *db; >> >> - message =3D notmuch_database_find_message (notmuch, message_id); >> + status =3D notmuch_database_find_message (notmuch, message_id, &mes= sage); >> + >> + if (status) >> + return status; >> >> if (message) { >> - thread_id =3D talloc_steal (ctx, notmuch_message_get_thread_id (messag= e)); >> + *thread_id =3D talloc_steal (ctx, notmuch_message_get_thread_id (messa= ge)); >> >> notmuch_message_destroy (message); >> >> - return thread_id; >> + return NOTMUCH_STATUS_SUCCESS; >> } >> >> /* Message has not been seen yet. >> @@ -1351,15 +1367,15 @@ _resolve_message_id_to_thread_id (notmuch_databa= se_t *notmuch, >> thread_id_string =3D notmuch->xapian_db->get_metadata (metadata_key= ); >> >> if (thread_id_string.empty()) { >> - thread_id =3D _notmuch_database_generate_thread_id (notmuch); >> - db->set_metadata (metadata_key, thread_id); >> + *thread_id =3D talloc_strdup (ctx, _notmuch_database_generate_thread_i= d (notmuch)); >> + db->set_metadata (metadata_key, *thread_id); >> } else { >> - thread_id =3D thread_id_string.c_str(); >> + *thread_id =3D talloc_strdup(ctx, thread_id_string.c_str()); > >Missing space after talloc_strdup. Oops, fixed. >> } >> >> talloc_free (metadata_key); >> >> - return talloc_strdup (ctx, thread_id); >> + return NOTMUCH_STATUS_SUCCESS; >> } >> >> static notmuch_status_t >> @@ -1446,9 +1462,12 @@ _notmuch_database_link_message_to_parents (notmuc= h_database_t *notmuch, >> _notmuch_message_add_term (message, "reference", >> parent_message_id); >> >> - parent_thread_id =3D _resolve_message_id_to_thread_id (notmuch, >> - message, >> - parent_message_id); >> + ret =3D _resolve_message_id_to_thread_id (notmuch, >> + message, >> + parent_message_id, >> + &parent_thread_id); >> + if (ret) >> + goto DONE; >> >> if (*thread_id =3D=3D NULL) { >> *thread_id =3D talloc_strdup (message, parent_thread_id); >> @@ -1759,11 +1778,12 @@ notmuch_status_t >> notmuch_database_remove_message (notmuch_database_t *notmuch, >> const char *filename) >> { >> - notmuch_message_t *message =3D >> - notmuch_database_find_message_by_filename (notmuch, filename); >> - notmuch_status_t status =3D NOTMUCH_STATUS_SUCCESS; >> + notmuch_status_t status; >> + notmuch_message_t *message; >> >> - if (message) { >> + status =3D notmuch_database_find_message_by_filename (notmuch, file= name, &message); >> + >> + if (status =3D=3D NOTMUCH_STATUS_SUCCESS && message) { >> status =3D _notmuch_message_remove_filename (message, filename); >> if (status =3D=3D NOTMUCH_STATUS_SUCCESS) >> _notmuch_message_delete (message); > >This isn't a problem with your patch, but shouldn't this function be >notmuch_message_destroy'ing message? > Exactly! I will provide a separate patch for this. >> @@ -1774,24 +1794,27 @@ notmuch_database_remove_message (notmuch_databas= e_t *notmuch, >> return status; >> } >> >> -notmuch_message_t * >> +notmuch_status_t >> notmuch_database_find_message_by_filename (notmuch_database_t *notmuch, >> - const char *filename) >> + const char *filename, >> + notmuch_message_t **message) > >message_ret? Same as above, fixed. >> { >> void *local; >> const char *prefix =3D _find_prefix ("file-direntry"); >> char *direntry, *term; >> Xapian::PostingIterator i, end; >> - notmuch_message_t *message =3D NULL; >> notmuch_status_t status; >> >> + if (message =3D=3D NULL) >> + return NOTMUCH_STATUS_NULL_POINTER; >> + >> local =3D talloc_new (notmuch); >> >> try { >> status =3D _notmuch_database_filename_to_direntry (local, notmuch, >> filename, &direntry); >> if (status) >> - return NULL; >> + goto DONE; >> >> term =3D talloc_asprintf (local, "%s%s", prefix, direntry); >> >> @@ -1800,19 +1823,24 @@ notmuch_database_find_message_by_filename (notmu= ch_database_t *notmuch, >> if (i !=3D end) { >> notmuch_private_status_t private_status; >> >> - message =3D _notmuch_message_create (notmuch, notmuch, >> - *i, &private_status); >> + *message =3D _notmuch_message_create (notmuch, notmuch, >> + *i, &private_status); >> + if (*message =3D=3D NULL) >> + status =3D NOTMUCH_STATUS_OUT_OF_MEMORY; >> } >> } catch (const Xapian::Error &error) { >> fprintf (stderr, "Error: A Xapian exception occurred finding message b= y filename: %s\n", >> error.get_msg().c_str()); >> notmuch->exception_reported =3D TRUE; >> - message =3D NULL; >> + status =3D NOTMUCH_STATUS_OUT_OF_MEMORY; >> } >> >> + DONE: >> talloc_free (local); >> >> - return message; >> + if (status) >> + *message =3D NULL; >> + return status; >> } >> >> notmuch_string_list_t * >> diff --git a/lib/message.cc b/lib/message.cc >> index 531d304..2a85744 100644 >> --- a/lib/message.cc >> +++ b/lib/message.cc >> @@ -216,11 +216,11 @@ _notmuch_message_create_for_message_id (notmuch_da= tabase_t *notmuch, >> unsigned int doc_id; >> char *term; >> >> - *status_ret =3D NOTMUCH_PRIVATE_STATUS_SUCCESS; >> - >> - message =3D notmuch_database_find_message (notmuch, message_id); >> + *status_ret =3D (notmuch_private_status_t) notmuch_database_find_me= ssage (notmuch, message_id, &message); > >Long line, should probably be wrapped. Done: (notmuch_private_status_t) notmuch_database_find_message looks like a single entity to my brain which makes wrapping rather pointless though... >> if (message) >> return talloc_steal (notmuch, message); >> + else if (*status_ret) >> + return NULL; >> >> term =3D talloc_asprintf (NULL, "%s%s", >> _find_prefix ("id"), message_id); >> diff --git a/lib/notmuch.h b/lib/notmuch.h >> index 6d7a99f..08b4ce2 100644 >> --- a/lib/notmuch.h >> +++ b/lib/notmuch.h >> @@ -347,35 +347,60 @@ notmuch_database_remove_message (notmuch_database_= t *database, >> >> /* Find a message with the given message_id. >> * >> - * If the database contains a message with the given message_id, then >> - * a new notmuch_message_t object is returned. The caller should call >> - * notmuch_message_destroy when done with the message. >> + * If message with the given message_id is found then, on successful re= turn > >"If a message" > >> + * (NOTMUCH_STATUS_SUCCESS) '*message' will be initialized to a message= object. >> + * The user should call notmuch_message_destroy when done with the mess= age. > >Probably s/user/caller/, since "the user" is the person sitting at the >keyboard. (notmuch.h isn't very good about this, but it does use >"caller" more often than "user"). As you wish sir, I can't say I care much about the wording. >> - * This function returns NULL in the following situations: >> + * On any failure or when the message is not found, this function initi= alizes >> + * '*message' to NULL. This means, when NOTMUCH_STATUS_SUCCESS is retur= ned, the >> + * user is supposed to check '*message' for NULL to find out whether the >> + * message with the given message_id was found. >> * >> - * * No message is found with the given message_id >> - * * An out-of-memory situation occurs >> - * * A Xapian exception occurs >> + * Note: The argument 'message' must not be NULL! > >Since it's clearly specified what happens if 'message' is NULL, this >note isn't necessary. Fair enough, removed. >> + * >> + * Return value: >> + * >> + * NOTMUCH_STATUS_SUCCESS: Successful return, check '*message'. >> + * >> + * NOTMUCH_STATUS_NULL_POINTER: The given 'message' argument is NULL >> + * >> + * NOTMUCH_STATUS_OUT_OF_MEMORY: Out of memory, creating message object >> + * >> + * NOTMUCH_STATUS_XAPIAN_EXCEPTION: A Xapian exception occurred >> */ >> -notmuch_message_t * >> +notmuch_status_t >> notmuch_database_find_message (notmuch_database_t *database, >> - const char *message_id); >> + const char *message_id, >> + notmuch_message_t **message); >> >> /* Find a message with the given filename. >> * >> - * If the database contains a message with the given filename, then a >> - * new notmuch_message_t object is returned. The caller should call >> - * notmuch_message_destroy when done with the message. >> + * If the database contains a message with the given filename then, on >> + * successful return (NOTMUCH_STATUS_SUCCESS) '*message' will be initia= lized to >> + * a message object. The user should call notmuch_message_destroy when = done >> + * with the message. > >Same comment about "user" as above. Same as above, fixed. >> * >> - * This function returns NULL in the following situations: >> + * On any failure or when the message is not found, this function initi= alizes >> + * '*message' to NULL. This means, when NOTMUCH_STATUS_SUCCESS is retur= ned, the >> + * user is supposed to check '*message' for NULL to find out whether the >> + * message with the given filename is found. >> * >> - * * No message is found with the given filename >> - * * An out-of-memory situation occurs >> - * * A Xapian exception occurs >> + * Note: The argument 'message' must not be NULL! > >Same comment about this note as above. Same as above, removed. >> + * >> + * Return value: >> + * >> + * NOTMUCH_STATUS_SUCCESS: Successful return, check '*message' >> + * >> + * NOTMUCH_STATUS_NULL_POINTER: The given 'message' argument is NULL >> + * >> + * NOTMUCH_STATUS_OUT_OF_MEMORY: Out of memory, creating the message ob= ject >> + * >> + * NOTMUCH_STATUS_XAPIAN_EXCEPTION: A Xapian exception occurred >> */ >> -notmuch_message_t * >> +notmuch_status_t >> notmuch_database_find_message_by_filename (notmuch_database_t *notmuch, >> - const char *filename); >> + const char *filename, >> + notmuch_message_t **message); >> >> /* Return a list of all tags found in the database. >> * >> diff --git a/notmuch-new.c b/notmuch-new.c >> index e79593c..96a1e31 100644 >> --- a/notmuch-new.c >> +++ b/notmuch-new.c >> @@ -743,7 +743,9 @@ remove_filename (notmuch_database_t *notmuch, >> status =3D notmuch_database_begin_atomic (notmuch); >> if (status) >> return status; >> - message =3D notmuch_database_find_message_by_filename (notmuch, pat= h); >> + status =3D notmuch_database_find_message_by_filename (notmuch, path= , &message); >> + if (status || message =3D=3D NULL) >> + return status; >> status =3D notmuch_database_remove_message (notmuch, path); >> if (status =3D=3D NOTMUCH_STATUS_DUPLICATE_MESSAGE_ID) { >> add_files_state->renamed_messages++; >> diff --git a/notmuch-restore.c b/notmuch-restore.c >> index f095f64..e4a5355 100644 >> --- a/notmuch-restore.c >> +++ b/notmuch-restore.c >> @@ -87,10 +87,13 @@ notmuch_restore_command (unused (void *ctx), int arg= c, char *argv[]) >> file_tags =3D xstrndup (line + match[2].rm_so, >> match[2].rm_eo - match[2].rm_so); >> >> - message =3D notmuch_database_find_message (notmuch, message_id); >> - if (message =3D=3D NULL) { >> - fprintf (stderr, "Warning: Cannot apply tags to missing message: %= s\n", >> - message_id); >> + status =3D notmuch_database_find_message (notmuch, message_id, &messag= e); >> + if (status || message =3D=3D NULL) { >> + fprintf (stderr, "Warning: Cannot apply tags to %smessage: %s\n", >> + message ? "" : "missing ", message_id); >> + if (status) >> + fprintf (stderr, "%s\n", >> + notmuch_status_to_string(status)); >> goto NEXT_LINE; >> } >> > >--=20 >Austin Clements MIT/'06/PhD/CSAIL >amdragon@mit.edu http://web.mit.edu/amdragon > Somewhere in the dream we call reality you will find me, > searching for the reality we call dreams. -alip --vtzGhvizbBRQ85DL Content-Type: application/pgp-signature -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.18 (GNU/Linux) iEYEARECAAYFAk6KHU0ACgkQQU4yORhF8iCNIQCfQQg6e7HbK610+S3PGqGQ8ogo rGYAnAwNteoHO4PvdqXlhgI5dTr1DlGU =RXG7 -----END PGP SIGNATURE----- --vtzGhvizbBRQ85DL--