BUG: Signing and encrypting a single space in textmode is broken

Werner Koch wk@gnupg.org
Mon Apr 22 09:13:02 2002


On Sat, 20 Apr 2002 20:18:55 -0400, David Shaw said:

> The problem seems to be in plaintext.c:handle_plaintext.  If you look
> at the if chain starting at line 117, it looks like this:

>   if(pt->len)
>     {
>       /* read pt->len bytes from the buffer and process them */
>     }
>   else if(!clearsig)
>     {
>       /* read all bytes from the buffer until end, and process them */

Argg.  I should know that one should better not use a special value as
a flag for a different thing (partial length encoded packets).

> The only thing this won't work with is if a GnuPG user signs a
> zero-length or stdin document with --rfc1991 set.  Since GnuPG doesn't

And with the old GnuPG-pre-OpenPGP partial length encoding.  But this
won't be a real problem - support for this should fade out anyway.

I think it will be cleaner to have an extra flag for partial length
encoded literal data packets instead of using the len == 0 and
new_ctb.  Setting it in parse_plaintext() and checking it instead of
!pt->len in handle_plaintext() should be simple enough for such a late
minute fix.

  Werner