[RFC Patch 2/2] lib: Let Xapian manage the memory for FieldProcessors

Jani Nikula jani at nikula.org
Sun Jan 29 02:46:41 PST 2017


On Sat, 28 Jan 2017, David Bremner <david at tethera.net> wrote:
> It turns out this is exactly what release() is for; Xapian will
> deallocate the objects when it's done with them.

release() fares 2 on Rusty scale [1][2]... after digging through source,
LGTM.

BR,
Jani.

[1] http://ozlabs.org/~rusty/index.cgi/tech/2008-03-30.html
[2] http://ozlabs.org/~rusty/index.cgi/tech/2008-04-01.html

> ---
>  lib/database-private.h |  4 ----
>  lib/database.cc        | 19 ++++++++-----------
>  2 files changed, 8 insertions(+), 15 deletions(-)
>
> diff --git a/lib/database-private.h b/lib/database-private.h
> index 32357ce0..3eac3c7e 100644
> --- a/lib/database-private.h
> +++ b/lib/database-private.h
> @@ -194,10 +194,6 @@ struct _notmuch_database {
>      Xapian::TermGenerator *term_gen;
>      Xapian::ValueRangeProcessor *value_range_processor;
>      Xapian::ValueRangeProcessor *date_range_processor;
> -#if HAVE_XAPIAN_FIELD_PROCESSOR
> -    Xapian::FieldProcessor *date_field_processor;
> -    Xapian::FieldProcessor *query_field_processor;
> -#endif
>      Xapian::ValueRangeProcessor *last_mod_range_processor;
>  };
>  
> diff --git a/lib/database.cc b/lib/database.cc
> index b98468a6..c1563ca7 100644
> --- a/lib/database.cc
> +++ b/lib/database.cc
> @@ -1029,10 +1029,14 @@ notmuch_database_open_verbose (const char *path,
>  #if HAVE_XAPIAN_FIELD_PROCESSOR
>  	/* This currently relies on the query parser to pass anything
>  	 * with a .. to the range processor */
> -	notmuch->date_field_processor = new DateFieldProcessor();
> -	notmuch->query_parser->add_boolean_prefix("date", notmuch->date_field_processor);
> -	notmuch->query_field_processor = new QueryFieldProcessor (*notmuch->query_parser, notmuch);
> -	notmuch->query_parser->add_boolean_prefix("query", notmuch->query_field_processor);
> +	{
> +	    Xapian::FieldProcessor * date_fp = new DateFieldProcessor();
> +	    Xapian::FieldProcessor * query_fp =
> +		new QueryFieldProcessor (*notmuch->query_parser, notmuch);
> +
> +	    notmuch->query_parser->add_boolean_prefix("date", date_fp->release ());
> +	    notmuch->query_parser->add_boolean_prefix("query", query_fp->release ());
> +	}
>  #endif
>  	notmuch->last_mod_range_processor = new Xapian::NumberValueRangeProcessor (NOTMUCH_VALUE_LAST_MOD, "lastmod:");
>  
> @@ -1125,13 +1129,6 @@ notmuch_database_close (notmuch_database_t *notmuch)
>      delete notmuch->last_mod_range_processor;
>      notmuch->last_mod_range_processor = NULL;
>  
> -#if HAVE_XAPIAN_FIELD_PROCESSOR
> -    delete notmuch->date_field_processor;
> -    notmuch->date_field_processor = NULL;
> -    delete notmuch->query_field_processor;
> -    notmuch->query_field_processor = NULL;
> -#endif
> -
>      return status;
>  }
>  
> -- 
> 2.11.0
>
> _______________________________________________
> notmuch mailing list
> notmuch at notmuchmail.org
> https://notmuchmail.org/mailman/listinfo/notmuch


More information about the notmuch mailing list