/* GNU Mailutils -- a suite of utilities for electronic mail
Copyright (C) 2005-2021 Free Software Foundation, Inc.
GNU Mailutils is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3, or (at your option)
any later version.
GNU Mailutils 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 GNU Mailutils. If not, see . */
#ifdef HAVE_CONFIG_H
# include
#endif
#include
#include
#include
#include
static int
enumfun (mu_folder_t folder, struct mu_list_response *resp, void *data)
{
printf ("%c%c %c %4d %s\n",
(resp->type & MU_FOLDER_ATTRIBUTE_DIRECTORY) ? 'd' : '-',
(resp->type & MU_FOLDER_ATTRIBUTE_FILE) ? 'f' : '-',
resp->separator,
resp->depth,
resp->name);
return 0;
}
int
ls_folders (char *fname, char *ref, char *pattern, int level)
{
int status;
mu_folder_t folder;
mu_list_t flist;
size_t count;
status = mu_folder_create (&folder, fname);
if (status)
{
mu_error ("mu_folder_create failed: %s", mu_strerror (status));
return 1;
}
status = mu_folder_open (folder, MU_STREAM_READ);
if (status)
{
mu_error ("mu_folder_create failed: %s", mu_strerror (status));
return 1;
}
status = mu_folder_enumerate (folder, ref, pattern, 0, level, &flist,
enumfun, NULL);
switch (status)
{
case 0:
mu_list_count (flist, &count);
printf ("Number of folders: %lu\n", (unsigned long) count);
mu_list_destroy (&flist);
break;
case MU_ERR_NOENT:
printf ("No folders matching %s %s in %s\n", ref, pattern, fname);
return 0;
default:
mu_error ("mu_folder_list failed: %s", mu_strerror (status));
}
return 0;
}
int
main (int argc, char *argv[])
{
char *folder;
char *ref = NULL;
char *pattern = "*";
int level = 0;
switch (argc)
{
case 5:
level = atoi (argv[4]);
case 4:
pattern = argv[3];
case 3:
ref = argv[2];
case 2:
folder = argv[1];
break;
default:
mu_error ("usage: lsf folder [ref] [pattern] [recursion-level]\n");
return 1;
}
mu_register_all_mbox_formats ();
return ls_folders (folder, ref, pattern, level);
}