aboutsummaryrefslogtreecommitdiffstats
path: root/g10
diff options
context:
space:
mode:
Diffstat (limited to 'g10')
-rw-r--r--g10/misc.c22
-rw-r--r--g10/pkglue.c2
2 files changed, 18 insertions, 6 deletions
diff --git a/g10/misc.c b/g10/misc.c
index c52091830..43be620e6 100644
--- a/g10/misc.c
+++ b/g10/misc.c
@@ -1578,25 +1578,37 @@ parse_options(char *str,unsigned int *options,
{
char *tok;
- if (str && (!strcmp (str, "help") || !strcmp (str, "full-help")))
+ if (str && (!strcmp (str, "help")
+ || !strcmp (str, "full-help") || !strcmp (str, "fullhelp")))
{
int i,maxlen=0;
int full = *str == 'f';
+ int set;
/* Figure out the longest option name so we can line these up
neatly. */
for(i=0;opts[i].name;i++)
- if(opts[i].help && maxlen<strlen(opts[i].name))
+ if((full || opts[i].help) && maxlen<strlen(opts[i].name))
maxlen=strlen(opts[i].name);
for(i=0;opts[i].name;i++)
if(opts[i].help)
- es_printf("%s%*s%s\n",opts[i].name,
- maxlen+2-(int)strlen(opts[i].name),"",_(opts[i].help));
+ {
+ set = (*options & opts[i].bit);
+ es_printf("%s%*s%s%s%s%s\n",opts[i].name,
+ maxlen+2-(int)strlen(opts[i].name),"",_(opts[i].help),
+ set?" [":"", set? _("enabled"):"", set?"]":"");
+ }
+
if (full)
for (i=0; opts[i].name; i++)
if(!opts[i].help)
- es_printf("%s\n",opts[i].name);
+ {
+ set = (*options & opts[i].bit);
+ es_printf("%s%*s%s%s%s\n",opts[i].name,
+ set? (maxlen+2-(int)strlen(opts[i].name)):0,"",
+ set?"[":"", set? _("enabled"):"", set?"]":"");
+ }
g10_exit(0);
}
diff --git a/g10/pkglue.c b/g10/pkglue.c
index a6bd893b3..11d252f0a 100644
--- a/g10/pkglue.c
+++ b/g10/pkglue.c
@@ -486,8 +486,8 @@ do_encrypt_kem (PKT_public_key *pk, gcry_mpi_t data, int seskey_algo,
goto leave;
}
ecc_ct_len = ecc_ecdh_len = ecc->point_len;
- ecc_ss_len = ecc->scalar_len;
ecc_hash_algo = ecc->hash_algo;
+ ecc_ss_len = gcry_md_get_algo_dlen (ecc_hash_algo);
ecc_pubkey = gcry_mpi_get_opaque (pk->pkey[1], &nbits);
ecc_pubkey_len = (nbits+7)/8;