hdr: use -HEADER to only display the header, else print all headers

pull/1/merge
Christian Neukirchen 8 years ago
parent 54f695dddf
commit 8b8f391052

54
hdr.c

@ -30,21 +30,51 @@ header(char *file)
printf("%s\n", v); printf("%s\n", v);
} }
static void
printhdr(char *hdr)
{
int uc = 1;
while (*hdr && *hdr != ':') {
putc(uc ? toupper(*hdr) : *hdr, stdout);
uc = (*hdr == '-');
hdr++;
}
fputs(hdr, stdout);
fputc('\n', stdout);
}
void
headerall(char *file)
{
struct message *msg;
msg = blaze822(file);
if (!msg)
return;
char *h = 0;
while (h = blaze822_next_header(msg, h))
printhdr(h);
}
int int
main(int argc, char *argv[]) main(int argc, char *argv[])
{ {
l = strlen(argv[1])+2; if (argv[1] && argv[1][0] == '-') {
hdr = malloc(l); l = strlen(argv[1])+1;
hdr[0] = 0; hdr = malloc(l);
char *s = hdr+1; hdr[0] = 0;
char *t = argv[1]; char *s = hdr+1;
while (*t) char *t = argv[1]+1;
*s++ = tolower(*t++); while (*t)
*s = ':'; *s++ = tolower(*t++);
*s = ':';
int i = blaze822_loop(argc-2, argv+2, header);
blaze822_loop(argc-2, argv+2, header);
printf("%d mails scanned\n", i); } else {
blaze822_loop(argc-1, argv+1, headerall);
}
return 0; return 0;
} }

Loading…
Cancel
Save