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:
parent
2421f7f7ed
commit
91bc783383
@ -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);
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user