Commit 138184ad authored by Heikki Linnakangas's avatar Heikki Linnakangas

Plug memory leak when reloading config file.

The absolute path to config file was not pfreed. There are probably more
small leaks here and there in the config file reload code and assign hooks,
and in practice no-one reloads the config files frequently enough for it to
be a problem, but this one is trivial enough that might as well fix it.

Backpatch to 9.3 where the leak was introduced.
parent bb598456
...@@ -409,6 +409,7 @@ ParseConfigFile(const char *config_file, const char *calling_file, bool strict, ...@@ -409,6 +409,7 @@ ParseConfigFile(const char *config_file, const char *calling_file, bool strict,
ConfigVariable **head_p, ConfigVariable **head_p,
ConfigVariable **tail_p) ConfigVariable **tail_p)
{ {
char *abs_path;
bool OK = true; bool OK = true;
FILE *fp; FILE *fp;
...@@ -426,8 +427,8 @@ ParseConfigFile(const char *config_file, const char *calling_file, bool strict, ...@@ -426,8 +427,8 @@ ParseConfigFile(const char *config_file, const char *calling_file, bool strict,
return false; return false;
} }
config_file = AbsoluteConfigLocation(config_file,calling_file); abs_path = AbsoluteConfigLocation(config_file, calling_file);
fp = AllocateFile(config_file, "r"); fp = AllocateFile(abs_path, "r");
if (!fp) if (!fp)
{ {
if (strict) if (strict)
...@@ -435,19 +436,20 @@ ParseConfigFile(const char *config_file, const char *calling_file, bool strict, ...@@ -435,19 +436,20 @@ ParseConfigFile(const char *config_file, const char *calling_file, bool strict,
ereport(elevel, ereport(elevel,
(errcode_for_file_access(), (errcode_for_file_access(),
errmsg("could not open configuration file \"%s\": %m", errmsg("could not open configuration file \"%s\": %m",
config_file))); abs_path)));
return false; return false;
} }
ereport(LOG, ereport(LOG,
(errmsg("skipping missing configuration file \"%s\"", (errmsg("skipping missing configuration file \"%s\"",
config_file))); abs_path)));
return OK; return OK;
} }
OK = ParseConfigFp(fp, config_file, depth, elevel, head_p, tail_p); OK = ParseConfigFp(fp, abs_path, depth, elevel, head_p, tail_p);
FreeFile(fp); FreeFile(fp);
pfree(abs_path);
return OK; return OK;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment