1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-08 12:44:23 +01:00

gpgtar: Simplify code by using ccparray.

* tools/gpgtar-create.c (gpgtar_create): Use ccparray functions.
* tools/gpgtar-extract.c (gpgtar_extract): Ditto.
* tools/gpgtar-list.c (gpgtar_list): Ditto.

Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
Werner Koch 2016-05-24 15:54:48 +02:00
parent 2421f7f7ed
commit 91bc783383
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B
3 changed files with 49 additions and 53 deletions

View File

@ -38,6 +38,7 @@
#include "i18n.h" #include "i18n.h"
#include "../common/exectool.h" #include "../common/exectool.h"
#include "../common/sysutils.h" #include "../common/sysutils.h"
#include "../common/ccparray.h"
#include "gpgtar.h" #include "gpgtar.h"
#ifndef HAVE_LSTAT #ifndef HAVE_LSTAT
@ -888,8 +889,8 @@ gpgtar_create (char **inpattern, int encrypt, int sign)
if (encrypt || sign) if (encrypt || sign)
{ {
int i;
strlist_t arg; strlist_t arg;
ccparray_t ccp;
const char **argv; const char **argv;
err = es_fseek (outstream, 0, SEEK_SET); err = es_fseek (outstream, 0, SEEK_SET);
@ -899,43 +900,36 @@ gpgtar_create (char **inpattern, int encrypt, int sign)
/* '--encrypt' may be combined with '--symmetric', but 'encrypt' /* '--encrypt' may be combined with '--symmetric', but 'encrypt'
is set either way. Clear it if no recipients are specified. is set either way. Clear it if no recipients are specified.
XXX: Fix command handling. */ XXX: Fix command handling. */
if (opt.symmetric && opt.recipients == NULL) if (opt.symmetric && opt.recipients == NULL)
encrypt = 0; encrypt = 0;
argv = xtrycalloc (strlist_length (opt.gpg_arguments) ccparray_init (&ccp, 0);
+ 2 * strlist_length (opt.recipients) if (encrypt)
+ 1 + !!encrypt + !!sign + 2 * !!opt.user ccparray_put (&ccp, "--encrypt");
+ !!opt.symmetric, if (sign)
sizeof *argv); ccparray_put (&ccp, "--sign");
if (argv == NULL) if (opt.user)
{
ccparray_put (&ccp, "--local-user");
ccparray_put (&ccp, opt.user);
}
if (opt.symmetric)
ccparray_put (&ccp, "--symmetric");
for (arg = opt.recipients; arg; arg = arg->next)
{
ccparray_put (&ccp, "--recipient");
ccparray_put (&ccp, arg->d);
}
for (arg = opt.gpg_arguments; arg; arg = arg->next)
ccparray_put (&ccp, arg->d);
ccparray_put (&ccp, NULL);
argv = ccparray_get (&ccp, NULL);
if (!argv)
{ {
err = gpg_error_from_syserror (); err = gpg_error_from_syserror ();
goto leave; goto leave;
} }
i = 0;
if (encrypt)
argv[i++] = "--encrypt";
if (sign)
argv[i++] = "--sign";
if (opt.user)
{
argv[i++] = "--local-user";
argv[i++] = opt.user;
}
if (opt.symmetric)
argv[i++] = "--symmetric";
for (arg = opt.recipients; arg; arg = arg->next)
{
argv[i++] = "--recipient";
argv[i++] = arg->d;
}
for (arg = opt.gpg_arguments; arg; arg = arg->next)
argv[i++] = arg->d;
argv[i++] = NULL;
assert (i == strlist_length (opt.gpg_arguments)
+ 2 * strlist_length (opt.recipients)
+ 1 + !!encrypt + !!sign + 2 * !!opt.user
+ !!opt.symmetric);
err = gnupg_exec_tool_stream (opt.gpg_program, argv, err = gnupg_exec_tool_stream (opt.gpg_program, argv,
outstream, cipher_stream); outstream, cipher_stream);

View File

@ -30,6 +30,7 @@
#include "i18n.h" #include "i18n.h"
#include "../common/exectool.h" #include "../common/exectool.h"
#include "../common/sysutils.h" #include "../common/sysutils.h"
#include "../common/ccparray.h"
#include "gpgtar.h" #include "gpgtar.h"
@ -299,8 +300,8 @@ gpgtar_extract (const char *filename, int decrypt)
if (decrypt) if (decrypt)
{ {
int i;
strlist_t arg; strlist_t arg;
ccparray_t ccp;
const char **argv; const char **argv;
cipher_stream = stream; cipher_stream = stream;
@ -311,19 +312,19 @@ gpgtar_extract (const char *filename, int decrypt)
goto leave; goto leave;
} }
argv = xtrycalloc (strlist_length (opt.gpg_arguments) + 2, ccparray_init (&ccp, 0);
sizeof *argv);
if (argv == NULL) ccparray_put (&ccp, "--decrypt");
for (arg = opt.gpg_arguments; arg; arg = arg->next)
ccparray_put (&ccp, arg->d);
ccparray_put (&ccp, NULL);
argv = ccparray_get (&ccp, NULL);
if (!argv)
{ {
err = gpg_error_from_syserror (); err = gpg_error_from_syserror ();
goto leave; goto leave;
} }
i = 0;
argv[i++] = "--decrypt";
for (arg = opt.gpg_arguments; arg; arg = arg->next)
argv[i++] = arg->d;
argv[i++] = NULL;
assert (i == strlist_length (opt.gpg_arguments) + 2);
err = gnupg_exec_tool_stream (opt.gpg_program, argv, err = gnupg_exec_tool_stream (opt.gpg_program, argv,
cipher_stream, stream); cipher_stream, stream);

View File

@ -27,6 +27,7 @@
#include "i18n.h" #include "i18n.h"
#include "gpgtar.h" #include "gpgtar.h"
#include "../common/exectool.h" #include "../common/exectool.h"
#include "../common/ccparray.h"
@ -299,8 +300,8 @@ gpgtar_list (const char *filename, int decrypt)
if (decrypt) if (decrypt)
{ {
int i;
strlist_t arg; strlist_t arg;
ccparray_t ccp;
const char **argv; const char **argv;
cipher_stream = stream; cipher_stream = stream;
@ -311,19 +312,19 @@ gpgtar_list (const char *filename, int decrypt)
goto leave; goto leave;
} }
argv = xtrycalloc (strlist_length (opt.gpg_arguments) + 2, ccparray_init (&ccp, 0);
sizeof *argv);
if (argv == NULL) ccparray_put (&ccp, "--decrypt");
for (arg = opt.gpg_arguments; arg; arg = arg->next)
ccparray_put (&ccp, arg->d);
ccparray_put (&ccp, NULL);
argv = ccparray_get (&ccp, NULL);
if (!argv)
{ {
err = gpg_error_from_syserror (); err = gpg_error_from_syserror ();
goto leave; goto leave;
} }
i = 0;
argv[i++] = "--decrypt";
for (arg = opt.gpg_arguments; arg; arg = arg->next)
argv[i++] = arg->d;
argv[i++] = NULL;
assert (i == strlist_length (opt.gpg_arguments) + 2);
err = gnupg_exec_tool_stream (opt.gpg_program, argv, err = gnupg_exec_tool_stream (opt.gpg_program, argv,
cipher_stream, stream); cipher_stream, stream);