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 | cfe00e6053832475ecda024f374fa58d740fc818 (patch) | |
tree | e5e664f58ead933ced03d6338594e847bdcf3c7f | |
parent | 90a8da866b3564772a80126692f533fa65852e81 (diff) | |
download | php-git-cfe00e6053832475ecda024f374fa58d740fc818.tar.gz |
fix Bug #47415 PDO_Firebird segfaults when passing lowercased column name to bindColumn()
-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); } |