1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-23 15:07:03 +01:00

Updated to match the switch to the NSIS installer.

This commit is contained in:
Werner Koch 2005-02-03 09:32:53 +00:00
parent b663f3f8d3
commit 334e3e96d2
7 changed files with 328 additions and 197 deletions

3
NEWS
View File

@ -23,6 +23,9 @@ Noteworthy changes in version 1.4.1
available, missing secret key stubs will be created on the fly. available, missing secret key stubs will be created on the fly.
Details of the key are listed too. Details of the key are listed too.
* The implicit packet dumping in double verbose mode is now send
to stderr and not to stdout.
* [W32] The algorithm for the default home directory changed: * [W32] The algorithm for the default home directory changed:
First we look at the environment variable GNUPGHOME, if this one First we look at the environment variable GNUPGHOME, if this one
is not set, we check whether the registry entry is not set, we check whether the registry entry

1
THANKS
View File

@ -34,6 +34,7 @@ Dan Winship danw@helixcode.com
Daniel Eisenbud eisenbud@cs.swarthmore.edu Daniel Eisenbud eisenbud@cs.swarthmore.edu
Daniel Koening dan@mail.isis.de Daniel Koening dan@mail.isis.de
Daniel Resare daniel@resare.com Daniel Resare daniel@resare.com
Dany Nativel dany@natzo.com
Dave Dykstra dwd@bell-labs.com Dave Dykstra dwd@bell-labs.com
David C Niemi niemi@tuxers.net David C Niemi niemi@tuxers.net
David Champion dgc@uchicago.edu David Champion dgc@uchicago.edu

View File

@ -1,3 +1,7 @@
2005-02-03 Werner Koch <wk@g10code.com>
* README.W32: Updated to match the switch to the NSIS installer.
2005-01-27 Werner Koch <wk@g10code.com> 2005-01-27 Werner Koch <wk@g10code.com>
* faq.raw: Updated to the version from 1.2.7. * faq.raw: Updated to the version from 1.2.7.

View File

