Skip to content
Toggle navigation
Toggle navigation
This project
Loading...
Sign in
John McEleney
/
mailutils
Go to a project
Toggle navigation
Toggle navigation pinning
Projects
Groups
Snippets
Help
Project
Activity
Repository
Pipelines
Graphs
Issues
0
Merge Requests
0
Wiki
Network
Create a new issue
Builds
Commits
Issue Boards
Files
Commits
Network
Compare
Branches
Tags
Commit
09491f73
...
09491f73ad89cacacdaab4946aeccd928ecf3cc1
authored
2002-09-18 17:40:26 +0000
by
Sergey Poznyakoff
Browse Files
Options
Browse Files
Tag
Download
Email Patches
Plain Diff
Use new mh framework
1 parent
860c98e6
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
13 additions
and
78 deletions
mh/rmm.c
mh/scan.c
mh/rmm.c
View file @
09491f7
...
...
@@ -21,7 +21,7 @@
const
char
*
argp_program_version
=
"rmm ("
PACKAGE_STRING
")"
;
static
char
doc
[]
=
"GNU MH rmm"
;
static
char
args_doc
[]
=
""
;
static
char
args_doc
[]
=
"
[messages]
"
;
/* GNU options */
static
struct
argp_option
options
[]
=
{
...
...
@@ -45,56 +45,19 @@ opt_handler (int key, char *arg, void *unused)
case
'f'
:
current_folder
=
arg
;
break
;
default:
return
1
;
}
return
0
;
}
int
member
(
size_t
num
,
size_t
*
msglist
,
size_t
msgcnt
)
void
rmm
(
mailbox_t
mbox
,
message_t
msg
,
size_t
num
,
void
*
data
)
{
size_t
i
;
for
(
i
=
0
;
i
<
msgcnt
;
i
++
)
if
(
msglist
[
i
]
==
num
)
return
1
;
return
0
;
}
int
rmm
(
mailbox_t
mbox
,
size_t
msgcnt
,
size_t
*
msglist
)
{
size_t
i
,
total
=
0
;
mailbox_messages_count
(
mbox
,
&
total
);
for
(
i
=
1
;
i
<=
total
;
i
++
)
{
message_t
msg
;
size_t
num
;
int
rc
;
if
((
rc
=
mailbox_get_message
(
mbox
,
i
,
&
msg
))
!=
0
)
{
mh_error
(
"can't get message %d: %s"
,
i
,
mu_errstring
(
rc
));
return
1
;
}
if
((
rc
=
mh_message_number
(
msg
,
&
num
))
!=
0
)
{
mh_error
(
"can't get sequence number for message %d: %s"
,
i
,
mu_errstring
(
rc
));
return
1
;
}
if
(
member
(
num
,
msglist
,
msgcnt
))
{
attribute_t
attr
;
message_get_attribute
(
msg
,
&
attr
);
attribute_set_deleted
(
attr
);
}
}
attribute_t
attr
;
message_get_attribute
(
msg
,
&
attr
);
attribute_set_deleted
(
attr
);
return
0
;
}
...
...
@@ -103,45 +66,17 @@ main (int argc, char **argv)
{
int
index
=
0
;
mailbox_t
mbox
;
size_t
msgcnt
=
0
,
*
msglist
=
NULL
;
mh_msgset_t
msgset
;
int
status
;
mh_argp_parse
(
argc
,
argv
,
options
,
mh_option
,
args_doc
,
doc
,
opt_handler
,
NULL
,
&
index
);
mbox
=
mh_open_folder
();
if
(
index
<
argc
)
{
size_t
i
;
msgcnt
=
argc
-
index
+
1
;
msglist
=
calloc
(
argc
-
index
+
1
,
sizeof
(
*
msglist
));
for
(
i
=
0
;
index
<
argc
;
index
++
,
i
++
)
{
char
*
p
=
NULL
;
msglist
[
i
]
=
strtol
(
argv
[
index
],
&
p
,
0
);
if
(
msglist
[
i
]
<=
0
||
*
p
)
{
mh_error
(
"bad message list `%s'"
,
argv
[
index
]);
exit
(
1
);
}
}
}
else
{
if
(
current_message
==
0
)
{
mh_error
(
"no cur message"
);
exit
(
1
);
}
msglist
=
calloc
(
1
,
sizeof
(
*
msglist
));
msglist
[
0
]
=
current_message
;
current_message
=
0
;
msgcnt
=
1
;
}
mbox
=
mh_open_folder
(
current_folder
);
mh_msgset_parse
(
mbox
,
&
msgset
,
argc
-
index
,
argv
+
index
);
status
=
rmm
(
mbox
,
msgcnt
,
msglist
);
status
=
mh_iterate
(
mbox
,
&
msgset
,
rmm
,
NULL
);
mailbox_expunge
(
mbox
);
mailbox_close
(
mbox
);
...
...
mh/scan.c
View file @
09491f7
...
...
@@ -137,7 +137,7 @@ main (int argc, char **argv)
exit
(
1
);
}
return
scan
(
mh_open_folder
());
return
scan
(
mh_open_folder
(
current_folder
));
}
#ifdef HAVE_TERMCAP_H
...
...
Please
register
or
sign in
to post a comment