1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-18 14:17:03 +01:00

Marcus Brinkmann <marcus@g10code.de>

* gpgconf-comp.c (retrieve_options_from_file): Transfer the
	NO_CHANGE flag from the file name option to the list option.
This commit is contained in:
Marcus Brinkmann 2008-08-06 11:48:23 +00:00
parent 201a348565
commit f923f576e1
2 changed files with 13 additions and 1 deletions

View File

@ -1,3 +1,8 @@
2008-08-06 Marcus Brinkmann <marcus@g10code.de>
* gpgconf-comp.c (retrieve_options_from_file): Transfer the
NO_CHANGE flag from the file name option to the list option.
2008-06-19 Werner Koch <wk@g10code.com> 2008-06-19 Werner Koch <wk@g10code.com>
* gpgconf-comp.c (GC_ARG_TYPE_ALIAS_LIST): New. * gpgconf-comp.c (GC_ARG_TYPE_ALIAS_LIST): New.

View File

@ -165,7 +165,7 @@ static struct
/* 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 filename. 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). Note: This must be unique among all components. */
const char *option_config_filename; const char *option_config_filename;
/* If this is a file backend rather than a program backend, then /* If this is a file backend rather than a program backend, then
@ -1949,6 +1949,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;
gc_option_t *config_option;
char *list_filename; char *list_filename;
FILE *list_file; FILE *list_file;
char *line = NULL; char *line = NULL;
@ -2008,6 +2009,12 @@ retrieve_options_from_file (gc_component_t component, gc_backend_t backend)
list_option->active = 1; list_option->active = 1;
list_option->value = list; list_option->value = list;
/* Fix up the read-only flag. */
config_option = find_option
(component, gc_backend[backend].option_config_filename, GC_BACKEND_ANY);
if (config_option->flags & GC_OPT_FLAG_NO_CHANGE)
list_option->flags |= GC_OPT_FLAG_NO_CHANGE;
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_filename); gc_error (1, errno, "error closing %s", list_filename);
xfree (line); xfree (line);