|
|
@ -53,6 +53,7 @@ sync_mailbox (mailbox_t * mbox, imap_t * imap, int flags, |
|
|
|
int fd; |
|
|
|
int fd; |
|
|
|
int ret; |
|
|
|
int ret; |
|
|
|
int fetched = 0; |
|
|
|
int fetched = 0; |
|
|
|
|
|
|
|
int upload = 0; |
|
|
|
|
|
|
|
|
|
|
|
if (mbox->uidvalidity > 0) |
|
|
|
if (mbox->uidvalidity > 0) |
|
|
|
{ |
|
|
|
{ |
|
|
@ -91,9 +92,17 @@ sync_mailbox (mailbox_t * mbox, imap_t * imap, int flags, |
|
|
|
if (cur->uid == (unsigned int) -1) |
|
|
|
if (cur->uid == (unsigned int) -1) |
|
|
|
{ |
|
|
|
{ |
|
|
|
struct stat sb; |
|
|
|
struct stat sb; |
|
|
|
int fd; |
|
|
|
|
|
|
|
int uid; |
|
|
|
int uid; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if ((flags & SYNC_QUIET) == 0) |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
if (!upload) |
|
|
|
|
|
|
|
fputs ("Uploading messages", stdout); |
|
|
|
|
|
|
|
fputc ('.', stdout); |
|
|
|
|
|
|
|
fflush (stdout); |
|
|
|
|
|
|
|
upload++; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/* upload the message if its not too big */ |
|
|
|
/* upload the message if its not too big */ |
|
|
|
snprintf (path, sizeof (path), "%s/%s/%s", mbox->path, |
|
|
|
snprintf (path, sizeof (path), "%s/%s/%s", mbox->path, |
|
|
|
cur->new ? "new" : "cur", cur->file); |
|
|
|
cur->new ? "new" : "cur", cur->file); |
|
|
@ -106,6 +115,7 @@ sync_mailbox (mailbox_t * mbox, imap_t * imap, int flags, |
|
|
|
} |
|
|
|
} |
|
|
|
if (imap->box->max_size > 0 && sb.st_size > imap->box->max_size) |
|
|
|
if (imap->box->max_size > 0 && sb.st_size > imap->box->max_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
|
|
|
|
if ((flags & SYNC_QUIET) == 0) |
|
|
|
printf |
|
|
|
printf |
|
|
|
("Warning, local message is too large (%ld), skipping...\n", |
|
|
|
("Warning, local message is too large (%ld), skipping...\n", |
|
|
|
sb.st_size); |
|
|
|
sb.st_size); |
|
|
@ -130,9 +140,6 @@ sync_mailbox (mailbox_t * mbox, imap_t * imap, int flags, |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
if (uid != -1) |
|
|
|
if (uid != -1) |
|
|
|
{ |
|
|
|
{ |
|
|
|
char newpath[_POSIX_PATH_MAX]; |
|
|
|
|
|
|
|
char *p; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
strfcpy (newpath, path, sizeof (newpath)); |
|
|
|
strfcpy (newpath, path, sizeof (newpath)); |
|
|
|
/* kill :info field */ |
|
|
|
/* kill :info field */ |
|
|
|
p = strchr (newpath, ':'); |
|
|
|
p = strchr (newpath, ':'); |
|
|
@ -153,17 +160,18 @@ sync_mailbox (mailbox_t * mbox, imap_t * imap, int flags, |
|
|
|
perror ("rename"); |
|
|
|
perror ("rename"); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
else |
|
|
|
else if (flags & SYNC_DELETE) |
|
|
|
{ |
|
|
|
|
|
|
|
printf ("Warning, uid %u doesn't exist on server\n", |
|
|
|
|
|
|
|
cur->uid); |
|
|
|
|
|
|
|
if (flags & SYNC_DELETE) |
|
|
|
|
|
|
|
{ |
|
|
|
{ |
|
|
|
cur->flags |= D_DELETED; |
|
|
|
cur->flags |= D_DELETED; |
|
|
|
cur->dead = 1; |
|
|
|
cur->dead = 1; |
|
|
|
mbox->deleted++; |
|
|
|
mbox->deleted++; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
/* if the user doesn't want local msgs deleted when they don't
|
|
|
|
|
|
|
|
* exist on the server, warn that such messages exist. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
else if ((flags & SYNC_QUIET) == 0) |
|
|
|
|
|
|
|
printf ("Warning, uid %u doesn't exist on server\n", |
|
|
|
|
|
|
|
cur->uid); |
|
|
|
continue; |
|
|
|
continue; |
|
|
|
} |
|
|
|
} |
|
|
|
tmp->processed = 1; |
|
|
|
tmp->processed = 1; |
|
|
@ -203,8 +211,15 @@ sync_mailbox (mailbox_t * mbox, imap_t * imap, int flags, |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (upload) |
|
|
|
|
|
|
|
fprintf (stdout, " %d messages.\n", upload); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if ((flags & SYNC_QUIET) == 0) |
|
|
|
|
|
|
|
{ |
|
|
|
fputs ("Fetching new messages", stdout); |
|
|
|
fputs ("Fetching new messages", stdout); |
|
|
|
fflush (stdout); |
|
|
|
fflush (stdout); |
|
|
|
|
|
|
|
} |
|
|
|
for (cur = imap->msgs; cur; cur = cur->next) |
|
|
|
for (cur = imap->msgs; cur; cur = cur->next) |
|
|
|
{ |
|
|
|
{ |
|
|
|
if (!cur->processed) |
|
|
|
if (!cur->processed) |
|
|
@ -222,6 +237,7 @@ sync_mailbox (mailbox_t * mbox, imap_t * imap, int flags, |
|
|
|
|
|
|
|
|
|
|
|
if (max_size && cur->size > max_size) |
|
|
|
if (max_size && cur->size > max_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
|
|
|
|
if ((flags & SYNC_QUIET) == 0) |
|
|
|
printf |
|
|
|
printf |
|
|
|
("Warning, message skipped because it is too big (%u)\n", |
|
|
|
("Warning, message skipped because it is too big (%u)\n", |
|
|
|
cur->size); |
|
|
|
cur->size); |
|
|
@ -261,9 +277,12 @@ sync_mailbox (mailbox_t * mbox, imap_t * imap, int flags, |
|
|
|
if (fd < 0) |
|
|
|
if (fd < 0) |
|
|
|
continue; |
|
|
|
continue; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if ((flags & SYNC_QUIET) == 0) |
|
|
|
|
|
|
|
{ |
|
|
|
/* give some visual feedback that something is happening */ |
|
|
|
/* give some visual feedback that something is happening */ |
|
|
|
fputs (".", stdout); |
|
|
|
fputs (".", stdout); |
|
|
|
fflush (stdout); |
|
|
|
fflush (stdout); |
|
|
|
|
|
|
|
} |
|
|
|
fetched++; |
|
|
|
fetched++; |
|
|
|
|
|
|
|
|
|
|
|
ret = imap_fetch_message (imap, cur->uid, fd); |
|
|
|
ret = imap_fetch_message (imap, cur->uid, fd); |
|
|
@ -293,6 +312,8 @@ sync_mailbox (mailbox_t * mbox, imap_t * imap, int flags, |
|
|
|
unlink (path); |
|
|
|
unlink (path); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if ((flags & SYNC_QUIET) == 0) |
|
|
|
printf (" %d messages\n", fetched); |
|
|
|
printf (" %d messages\n", fetched); |
|
|
|
|
|
|
|
|
|
|
|
return 0; |
|
|
|
return 0; |
|
|
|