summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPopa Adrian Marius <mariuz@php.net>2011-12-28 10:17:17 +0000
committerPopa Adrian Marius <mariuz@php.net>2011-12-28 10:17:17 +0000
commit9b000683636aec0bc9cc792c536dcf65d08f9ec0 (patch)
tree6fe191bb1a15d7f40c58fafb908d0ac65c7f5152
parente2c5167b7bb1b41e5db082162f97305ab6cb5184 (diff)
downloadphp-git-9b000683636aec0bc9cc792c536dcf65d08f9ec0.tar.gz
fix Bug #47415 PDO_Firebird segfaults when passing lowercased column name to bindColumn()
-rw-r--r--ext/pdo_firebird/firebird_statement.c12
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);
}