Thanks Mark.

I wasn't aware of the single buffer for all mail_fetch***() functions,
but I'm converting the results to std::strings directly afterwards so
it doesn't affect the app.

Turning on debugging telemetry showed that the message is transmitted
truncated by the server. This is the Gmail IMAP server. I guess I'll
have to download the messages in parts and then glue them back
together again.

Thanks for your help!
David

On Sun, Jul 19, 2009 at 7:24 PM, Mark Crispin<mrc...@panda.com> wrote:
> Turn on debugging telemetry and you will see the IMAP protocol interactions
> via mm_dlog().  Is the data being truncated from the server? Note that
> mm_dlog() will not show the data in literals, but you will see the byte
> counts and that should indicate if you are getting truncated data.
>
> If the data is truncated from the server, that's where you need to persue
> your further investigations.  If it's coming from the server OK, then there
> is some problem in how you are calling c-client.
>
> Are you aware that the buffer used by mail_fetchtext() is used by other
> functions?  This means that you can only use the return data from a
> mail_fetch***() function until you call another mail_fetch****() function. A
> common mistake is to call mail_fetchheader() and then mail_fetchtext() and
> expect to use both pointers afterwards.
>
> In any case, be sure to verify that the server isn't doing this, especially
> if it is not one of the standard good ones such as UW/Panda, Cyrus, or
> Dovecot.
>
> -- Mark --
>
> http://panda.com/mrc
> Science does not emerge from voting, party politics, or public debate.
> Si vis pacem, para bellum.
>



-- 
If automobiles had followed the same development cycle as the
computer, a Rolls-Royce would today cost $100, get a million miles per
gallon, and explode once a year, killing everyone inside.
 - Robert X. Cringely
_______________________________________________
Imap-uw mailing list
Imap-uw@u.washington.edu
http://mailman2.u.washington.edu/mailman/listinfo/imap-uw

Reply via email to