NeoMutt  2025-12-11-911-gd8d604
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches
module.c File Reference

Definition of the Mutt Module. More...

#include "config.h"
#include <stdbool.h>
#include <stddef.h>
#include "core/lib.h"
#include "memory.h"
#include "module_data.h"
#include "notify.h"
#include "signal2.h"
+ Include dependency graph for module.c:

Go to the source code of this file.

Functions

static bool mutt_init (struct NeoMutt *n)
 Initialise a Module - Implements Module::init()
 
static bool mutt_cleanup (struct NeoMutt *n, void *data)
 Clean up a Module - Implements Module::cleanup()
 

Variables

const struct Module ModuleMutt
 Module for the Mutt library.
 

Detailed Description

Definition of the Mutt Module.

Authors
  • Richard Russon

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.

Definition in file module.c.

Function Documentation

◆ mutt_init()

static bool mutt_init ( struct NeoMutt * n)
static

Initialise a Module - Implements Module::init()

Definition at line 41 of file module.c.

42{
43 struct MuttModuleData *mod_data = MUTT_MEM_CALLOC(1, struct MuttModuleData);
45
46 mod_data->notify = notify_new();
47 notify_set_parent(mod_data->notify, n->notify);
48
49 return true;
50}
#define MUTT_MEM_CALLOC(n, type)
Definition memory.h:52
@ MODULE_ID_MUTT
ModuleMutt, Mutt
Definition module_api.h:79
struct Notify * notify_new(void)
Create a new notifications handler.
Definition notify.c:62
void notify_set_parent(struct Notify *notify, struct Notify *parent)
Set the parent notification handler.
Definition notify.c:95
void neomutt_set_module_data(struct NeoMutt *n, enum ModuleId id, void *data)
Set the private data for a Module.
Definition neomutt.c:677
Mutt private Module data.
Definition module_data.h:30
struct Notify * notify
Notifications.
Definition module_data.h:31
struct Notify * notify
Notifications handler.
Definition neomutt.h:45
+ Here is the call graph for this function:

◆ mutt_cleanup()

static bool mutt_cleanup ( struct NeoMutt * n,
void * data )
static

Clean up a Module - Implements Module::cleanup()

Definition at line 55 of file module.c.

56{
57 struct MuttModuleData *mod_data = data;
58
59 notify_free(&mod_data->notify);
60
61 FREE(&mod_data);
62 return true;
63}
#define FREE(x)
Free memory and set the pointer to NULL.
Definition memory.h:68
void notify_free(struct Notify **ptr)
Free a notification handler.
Definition notify.c:75
+ Here is the call graph for this function:

Variable Documentation

◆ ModuleMutt

const struct Module ModuleMutt
Initial value:
= {
NULL,
NULL,
NULL,
NULL,
NULL,
}
static int mutt_init(struct ConfigSet *cs, struct Buffer *dlevel, struct Buffer *dfile, bool skip_sys_rc, struct StringArray *user_files, struct StringArray *commands)
Initialise NeoMutt.
Definition main.c:421
static bool mutt_cleanup(struct NeoMutt *n, void *data)
Clean up a Module - Implements Module::cleanup()
Definition module.c:55

Module for the Mutt library.

Definition at line 68 of file module.c.

68 {
70 NULL, // config_define_types
71 NULL, // config_define_variables
72 NULL, // commands_register
73 NULL, // gui_init
74 NULL, // gui_cleanup
76};