mirror of
git://git.gnupg.org/gnupg.git
synced 2025-07-02 22:46:30 +02:00
Replace use of opt.homedir by accessor functions.
* common/homedir.c (the_gnupg_homedir): New var. (gnupg_set_homedir): New. (gnupg_homedir): New. * g10/options.h (struct opt): Remove 'homedir' and replace all users by the new accessor functions. * g13/g13-common.h (struct opt): Ditto. * scd/scdaemon.h (struct opt): Ditto. * sm/gpgsm.h (struct opt): Ditto. * dirmngr/dirmngr.h (struct opt): Ditto. * agent/preset-passphrase.c (opt_homedir): Ditto. * agent/protect-tool.c (opt_homedir): Ditto. -- This will make detection of a non-default homedir easier. Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
parent
650abbab71
commit
22a7ef01aa
44 changed files with 188 additions and 179 deletions
|
@ -303,7 +303,7 @@ start_agent (ctrl_t ctrl, int for_card)
|
|||
{
|
||||
rc = start_new_gpg_agent (&agent_ctx,
|
||||
GPG_ERR_SOURCE_DEFAULT,
|
||||
opt.homedir,
|
||||
gnupg_homedir (),
|
||||
opt.agent_program,
|
||||
opt.lc_ctype, opt.lc_messages,
|
||||
opt.session_env,
|
||||
|
|
|
@ -177,7 +177,7 @@ create_context (ctrl_t ctrl, assuan_context_t *r_ctx)
|
|||
*r_ctx = NULL;
|
||||
err = start_new_dirmngr (&ctx,
|
||||
GPG_ERR_SOURCE_DEFAULT,
|
||||
opt.homedir,
|
||||
gnupg_homedir (),
|
||||
opt.dirmngr_program,
|
||||
opt.autostart, opt.verbose, DBG_IPC,
|
||||
NULL /*gpg_status2*/, ctrl);
|
||||
|
|
46
g10/gpg.c
46
g10/gpg.c
|
@ -1000,9 +1000,9 @@ my_strusage( int level )
|
|||
|
||||
case 31: p = "\nHome: "; break;
|
||||
#ifndef __riscos__
|
||||
case 32: p = opt.homedir; break;
|
||||
case 32: p = gnupg_homedir (); break;
|
||||
#else /* __riscos__ */
|
||||
case 32: p = make_filename(opt.homedir, NULL); break;
|
||||
case 32: p = make_filename(gnupg_homedir (), NULL); break;
|
||||
#endif /* __riscos__ */
|
||||
case 33: p = _("\nSupported algorithms:\n"); break;
|
||||
case 34:
|
||||
|
@ -1180,18 +1180,6 @@ set_debug (const char *level)
|
|||
}
|
||||
|
||||
|
||||
|
||||
/* We need the home directory also in some other directories, so make
|
||||
sure that both variables are always in sync. */
|
||||
static void
|
||||
set_homedir (const char *dir)
|
||||
{
|
||||
if (!dir)
|
||||
dir = "";
|
||||
opt.homedir = dir;
|
||||
}
|
||||
|
||||
|
||||
/* We set the screen dimensions for UI purposes. Do not allow screens
|
||||
smaller than 80x24 for the sake of simplicity. */
|
||||
static void
|
||||
|
@ -1412,7 +1400,8 @@ check_permissions (const char *path, int item)
|
|||
could be rectified if the homedir itself had proper
|
||||
permissions. */
|
||||
if(item!=0 && homedir_cache>-1
|
||||
&& ascii_strncasecmp(opt.homedir,tmppath,strlen(opt.homedir))==0)
|
||||
&& !ascii_strncasecmp (gnupg_homedir (), tmppath,
|
||||
strlen (gnupg_homedir ())))
|
||||
{
|
||||
ret=homedir_cache;
|
||||
goto end;
|
||||
|
@ -2082,18 +2071,19 @@ get_default_configname (void)
|
|||
break;
|
||||
}
|
||||
|
||||
configname = make_filename (opt.homedir, name, NULL);
|
||||
configname = make_filename (gnupg_homedir (), name, NULL);
|
||||
}
|
||||
while (access (configname, R_OK));
|
||||
|
||||
xfree(name);
|
||||
|
||||
if (! configname)
|
||||
configname = make_filename (opt.homedir, GPG_NAME EXTSEP_S "conf", NULL);
|
||||
configname = make_filename (gnupg_homedir (),
|
||||
GPG_NAME EXTSEP_S "conf", NULL);
|
||||
if (! access (configname, R_OK))
|
||||
{
|
||||
/* Print a warning when both config files are present. */
|
||||
char *p = make_filename (opt.homedir, "options", NULL);
|
||||
char *p = make_filename (gnupg_homedir (), "options", NULL);
|
||||
if (! access (p, R_OK))
|
||||
log_info (_("Note: old default options file '%s' ignored\n"), p);
|
||||
xfree (p);
|
||||
|
@ -2101,7 +2091,7 @@ get_default_configname (void)
|
|||
else
|
||||
{
|
||||
/* Use the old default only if it exists. */
|
||||
char *p = make_filename (opt.homedir, "options", NULL);
|
||||
char *p = make_filename (gnupg_homedir (), "options", NULL);
|
||||
if (!access (p, R_OK))
|
||||
{
|
||||
xfree (configname);
|
||||
|
@ -2252,7 +2242,7 @@ main (int argc, char **argv)
|
|||
opt.keyid_format = KF_NONE;
|
||||
opt.def_sig_expire = "0";
|
||||
opt.def_cert_expire = "0";
|
||||
set_homedir (default_homedir ());
|
||||
gnupg_set_homedir (NULL);
|
||||
opt.passphrase_repeat = 1;
|
||||
opt.emit_version = 1; /* Limit to the major number. */
|
||||
opt.weak_digests = NULL;
|
||||
|
@ -2281,7 +2271,7 @@ main (int argc, char **argv)
|
|||
opt.no_homedir_creation = 1;
|
||||
}
|
||||
else if( pargs.r_opt == oHomedir )
|
||||
set_homedir ( pargs.r.ret_str );
|
||||
gnupg_set_homedir (pargs.r.ret_str);
|
||||
else if( pargs.r_opt == oNoPermissionWarn )
|
||||
opt.no_perm_warn=1;
|
||||
else if (pargs.r_opt == oStrict )
|
||||
|
@ -2295,10 +2285,10 @@ main (int argc, char **argv)
|
|||
}
|
||||
|
||||
#ifdef HAVE_DOSISH_SYSTEM
|
||||
if ( strchr (opt.homedir,'\\') ) {
|
||||
char *d, *buf = xmalloc (strlen (opt.homedir)+1);
|
||||
const char *s = opt.homedir;
|
||||
for (d=buf,s=opt.homedir; *s; s++)
|
||||
if ( strchr (gnupg_homedir, '\\') ) {
|
||||
char *d, *buf = xmalloc (strlen (gnupg_homedir ())+1);
|
||||
const char *s;
|
||||
for (d=buf, s = gnupg_homedir (); *s; s++)
|
||||
{
|
||||
*d++ = *s == '\\'? '/': *s;
|
||||
#ifdef HAVE_W32_SYSTEM
|
||||
|
@ -2307,7 +2297,7 @@ main (int argc, char **argv)
|
|||
#endif
|
||||
}
|
||||
*d = 0;
|
||||
set_homedir (buf);
|
||||
gnupg_set_homedir (buf);
|
||||
}
|
||||
#endif
|
||||
|
||||
|
@ -2344,7 +2334,7 @@ main (int argc, char **argv)
|
|||
pargs.flags= ARGPARSE_FLAG_KEEP;
|
||||
|
||||
/* By this point we have a homedir, and cannot change it. */
|
||||
check_permissions(opt.homedir,0);
|
||||
check_permissions (gnupg_homedir (), 0);
|
||||
|
||||
next_pass:
|
||||
if( configname ) {
|
||||
|
@ -3668,7 +3658,7 @@ main (int argc, char **argv)
|
|||
|
||||
/* Set the random seed file. */
|
||||
if( use_random_seed ) {
|
||||
char *p = make_filename(opt.homedir, "random_seed", NULL );
|
||||
char *p = make_filename (gnupg_homedir (), "random_seed", NULL );
|
||||
gcry_control (GCRYCTL_SET_RANDOM_SEED_FILE, p);
|
||||
if (!access (p, F_OK))
|
||||
register_secured_file (p);
|
||||
|
|
|
@ -2956,10 +2956,6 @@ main (int argc, char *argv[])
|
|||
int processed;
|
||||
ctrl_t ctrl;
|
||||
|
||||
opt.homedir = default_homedir ();
|
||||
if (! opt.homedir)
|
||||
opt.homedir = "";
|
||||
|
||||
opt.ignore_time_conflict = 1;
|
||||
/* Allow notations in the IETF space, for instance. */
|
||||
opt.expert = 1;
|
||||
|
|
|
@ -169,7 +169,6 @@ main( int argc, char **argv )
|
|||
opt.trust_model = TM_ALWAYS;
|
||||
opt.batch = 1;
|
||||
|
||||
opt.homedir = default_homedir ();
|
||||
opt.weak_digests = NULL;
|
||||
|
||||
tty_no_terminal(1);
|
||||
|
@ -196,7 +195,7 @@ main( int argc, char **argv )
|
|||
case oLoggerFD:
|
||||
log_set_fd (translate_sys2libc_fd_int (pargs.r.ret_int, 1));
|
||||
break;
|
||||
case oHomedir: opt.homedir = pargs.r.ret_str; break;
|
||||
case oHomedir: gnupg_set_homedir (pargs.r.ret_str); break;
|
||||
case oWeakDigest:
|
||||
additional_weak_digest(pargs.r.ret_str);
|
||||
break;
|
||||
|
|
|
@ -666,7 +666,7 @@ keydb_add_resource (const char *url, unsigned int flags)
|
|||
)
|
||||
filename = make_filename (resname, NULL);
|
||||
else
|
||||
filename = make_filename (opt.homedir, resname, NULL);
|
||||
filename = make_filename (gnupg_homedir (), resname, NULL);
|
||||
}
|
||||
else
|
||||
filename = xstrdup (resname);
|
||||
|
|
|
@ -2428,7 +2428,7 @@ keyedit_menu (ctrl_t ctrl, const char *username, strlist_t locusr,
|
|||
else if (*arg_string == '~')
|
||||
fname = make_filename (arg_string, NULL);
|
||||
else
|
||||
fname = make_filename (opt.homedir, arg_string, NULL);
|
||||
fname = make_filename (gnupg_homedir (), arg_string, NULL);
|
||||
|
||||
/* Open that file. */
|
||||
a = iobuf_open (fname);
|
||||
|
|
|
@ -4261,7 +4261,8 @@ do_generate_keypair (ctrl_t ctrl, struct para_data_s *para,
|
|||
log_assert (sub_psk);
|
||||
|
||||
if (s)
|
||||
err = card_store_key_with_backup (ctrl, sub_psk, opt.homedir);
|
||||
err = card_store_key_with_backup (ctrl,
|
||||
sub_psk, gnupg_homedir ());
|
||||
}
|
||||
}
|
||||
else
|
||||
|
|
|
@ -49,10 +49,10 @@ migrate_secring (ctrl_t ctrl)
|
|||
char *flagfile = NULL;
|
||||
char *agent_version = NULL;
|
||||
|
||||
secring = make_filename (opt.homedir, "secring" EXTSEP_S "gpg", NULL);
|
||||
secring = make_filename (gnupg_homedir (), "secring" EXTSEP_S "gpg", NULL);
|
||||
if (access (secring, F_OK))
|
||||
goto leave; /* Does not exist or is not readable. */
|
||||
flagfile = make_filename (opt.homedir, V21_MIGRATION_FNAME, NULL);
|
||||
flagfile = make_filename (gnupg_homedir (), V21_MIGRATION_FNAME, NULL);
|
||||
if (!access (flagfile, F_OK))
|
||||
goto leave; /* Does exist - fine. */
|
||||
|
||||
|
|
|
@ -106,7 +106,6 @@ struct
|
|||
int marginals_needed;
|
||||
int completes_needed;
|
||||
int max_cert_depth;
|
||||
const char *homedir;
|
||||
const char *agent_program;
|
||||
const char *dirmngr_program;
|
||||
|
||||
|
|
|
@ -533,7 +533,7 @@ gen_standard_revoke (PKT_public_key *psk, const char *cache_nonce)
|
|||
int kl;
|
||||
char *orig_codeset;
|
||||
|
||||
dir = get_openpgp_revocdir (opt.homedir);
|
||||
dir = get_openpgp_revocdir (gnupg_homedir ());
|
||||
tmpstr = hexfingerprint (psk, NULL, 0);
|
||||
fname = xstrconcat (dir, DIRSEP_S, tmpstr, NULL);
|
||||
xfree (tmpstr);
|
||||
|
|
|
@ -695,12 +695,12 @@ gpg_server (ctrl_t ctrl)
|
|||
assuan_set_pointer (ctx, ctrl);
|
||||
if (opt.verbose || opt.debug)
|
||||
{
|
||||
char *tmp = NULL;
|
||||
char *tmp;
|
||||
|
||||
tmp = xtryasprintf ("Home: %s\n"
|
||||
"Config: %s\n"
|
||||
"%s",
|
||||
opt.homedir,
|
||||
gnupg_homedir (),
|
||||
"fixme: need config filename",
|
||||
hello);
|
||||
if (tmp)
|
||||
|
|
|
@ -617,14 +617,15 @@ tdbio_set_dbname (const char *new_dbname, int create, int *r_nofile)
|
|||
|
||||
if (!new_dbname)
|
||||
{
|
||||
fname = make_filename (opt.homedir, "trustdb" EXTSEP_S GPGEXT_GPG, NULL);
|
||||
fname = make_filename (gnupg_homedir (),
|
||||
"trustdb" EXTSEP_S GPGEXT_GPG, NULL);
|
||||
}
|
||||
else if (*new_dbname != DIRSEP_C )
|
||||
{
|
||||
if (strchr (new_dbname, DIRSEP_C))
|
||||
fname = make_filename (new_dbname, NULL);
|
||||
else
|
||||
fname = make_filename (opt.homedir, new_dbname, NULL);
|
||||
fname = make_filename (gnupg_homedir (), new_dbname, NULL);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
10
g10/tofu.c
10
g10/tofu.c
|
@ -747,7 +747,7 @@ opendb (char *filename, enum db_type type)
|
|||
log_assert (! filename);
|
||||
log_assert (type == DB_COMBINED);
|
||||
|
||||
filename = make_filename (opt.homedir, "tofu.db", NULL);
|
||||
filename = make_filename (gnupg_homedir (), "tofu.db", NULL);
|
||||
filename_free = 1;
|
||||
}
|
||||
else
|
||||
|
@ -895,10 +895,10 @@ getdb (tofu_dbs_t dbs, const char *name, enum db_type type)
|
|||
char *name_db;
|
||||
|
||||
/* Make the directory. */
|
||||
rc = gnupg_mkdir_p (opt.homedir, "tofu.d", type_str, prefix, NULL);
|
||||
rc = gnupg_mkdir_p (gnupg_homedir (), "tofu.d", type_str, prefix, NULL);
|
||||
if (rc)
|
||||
{
|
||||
name_db = xstrconcat (opt.homedir, "tofu.d",
|
||||
name_db = xstrconcat (gnupg_homedir (), "tofu.d",
|
||||
type_str, prefix, NULL);
|
||||
log_error (_("can't create directory '%s': %s\n"),
|
||||
name_db, gpg_strerror (rc));
|
||||
|
@ -908,7 +908,7 @@ getdb (tofu_dbs_t dbs, const char *name, enum db_type type)
|
|||
|
||||
name_db = xstrconcat (name_sanitized, ".db", NULL);
|
||||
filename = make_filename
|
||||
(opt.homedir, "tofu.d", type_str, prefix, name_db, NULL);
|
||||
(gnupg_homedir (), "tofu.d", type_str, prefix, name_db, NULL);
|
||||
xfree (name_db);
|
||||
}
|
||||
}
|
||||
|
@ -989,7 +989,7 @@ opendbs (ctrl_t ctrl)
|
|||
|
||||
if (opt.tofu_db_format == TOFU_DB_AUTO)
|
||||
{
|
||||
char *filename = make_filename (opt.homedir, "tofu.db", NULL);
|
||||
char *filename = make_filename (gnupg_homedir (), "tofu.db", NULL);
|
||||
struct stat s;
|
||||
int have_tofu_db = 0;
|
||||
int have_tofu_d = 0;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue