diff options
author | Michael Meskes <meskes@postgresql.org> | 2016-12-22 08:28:13 +0100 |
---|---|---|
committer | Michael Meskes <meskes@postgresql.org> | 2016-12-22 08:28:13 +0100 |
commit | 4032ef18d06aa7a3db515926ddebe8af04e533fe (patch) | |
tree | 63e93a684c8adbdfd28853cc0635268ff4390ec1 /src | |
parent | ea0aa9698cfa74bb04cf53d813924fe67f278c30 (diff) | |
download | postgresql-4032ef18d06aa7a3db515926ddebe8af04e533fe.tar.gz postgresql-4032ef18d06aa7a3db515926ddebe8af04e533fe.zip |
Fix buffer overflow on particularly named files and clarify documentation about
output file naming.
Patch by Tsunakawa, Takayuki <tsunakawa.takay@jp.fujitsu.com>
Diffstat (limited to 'src')
-rw-r--r-- | src/interfaces/ecpg/preproc/ecpg.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/interfaces/ecpg/preproc/ecpg.c b/src/interfaces/ecpg/preproc/ecpg.c index 3b0de973210..59dce140a93 100644 --- a/src/interfaces/ecpg/preproc/ecpg.c +++ b/src/interfaces/ecpg/preproc/ecpg.c @@ -313,7 +313,8 @@ main(int argc, char *const argv[]) base_yyout = stdout; else { - output_filename = mm_strdup(input_filename); + output_filename = mm_alloc(strlen(input_filename) + 3); + strcpy(output_filename, input_filename); ptr2ext = strrchr(output_filename, '.'); /* make extension = .c resp. .h */ |