mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-28 06:13:31 +01:00
Clean up nonsensical calling convention for config_load_geoip_file_
(How many "load a file" functions do you typically see where the function frees the filename argument?)
This commit is contained in:
parent
626a8b60d7
commit
98204729aa
@ -5566,27 +5566,28 @@ parse_outbound_addresses(or_options_t *options, int validate_only, char **msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** Load one of the geoip files, <a>family</a> determining which
|
/** Load one of the geoip files, <a>family</a> determining which
|
||||||
* one. Note that <a>fname</a> will be freed by this
|
* one. <a>default_fname</a> is used if on Windows and
|
||||||
* function. <a>default_fname</a> is used if on Windows and
|
|
||||||
* <a>fname</a> equals "<default>". */
|
* <a>fname</a> equals "<default>". */
|
||||||
static void
|
static void
|
||||||
config_load_geoip_file_(sa_family_t family,
|
config_load_geoip_file_(sa_family_t family,
|
||||||
char *fname, /* will be freed */
|
const char *fname,
|
||||||
const char *default_fname)
|
const char *default_fname)
|
||||||
{
|
{
|
||||||
(void)default_fname;
|
#ifdef _WIN32
|
||||||
|
char *free_fname = NULL; /* Used to hold any temporary-allocated value */
|
||||||
/* XXXX Don't use this "<default>" junk; make our filename options
|
/* XXXX Don't use this "<default>" junk; make our filename options
|
||||||
* understand prefixes somehow. -NM */
|
* understand prefixes somehow. -NM */
|
||||||
/* XXXX024 Reload GeoIPFile on SIGHUP. -NM */
|
|
||||||
#ifdef _WIN32
|
|
||||||
if (!strcmp(fname, "<default>")) {
|
if (!strcmp(fname, "<default>")) {
|
||||||
const char *conf_root = get_windows_conf_root();
|
const char *conf_root = get_windows_conf_root();
|
||||||
tor_free(fname);
|
tor_asprintf(&free_fname, "%s\\%s", conf_root, default_fname);
|
||||||
tor_asprintf(&fname, "%s\\%s", conf_root, default_fname);
|
fname = free_fname;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
geoip_load_file(family, fname);
|
geoip_load_file(family, fname);
|
||||||
tor_free(fname);
|
tor_free(free_fname);
|
||||||
|
#else
|
||||||
|
(void)default_fname;
|
||||||
|
geoip_load_file(family, fname);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Load geoip files for IPv4 and IPv6 if <a>options</a> and
|
/** Load geoip files for IPv4 and IPv6 if <a>options</a> and
|
||||||
@ -5595,14 +5596,16 @@ static void
|
|||||||
config_maybe_load_geoip_files_(const or_options_t *options,
|
config_maybe_load_geoip_files_(const or_options_t *options,
|
||||||
const or_options_t *old_options)
|
const or_options_t *old_options)
|
||||||
{
|
{
|
||||||
|
/* XXXX024 Reload GeoIPFile on SIGHUP. -NM */
|
||||||
|
|
||||||
if (options->GeoIPFile &&
|
if (options->GeoIPFile &&
|
||||||
((!old_options || !opt_streq(old_options->GeoIPFile,
|
((!old_options || !opt_streq(old_options->GeoIPFile,
|
||||||
options->GeoIPFile))
|
options->GeoIPFile))
|
||||||
|| !geoip_is_loaded(AF_INET)))
|
|| !geoip_is_loaded(AF_INET)))
|
||||||
config_load_geoip_file_(AF_INET, tor_strdup(options->GeoIPFile), "geoip");
|
config_load_geoip_file_(AF_INET, options->GeoIPFile, "geoip");
|
||||||
if (options->GeoIPv6File &&
|
if (options->GeoIPv6File &&
|
||||||
((!old_options || !opt_streq(old_options->GeoIPv6File,
|
((!old_options || !opt_streq(old_options->GeoIPv6File,
|
||||||
options->GeoIPv6File))
|
options->GeoIPv6File))
|
||||||
|| !geoip_is_loaded(AF_INET6)))
|
|| !geoip_is_loaded(AF_INET6)))
|
||||||
config_load_geoip_file_(AF_INET6, tor_strdup(options->GeoIPv6File), "geoip6");
|
config_load_geoip_file_(AF_INET6, options->GeoIPv6File, "geoip6");
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user