diff options
author | Anatol Belski <ab@php.net> | 2018-07-30 18:27:59 +0200 |
---|---|---|
committer | Anatol Belski <ab@php.net> | 2018-07-30 18:27:59 +0200 |
commit | cc69950b1527b321bf54a9394938d57e8f5a35cc (patch) | |
tree | 16ef3f670d59eacbe50870316ebae51e7400503a /ext/pdo_pgsql/pgsql_statement.c | |
parent | ed7e3bc70a89a0838a5b7e44928cbd65aec50bb1 (diff) | |
download | php-git-cc69950b1527b321bf54a9394938d57e8f5a35cc.tar.gz |
Fixed bug #75402 Possible Memory Leak using PDO::CURSOR_SCROLL option
Diffstat (limited to 'ext/pdo_pgsql/pgsql_statement.c')
-rw-r--r-- | ext/pdo_pgsql/pgsql_statement.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/ext/pdo_pgsql/pgsql_statement.c b/ext/pdo_pgsql/pgsql_statement.c index b401917669..a9df2a97bf 100644 --- a/ext/pdo_pgsql/pgsql_statement.c +++ b/ext/pdo_pgsql/pgsql_statement.c @@ -165,6 +165,7 @@ static int pgsql_stmt_execute(pdo_stmt_t *stmt) pdo_pgsql_error_stmt(stmt, status, pdo_pgsql_sqlstate(S->result)); return 0; } + PQclear(S->result); /* the cursor was declared correctly */ S->is_prepared = 1; @@ -434,6 +435,11 @@ static int pgsql_stmt_fetch(pdo_stmt_t *stmt, return 0; } + if(S->result) { + PQclear(S->result); + S->result = NULL; + } + spprintf(&q, 0, "FETCH %s FROM %s", ori_str, S->cursor_name); efree(ori_str); S->result = PQexec(S->H->server, q); |