mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-09 12:54:23 +01:00
2008-05-26 Marcus Brinkmann <marcus@g10code.de>
* gpgconf-comp.c: Replace pathname by filename everywhere.
This commit is contained in:
parent
9c10eb6625
commit
0950648f34
@ -1,4 +1,4 @@
|
|||||||
2008-05-26 Marcus Brinkmann <marcus@ulysses.g10code.com>
|
2008-05-26 Marcus Brinkmann <marcus@g10code.de>
|
||||||
|
|
||||||
* tools.texi (Invoking gpgconf): Document --list-dirs.
|
* tools.texi (Invoking gpgconf): Document --list-dirs.
|
||||||
|
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
2008-05-26 Marcus Brinkmann <marcus@ulysses.g10code.com>
|
2008-05-26 Marcus Brinkmann <marcus@g10code.de>
|
||||||
|
|
||||||
|
* gpgconf-comp.c: Replace pathname by filename everywhere.
|
||||||
|
|
||||||
* gpgconf.c (enum cmd_and_opt_values): Add aListDirs.
|
* gpgconf.c (enum cmd_and_opt_values): Add aListDirs.
|
||||||
(opts): Add aListDirs option.
|
(opts): Add aListDirs option.
|
||||||
|
@ -163,7 +163,7 @@ static struct
|
|||||||
void (*runtime_change) (void);
|
void (*runtime_change) (void);
|
||||||
|
|
||||||
/* The option name for the configuration filename of this backend.
|
/* The option name for the configuration filename of this backend.
|
||||||
This must be an absolute pathname. It can be an option from a
|
This must be an absolute filename. It can be an option from a
|
||||||
different backend (but then ordering of the options might
|
different backend (but then ordering of the options might
|
||||||
matter). */
|
matter). */
|
||||||
const char *option_config_filename;
|
const char *option_config_filename;
|
||||||
@ -218,8 +218,8 @@ typedef enum
|
|||||||
|
|
||||||
/* Complex argument types. */
|
/* Complex argument types. */
|
||||||
|
|
||||||
/* A complete pathname. */
|
/* A complete filename. */
|
||||||
GC_ARG_TYPE_PATHNAME = 32,
|
GC_ARG_TYPE_FILENAME = 32,
|
||||||
|
|
||||||
/* An LDAP server in the format
|
/* An LDAP server in the format
|
||||||
HOSTNAME:PORT:USERNAME:PASSWORD:BASE_DN. */
|
HOSTNAME:PORT:USERNAME:PASSWORD:BASE_DN. */
|
||||||
@ -276,7 +276,7 @@ static struct
|
|||||||
{ GC_ARG_TYPE_NR, NULL }, { GC_ARG_TYPE_NR, NULL },
|
{ GC_ARG_TYPE_NR, NULL }, { GC_ARG_TYPE_NR, NULL },
|
||||||
|
|
||||||
/* The complex argument types have a basic type as fallback. */
|
/* The complex argument types have a basic type as fallback. */
|
||||||
{ GC_ARG_TYPE_STRING, "pathname" },
|
{ GC_ARG_TYPE_STRING, "filename" },
|
||||||
{ GC_ARG_TYPE_STRING, "ldap server" },
|
{ GC_ARG_TYPE_STRING, "ldap server" },
|
||||||
{ GC_ARG_TYPE_STRING, "key fpr" },
|
{ GC_ARG_TYPE_STRING, "key fpr" },
|
||||||
{ GC_ARG_TYPE_STRING, "pub key" },
|
{ GC_ARG_TYPE_STRING, "pub key" },
|
||||||
@ -460,7 +460,7 @@ static gc_option_t gc_options_gpg_agent[] =
|
|||||||
{
|
{
|
||||||
/* The configuration file to which we write the changes. */
|
/* The configuration file to which we write the changes. */
|
||||||
{ "gpgconf-gpg-agent.conf", GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
{ "gpgconf-gpg-agent.conf", GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
||||||
NULL, NULL, GC_ARG_TYPE_PATHNAME, GC_BACKEND_GPG_AGENT },
|
NULL, NULL, GC_ARG_TYPE_FILENAME, GC_BACKEND_GPG_AGENT },
|
||||||
|
|
||||||
{ "Monitor",
|
{ "Monitor",
|
||||||
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
||||||
@ -480,7 +480,7 @@ static gc_option_t gc_options_gpg_agent[] =
|
|||||||
"gnupg", N_("Options controlling the configuration") },
|
"gnupg", N_("Options controlling the configuration") },
|
||||||
{ "options", GC_OPT_FLAG_NONE, GC_LEVEL_EXPERT,
|
{ "options", GC_OPT_FLAG_NONE, GC_LEVEL_EXPERT,
|
||||||
"gnupg", "|FILE|read options from FILE",
|
"gnupg", "|FILE|read options from FILE",
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_GPG_AGENT },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_GPG_AGENT },
|
||||||
{ "disable-scdaemon", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
{ "disable-scdaemon", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
||||||
"gnupg", "do not use the SCdaemon",
|
"gnupg", "do not use the SCdaemon",
|
||||||
GC_ARG_TYPE_NONE, GC_BACKEND_GPG_AGENT },
|
GC_ARG_TYPE_NONE, GC_BACKEND_GPG_AGENT },
|
||||||
@ -493,7 +493,7 @@ static gc_option_t gc_options_gpg_agent[] =
|
|||||||
GC_ARG_TYPE_STRING, GC_BACKEND_GPG_AGENT },
|
GC_ARG_TYPE_STRING, GC_BACKEND_GPG_AGENT },
|
||||||
{ "log-file", GC_OPT_FLAG_RUNTIME, GC_LEVEL_ADVANCED,
|
{ "log-file", GC_OPT_FLAG_RUNTIME, GC_LEVEL_ADVANCED,
|
||||||
"gnupg", N_("|FILE|write server mode logs to FILE"),
|
"gnupg", N_("|FILE|write server mode logs to FILE"),
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_GPG_AGENT },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_GPG_AGENT },
|
||||||
{ "faked-system-time", GC_OPT_FLAG_NONE, GC_LEVEL_INVISIBLE,
|
{ "faked-system-time", GC_OPT_FLAG_NONE, GC_LEVEL_INVISIBLE,
|
||||||
NULL, NULL,
|
NULL, NULL,
|
||||||
GC_ARG_TYPE_UINT32, GC_BACKEND_GPG_AGENT },
|
GC_ARG_TYPE_UINT32, GC_BACKEND_GPG_AGENT },
|
||||||
@ -545,7 +545,7 @@ static gc_option_t gc_options_gpg_agent[] =
|
|||||||
{ "check-passphrase-pattern", GC_OPT_FLAG_RUNTIME,
|
{ "check-passphrase-pattern", GC_OPT_FLAG_RUNTIME,
|
||||||
GC_LEVEL_EXPERT,
|
GC_LEVEL_EXPERT,
|
||||||
"gnupg", N_("|FILE|check new passphrases against pattern in FILE"),
|
"gnupg", N_("|FILE|check new passphrases against pattern in FILE"),
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_GPG_AGENT },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_GPG_AGENT },
|
||||||
{ "max-passphrase-days", GC_OPT_FLAG_RUNTIME,
|
{ "max-passphrase-days", GC_OPT_FLAG_RUNTIME,
|
||||||
GC_LEVEL_EXPERT, "gnupg",
|
GC_LEVEL_EXPERT, "gnupg",
|
||||||
N_("|N|expire the passphrase after N days"),
|
N_("|N|expire the passphrase after N days"),
|
||||||
@ -564,7 +564,7 @@ static gc_option_t gc_options_scdaemon[] =
|
|||||||
{
|
{
|
||||||
/* The configuration file to which we write the changes. */
|
/* The configuration file to which we write the changes. */
|
||||||
{ "gpgconf-scdaemon.conf", GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
{ "gpgconf-scdaemon.conf", GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
||||||
NULL, NULL, GC_ARG_TYPE_PATHNAME, GC_BACKEND_SCDAEMON },
|
NULL, NULL, GC_ARG_TYPE_FILENAME, GC_BACKEND_SCDAEMON },
|
||||||
|
|
||||||
{ "Monitor",
|
{ "Monitor",
|
||||||
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
||||||
@ -584,7 +584,7 @@ static gc_option_t gc_options_scdaemon[] =
|
|||||||
"gnupg", N_("Options controlling the configuration") },
|
"gnupg", N_("Options controlling the configuration") },
|
||||||
{ "options", GC_OPT_FLAG_NONE, GC_LEVEL_EXPERT,
|
{ "options", GC_OPT_FLAG_NONE, GC_LEVEL_EXPERT,
|
||||||
"gnupg", "|FILE|read options from FILE",
|
"gnupg", "|FILE|read options from FILE",
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_SCDAEMON },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_SCDAEMON },
|
||||||
{ "reader-port", GC_OPT_FLAG_NONE, GC_LEVEL_BASIC,
|
{ "reader-port", GC_OPT_FLAG_NONE, GC_LEVEL_BASIC,
|
||||||
"gnupg", "|N|connect to reader at port N",
|
"gnupg", "|N|connect to reader at port N",
|
||||||
GC_ARG_TYPE_STRING, GC_BACKEND_SCDAEMON },
|
GC_ARG_TYPE_STRING, GC_BACKEND_SCDAEMON },
|
||||||
@ -612,7 +612,7 @@ static gc_option_t gc_options_scdaemon[] =
|
|||||||
GC_ARG_TYPE_STRING, GC_BACKEND_SCDAEMON },
|
GC_ARG_TYPE_STRING, GC_BACKEND_SCDAEMON },
|
||||||
{ "log-file", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
{ "log-file", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
||||||
"gnupg", N_("|FILE|write server mode logs to FILE"),
|
"gnupg", N_("|FILE|write server mode logs to FILE"),
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_SCDAEMON },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_SCDAEMON },
|
||||||
|
|
||||||
{ "Security",
|
{ "Security",
|
||||||
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
||||||
@ -631,7 +631,7 @@ static gc_option_t gc_options_gpg[] =
|
|||||||
{
|
{
|
||||||
/* The configuration file to which we write the changes. */
|
/* The configuration file to which we write the changes. */
|
||||||
{ "gpgconf-gpg.conf", GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
{ "gpgconf-gpg.conf", GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
||||||
NULL, NULL, GC_ARG_TYPE_PATHNAME, GC_BACKEND_GPG },
|
NULL, NULL, GC_ARG_TYPE_FILENAME, GC_BACKEND_GPG },
|
||||||
|
|
||||||
{ "Monitor",
|
{ "Monitor",
|
||||||
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
||||||
@ -657,7 +657,7 @@ static gc_option_t gc_options_gpg[] =
|
|||||||
GC_ARG_TYPE_STRING, GC_BACKEND_GPG },
|
GC_ARG_TYPE_STRING, GC_BACKEND_GPG },
|
||||||
{ "options", GC_OPT_FLAG_NONE, GC_LEVEL_EXPERT,
|
{ "options", GC_OPT_FLAG_NONE, GC_LEVEL_EXPERT,
|
||||||
"gnupg", "|FILE|read options from FILE",
|
"gnupg", "|FILE|read options from FILE",
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_GPG },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_GPG },
|
||||||
|
|
||||||
{ "Debug",
|
{ "Debug",
|
||||||
GC_OPT_FLAG_GROUP, GC_LEVEL_ADVANCED,
|
GC_OPT_FLAG_GROUP, GC_LEVEL_ADVANCED,
|
||||||
@ -667,7 +667,7 @@ static gc_option_t gc_options_gpg[] =
|
|||||||
GC_ARG_TYPE_STRING, GC_BACKEND_GPG },
|
GC_ARG_TYPE_STRING, GC_BACKEND_GPG },
|
||||||
{ "log-file", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
{ "log-file", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
||||||
"gnupg", N_("|FILE|write server mode logs to FILE"),
|
"gnupg", N_("|FILE|write server mode logs to FILE"),
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_GPG },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_GPG },
|
||||||
/* { "faked-system-time", GC_OPT_FLAG_NONE, GC_LEVEL_INVISIBLE, */
|
/* { "faked-system-time", GC_OPT_FLAG_NONE, GC_LEVEL_INVISIBLE, */
|
||||||
/* NULL, NULL, */
|
/* NULL, NULL, */
|
||||||
/* GC_ARG_TYPE_UINT32, GC_BACKEND_GPG }, */
|
/* GC_ARG_TYPE_UINT32, GC_BACKEND_GPG }, */
|
||||||
@ -696,7 +696,7 @@ static gc_option_t gc_options_gpgsm[] =
|
|||||||
{
|
{
|
||||||
/* The configuration file to which we write the changes. */
|
/* The configuration file to which we write the changes. */
|
||||||
{ "gpgconf-gpgsm.conf", GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
{ "gpgconf-gpgsm.conf", GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
||||||
NULL, NULL, GC_ARG_TYPE_PATHNAME, GC_BACKEND_GPGSM },
|
NULL, NULL, GC_ARG_TYPE_FILENAME, GC_BACKEND_GPGSM },
|
||||||
|
|
||||||
{ "Monitor",
|
{ "Monitor",
|
||||||
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
||||||
@ -722,7 +722,7 @@ static gc_option_t gc_options_gpgsm[] =
|
|||||||
GC_ARG_TYPE_STRING, GC_BACKEND_GPGSM },
|
GC_ARG_TYPE_STRING, GC_BACKEND_GPGSM },
|
||||||
{ "options", GC_OPT_FLAG_NONE, GC_LEVEL_EXPERT,
|
{ "options", GC_OPT_FLAG_NONE, GC_LEVEL_EXPERT,
|
||||||
"gnupg", "|FILE|read options from FILE",
|
"gnupg", "|FILE|read options from FILE",
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_GPGSM },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_GPGSM },
|
||||||
{ "prefer-system-dirmngr", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
{ "prefer-system-dirmngr", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
||||||
"gnupg", "use system's dirmngr if available",
|
"gnupg", "use system's dirmngr if available",
|
||||||
GC_ARG_TYPE_NONE, GC_BACKEND_GPGSM },
|
GC_ARG_TYPE_NONE, GC_BACKEND_GPGSM },
|
||||||
@ -741,7 +741,7 @@ static gc_option_t gc_options_gpgsm[] =
|
|||||||
GC_ARG_TYPE_STRING, GC_BACKEND_GPGSM },
|
GC_ARG_TYPE_STRING, GC_BACKEND_GPGSM },
|
||||||
{ "log-file", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
{ "log-file", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
||||||
"gnupg", N_("|FILE|write server mode logs to FILE"),
|
"gnupg", N_("|FILE|write server mode logs to FILE"),
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_GPGSM },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_GPGSM },
|
||||||
{ "faked-system-time", GC_OPT_FLAG_NONE, GC_LEVEL_INVISIBLE,
|
{ "faked-system-time", GC_OPT_FLAG_NONE, GC_LEVEL_INVISIBLE,
|
||||||
NULL, NULL,
|
NULL, NULL,
|
||||||
GC_ARG_TYPE_UINT32, GC_BACKEND_GPGSM },
|
GC_ARG_TYPE_UINT32, GC_BACKEND_GPGSM },
|
||||||
@ -780,7 +780,7 @@ static gc_option_t gc_options_dirmngr[] =
|
|||||||
{
|
{
|
||||||
/* The configuration file to which we write the changes. */
|
/* The configuration file to which we write the changes. */
|
||||||
{ "gpgconf-dirmngr.conf", GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
{ "gpgconf-dirmngr.conf", GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
||||||
NULL, NULL, GC_ARG_TYPE_PATHNAME, GC_BACKEND_DIRMNGR },
|
NULL, NULL, GC_ARG_TYPE_FILENAME, GC_BACKEND_DIRMNGR },
|
||||||
|
|
||||||
{ "Monitor",
|
{ "Monitor",
|
||||||
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
GC_OPT_FLAG_GROUP, GC_LEVEL_BASIC,
|
||||||
@ -810,7 +810,7 @@ static gc_option_t gc_options_dirmngr[] =
|
|||||||
"gnupg", N_("Options controlling the configuration") },
|
"gnupg", N_("Options controlling the configuration") },
|
||||||
{ "options", GC_OPT_FLAG_NONE, GC_LEVEL_EXPERT,
|
{ "options", GC_OPT_FLAG_NONE, GC_LEVEL_EXPERT,
|
||||||
"dirmngr", "|FILE|read options from FILE",
|
"dirmngr", "|FILE|read options from FILE",
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_DIRMNGR },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_DIRMNGR },
|
||||||
|
|
||||||
{ "Debug",
|
{ "Debug",
|
||||||
GC_OPT_FLAG_GROUP, GC_LEVEL_ADVANCED,
|
GC_OPT_FLAG_GROUP, GC_LEVEL_ADVANCED,
|
||||||
@ -823,7 +823,7 @@ static gc_option_t gc_options_dirmngr[] =
|
|||||||
GC_ARG_TYPE_NONE, GC_BACKEND_DIRMNGR },
|
GC_ARG_TYPE_NONE, GC_BACKEND_DIRMNGR },
|
||||||
{ "log-file", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
{ "log-file", GC_OPT_FLAG_NONE, GC_LEVEL_ADVANCED,
|
||||||
"dirmngr", N_("|FILE|write server mode logs to FILE"),
|
"dirmngr", N_("|FILE|write server mode logs to FILE"),
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_DIRMNGR },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_DIRMNGR },
|
||||||
{ "debug-wait", GC_OPT_FLAG_NONE, GC_LEVEL_INVISIBLE,
|
{ "debug-wait", GC_OPT_FLAG_NONE, GC_LEVEL_INVISIBLE,
|
||||||
NULL, NULL,
|
NULL, NULL,
|
||||||
GC_ARG_TYPE_UINT32, GC_BACKEND_DIRMNGR },
|
GC_ARG_TYPE_UINT32, GC_BACKEND_DIRMNGR },
|
||||||
@ -883,7 +883,7 @@ static gc_option_t gc_options_dirmngr[] =
|
|||||||
{ "ldapserverlist-file",
|
{ "ldapserverlist-file",
|
||||||
GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
GC_OPT_FLAG_NONE, GC_LEVEL_INTERNAL,
|
||||||
"dirmngr", "|FILE|read LDAP server list from FILE",
|
"dirmngr", "|FILE|read LDAP server list from FILE",
|
||||||
GC_ARG_TYPE_PATHNAME, GC_BACKEND_DIRMNGR },
|
GC_ARG_TYPE_FILENAME, GC_BACKEND_DIRMNGR },
|
||||||
/* This entry must come after at least one entry for
|
/* This entry must come after at least one entry for
|
||||||
GC_BACKEND_DIRMNGR in this component, so that the entry for
|
GC_BACKEND_DIRMNGR in this component, so that the entry for
|
||||||
"ldapserverlist-file will be initialized before this one. */
|
"ldapserverlist-file will be initialized before this one. */
|
||||||
@ -1673,16 +1673,16 @@ find_option (gc_component_t component, const char *name,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Determine the configuration pathname for the component COMPONENT
|
/* Determine the configuration filename for the component COMPONENT
|
||||||
and backend BACKEND. */
|
and backend BACKEND. */
|
||||||
static char *
|
static char *
|
||||||
get_config_pathname (gc_component_t component, gc_backend_t backend)
|
get_config_filename (gc_component_t component, gc_backend_t backend)
|
||||||
{
|
{
|
||||||
char *pathname = NULL;
|
char *filename = NULL;
|
||||||
gc_option_t *option = find_option
|
gc_option_t *option = find_option
|
||||||
(component, gc_backend[backend].option_config_filename, GC_BACKEND_ANY);
|
(component, gc_backend[backend].option_config_filename, GC_BACKEND_ANY);
|
||||||
assert (option);
|
assert (option);
|
||||||
assert (option->arg_type == GC_ARG_TYPE_PATHNAME);
|
assert (option->arg_type == GC_ARG_TYPE_FILENAME);
|
||||||
assert (!(option->flags & GC_OPT_FLAG_LIST));
|
assert (!(option->flags & GC_OPT_FLAG_LIST));
|
||||||
|
|
||||||
if (!option->active || !option->default_value)
|
if (!option->active || !option->default_value)
|
||||||
@ -1691,24 +1691,24 @@ get_config_pathname (gc_component_t component, gc_backend_t backend)
|
|||||||
gc_backend[backend].name);
|
gc_backend[backend].name);
|
||||||
|
|
||||||
if (option->value && *option->value)
|
if (option->value && *option->value)
|
||||||
pathname = percent_deescape (&option->value[1]);
|
filename = percent_deescape (&option->value[1]);
|
||||||
else if (option->default_value && *option->default_value)
|
else if (option->default_value && *option->default_value)
|
||||||
pathname = percent_deescape (&option->default_value[1]);
|
filename = percent_deescape (&option->default_value[1]);
|
||||||
else
|
else
|
||||||
pathname = "";
|
filename = "";
|
||||||
|
|
||||||
#ifdef HAVE_DOSISH_SYSTEM
|
#ifdef HAVE_DOSISH_SYSTEM
|
||||||
if (!(pathname[0]
|
if (!(filename[0]
|
||||||
&& pathname[1] == ':'
|
&& filename[1] == ':'
|
||||||
&& (pathname[2] == '/' || pathname[2] == '\\')))
|
&& (filename[2] == '/' || filename[2] == '\\')))
|
||||||
#else
|
#else
|
||||||
if (pathname[0] != '/')
|
if (filename[0] != '/')
|
||||||
#endif
|
#endif
|
||||||
gc_error (1, 0, "Option %s, needed by backend %s, is not absolute",
|
gc_error (1, 0, "Option %s, needed by backend %s, is not absolute",
|
||||||
gc_backend[backend].option_config_filename,
|
gc_backend[backend].option_config_filename,
|
||||||
gc_backend[backend].name);
|
gc_backend[backend].name);
|
||||||
|
|
||||||
return pathname;
|
return filename;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1727,7 +1727,7 @@ retrieve_options_from_program (gc_component_t component, gc_backend_t backend)
|
|||||||
size_t line_len = 0;
|
size_t line_len = 0;
|
||||||
ssize_t length;
|
ssize_t length;
|
||||||
FILE *config;
|
FILE *config;
|
||||||
char *config_pathname;
|
char *config_filename;
|
||||||
|
|
||||||
err = gnupg_create_inbound_pipe (filedes);
|
err = gnupg_create_inbound_pipe (filedes);
|
||||||
if (err)
|
if (err)
|
||||||
@ -1833,12 +1833,12 @@ retrieve_options_from_program (gc_component_t component, gc_backend_t backend)
|
|||||||
|
|
||||||
|
|
||||||
/* At this point, we can parse the configuration file. */
|
/* At this point, we can parse the configuration file. */
|
||||||
config_pathname = get_config_pathname (component, backend);
|
config_filename = get_config_filename (component, backend);
|
||||||
|
|
||||||
config = fopen (config_pathname, "r");
|
config = fopen (config_filename, "r");
|
||||||
if (!config)
|
if (!config)
|
||||||
gc_error (0, errno, "warning: can not open config file %s",
|
gc_error (0, errno, "warning: can not open config file %s",
|
||||||
config_pathname);
|
config_filename);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
while ((length = read_line (config, &line, &line_len, NULL)) > 0)
|
while ((length = read_line (config, &line, &line_len, NULL)) > 0)
|
||||||
@ -1923,9 +1923,9 @@ retrieve_options_from_program (gc_component_t component, gc_backend_t backend)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (length < 0 || ferror (config))
|
if (length < 0 || ferror (config))
|
||||||
gc_error (1, errno, "error reading from %s", config_pathname);
|
gc_error (1, errno, "error reading from %s", config_filename);
|
||||||
if (fclose (config) && ferror (config))
|
if (fclose (config) && ferror (config))
|
||||||
gc_error (1, errno, "error closing %s", config_pathname);
|
gc_error (1, errno, "error closing %s", config_filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
xfree (line);
|
xfree (line);
|
||||||
@ -1938,7 +1938,7 @@ static void
|
|||||||
retrieve_options_from_file (gc_component_t component, gc_backend_t backend)
|
retrieve_options_from_file (gc_component_t component, gc_backend_t backend)
|
||||||
{
|
{
|
||||||
gc_option_t *list_option;
|
gc_option_t *list_option;
|
||||||
char *list_pathname;
|
char *list_filename;
|
||||||
FILE *list_file;
|
FILE *list_file;
|
||||||
char *line = NULL;
|
char *line = NULL;
|
||||||
size_t line_len = 0;
|
size_t line_len = 0;
|
||||||
@ -1950,10 +1950,10 @@ retrieve_options_from_file (gc_component_t component, gc_backend_t backend)
|
|||||||
assert (list_option);
|
assert (list_option);
|
||||||
assert (!list_option->active);
|
assert (!list_option->active);
|
||||||
|
|
||||||
list_pathname = get_config_pathname (component, backend);
|
list_filename = get_config_filename (component, backend);
|
||||||
list_file = fopen (list_pathname, "r");
|
list_file = fopen (list_filename, "r");
|
||||||
if (!list_file)
|
if (!list_file)
|
||||||
gc_error (0, errno, "warning: can not open list file %s", list_pathname);
|
gc_error (0, errno, "warning: can not open list file %s", list_filename);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -1991,14 +1991,14 @@ retrieve_options_from_file (gc_component_t component, gc_backend_t backend)
|
|||||||
list = xasprintf ("\"%s", gc_percent_escape (start));
|
list = xasprintf ("\"%s", gc_percent_escape (start));
|
||||||
}
|
}
|
||||||
if (length < 0 || ferror (list_file))
|
if (length < 0 || ferror (list_file))
|
||||||
gc_error (1, errno, "can not read list file %s", list_pathname);
|
gc_error (1, errno, "can not read list file %s", list_filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
list_option->active = 1;
|
list_option->active = 1;
|
||||||
list_option->value = list;
|
list_option->value = list;
|
||||||
|
|
||||||
if (list_file && fclose (list_file) && ferror (list_file))
|
if (list_file && fclose (list_file) && ferror (list_file))
|
||||||
gc_error (1, errno, "error closing %s", list_pathname);
|
gc_error (1, errno, "error closing %s", list_filename);
|
||||||
xfree (line);
|
xfree (line);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2259,9 +2259,9 @@ change_options_file (gc_component_t component, gc_backend_t backend,
|
|||||||
assert (gc_arg_type[option->arg_type].fallback != GC_ARG_TYPE_NONE);
|
assert (gc_arg_type[option->arg_type].fallback != GC_ARG_TYPE_NONE);
|
||||||
|
|
||||||
/* FIXME. Throughout the function, do better error reporting. */
|
/* FIXME. Throughout the function, do better error reporting. */
|
||||||
/* Note that get_config_pathname() calls percent_deescape(), so we
|
/* Note that get_config_filename() calls percent_deescape(), so we
|
||||||
call this before processing the arguments. */
|
call this before processing the arguments. */
|
||||||
dest_filename = xstrdup (get_config_pathname (component, backend));
|
dest_filename = xstrdup (get_config_filename (component, backend));
|
||||||
src_filename = xasprintf ("%s.gpgconf.%i.new", dest_filename, getpid ());
|
src_filename = xasprintf ("%s.gpgconf.%i.new", dest_filename, getpid ());
|
||||||
orig_filename = xasprintf ("%s.gpgconf.%i.bak", dest_filename, getpid ());
|
orig_filename = xasprintf ("%s.gpgconf.%i.bak", dest_filename, getpid ());
|
||||||
|
|
||||||
@ -2553,7 +2553,7 @@ change_options_program (gc_component_t component, gc_backend_t backend,
|
|||||||
int utf8strings_seen = 0;
|
int utf8strings_seen = 0;
|
||||||
|
|
||||||
/* FIXME. Throughout the function, do better error reporting. */
|
/* FIXME. Throughout the function, do better error reporting. */
|
||||||
dest_filename = xstrdup (get_config_pathname (component, backend));
|
dest_filename = xstrdup (get_config_filename (component, backend));
|
||||||
src_filename = xasprintf ("%s.gpgconf.%i.new", dest_filename, getpid ());
|
src_filename = xasprintf ("%s.gpgconf.%i.new", dest_filename, getpid ());
|
||||||
orig_filename = xasprintf ("%s.gpgconf.%i.bak", dest_filename, getpid ());
|
orig_filename = xasprintf ("%s.gpgconf.%i.bak", dest_filename, getpid ());
|
||||||
|
|
||||||
@ -2874,9 +2874,9 @@ gc_component_change_options (int component, FILE *in, FILE *out)
|
|||||||
{
|
{
|
||||||
int err = 0;
|
int err = 0;
|
||||||
int runtime[GC_BACKEND_NR];
|
int runtime[GC_BACKEND_NR];
|
||||||
char *src_pathname[GC_BACKEND_NR];
|
char *src_filename[GC_BACKEND_NR];
|
||||||
char *dest_pathname[GC_BACKEND_NR];
|
char *dest_filename[GC_BACKEND_NR];
|
||||||
char *orig_pathname[GC_BACKEND_NR];
|
char *orig_filename[GC_BACKEND_NR];
|
||||||
gc_backend_t backend;
|
gc_backend_t backend;
|
||||||
gc_option_t *option;
|
gc_option_t *option;
|
||||||
char *line = NULL;
|
char *line = NULL;
|
||||||
@ -2886,9 +2886,9 @@ gc_component_change_options (int component, FILE *in, FILE *out)
|
|||||||
for (backend = 0; backend < GC_BACKEND_NR; backend++)
|
for (backend = 0; backend < GC_BACKEND_NR; backend++)
|
||||||
{
|
{
|
||||||
runtime[backend] = 0;
|
runtime[backend] = 0;
|
||||||
src_pathname[backend] = NULL;
|
src_filename[backend] = NULL;
|
||||||
dest_pathname[backend] = NULL;
|
dest_filename[backend] = NULL;
|
||||||
orig_pathname[backend] = NULL;
|
orig_filename[backend] = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (in)
|
if (in)
|
||||||
@ -2966,7 +2966,7 @@ gc_component_change_options (int component, FILE *in, FILE *out)
|
|||||||
{
|
{
|
||||||
/* Go on if we have already seen this backend, or if there is
|
/* Go on if we have already seen this backend, or if there is
|
||||||
nothing to do. */
|
nothing to do. */
|
||||||
if (src_pathname[option->backend]
|
if (src_filename[option->backend]
|
||||||
|| !(option->new_flags || option->new_value))
|
|| !(option->new_flags || option->new_value))
|
||||||
{
|
{
|
||||||
option++;
|
option++;
|
||||||
@ -2976,14 +2976,14 @@ gc_component_change_options (int component, FILE *in, FILE *out)
|
|||||||
if (gc_backend[option->backend].program)
|
if (gc_backend[option->backend].program)
|
||||||
{
|
{
|
||||||
err = change_options_program (component, option->backend,
|
err = change_options_program (component, option->backend,
|
||||||
&src_pathname[option->backend],
|
&src_filename[option->backend],
|
||||||
&dest_pathname[option->backend],
|
&dest_filename[option->backend],
|
||||||
&orig_pathname[option->backend]);
|
&orig_filename[option->backend]);
|
||||||
if (! err)
|
if (! err)
|
||||||
{
|
{
|
||||||
/* External verification. */
|
/* External verification. */
|
||||||
err = gc_component_check_options (component, out,
|
err = gc_component_check_options (component, out,
|
||||||
src_pathname[option->backend]);
|
src_filename[option->backend]);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
gc_error (0, 0,
|
gc_error (0, 0,
|
||||||
@ -2996,9 +2996,9 @@ gc_component_change_options (int component, FILE *in, FILE *out)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
err = change_options_file (component, option->backend,
|
err = change_options_file (component, option->backend,
|
||||||
&src_pathname[option->backend],
|
&src_filename[option->backend],
|
||||||
&dest_pathname[option->backend],
|
&dest_filename[option->backend],
|
||||||
&orig_pathname[option->backend]);
|
&orig_filename[option->backend]);
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
break;
|
break;
|
||||||
@ -3012,39 +3012,39 @@ gc_component_change_options (int component, FILE *in, FILE *out)
|
|||||||
|
|
||||||
for (i = 0; i < GC_BACKEND_NR; i++)
|
for (i = 0; i < GC_BACKEND_NR; i++)
|
||||||
{
|
{
|
||||||
if (src_pathname[i])
|
if (src_filename[i])
|
||||||
{
|
{
|
||||||
/* FIXME: Make a verification here. */
|
/* FIXME: Make a verification here. */
|
||||||
|
|
||||||
assert (dest_pathname[i]);
|
assert (dest_filename[i]);
|
||||||
|
|
||||||
if (orig_pathname[i])
|
if (orig_filename[i])
|
||||||
{
|
{
|
||||||
#ifdef HAVE_W32_SYSTEM
|
#ifdef HAVE_W32_SYSTEM
|
||||||
/* There is no atomic update on W32. */
|
/* There is no atomic update on W32. */
|
||||||
err = unlink (dest_pathname[i]);
|
err = unlink (dest_filename[i]);
|
||||||
#endif /* HAVE_W32_SYSTEM */
|
#endif /* HAVE_W32_SYSTEM */
|
||||||
if (!err)
|
if (!err)
|
||||||
err = rename (src_pathname[i], dest_pathname[i]);
|
err = rename (src_filename[i], dest_filename[i]);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
#ifdef HAVE_W32_SYSTEM
|
#ifdef HAVE_W32_SYSTEM
|
||||||
/* We skip the unlink if we expect the file not to
|
/* We skip the unlink if we expect the file not to
|
||||||
be there. */
|
be there. */
|
||||||
err = rename (src_pathname[i], dest_pathname[i]);
|
err = rename (src_filename[i], dest_filename[i]);
|
||||||
#else /* HAVE_W32_SYSTEM */
|
#else /* HAVE_W32_SYSTEM */
|
||||||
/* This is a bit safer than rename() because we
|
/* This is a bit safer than rename() because we
|
||||||
expect DEST_PATHNAME not to be there. If it
|
expect DEST_FILENAME not to be there. If it
|
||||||
happens to be there, this will fail. */
|
happens to be there, this will fail. */
|
||||||
err = link (src_pathname[i], dest_pathname[i]);
|
err = link (src_filename[i], dest_filename[i]);
|
||||||
if (!err)
|
if (!err)
|
||||||
err = unlink (src_pathname[i]);
|
err = unlink (src_filename[i]);
|
||||||
#endif /* !HAVE_W32_SYSTEM */
|
#endif /* !HAVE_W32_SYSTEM */
|
||||||
}
|
}
|
||||||
if (err)
|
if (err)
|
||||||
break;
|
break;
|
||||||
src_pathname[i] = NULL;
|
src_filename[i] = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3057,12 +3057,12 @@ gc_component_change_options (int component, FILE *in, FILE *out)
|
|||||||
/* An error occured or a dry-run is requested. */
|
/* An error occured or a dry-run is requested. */
|
||||||
for (i = 0; i < GC_BACKEND_NR; i++)
|
for (i = 0; i < GC_BACKEND_NR; i++)
|
||||||
{
|
{
|
||||||
if (src_pathname[i])
|
if (src_filename[i])
|
||||||
{
|
{
|
||||||
/* The change was not yet committed. */
|
/* The change was not yet committed. */
|
||||||
unlink (src_pathname[i]);
|
unlink (src_filename[i]);
|
||||||
if (orig_pathname[i])
|
if (orig_filename[i])
|
||||||
unlink (orig_pathname[i]);
|
unlink (orig_filename[i]);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -3070,16 +3070,16 @@ gc_component_change_options (int component, FILE *in, FILE *out)
|
|||||||
tad dangerous, as we don't know if we don't overwrite
|
tad dangerous, as we don't know if we don't overwrite
|
||||||
a version of the file that is even newer than the one
|
a version of the file that is even newer than the one
|
||||||
we just installed. */
|
we just installed. */
|
||||||
if (orig_pathname[i])
|
if (orig_filename[i])
|
||||||
{
|
{
|
||||||
#ifdef HAVE_W32_SYSTEM
|
#ifdef HAVE_W32_SYSTEM
|
||||||
/* There is no atomic update on W32. */
|
/* There is no atomic update on W32. */
|
||||||
unlink (dest_pathname[i]);
|
unlink (dest_filename[i]);
|
||||||
#endif /* HAVE_W32_SYSTEM */
|
#endif /* HAVE_W32_SYSTEM */
|
||||||
rename (orig_pathname[i], dest_pathname[i]);
|
rename (orig_filename[i], dest_filename[i]);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
unlink (dest_pathname[i]);
|
unlink (dest_filename[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (err)
|
if (err)
|
||||||
@ -3099,19 +3099,19 @@ gc_component_change_options (int component, FILE *in, FILE *out)
|
|||||||
|
|
||||||
/* Move the per-process backup file into its place. */
|
/* Move the per-process backup file into its place. */
|
||||||
for (backend = 0; backend < GC_BACKEND_NR; backend++)
|
for (backend = 0; backend < GC_BACKEND_NR; backend++)
|
||||||
if (orig_pathname[backend])
|
if (orig_filename[backend])
|
||||||
{
|
{
|
||||||
char *backup_pathname;
|
char *backup_filename;
|
||||||
|
|
||||||
assert (dest_pathname[backend]);
|
assert (dest_filename[backend]);
|
||||||
|
|
||||||
backup_pathname = xasprintf ("%s.gpgconf.bak", dest_pathname[backend]);
|
backup_filename = xasprintf ("%s.gpgconf.bak", dest_filename[backend]);
|
||||||
|
|
||||||
#ifdef HAVE_W32_SYSTEM
|
#ifdef HAVE_W32_SYSTEM
|
||||||
/* There is no atomic update on W32. */
|
/* There is no atomic update on W32. */
|
||||||
unlink (backup_pathname);
|
unlink (backup_filename);
|
||||||
#endif /* HAVE_W32_SYSTEM */
|
#endif /* HAVE_W32_SYSTEM */
|
||||||
rename (orig_pathname[backend], backup_pathname);
|
rename (orig_filename[backend], backup_filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
leave:
|
leave:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user