@ -1,5 +1,7 @@
This is a binary version of GnuPG for MS-Windows 95, 98, WNT, W2000 README.W32 -*- text -*-
and XP.
This is a binary package with GnuPG for MS-Windows 95, 98, WNT, W2000
and XP. See the file README for generic instructions and usage hints.
A FAQ comes with this package and a probably more recent one can be A FAQ comes with this package and a probably more recent one can be
found online at http://www.gnupg.org/faq.html. See found online at http://www.gnupg.org/faq.html. See
@ -7,85 +9,178 @@ http://www.gnupg.org/docs-mls.html for a list of mailing lists. In
particular the list gnupg-users@gnupg.org might be useful to answer particular the list gnupg-users@gnupg.org might be useful to answer
questions - but please read the FAQ first. questions - but please read the FAQ first.
Note: Due to the use of the NSIS installer, the information below are
mostly out of date.
Installation instructions: Installation directory:
-------------------------- =======================
1. Unpack the ZIP archive (alright, you already did this).
2. Copy "gpg.exe", "gpgv.exe" and "gpgkeys_ldap.exe" to a place The installation directory of GnuPG is stored in the Registry under
where you usually store your binaries. the key HKEY_LCOAL_MACHINE\Software\GNU\GnuPG with the name "Install
3. Create a directory "c:\gnupg" (or any other as you like) Directory". The installer does not change the PATH environment
4. If you did not use the default directory "c:\gnupg", you variable to include this directory. You might want to do this
should enter a string with the directory into the Registry manually.
under the key:
HKEY_CURRENT_USER -> Software -> GNU -> GnuPG Below the Installation directory, you will find directories named
(you probably need to create the keys GNU and GnuPG) and insert a "Doc", "gnupg.nls" and "Src". The latter will be used for distributed
new string under the name "HomeDir" with the value of the default patched, if any, and to store the source file if they have been
directory you want to use. Please use forward slashes and not the included in this package. The source files usually require further
backslashes when setting filenames for GnuPG into the Registry. unpacking using a the TAR utility.
5. Enter "gpg" and see what happens
6. Read the file README and the online HOWTOs
Internationalization support: Internationalization support:
----------------------------- =============================
1
Store the locale id (like "de") into the registry under the key Store the locale id (like "de") into the Registry under the key
HKEY_CURRENT_USER\Software\GNU\GnuPG with the name "Lang". HKEY_CURRENT_USER\Software\GNU\GnuPG with the name "Lang". This must
match one of the installed languages files in the directory named
"gnupg.nls" below the installation directory. Note, that the ".mo"
extension is not part of the lcoale id.
How to build it from the source: Home directory:
-------------------------------- ===============
This version has been build with the Mingw32/CPD kit using the latest
stable version of GnuPG.
First get the source: It has to be available at the same location you GnuPG makes use of a per user home directory to store its keys as well
found this binary package - if not you should have received a written as configuration files. The default home directory is a directory
offer to get the source delivered to you See the file COPYING (section named "gnupg" below the application data directory of the user. This
3) for details. directory will be created if it does not exist. Being only a default,
it may be changed by setting the name of the home directory into the
Registry under the key HKEY_CURRENT_USER\Software\GNU\GnuPG using the
name "HomeDir". If an environment varaibale "GNUPGHOME" exists, this
even overrides the registry setting. The command line option
"--homedir" may be used to override all other settings of the home
directory.
If you got this package from its canonical place (ftp.gnupg.org), the
source is available at:
ftp://ftp.gnupg.org/gcrypt/gnupg/gnupg-1.2.n.tar.gz Reporting bugs:
===============
or for development snapshots Please check the documentation first before asking or reporting a
bugs. In particular check the archives of the mailing lists (see
www.gnupg.org) and the bug tracking system at http://bugs.gnupg.org
(login is "guest" password is "guest") whether the problem is already
known. Asking on the gnupg-users mailing list is also strongly
encouraged; if you are not subscribed it may some time until a posting
is approved (this is an anti-spam measure). Bug reporting addresses
are listed in the file AUTHORS.
ftp://ftp.gnupg.org/gcrypt/alpha/gnupg/gnupg-1.x.n.tar.gz If you want to report a bug or have other problems, always give
detailed description of the problem, the version of GnuPG you used,
the version of the OS, whether it is the official version from
gnupg.org or how you built it. Don't edit error messages - replacing
sensitive information like user IDs, fingerprints and keyids is okay.
If possible, switch to English messages by changing the "Lang" entry
to empty (see under Internationalization support).
this is the same source as for the Unix version. If your binary
version of GnuPG is called something like gnupg-w32-1.0.4-1.zip, you
should find a patch file named gnupg-w32-1.0.4-1.0.4-1.diff.gz at the
same location, which has to be applied to the stock gpg source file.
Instructions are at the top of this file.
To build it, you need the MingW32/CPD kit, which is available at How to build GnuPG from the source:
===================================
ftp://ftp.gnupg.org/people/werner/cpd/mingw32-cpd-0.3.2.tar.gz Until recently all official GnuPG versions have been build using the
ftp://ftp.gnupg.org/people/werner/cpd/gcc-core-2.95.2.tar.gz Mingw32/CPD kit as available at
ftp://ftp.gnupg.org/people/werner/cpd/binutils-2.9.1.tar.gz ftp://ftp.gnupg.org/people/werner/cpd/mingw32-cqpd-0.3.2.tar.gz .
However, for maintenance reasons we switched to Debian's mingw32 cross
compiler package and that is now the recommended way of building GnuPG
for W32 platforms. It might be possible to build it nativly on a W32
platform but this is not supported. Please don't file any bug reports
if it does not build with any other system than the recommended one.
gcc and binutils are stock GNU source which are available According to the conditions of the GNU General Public License you
at every GNU mirror. either got the source files with this package, a written offer to send
you the source on demand or the source is available at the same site
you downloaded the binary package. If you downloaded the package from
the official GnuPG site or one of its mirrors, the corresponding
source tarball is available in the sibling directory named gnupg. The
source used to build all versions is always the same and the version
numbers should match. If the version number of the binary package has
a letter suffix, you will find a patch file installed in the "Src"
directory with the changes relative to the generic version.
After you have installed this environment you should be able to do this: The source is distributed as a BZIP2 or GZIP compressed tar archive.
See the instructions in file README on how to check the integrity of
that file. Wir a properly setup build environment, you unpack the
tarball change to the created directory and run
$ scripts/autogen.sh --build-w32 $ ./autogen.sh --build-w32
$ make $ make
$ mingw32 strip g10/gpg.exe $ cp g10/gpg*.exe /some_windows_drive/
$ cp g10/gpg.exe /some_windows_drive/
And everything hopefully works. If there is a make problem in the Building a version with the installer is a bit more complex and
"po" directory you can eiterignore it or do a "touch po/all". To basically works by creating a top directory, unpacking in that top
build the distribtion ZIP file, you have to create a directory directory, switching to the gnupg-1.x.y directory, running
"dist-w32" and run "scripts/mk-w32-dist" right after a successul make "./autogen.sh --build-w32" and "make", switching back to the top
run. directory, running a "mkdir dist-w32; mkdir iconv", copying the
required iconv files (iconv.dll, README.iconv, COPYING.LIB) into the
iconv directory, running gnupg-1.x.y/scripts/mk-w32-dist and voila,
the installer package will be available in the dist-w32 directory.
Don't forget that MS-Windows ist just a temporary workaround until
you can switch to a GNU system ;-)
Be the source always with you. Copying:
========
Werner GnuPG is
Copyright 1998, 1999, 2000, 2001, 2002, 2003, 2004,
2005 Free Software Foundation, Inc.
GnuPG 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 2 of the License, or
(at your option) any later version.
GnuPG 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 this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
02111-1307, USA
See the files AUTHORS and THANKS for credits, further legal
information and bug reporting addresses pertaining to GnuPG.
For copying conditions of the GNU LIBICONV library see the file
README.iconv.
The installer software used to create the official binary packages for
W32 is NSIS (http://nsis.sourceforge.net/):
Copyright (C) 1999-2005 Nullsoft, Inc.
This license applies to everything in the NSIS package, except where
otherwise noted.
This software is provided 'as-is', without any express or implied
warranty. In no event will the authors be held liable for any
damages arising from the use of this software.
Permission is granted to anyone to use this software for any
purpose, including commercial applications, and to alter it and
redistribute it freely, subject to the following restrictions:
1. The origin of this software must not be misrepresented; you must
not claim that you wrote the original software. If you use this
software in a product, an acknowledgment in the product
documentation would be appreciated but is not required.
2. Altered source versions must be plainly marked as such, and must
not be misrepresented as being the original software.
3. This notice may not be removed or altered from any source
distribution.
The user interface used with the installer is
Copyright (C) 2002-2005 Joost Verburg
[It is distributed along with NSIS and the same conditions as stated
above apply]
The term "W32" is used to describe the API used by current Microsoft
Windows versions. We don't use the Microsft terminology here; in
hacker terminology, calling something a "win" is a form of praise.
Keep in mind that Windows ist just a temporary workaround until you
can switch to a complete Free Software system. Be the source always
with you.

View File

@ -18,6 +18,10 @@
2005-01-27 Werner Koch <wk@g10code.com> 2005-01-27 Werner Koch <wk@g10code.com>
* parse-packet.c (listfp): New.
(set_packet_list_mode): Intialize it to stdout or stderr depending
on a global option. Made all printing in list mode use LISTFP.
* keygen.c (generate_subkeypair): Detect primary key on-card and * keygen.c (generate_subkeypair): Detect primary key on-card and
ask for the passphrase. Return an error if the primary key is a ask for the passphrase. Return an error if the primary key is a
plain stub. plain stub.

View File

@ -1151,7 +1151,7 @@ do_proc_packets( CTX c, IOBUF a )
if( rc ) { if( rc ) {
free_packet(pkt); free_packet(pkt);
/* stop processing when an invalid packet has been encountered /* stop processing when an invalid packet has been encountered
* but don't do so when we are doing a --list-packet. */ * but don't do so when we are doing a --list-packets. */
if( rc == G10ERR_INVALID_PACKET && opt.list_packets != 2 ) if( rc == G10ERR_INVALID_PACKET && opt.list_packets != 2 )
break; break;
continue; continue;

View File

@ -1,6 +1,6 @@
/* parse-packet.c - read packets /* parse-packet.c - read packets
* Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, * Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003,
* 2004 Free Software Foundation, Inc. * 2004, 2005 Free Software Foundation, Inc.
* *
* This file is part of GnuPG. * This file is part of GnuPG.
* *
@ -37,8 +37,9 @@
#include "main.h" #include "main.h"
#include "i18n.h" #include "i18n.h"
static int mpi_print_mode = 0; static int mpi_print_mode;
static int list_mode = 0; static int list_mode;
static FILE *listfp;
static int parse( IOBUF inp, PACKET *pkt, int onlykeypkts, static int parse( IOBUF inp, PACKET *pkt, int onlykeypkts,
off_t *retpos, int *skip, IOBUF out, int do_skip off_t *retpos, int *skip, IOBUF out, int do_skip
@ -105,6 +106,23 @@ set_packet_list_mode( int mode )
int old = list_mode; int old = list_mode;
list_mode = mode; list_mode = mode;
mpi_print_mode = DBG_MPI; mpi_print_mode = DBG_MPI;
/* We use stdout print only if invoked by the --list-packets
command but switch to stderr in all otehr cases. This breaks
the previous behaviour but that seems to be more of a bug than
intentional. I don't believe that any application makes use of
this long standing annoying way of printing to stdout except
when doing a --list-packets. If this assumption fails, it will
be easy to add an option for the listing stream. Note that we
initialize it only once; mainly because some code may switch
the option value later back to 1 and we want to have all output
to the same stream.
Using stderr is not actually very clean because it bypasses the
logging code but it is a special thing anyay. I am not sure
whether using log_stream() would be better. Perhaps we should
enable the list mdoe only with a special option. */
if (!listfp)
listfp = opt.list_packets == 2 ? stdout : stderr;
return old; return old;
} }
@ -523,14 +541,14 @@ dump_hex_line( int c, int *i )
{ {
if( *i && !(*i%8) ) { if( *i && !(*i%8) ) {
if( *i && !(*i%24) ) if( *i && !(*i%24) )
printf("\n%4d:", *i ); fprintf (listfp, "\n%4d:", *i );
else else
putchar(' '); putc (' ', listfp);
} }
if( c == -1 ) if( c == -1 )
printf(" EOF" ); fprintf (listfp, " EOF" );
else else
printf(" %02x", c ); fprintf (listfp, " %02x", c );
++*i; ++*i;
} }
@ -573,13 +591,14 @@ skip_packet( IOBUF inp, int pkttype, unsigned long pktlen, int partial )
{ {
if( list_mode ) { if( list_mode ) {
if( pkttype == PKT_MARKER ) if( pkttype == PKT_MARKER )
fputs(":marker packet:\n", stdout ); fputs(":marker packet:\n", listfp );
else else
printf(":unknown packet: type %2d, length %lu\n", pkttype, pktlen); fprintf (listfp, ":unknown packet: type %2d, length %lu\n",
pkttype, pktlen);
if( pkttype ) { if( pkttype ) {
int c, i=0 ; int c, i=0 ;
if( pkttype != PKT_MARKER ) if( pkttype != PKT_MARKER )
fputs("dump:", stdout ); fputs("dump:", listfp );
if( partial ) { if( partial ) {
while( (c=iobuf_get(inp)) != -1 ) while( (c=iobuf_get(inp)) != -1 )
dump_hex_line(c, &i); dump_hex_line(c, &i);
@ -588,7 +607,7 @@ skip_packet( IOBUF inp, int pkttype, unsigned long pktlen, int partial )
for( ; pktlen; pktlen-- ) for( ; pktlen; pktlen-- )
dump_hex_line(iobuf_get(inp), &i); dump_hex_line(iobuf_get(inp), &i);
} }
putchar('\n'); putc ('\n', listfp);
return; return;
} }
} }
@ -691,18 +710,18 @@ parse_symkeyenc( IOBUF inp, int pkttype, unsigned long pktlen, PACKET *packet )
assert( !pktlen ); assert( !pktlen );
if( list_mode ) { if( list_mode ) {
printf(":symkey enc packet: version %d, cipher %d, s2k %d, hash %d", fprintf (listfp, ":symkey enc packet: version %d, cipher %d, s2k %d, hash %d",
version, cipher_algo, s2kmode, hash_algo); version, cipher_algo, s2kmode, hash_algo);
if(seskeylen) if(seskeylen)
printf(", seskey %d bits",(seskeylen-1)*8); fprintf (listfp, ", seskey %d bits",(seskeylen-1)*8);
printf("\n"); fprintf (listfp, "\n");
if( s2kmode == 1 || s2kmode == 3 ) { if( s2kmode == 1 || s2kmode == 3 ) {
printf("\tsalt "); fprintf (listfp, "\tsalt ");
for(i=0; i < 8; i++ ) for(i=0; i < 8; i++ )
printf("%02x", k->s2k.salt[i]); fprintf (listfp, "%02x", k->s2k.salt[i]);
if( s2kmode == 3 ) if( s2kmode == 3 )
printf(", count %lu", (ulong)k->s2k.count ); fprintf (listfp, ", count %lu", (ulong)k->s2k.count );
printf("\n"); fprintf (listfp, "\n");
} }
} }
@ -736,13 +755,13 @@ parse_pubkeyenc( IOBUF inp, int pkttype, unsigned long pktlen, PACKET *packet )
k->pubkey_algo = iobuf_get_noeof(inp); pktlen--; k->pubkey_algo = iobuf_get_noeof(inp); pktlen--;
k->throw_keyid = 0; /* only used as flag for build_packet */ k->throw_keyid = 0; /* only used as flag for build_packet */
if( list_mode ) if( list_mode )
printf(":pubkey enc packet: version %d, algo %d, keyid %08lX%08lX\n", fprintf (listfp, ":pubkey enc packet: version %d, algo %d, keyid %08lX%08lX\n",
k->version, k->pubkey_algo, (ulong)k->keyid[0], (ulong)k->keyid[1]); k->version, k->pubkey_algo, (ulong)k->keyid[0], (ulong)k->keyid[1]);
ndata = pubkey_get_nenc(k->pubkey_algo); ndata = pubkey_get_nenc(k->pubkey_algo);
if( !ndata ) { if( !ndata ) {
if( list_mode ) if( list_mode )
printf("\tunsupported algorithm %d\n", k->pubkey_algo ); fprintf (listfp, "\tunsupported algorithm %d\n", k->pubkey_algo );
unknown_pubkey_warning( k->pubkey_algo ); unknown_pubkey_warning( k->pubkey_algo );
k->data[0] = NULL; /* no need to store the encrypted data */ k->data[0] = NULL; /* no need to store the encrypted data */
} }
@ -751,9 +770,9 @@ parse_pubkeyenc( IOBUF inp, int pkttype, unsigned long pktlen, PACKET *packet )
n = pktlen; n = pktlen;
k->data[i] = mpi_read(inp, &n, 0); pktlen -=n; k->data[i] = mpi_read(inp, &n, 0); pktlen -=n;
if( list_mode ) { if( list_mode ) {
printf("\tdata: "); fprintf (listfp, "\tdata: ");
mpi_print(stdout, k->data[i], mpi_print_mode ); mpi_print(listfp, k->data[i], mpi_print_mode );
putchar('\n'); putc ('\n', listfp);
} }
if (!k->data[i]) if (!k->data[i])
rc = G10ERR_INVALID_PACKET; rc = G10ERR_INVALID_PACKET;
@ -777,7 +796,8 @@ dump_sig_subpkt( int hashed, int type, int critical,
* detect the ARRs - we print our old message here when it is a faked * detect the ARRs - we print our old message here when it is a faked
* ARR and add an additional notice */ * ARR and add an additional notice */
if ( type == SIGSUBPKT_ARR && !hashed ) { if ( type == SIGSUBPKT_ARR && !hashed ) {
printf("\tsubpkt %d len %u (additional recipient request)\n" fprintf (listfp,
"\tsubpkt %d len %u (additional recipient request)\n"
"WARNING: PGP versions > 5.0 and < 6.5.8 will automagically " "WARNING: PGP versions > 5.0 and < 6.5.8 will automagically "
"encrypt to this key and thereby reveal the plaintext to " "encrypt to this key and thereby reveal the plaintext to "
"the owner of this ARR key. Detailed info follows:\n", "the owner of this ARR key. Detailed info follows:\n",
@ -787,72 +807,72 @@ dump_sig_subpkt( int hashed, int type, int critical,
buffer++; buffer++;
length--; length--;
printf("\t%s%ssubpkt %d len %u (", /*)*/ fprintf (listfp, "\t%s%ssubpkt %d len %u (", /*)*/
critical ? "critical ":"", critical ? "critical ":"",
hashed ? "hashed ":"", type, (unsigned)length ); hashed ? "hashed ":"", type, (unsigned)length );
if( length > buflen ) { if( length > buflen ) {
printf("too short: buffer is only %u)\n", (unsigned)buflen ); fprintf (listfp, "too short: buffer is only %u)\n", (unsigned)buflen );
return; return;
} }
switch( type ) { switch( type ) {
case SIGSUBPKT_SIG_CREATED: case SIGSUBPKT_SIG_CREATED:
if( length >= 4 ) if( length >= 4 )
printf("sig created %s", strtimestamp( buffer_to_u32(buffer) ) ); fprintf (listfp, "sig created %s", strtimestamp( buffer_to_u32(buffer) ) );
break; break;
case SIGSUBPKT_SIG_EXPIRE: case SIGSUBPKT_SIG_EXPIRE:
if( length >= 4 ) if( length >= 4 )
printf("sig expires after %s", fprintf (listfp, "sig expires after %s",
strtimevalue( buffer_to_u32(buffer) ) ); strtimevalue( buffer_to_u32(buffer) ) );
break; break;
case SIGSUBPKT_EXPORTABLE: case SIGSUBPKT_EXPORTABLE:
if( length ) if( length )
printf("%sexportable", *buffer? "":"not "); fprintf (listfp, "%sexportable", *buffer? "":"not ");
break; break;
case SIGSUBPKT_TRUST: case SIGSUBPKT_TRUST:
if(length!=2) if(length!=2)
p="[invalid trust subpacket]"; p="[invalid trust subpacket]";
else else
printf("trust signature of depth %d, value %d",buffer[0],buffer[1]); fprintf (listfp, "trust signature of depth %d, value %d",buffer[0],buffer[1]);
break; break;
case SIGSUBPKT_REGEXP: case SIGSUBPKT_REGEXP:
if(!length) if(!length)
p="[invalid regexp subpacket]"; p="[invalid regexp subpacket]";
else else
printf("regular expression: \"%s\"",buffer); fprintf (listfp, "regular expression: \"%s\"",buffer);
break; break;
case SIGSUBPKT_REVOCABLE: case SIGSUBPKT_REVOCABLE:
if( length ) if( length )
printf("%srevocable", *buffer? "":"not "); fprintf (listfp, "%srevocable", *buffer? "":"not ");
break; break;
case SIGSUBPKT_KEY_EXPIRE: case SIGSUBPKT_KEY_EXPIRE:
if( length >= 4 ) if( length >= 4 )
printf("key expires after %s", fprintf (listfp, "key expires after %s",
strtimevalue( buffer_to_u32(buffer) ) ); strtimevalue( buffer_to_u32(buffer) ) );
break; break;
case SIGSUBPKT_PREF_SYM: case SIGSUBPKT_PREF_SYM:
fputs("pref-sym-algos:", stdout ); fputs("pref-sym-algos:", listfp );
for( i=0; i < length; i++ ) for( i=0; i < length; i++ )
printf(" %d", buffer[i] ); fprintf (listfp, " %d", buffer[i] );
break; break;
case SIGSUBPKT_REV_KEY: case SIGSUBPKT_REV_KEY:
fputs("revocation key: ", stdout ); fputs("revocation key: ", listfp );
if( length < 22 ) if( length < 22 )
p = "[too short]"; p = "[too short]";
else { else {
printf("c=%02x a=%d f=", buffer[0], buffer[1] ); fprintf (listfp, "c=%02x a=%d f=", buffer[0], buffer[1] );
for( i=2; i < length; i++ ) for( i=2; i < length; i++ )
printf("%02X", buffer[i] ); fprintf (listfp, "%02X", buffer[i] );
} }
break; break;
case SIGSUBPKT_ISSUER: case SIGSUBPKT_ISSUER:
if( length >= 8 ) if( length >= 8 )
printf("issuer key ID %08lX%08lX", fprintf (listfp, "issuer key ID %08lX%08lX",
(ulong)buffer_to_u32(buffer), (ulong)buffer_to_u32(buffer),
(ulong)buffer_to_u32(buffer+4) ); (ulong)buffer_to_u32(buffer+4) );
break; break;
case SIGSUBPKT_NOTATION: case SIGSUBPKT_NOTATION:
{ {
fputs("notation: ", stdout ); fputs("notation: ", listfp );
if( length < 8 ) if( length < 8 )
p = "[too short]"; p = "[too short]";
else { else {
@ -865,11 +885,11 @@ dump_sig_subpkt( int hashed, int type, int critical,
if( 8+n1+n2 != length ) if( 8+n1+n2 != length )
p = "[error]"; p = "[error]";
else { else {
print_string( stdout, s, n1, ')' ); print_string( listfp, s, n1, ')' );
putc( '=', stdout ); putc( '=', listfp );
if( *buffer & 0x80 ) if( *buffer & 0x80 )
print_string( stdout, s+n1, n2, ')' ); print_string( listfp, s+n1, n2, ')' );
else else
p = "[not human readable]"; p = "[not human readable]";
} }
@ -877,67 +897,67 @@ dump_sig_subpkt( int hashed, int type, int critical,
} }
break; break;
case SIGSUBPKT_PREF_HASH: case SIGSUBPKT_PREF_HASH:
fputs("pref-hash-algos:", stdout ); fputs("pref-hash-algos:", listfp );
for( i=0; i < length; i++ ) for( i=0; i < length; i++ )
printf(" %d", buffer[i] ); fprintf (listfp, " %d", buffer[i] );
break; break;
case SIGSUBPKT_PREF_COMPR: case SIGSUBPKT_PREF_COMPR:
fputs("pref-zip-algos:", stdout ); fputs("pref-zip-algos:", listfp );
for( i=0; i < length; i++ ) for( i=0; i < length; i++ )
printf(" %d", buffer[i] ); fprintf (listfp, " %d", buffer[i] );
break; break;
case SIGSUBPKT_KS_FLAGS: case SIGSUBPKT_KS_FLAGS:
fputs("key server preferences:",stdout); fputs("key server preferences:",listfp);
for(i=0;i<length;i++) for(i=0;i<length;i++)
printf(" %02X", buffer[i]); fprintf (listfp, " %02X", buffer[i]);
break; break;
case SIGSUBPKT_PREF_KS: case SIGSUBPKT_PREF_KS:
fputs("preferred key server: ", stdout ); fputs("preferred key server: ", listfp );
print_string( stdout, buffer, length, ')' ); print_string( listfp, buffer, length, ')' );
break; break;
case SIGSUBPKT_PRIMARY_UID: case SIGSUBPKT_PRIMARY_UID:
p = "primary user ID"; p = "primary user ID";
break; break;
case SIGSUBPKT_POLICY: case SIGSUBPKT_POLICY:
fputs("policy: ", stdout ); fputs("policy: ", listfp );
print_string( stdout, buffer, length, ')' ); print_string( listfp, buffer, length, ')' );
break; break;
case SIGSUBPKT_KEY_FLAGS: case SIGSUBPKT_KEY_FLAGS:
fputs ( "key flags:", stdout ); fputs ( "key flags:", listfp );
for( i=0; i < length; i++ ) for( i=0; i < length; i++ )
printf(" %02X", buffer[i] ); fprintf (listfp, " %02X", buffer[i] );
break; break;
case SIGSUBPKT_SIGNERS_UID: case SIGSUBPKT_SIGNERS_UID:
p = "signer's user ID"; p = "signer's user ID";
break; break;
case SIGSUBPKT_REVOC_REASON: case SIGSUBPKT_REVOC_REASON:
if( length ) { if( length ) {
printf("revocation reason 0x%02x (", *buffer ); fprintf (listfp, "revocation reason 0x%02x (", *buffer );
print_string( stdout, buffer+1, length-1, ')' ); print_string( listfp, buffer+1, length-1, ')' );
p = ")"; p = ")";
} }
break; break;
case SIGSUBPKT_ARR: case SIGSUBPKT_ARR:
fputs("Big Brother's key (ignored): ", stdout ); fputs("Big Brother's key (ignored): ", listfp );
if( length < 22 ) if( length < 22 )
p = "[too short]"; p = "[too short]";
else { else {
printf("c=%02x a=%d f=", buffer[0], buffer[1] ); fprintf (listfp, "c=%02x a=%d f=", buffer[0], buffer[1] );
for( i=2; i < length; i++ ) for( i=2; i < length; i++ )
printf("%02X", buffer[i] ); fprintf (listfp, "%02X", buffer[i] );
} }
break; break;
case SIGSUBPKT_FEATURES: case SIGSUBPKT_FEATURES:
fputs ( "features:", stdout ); fputs ( "features:", listfp );
for( i=0; i < length; i++ ) for( i=0; i < length; i++ )
printf(" %02x", buffer[i] ); fprintf (listfp, " %02x", buffer[i] );
break; break;
case SIGSUBPKT_SIGNATURE: case SIGSUBPKT_SIGNATURE:
fputs("signature: ",stdout); fputs("signature: ",listfp);
if(length<17) if(length<17)
p="[too short]"; p="[too short]";
else else
printf("v%d, class 0x%02X, algo %d, digest algo %d", fprintf (listfp, "v%d, class 0x%02X, algo %d, digest algo %d",
buffer[0], buffer[0],
buffer[0]==3?buffer[2]:buffer[1], buffer[0]==3?buffer[2]:buffer[1],
buffer[0]==3?buffer[15]:buffer[2], buffer[0]==3?buffer[15]:buffer[2],
@ -951,7 +971,7 @@ dump_sig_subpkt( int hashed, int type, int critical,
break; break;
} }
printf("%s)\n", p? p: ""); fprintf (listfp, "%s)\n", p? p: "");
} }
/**************** /****************
@ -1369,7 +1389,7 @@ parse_signature( IOBUF inp, int pkttype, unsigned long pktlen,
} }
if( list_mode ) { if( list_mode ) {
printf(":signature packet: algo %d, keyid %08lX%08lX\n" fprintf (listfp, ":signature packet: algo %d, keyid %08lX%08lX\n"
"\tversion %d, created %lu, md5len %d, sigclass %02x\n" "\tversion %d, created %lu, md5len %d, sigclass %02x\n"
"\tdigest algo %d, begin of digest %02x %02x\n", "\tdigest algo %d, begin of digest %02x %02x\n",
sig->pubkey_algo, sig->pubkey_algo,
@ -1386,7 +1406,7 @@ parse_signature( IOBUF inp, int pkttype, unsigned long pktlen,
ndata = pubkey_get_nsig(sig->pubkey_algo); ndata = pubkey_get_nsig(sig->pubkey_algo);
if( !ndata ) { if( !ndata ) {
if( list_mode ) if( list_mode )
printf("\tunknown algorithm %d\n", sig->pubkey_algo ); fprintf (listfp, "\tunknown algorithm %d\n", sig->pubkey_algo );
unknown_pubkey_warning( sig->pubkey_algo ); unknown_pubkey_warning( sig->pubkey_algo );
/* we store the plain material in data[0], so that we are able /* we store the plain material in data[0], so that we are able
* to write it back with build_packet() */ * to write it back with build_packet() */
@ -1399,9 +1419,9 @@ parse_signature( IOBUF inp, int pkttype, unsigned long pktlen,
sig->data[i] = mpi_read(inp, &n, 0 ); sig->data[i] = mpi_read(inp, &n, 0 );
pktlen -=n; pktlen -=n;
if( list_mode ) { if( list_mode ) {
printf("\tdata: "); fprintf (listfp, "\tdata: ");
mpi_print(stdout, sig->data[i], mpi_print_mode ); mpi_print(listfp, sig->data[i], mpi_print_mode );
putchar('\n'); putc ('\n', listfp);
} }
if (!sig->data[i]) if (!sig->data[i])
rc = G10ERR_INVALID_PACKET; rc = G10ERR_INVALID_PACKET;
@ -1439,7 +1459,7 @@ parse_onepass_sig( IOBUF inp, int pkttype, unsigned long pktlen,
ops->keyid[1] = read_32(inp); pktlen -= 4; ops->keyid[1] = read_32(inp); pktlen -= 4;
ops->last = iobuf_get_noeof(inp); pktlen--; ops->last = iobuf_get_noeof(inp); pktlen--;
if( list_mode ) if( list_mode )
printf(":onepass_sig packet: keyid %08lX%08lX\n" fprintf (listfp, ":onepass_sig packet: keyid %08lX%08lX\n"
"\tversion %d, sigclass %02x, digest %d, pubkey %d, last=%d\n", "\tversion %d, sigclass %02x, digest %d, pubkey %d, last=%d\n",
(ulong)ops->keyid[0], (ulong)ops->keyid[1], (ulong)ops->keyid[0], (ulong)ops->keyid[1],
version, ops->sig_class, version, ops->sig_class,
@ -1515,16 +1535,16 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
/* early versions of G10 use old PGP comments packets; /* early versions of G10 use old PGP comments packets;
* luckily all those comments are started by a hash */ * luckily all those comments are started by a hash */
if( list_mode ) { if( list_mode ) {
printf(":rfc1991 comment packet: \"" ); fprintf (listfp, ":rfc1991 comment packet: \"" );
for( ; pktlen; pktlen-- ) { for( ; pktlen; pktlen-- ) {
int c; int c;
c = iobuf_get_noeof(inp); c = iobuf_get_noeof(inp);
if( c >= ' ' && c <= 'z' ) if( c >= ' ' && c <= 'z' )
putchar(c); putc (c, listfp);
else else
printf("\\x%02x", c ); fprintf (listfp, "\\x%02x", c );
} }
printf("\"\n"); fprintf (listfp, "\"\n");
} }
iobuf_skip_rest(inp, pktlen, 0); iobuf_skip_rest(inp, pktlen, 0);
return 0; return 0;
@ -1560,7 +1580,7 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
} }
algorithm = iobuf_get_noeof(inp); pktlen--; algorithm = iobuf_get_noeof(inp); pktlen--;
if( list_mode ) if( list_mode )
printf(":%s key packet:\n" fprintf (listfp, ":%s key packet:\n"
"\tversion %d, algo %d, created %lu, expires %lu\n", "\tversion %d, algo %d, created %lu, expires %lu\n",
pkttype == PKT_PUBLIC_KEY? "public" : pkttype == PKT_PUBLIC_KEY? "public" :
pkttype == PKT_SECRET_KEY? "secret" : pkttype == PKT_SECRET_KEY? "secret" :
@ -1602,7 +1622,7 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
npkey = pubkey_get_npkey( algorithm ); npkey = pubkey_get_npkey( algorithm );
if( !npkey ) { if( !npkey ) {
if( list_mode ) if( list_mode )
printf("\tunknown algorithm %d\n", algorithm ); fprintf (listfp, "\tunknown algorithm %d\n", algorithm );
unknown_pubkey_warning( algorithm ); unknown_pubkey_warning( algorithm );
} }
@ -1622,9 +1642,9 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
for(i=0; i < npkey; i++ ) { for(i=0; i < npkey; i++ ) {
n = pktlen; sk->skey[i] = mpi_read(inp, &n, 0 ); pktlen -=n; n = pktlen; sk->skey[i] = mpi_read(inp, &n, 0 ); pktlen -=n;
if( list_mode ) { if( list_mode ) {
printf( "\tskey[%d]: ", i); fprintf (listfp, "\tskey[%d]: ", i);
mpi_print(stdout, sk->skey[i], mpi_print_mode ); mpi_print(listfp, sk->skey[i], mpi_print_mode );
putchar('\n'); putc ('\n', listfp);
} }
if (!sk->skey[i]) if (!sk->skey[i])
rc = G10ERR_INVALID_PACKET; rc = G10ERR_INVALID_PACKET;
@ -1654,7 +1674,7 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
temp[i] = iobuf_get_noeof(inp); temp[i] = iobuf_get_noeof(inp);
if( i < 4 || memcmp( temp, "GNU", 3 ) ) { if( i < 4 || memcmp( temp, "GNU", 3 ) ) {
if( list_mode ) if( list_mode )
printf( "\tunknown S2K %d\n", fprintf (listfp, "\tunknown S2K %d\n",
sk->protect.s2k.mode ); sk->protect.s2k.mode );
rc = G10ERR_INVALID_PACKET; rc = G10ERR_INVALID_PACKET;
goto leave; goto leave;
@ -1675,19 +1695,21 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
break; break;
} }
switch( sk->protect.s2k.mode ) { switch( sk->protect.s2k.mode ) {
case 0: if( list_mode ) printf( "\tsimple S2K" ); case 0: if( list_mode ) fprintf (listfp, "\tsimple S2K" );
break; break;
case 1: if( list_mode ) printf( "\tsalted S2K" ); case 1: if( list_mode ) fprintf (listfp, "\tsalted S2K" );
break; break;
case 3: if( list_mode ) printf( "\titer+salt S2K" ); case 3: if( list_mode ) fprintf (listfp, "\titer+salt S2K" );
break; break;
case 1001: if( list_mode ) printf( "\tgnu-dummy S2K" ); case 1001: if( list_mode ) fprintf (listfp,
"\tgnu-dummy S2K" );
break; break;
case 1002: if (list_mode) printf("\tgnu-divert-to-card S2K"); case 1002: if (list_mode) fprintf (listfp,
"\tgnu-divert-to-card S2K");
break; break;
default: default:
if( list_mode ) if( list_mode )
printf( "\tunknown %sS2K %d\n", fprintf (listfp, "\tunknown %sS2K %d\n",
sk->protect.s2k.mode < 1000? "":"GNU ", sk->protect.s2k.mode < 1000? "":"GNU ",
sk->protect.s2k.mode ); sk->protect.s2k.mode );
rc = G10ERR_INVALID_PACKET; rc = G10ERR_INVALID_PACKET;
@ -1695,18 +1717,18 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
} }
if( list_mode ) { if( list_mode ) {
printf(", algo: %d,%s hash: %d", fprintf (listfp, ", algo: %d,%s hash: %d",
sk->protect.algo, sk->protect.algo,
sk->protect.sha1chk?" SHA1 protection," sk->protect.sha1chk?" SHA1 protection,"
:" simple checksum,", :" simple checksum,",
sk->protect.s2k.hash_algo ); sk->protect.s2k.hash_algo );
if( sk->protect.s2k.mode == 1 if( sk->protect.s2k.mode == 1
|| sk->protect.s2k.mode == 3 ) { || sk->protect.s2k.mode == 3 ) {
printf(", salt: "); fprintf (listfp, ", salt: ");
for(i=0; i < 8; i++ ) for(i=0; i < 8; i++ )
printf("%02x", sk->protect.s2k.salt[i]); fprintf (listfp, "%02x", sk->protect.s2k.salt[i]);
} }
putchar('\n'); putc ('\n', listfp);
} }
if( sk->protect.s2k.mode == 3 ) { if( sk->protect.s2k.mode == 3 ) {
@ -1717,7 +1739,7 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
sk->protect.s2k.count = iobuf_get(inp); sk->protect.s2k.count = iobuf_get(inp);
pktlen--; pktlen--;
if( list_mode ) if( list_mode )
printf("\tprotect count: %lu\n", fprintf (listfp, "\tprotect count: %lu\n",
(ulong)sk->protect.s2k.count); (ulong)sk->protect.s2k.count);
} }
else if( sk->protect.s2k.mode == 1002 ) { else if( sk->protect.s2k.mode == 1002 ) {
@ -1741,7 +1763,7 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
sk->protect.s2k.mode = 0; sk->protect.s2k.mode = 0;
sk->protect.s2k.hash_algo = DIGEST_ALGO_MD5; sk->protect.s2k.hash_algo = DIGEST_ALGO_MD5;
if( list_mode ) if( list_mode )
printf( "\tprotect algo: %d (hash algo: %d)\n", fprintf (listfp, "\tprotect algo: %d (hash algo: %d)\n",
sk->protect.algo, sk->protect.s2k.hash_algo ); sk->protect.algo, sk->protect.s2k.hash_algo );
} }
/* It is really ugly that we don't know the size /* It is really ugly that we don't know the size
@ -1772,11 +1794,12 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
for(i=0; i < sk->protect.ivlen && pktlen; i++, pktlen-- ) for(i=0; i < sk->protect.ivlen && pktlen; i++, pktlen-- )
temp[i] = iobuf_get_noeof(inp); temp[i] = iobuf_get_noeof(inp);
if( list_mode ) { if( list_mode ) {
printf( sk->protect.s2k.mode == 1002? "\tserial-number: " fprintf (listfp,
sk->protect.s2k.mode == 1002? "\tserial-number: "
: "\tprotect IV: "); : "\tprotect IV: ");
for(i=0; i < sk->protect.ivlen; i++ ) for(i=0; i < sk->protect.ivlen; i++ )
printf(" %02x", temp[i] ); fprintf (listfp, " %02x", temp[i] );
putchar('\n'); putc ('\n', listfp);
} }
memcpy(sk->protect.iv, temp, sk->protect.ivlen ); memcpy(sk->protect.iv, temp, sk->protect.ivlen );
} }
@ -1800,7 +1823,7 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
read_rest(inp, pktlen, 0),pktlen); read_rest(inp, pktlen, 0),pktlen);
pktlen = 0; pktlen = 0;
if( list_mode ) { if( list_mode ) {
printf("\tencrypted stuff follows\n"); fprintf (listfp, "\tencrypted stuff follows\n");
} }
} }
else { /* v3 method: the mpi length is not encrypted */ else { /* v3 method: the mpi length is not encrypted */
@ -1808,16 +1831,16 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
if ( sk->is_protected ) { if ( sk->is_protected ) {
sk->skey[i] = read_protected_v3_mpi (inp, &pktlen); sk->skey[i] = read_protected_v3_mpi (inp, &pktlen);
if( list_mode ) if( list_mode )
printf( "\tskey[%d]: [encrypted]\n", i); fprintf (listfp, "\tskey[%d]: [encrypted]\n", i);
} }
else { else {
n = pktlen; n = pktlen;
sk->skey[i] = mpi_read(inp, &n, 0 ); sk->skey[i] = mpi_read(inp, &n, 0 );
pktlen -=n; pktlen -=n;
if( list_mode ) { if( list_mode ) {
printf( "\tskey[%d]: ", i); fprintf (listfp, "\tskey[%d]: ", i);
mpi_print(stdout, sk->skey[i], mpi_print_mode ); mpi_print(listfp, sk->skey[i], mpi_print_mode );
putchar('\n'); putc ('\n', listfp);
} }
} }
@ -1829,7 +1852,7 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
sk->csum = read_16(inp); pktlen -= 2; sk->csum = read_16(inp); pktlen -= 2;
if( list_mode ) { if( list_mode ) {
printf("\tchecksum: %04hx\n", sk->csum); fprintf (listfp, "\tchecksum: %04hx\n", sk->csum);
} }
} }
} }
@ -1846,9 +1869,9 @@ parse_key( IOBUF inp, int pkttype, unsigned long pktlen,
for(i=0; i < npkey; i++ ) { for(i=0; i < npkey; i++ ) {
n = pktlen; pk->pkey[i] = mpi_read(inp, &n, 0 ); pktlen -=n; n = pktlen; pk->pkey[i] = mpi_read(inp, &n, 0 ); pktlen -=n;
if( list_mode ) { if( list_mode ) {
printf( "\tpkey[%d]: ", i); fprintf (listfp, "\tpkey[%d]: ", i);
mpi_print(stdout, pk->pkey[i], mpi_print_mode ); mpi_print(listfp, pk->pkey[i], mpi_print_mode );
putchar('\n'); putc ('\n', listfp);
} }
if (!pk->pkey[i]) if (!pk->pkey[i])
rc = G10ERR_INVALID_PACKET; rc = G10ERR_INVALID_PACKET;
@ -1959,15 +1982,15 @@ parse_user_id( IOBUF inp, int pkttype, unsigned long pktlen, PACKET *packet )
if( list_mode ) { if( list_mode ) {
int n = packet->pkt.user_id->len; int n = packet->pkt.user_id->len;
printf(":user ID packet: \""); fprintf (listfp, ":user ID packet: \"");
/* fixme: Hey why don't we replace this with print_string?? */ /* fixme: Hey why don't we replace this with print_string?? */
for(p=packet->pkt.user_id->name; n; p++, n-- ) { for(p=packet->pkt.user_id->name; n; p++, n-- ) {
if( *p >= ' ' && *p <= 'z' ) if( *p >= ' ' && *p <= 'z' )
putchar(*p); putc (*p, listfp);
else else
printf("\\x%02x", *p ); fprintf (listfp, "\\x%02x", *p );
} }
printf("\"\n"); fprintf (listfp, "\"\n");
} }
return 0; return 0;
} }
@ -2030,7 +2053,7 @@ parse_attribute( IOBUF inp, int pkttype, unsigned long pktlen, PACKET *packet )
make_attribute_uidname(packet->pkt.user_id, EXTRA_UID_NAME_SPACE); make_attribute_uidname(packet->pkt.user_id, EXTRA_UID_NAME_SPACE);
if( list_mode ) { if( list_mode ) {
printf(":attribute packet: %s\n", packet->pkt.user_id->name ); fprintf (listfp, ":attribute packet: %s\n", packet->pkt.user_id->name );
} }
return 0; return 0;
} }
@ -2049,15 +2072,15 @@ parse_comment( IOBUF inp, int pkttype, unsigned long pktlen, PACKET *packet )
if( list_mode ) { if( list_mode ) {
int n = packet->pkt.comment->len; int n = packet->pkt.comment->len;
printf(":%scomment packet: \"", pkttype == PKT_OLD_COMMENT? fprintf (listfp, ":%scomment packet: \"", pkttype == PKT_OLD_COMMENT?
"OpenPGP draft " : "" ); "OpenPGP draft " : "" );
for(p=packet->pkt.comment->data; n; p++, n-- ) { for(p=packet->pkt.comment->data; n; p++, n-- ) {
if( *p >= ' ' && *p <= 'z' ) if( *p >= ' ' && *p <= 'z' )
putchar(*p); putc (*p, listfp);
else else
printf("\\x%02x", *p ); fprintf (listfp, "\\x%02x", *p );
} }
printf("\"\n"); fprintf (listfp, "\"\n");
} }
return 0; return 0;
} }
@ -2084,14 +2107,14 @@ parse_trust( IOBUF inp, int pkttype, unsigned long pktlen, PACKET *pkt )
pkt->pkt.ring_trust->sigcache = c; pkt->pkt.ring_trust->sigcache = c;
} }
if( list_mode ) if( list_mode )
printf(":trust packet: flag=%02x sigcache=%02x\n", fprintf (listfp, ":trust packet: flag=%02x sigcache=%02x\n",
pkt->pkt.ring_trust->trustval, pkt->pkt.ring_trust->trustval,
pkt->pkt.ring_trust->sigcache); pkt->pkt.ring_trust->sigcache);
} }
else else
{ {
if( list_mode ) if( list_mode )
printf(":trust packet: empty\n"); fprintf (listfp, ":trust packet: empty\n");
} }
iobuf_skip_rest (inp, pktlen, 0); iobuf_skip_rest (inp, pktlen, 0);
} }
@ -2136,21 +2159,21 @@ parse_plaintext( IOBUF inp, int pkttype, unsigned long pktlen,
pktlen = 0; pktlen = 0;
if( list_mode ) { if( list_mode ) {
printf(":literal data packet:\n" fprintf (listfp, ":literal data packet:\n"
"\tmode %c (%X), created %lu, name=\"", "\tmode %c (%X), created %lu, name=\"",
mode >= ' ' && mode <'z'? mode : '?', mode, mode >= ' ' && mode <'z'? mode : '?', mode,
(ulong)pt->timestamp ); (ulong)pt->timestamp );
for(p=pt->name,i=0; i < namelen; p++, i++ ) { for(p=pt->name,i=0; i < namelen; p++, i++ ) {
if( *p >= ' ' && *p <= 'z' ) if( *p >= ' ' && *p <= 'z' )
putchar(*p); putc (*p, listfp);
else else
printf("\\x%02x", *p ); fprintf (listfp, "\\x%02x", *p );
} }
printf("\",\n\traw data: "); fprintf (listfp, "\",\n\traw data: ");
if(partial) if(partial)
printf("unknown length\n"); fprintf (listfp, "unknown length\n");
else else
printf("%lu bytes\n", (ulong)pt->len ); fprintf (listfp, "%lu bytes\n", (ulong)pt->len );
} }
leave: leave:
@ -2174,7 +2197,7 @@ parse_compressed( IOBUF inp, int pkttype, unsigned long pktlen,
zd->new_ctb = new_ctb; zd->new_ctb = new_ctb;
zd->buf = inp; zd->buf = inp;
if( list_mode ) if( list_mode )
printf(":compressed packet: algo=%d\n", zd->algorithm); fprintf (listfp, ":compressed packet: algo=%d\n", zd->algorithm);
return 0; return 0;
} }
@ -2223,11 +2246,12 @@ parse_encrypted( IOBUF inp, int pkttype, unsigned long pktlen,
} }
if( list_mode ) { if( list_mode ) {
if( orig_pktlen ) if( orig_pktlen )
printf(":encrypted data packet:\n\tlength: %lu\n", orig_pktlen); fprintf (listfp, ":encrypted data packet:\n\tlength: %lu\n",
orig_pktlen);
else else
printf(":encrypted data packet:\n\tlength: unknown\n"); fprintf (listfp, ":encrypted data packet:\n\tlength: unknown\n");
if( ed->mdc_method ) if( ed->mdc_method )
printf("\tmdc_method: %d\n", ed->mdc_method ); fprintf (listfp, "\tmdc_method: %d\n", ed->mdc_method );
} }
ed->buf = inp; ed->buf = inp;
@ -2247,7 +2271,7 @@ parse_mdc( IOBUF inp, int pkttype, unsigned long pktlen,
mdc = pkt->pkt.mdc= m_alloc(sizeof *pkt->pkt.mdc ); mdc = pkt->pkt.mdc= m_alloc(sizeof *pkt->pkt.mdc );
if( list_mode ) if( list_mode )
printf(":mdc packet: length=%lu\n", pktlen); fprintf (listfp, ":mdc packet: length=%lu\n", pktlen);
if( !new_ctb || pktlen != 20 ) { if( !new_ctb || pktlen != 20 ) {
log_error("mdc_packet with invalid encoding\n"); log_error("mdc_packet with invalid encoding\n");
rc = G10ERR_INVALID_PACKET; rc = G10ERR_INVALID_PACKET;
@ -2283,7 +2307,7 @@ parse_gpg_control( IOBUF inp, int pkttype,
int i; int i;
if ( list_mode ) if ( list_mode )
printf(":packet 63: length %lu ", pktlen); fprintf (listfp, ":packet 63: length %lu ", pktlen);
sesmark = get_session_marker ( &sesmarklen ); sesmark = get_session_marker ( &sesmarklen );
if ( pktlen < sesmarklen+1 ) /* 1 is for the control bytes */ if ( pktlen < sesmarklen+1 ) /* 1 is for the control bytes */
@ -2310,7 +2334,7 @@ parse_gpg_control( IOBUF inp, int pkttype,
int c; int c;
i=0; i=0;
printf("- private (rest length %lu)\n", pktlen); fprintf (listfp, "- private (rest length %lu)\n", pktlen);
if( partial ) { if( partial ) {
while( (c=iobuf_get(inp)) != -1 ) while( (c=iobuf_get(inp)) != -1 )
dump_hex_line(c, &i); dump_hex_line(c, &i);
@ -2319,7 +2343,7 @@ parse_gpg_control( IOBUF inp, int pkttype,
for( ; pktlen; pktlen-- ) for( ; pktlen; pktlen-- )
dump_hex_line(iobuf_get(inp), &i); dump_hex_line(iobuf_get(inp), &i);
} }
putchar('\n'); putc ('\n', listfp);
} }
iobuf_skip_rest(inp,pktlen, 0); iobuf_skip_rest(inp,pktlen, 0);
return G10ERR_INVALID_PACKET; return G10ERR_INVALID_PACKET;