diff options
| -rw-r--r-- | src/w32-util.c | 25 | 
1 files changed, 22 insertions, 3 deletions
| diff --git a/src/w32-util.c b/src/w32-util.c index 5b02c7ea..30dd081a 100644 --- a/src/w32-util.c +++ b/src/w32-util.c @@ -72,6 +72,17 @@  # define F_OK 0  #endif +/* The Registry key used by GNUPG.  */ +#ifdef _WIN64 +# define GNUPG_REGKEY_2  "Software\\Wow6432Node\\GNU\\GnuPG" +#else +# define GNUPG_REGKEY_2  "Software\\GNU\\GnuPG" +#endif +#ifdef _WIN64 +# define GNUPG_REGKEY_3  "Software\\Wow6432Node\\GnuPG" +#else +# define GNUPG_REGKEY_3  "Software\\GnuPG" +#endif  DEFINE_STATIC_LOCK (get_path_lock); @@ -513,7 +524,7 @@ _gpgme_get_gpg_path (void)        char *dir;        dir = read_w32_registry_string ("HKEY_LOCAL_MACHINE", -                                      "Software\\GNU\\GnuPG", +                                      GNUPG_REGKEY_2,                                        "Install Directory");        if (dir)          { @@ -568,12 +579,12 @@ _gpgme_get_gpgconf_path (void)        char *dir;        dir = read_w32_registry_string (NULL, -                                      "Software\\GNU\\GnuPG", +                                      GNUPG_REGKEY_2,                                        "Install Directory");        if (!dir)          {            char *tmp = read_w32_registry_string (NULL, -                                                "Software\\GnuPG", +                                                GNUPG_REGKEY_3,                                                  "Install Directory");            if (tmp)              { @@ -596,6 +607,14 @@ _gpgme_get_gpgconf_path (void)        gpgconf = find_program_at_standard_place ("GNU\\GnuPG\\gpgconf.exe");      } +  /* 5. Try to find gpgconf.exe relative to us.  */ +  if (!gpgconf && inst_dir) +    { +      char *dir = _gpgme_strconcat (inst_dir, "\\..\\..\\GnuPG\\bin"); +      gpgconf = find_program_in_dir (dir, name); +      free (dir); +    } +    /* 5. Print a debug message if not found.  */    if (!gpgconf)      _gpgme_debug (DEBUG_ENGINE, "_gpgme_get_gpgconf_path: '%s' not found",name); | 
