Commit c47a5585 authored by Tom Lane's avatar Tom Lane

Ensure ParseTzFile() closes the input file after failing.

We hadn't noticed this because (a) few people feed invalid
timezone abbreviation files to the server, and (b) in typical
scenarios guc.c would throw ereport(ERROR) and then transaction
abort handling would silently clean up the leaked file reference.
However, it was possible to observe file leakage warnings if one
breaks an already-active abbreviation file, because guc.c does
not throw ERROR when loading supposedly-validated settings during
session start or SIGHUP processing.

Report and fix by Kyotaro Horiguchi (cosmetic adjustments by me)

Discussion: https://postgr.es/m/20220530.173740.748502979257582392.horikyota.ntt@gmail.com
parent a18b2a3f
...@@ -364,7 +364,8 @@ ParseTzFile(const char *filename, int depth, ...@@ -364,7 +364,8 @@ ParseTzFile(const char *filename, int depth,
{ {
GUC_check_errmsg("could not read time zone file \"%s\": %m", GUC_check_errmsg("could not read time zone file \"%s\": %m",
filename); filename);
return -1; n = -1;
break;
} }
/* else we're at EOF after all */ /* else we're at EOF after all */
break; break;
...@@ -374,7 +375,8 @@ ParseTzFile(const char *filename, int depth, ...@@ -374,7 +375,8 @@ ParseTzFile(const char *filename, int depth,
/* the line is too long for tzbuf */ /* the line is too long for tzbuf */
GUC_check_errmsg("line is too long in time zone file \"%s\", line %d", GUC_check_errmsg("line is too long in time zone file \"%s\", line %d",
filename, lineno); filename, lineno);
return -1; n = -1;
break;
} }
/* skip over whitespace */ /* skip over whitespace */
...@@ -397,12 +399,13 @@ ParseTzFile(const char *filename, int depth, ...@@ -397,12 +399,13 @@ ParseTzFile(const char *filename, int depth,
{ {
GUC_check_errmsg("@INCLUDE without file name in time zone file \"%s\", line %d", GUC_check_errmsg("@INCLUDE without file name in time zone file \"%s\", line %d",
filename, lineno); filename, lineno);
return -1; n = -1;
break;
} }
n = ParseTzFile(includeFile, depth + 1, n = ParseTzFile(includeFile, depth + 1,
base, arraysize, n); base, arraysize, n);
if (n < 0) if (n < 0)
return -1; break;
continue; continue;
} }
...@@ -413,12 +416,18 @@ ParseTzFile(const char *filename, int depth, ...@@ -413,12 +416,18 @@ ParseTzFile(const char *filename, int depth,
} }
if (!splitTzLine(filename, lineno, line, &tzentry)) if (!splitTzLine(filename, lineno, line, &tzentry))
return -1; {
n = -1;
break;
}
if (!validateTzEntry(&tzentry)) if (!validateTzEntry(&tzentry))
return -1; {
n = -1;
break;
}
n = addToArray(base, arraysize, n, &tzentry, override); n = addToArray(base, arraysize, n, &tzentry, override);
if (n < 0) if (n < 0)
return -1; break;
} }
FreeFile(tzFile); FreeFile(tzFile);
......
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