NeoMutt  2020-11-20
Teaching an old dog new tricks
Go to the documentation of this file.
29 #include "config.h"
30 #include <stddef.h>
31 #include "mutt/lib.h"
32 #include "config/lib.h"
33 #include "core/neomutt.h"
34 #include "account.h"
35 #include "mailbox.h"
43 struct Account *account_new(const char *name, struct ConfigSubset *sub)
44 {
45  if (!sub)
46  return NULL;
48  struct Account *a = mutt_mem_calloc(1, sizeof(struct Account));
51  a->notify = notify_new();
52  a->name = mutt_str_dup(name);
53  a->sub = cs_subset_new(name, sub, a->notify);
54  a->sub->cs = sub->cs;
57  return a;
58 }
66 bool account_mailbox_add(struct Account *a, struct Mailbox *m)
67 {
68  if (!a || !m)
69  return false;
71  if (a->type == MUTT_UNKNOWN)
72  a->type = m->type;
74  m->account = a;
75  struct MailboxNode *np = mutt_mem_calloc(1, sizeof(*np));
76  np->mailbox = m;
77  STAILQ_INSERT_TAIL(&a->mailboxes, np, entries);
78  mailbox_set_subset(m, a->sub);
81  struct EventMailbox ev_m = { m };
83  return true;
84 }
94 bool account_mailbox_remove(struct Account *a, struct Mailbox *m)
95 {
96  if (!a)
97  return false;
99  bool result = false;
100  struct MailboxNode *np = NULL;
101  struct MailboxNode *tmp = NULL;
102  STAILQ_FOREACH_SAFE(np, &a->mailboxes, entries, tmp)
103  {
104  if (!m || (np->mailbox == m))
105  {
106  struct EventMailbox ev_m = { m };
108  STAILQ_REMOVE(&a->mailboxes, np, MailboxNode, entries);
109  if (!m)
110  mailbox_free(&np->mailbox);
111  FREE(&np);
112  result = true;
113  if (m)
114  break;
115  }
116  }
118  return result;
119 }
125 void account_free(struct Account **ptr)
126 {
127  if (!ptr || !*ptr)
128  return;
130  struct Account *a = *ptr;
132  if (a->adata_free)
133  a->adata_free(&a->adata);
135  account_mailbox_remove(a, NULL);
136  cs_subset_free(&a->sub);
137  FREE(&a->name);
138  notify_free(&a->notify);
140  FREE(ptr);
141 }
enum MailboxType type
Mailbox type.
Definition: mailbox.h:105
void * mutt_mem_calloc(size_t nmemb, size_t size)
Allocate zeroed memory on the heap.
Definition: memory.c:50
#define STAILQ_REMOVE(head, elm, type, field)
Definition: queue.h:399
char * name
Name of Account.
Definition: account.h:39
void notify_free(struct Notify **ptr)
Free a notification handler.
Definition: notify.c:62
struct Notify * notify
Notifications handler.
Definition: account.h:42
struct MailboxList mailboxes
List of Mailboxes.
Definition: account.h:41
A group of associated Mailboxes.
Definition: account.h:36
char * mutt_str_dup(const char *str)
Copy a string, safely.
Definition: string.c:370
Mailbox wasn&#39;t recognised.
Definition: mailbox.h:47
#define STAILQ_INSERT_TAIL(head, elm, field)
Definition: queue.h:386
void cs_subset_free(struct ConfigSubset **ptr)
Free a Config Subset.
Definition: subset.c:93
enum MailboxType type
Type of Mailboxes this Account contains.
Definition: account.h:38
An Event that happened to a Mailbox.
Definition: mailbox.h:183
Convenience wrapper for the config headers.
struct ConfigSet * cs
Parent ConfigSet.
Definition: subset.h:51
A new Mailbox has been created.
Definition: mailbox.h:166
void mailbox_free(struct Mailbox **ptr)
Free a Mailbox.
Definition: mailbox.c:63
#define STAILQ_INIT(head)
Definition: queue.h:369
void(* adata_free)(void **ptr)
Free the private data attached to the Account.
Definition: account.h:49
#define STAILQ_FOREACH_SAFE(var, head, field, tvar)
Definition: queue.h:359
void account_free(struct Account **ptr)
Free an Account.
Definition: account.c:125
struct Notify * notify_new(void)
Create a new notifications handler.
Definition: notify.c:49
A set of inherited config items.
Definition: subset.h:46
A mailbox.
Definition: mailbox.h:81
Container for Accounts, Notifications.
void * adata
Private data (for Mailbox backends)
Definition: account.h:43
This Config is Account-specific.
Definition: subset.h:39
A group of associated Mailboxes.
enum ConfigScope scope
Scope of Subset, e.g. SET_SCOPE_ACCOUNT.
Definition: subset.h:49
struct Account * account_new(const char *name, struct ConfigSubset *sub)
Create a new Account.
Definition: account.c:43
struct ConfigSubset * cs_subset_new(const char *name, struct ConfigSubset *sub_parent, struct Notify *not_parent)
Create a new Config Subset.
Definition: subset.c:133
Representation of a mailbox.
struct Account * account
Account that owns this Mailbox.
Definition: mailbox.h:131
bool mailbox_set_subset(struct Mailbox *m, struct ConfigSubset *sub)
Set a Mailbox&#39;s Config Subset.
Definition: mailbox.c:212
A Mailbox is about to be destroyed.
Definition: mailbox.h:167
bool account_mailbox_add(struct Account *a, struct Mailbox *m)
Add a Mailbox to an Account.
Definition: account.c:66
#define FREE(x)
Definition: memory.h:40
bool account_mailbox_remove(struct Account *a, struct Mailbox *m)
Remove a Mailbox from an Account.
Definition: account.c:94
Mailbox has changed, NotifyMailbox, EventMailbox.
Definition: notify_type.h:42
struct ConfigSubset * sub
Inherited config items.
Definition: account.h:40
void notify_set_parent(struct Notify *notify, struct Notify *parent)
Set the parent notification handler.
Definition: notify.c:82
List of Mailboxes.
Definition: mailbox.h:152
struct Notify * notify
Notifications handler.
Definition: mailbox.h:144
Convenience wrapper for the library headers.
struct Mailbox * mailbox
Mailbox in the list.
Definition: mailbox.h:154
bool notify_send(struct Notify *notify, enum NotifyType event_type, int event_subtype, void *event_data)
Send out a notification message.
Definition: notify.c:152