NeoMutt  2024-12-12-14-g7b49f7
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches

Tag some menu items. More...

+ Collaboration diagram for tag():

Functions

static int alias_tag (struct Menu *menu, int sel, int act)
 Tag some aliases - Implements Menu::tag() -.
 
static int query_tag (struct Menu *menu, int sel, int act)
 Tag an entry in the Query Menu - Implements Menu::tag() -.
 
static int attach_tag (struct Menu *menu, int sel, int act)
 Tag an attachment - Implements Menu::tag() -.
 
static int file_tag (struct Menu *menu, int sel, int act)
 Tag an entry in the menu - Implements Menu::tag() -.
 
static int compose_attach_tag (struct Menu *menu, int sel, int act)
 Tag an attachment - Implements Menu::tag() -.
 

Detailed Description

Tag some menu items.

Parameters
menuMenu to tag
selCurrent selection
actAction: 0 untag, 1 tag, -1 toggle
Return values
numNet change in number of tagged attachments

Function Documentation

◆ alias_tag()

static int alias_tag ( struct Menu menu,
int  sel,
int  act 
)
static

Tag some aliases - Implements Menu::tag() -.

Definition at line 139 of file dlg_alias.c.

140{
141 const struct AliasMenuData *mdata = menu->mdata;
142 const struct AliasViewArray *ava = &mdata->ava;
143 struct AliasView *av = ARRAY_GET(ava, sel);
144
145 bool ot = av->is_tagged;
146
147 av->is_tagged = ((act >= 0) ? act : !av->is_tagged);
148
149 return av->is_tagged - ot;
150}
#define ARRAY_GET(head, idx)
Return the element at index.
Definition: array.h:109
AliasView array wrapper with Pattern information -.
Definition: gui.h:54
struct AliasViewArray ava
All Aliases/Queries.
Definition: gui.h:55
struct Menu * menu
Menu.
Definition: gui.h:58
GUI data wrapping an Alias.
Definition: gui.h:38
bool is_tagged
Is it tagged?
Definition: gui.h:43
void * mdata
Private data.
Definition: lib.h:147
+ Here is the caller graph for this function:

◆ query_tag()

static int query_tag ( struct Menu menu,
int  sel,
int  act 
)
static

Tag an entry in the Query Menu - Implements Menu::tag() -.

Definition at line 168 of file dlg_query.c.

169{
170 const struct AliasMenuData *mdata = menu->mdata;
171 const struct AliasViewArray *ava = &mdata->ava;
172 struct AliasView *av = ARRAY_GET(ava, sel);
173
174 bool ot = av->is_tagged;
175
176 av->is_tagged = ((act >= 0) ? act : !av->is_tagged);
177 return av->is_tagged - ot;
178}
+ Here is the caller graph for this function:

◆ attach_tag()

static int attach_tag ( struct Menu menu,
int  sel,
int  act 
)
static

Tag an attachment - Implements Menu::tag() -.

Definition at line 154 of file dlg_attach.c.

155{
156 struct AttachPrivateData *priv = menu->mdata;
157 struct AttachCtx *actx = priv->actx;
158
159 struct Body *cur = actx->idx[actx->v2r[sel]]->body;
160 bool ot = cur->tagged;
161
162 cur->tagged = ((act >= 0) ? act : !cur->tagged);
163 return cur->tagged - ot;
164}
A set of attachments.
Definition: attach.h:63
struct AttachPtr ** idx
Array of attachments.
Definition: attach.h:67
short * v2r
Mapping from virtual to real attachment.
Definition: attach.h:71
Private state data for Attachments.
Definition: private_data.h:36
struct Menu * menu
Current Menu.
Definition: private_data.h:37
struct AttachCtx * actx
List of all Attachments.
Definition: private_data.h:38
struct Body * body
Attachment.
Definition: attach.h:36
The body of an email.
Definition: body.h:36
bool tagged
This attachment is tagged.
Definition: body.h:90
+ Here is the caller graph for this function:

◆ file_tag()

static int file_tag ( struct Menu menu,
int  sel,
int  act 
)
static

Tag an entry in the menu - Implements Menu::tag() -.

Definition at line 690 of file dlg_browser.c.

691{
692 struct BrowserPrivateData *priv = menu->mdata;
693 struct BrowserEntryArray *entry = &priv->state.entry;
694 struct FolderFile *ff = ARRAY_GET(entry, sel);
695 if (S_ISDIR(ff->mode) ||
696 (S_ISLNK(ff->mode) && link_is_dir(buf_string(&LastDir), ff->name)))
697 {
698 mutt_error(_("Can't attach a directory"));
699 return 0;
700 }
701
702 bool ot = ff->tagged;
703 ff->tagged = ((act >= 0) ? act : !ff->tagged);
704
705 return ff->tagged - ot;
706}
static const char * buf_string(const struct Buffer *buf)
Convert a buffer to a const char * "string".
Definition: buffer.h:96
struct Buffer LastDir
Browser: previous selected directory.
Definition: dlg_browser.c:136
bool link_is_dir(const char *folder, const char *path)
Does this symlink point to a directory?
Definition: dlg_browser.c:172
#define mutt_error(...)
Definition: logging2.h:92
#define _(a)
Definition: message.h:28
Private state data for the Browser.
Definition: private_data.h:34
struct Menu * menu
Menu.
Definition: private_data.h:43
struct BrowserState state
State containing list of files/dir/mailboxes.
Definition: private_data.h:42
struct BrowserEntryArray entry
Array of files / dirs / mailboxes.
Definition: lib.h:145
Browser entry representing a folder/dir.
Definition: lib.h:78
char * name
Name of file/dir/mailbox.
Definition: lib.h:86
bool tagged
Folder is tagged.
Definition: lib.h:102
mode_t mode
File permissions.
Definition: lib.h:79
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ compose_attach_tag()

static int compose_attach_tag ( struct Menu menu,
int  sel,
int  act 
)
static

Tag an attachment - Implements Menu::tag() -.

Definition at line 202 of file attach.c.

203{
204 struct ComposeAttachData *adata = menu->mdata;
205 struct AttachCtx *actx = adata->actx;
206 struct Body *cur = actx->idx[actx->v2r[sel]]->body;
207 bool ot = cur->tagged;
208
209 cur->tagged = ((act >= 0) ? act : !cur->tagged);
210 return cur->tagged - ot;
211}
Data to fill the Compose Attach Window.
Definition: attach_data.h:33
struct Menu * menu
Menu displaying the attachments.
Definition: attach_data.h:35
struct AttachCtx * actx
Set of attachments.
Definition: attach_data.h:34
+ Here is the caller graph for this function: