aboutsummaryrefslogtreecommitdiffstats
path: root/src/engine-gpg.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/engine-gpg.c')
-rw-r--r--src/engine-gpg.c34
1 files changed, 33 insertions, 1 deletions
diff --git a/src/engine-gpg.c b/src/engine-gpg.c
index b099f566..fc9c7f90 100644
--- a/src/engine-gpg.c
+++ b/src/engine-gpg.c
@@ -153,6 +153,7 @@ struct engine_gpg
unsigned int include_key_block : 1;
unsigned int auto_key_import : 1;
unsigned int no_auto_check_trustdb : 1;
+ unsigned int proc_all_sigs : 1;
} flags;
/* NULL or the data object fed to --override_session_key-fd. */
@@ -435,6 +436,26 @@ have_usable_gpgtar (engine_gpg_t gpg)
}
+static int
+have_option_proc_all_sigs (engine_gpg_t gpg)
+{
+ static unsigned int flag;
+
+ if (flag)
+ ;
+ else if (have_gpg_version (gpg, "2.5.1"))
+ flag = 1|2;
+ else if (have_gpg_version (gpg, "2.4.6") && !have_gpg_version (gpg, "2.5.0"))
+ flag = 1|2;
+ else if (have_gpg_version (gpg, "2.2.45") && !have_gpg_version (gpg, "2.3.0"))
+ flag = 1|2;
+ else
+ flag = 1;
+
+ return !!(flag & 2);
+}
+
+
static void
free_argv (char **argv)
{
@@ -741,6 +762,7 @@ gpg_set_engine_flags (void *engine, const gpgme_ctx_t ctx)
}
gpg->flags.no_auto_check_trustdb = !!ctx->no_auto_check_trustdb;
+ gpg->flags.proc_all_sigs = !!ctx->proc_all_sigs;
}
@@ -985,7 +1007,7 @@ build_argv (engine_gpg_t gpg, const char *pgmname)
if (gpg->pinentry_mode)
argc += 1 + !!gpg->flags.use_gpgtar;
if (!gpg->cmd.used)
- argc++; /* --batch */
+ argc += 2; /* --batch and --proc-all-sigs */
argv = calloc (argc + 1, sizeof *argv);
allocated_argc = argc;
@@ -1220,6 +1242,16 @@ build_argv (engine_gpg_t gpg, const char *pgmname)
goto leave;
}
argc++;
+ if (gpg->flags.proc_all_sigs && have_option_proc_all_sigs (gpg))
+ {
+ argv[argc] = strdup ("--proc-all-sigs");
+ if (!argv[argc])
+ {
+ err = gpg_error_from_syserror ();
+ goto leave;
+ }
+ argc++;
+ }
}
for (a = gpg->arglist; a; a = a->next)
{