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

Definition of the Mh Module. More...

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

Go to the source code of this file.

Functions

static bool mh_init (struct NeoMutt *n)
 Initialise a Module - Implements Module::init()
 
static bool mh_config_define_variables (struct NeoMutt *n, struct ConfigSet *cs)
 Define the Config Variables - Implements Module::config_define_variables()
 
static bool mh_cleanup (struct NeoMutt *n, void *data)
 Clean up a Module - Implements Module::cleanup()
 

Variables

struct ConfigDef MhVars []
 Config definitions for the Mh library.
 
const struct Module ModuleMh
 Module for the Mh library.
 

Detailed Description

Definition of the Mh 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

◆ mh_init()

static bool mh_init ( struct NeoMutt * n)
static

Initialise a Module - Implements Module::init()

Definition at line 42 of file module.c.

43{
44 struct MhModuleData *mod_data = MUTT_MEM_CALLOC(1, struct MhModuleData);
46
47 mod_data->notify = notify_new();
48 notify_set_parent(mod_data->notify, n->notify);
49
50 return true;
51}
#define MUTT_MEM_CALLOC(n, type)
Definition memory.h:52
@ MODULE_ID_MH
ModuleMh, Mh Mailbox
Definition module_api.h:78
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
Mh 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:

◆ mh_config_define_variables()

static bool mh_config_define_variables ( struct NeoMutt * n,
struct ConfigSet * cs )
static

Define the Config Variables - Implements Module::config_define_variables()

Definition at line 56 of file module.c.

57{
58 return cs_register_variables(cs, MhVars);
59}
bool cs_register_variables(const struct ConfigSet *cs, struct ConfigDef vars[])
Register a set of config items.
Definition set.c:290
struct ConfigDef MhVars[]
Config definitions for the Mh library.
Definition config.c:37
+ Here is the call graph for this function:

◆ mh_cleanup()

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

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

Definition at line 64 of file module.c.

65{
66 struct MhModuleData *mod_data = data;
67
68 notify_free(&mod_data->notify);
69
70 FREE(&mod_data);
71 return true;
72}
#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

◆ MhVars

struct ConfigDef MhVars[]
extern

Config definitions for the Mh library.

Definition at line 37 of file config.c.

37 {
38 // clang-format off
39 { "mh_purge", DT_BOOL, false, 0, NULL,
40 "Really delete files in MH mailboxes"
41 },
42 { "mh_seq_flagged", DT_STRING, IP "flagged", 0, NULL,
43 "MH sequence for flagged message"
44 },
45 { "mh_seq_replied", DT_STRING, IP "replied", 0, NULL,
46 "MH sequence to tag replied messages"
47 },
48 { "mh_seq_unseen", DT_STRING, IP "unseen", 0, NULL,
49 "MH sequence for unseen messages"
50 },
51 { NULL },
52 // clang-format on
53};
#define IP
Definition set.h:55
@ DT_BOOL
boolean option
Definition types.h:32
@ DT_STRING
a string
Definition types.h:44

◆ ModuleMh

const struct Module ModuleMh
Initial value:
= {
"mh",
NULL,
NULL,
NULL,
NULL,
}
static bool mh_config_define_variables(struct NeoMutt *n, struct ConfigSet *cs)
Define the Config Variables - Implements Module::config_define_variables()
Definition module.c:56
static bool mh_cleanup(struct NeoMutt *n, void *data)
Clean up a Module - Implements Module::cleanup()
Definition module.c:64
static bool mh_init(struct NeoMutt *n)
Initialise a Module - Implements Module::init()
Definition module.c:42

Module for the Mh library.

Definition at line 77 of file module.c.

77 {
79 "mh",
80 mh_init,
81 NULL, // config_define_types
83 NULL, // commands_register
84 NULL, // gui_init
85 NULL, // gui_cleanup
87};