diff options
author | Popa Adrian Marius <mariuz@php.net> | 2011-12-28 10:17:17 +0000 |
---|---|---|
committer | Popa Adrian Marius <mariuz@php.net> | 2011-12-28 10:17:17 +0000 |
commit | 9b000683636aec0bc9cc792c536dcf65d08f9ec0 (patch) | |
tree | 6fe191bb1a15d7f40c58fafb908d0ac65c7f5152 /ext/pdo_firebird | |
parent | e2c5167b7bb1b41e5db082162f97305ab6cb5184 (diff) | |
download | php-git-9b000683636aec0bc9cc792c536dcf65d08f9ec0.tar.gz |
fix Bug #47415 PDO_Firebird segfaults when passing lowercased column name to bindColumn()
Diffstat (limited to 'ext/pdo_firebird')
-rw-r--r-- | ext/pdo_firebird/firebird_statement.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/ext/pdo_firebird/firebird_statement.c b/ext/pdo_firebird/firebird_statement.c index 6dcd09c35a..d52850b95b 100644 --- a/ext/pdo_firebird/firebird_statement.c +++ b/ext/pdo_firebird/firebird_statement.c @@ -582,6 +582,9 @@ static int firebird_stmt_param_hook(pdo_stmt_t *stmt, struct pdo_bound_param_dat break; case PDO_PARAM_EVT_FETCH_POST: + if (param->paramno == -1) { + return 0; + } value = NULL; value_len = 0; caller_frees = 0; @@ -598,6 +601,15 @@ static int firebird_stmt_param_hook(pdo_stmt_t *stmt, struct pdo_bound_param_dat ZVAL_LONG(param->parameter, *(long*)value); break; } + case PDO_PARAM_EVT_NORMALIZE: + if (!param->is_param) { + char *s = param->name; + while (*s != '\0') { + *s = toupper(*s); + s++; + } + } + break; default: ZVAL_NULL(param->parameter); } |