From 5be95ca835d30b31a67d1e7435dcd5dca58ae8ea Mon Sep 17 00:00:00 2001 From: Marco Bettini Date: Tue, 18 Feb 2025 11:39:06 +0000 Subject: [PATCH] fts-flatcurve: fts_flatcurve_mail_user_deinit() - Defer deallocation of fuser->set This is required to prevent premature deallocation that can cause fts_flatcurve_xapian_need_optimize() to crash inside fts_mailbox_list_deinit() in mail_user_unref() --- src/plugins/fts-flatcurve/fts-flatcurve-plugin.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/plugins/fts-flatcurve/fts-flatcurve-plugin.c b/src/plugins/fts-flatcurve/fts-flatcurve-plugin.c index d1f4218419..511d4b44c1 100644 --- a/src/plugins/fts-flatcurve/fts-flatcurve-plugin.c +++ b/src/plugins/fts-flatcurve/fts-flatcurve-plugin.c @@ -20,8 +20,8 @@ static void fts_flatcurve_mail_user_deinit(struct mail_user *user) struct fts_flatcurve_user *fuser = FTS_FLATCURVE_USER_CONTEXT_REQUIRE(user); - settings_free(fuser->set); fuser->module_ctx.super.deinit(user); + settings_free(fuser->set); } int fts_flatcurve_mail_user_get(struct mail_user *user, struct event *event, -- 2.47.3