]> granicus.if.org Git - php/commitdiff
- Fixed bug #52699 (PDO bindValue writes long int 32bit enum)
authorFelipe Pena <felipe@php.net>
Wed, 25 Aug 2010 22:03:03 +0000 (22:03 +0000)
committerFelipe Pena <felipe@php.net>
Wed, 25 Aug 2010 22:03:03 +0000 (22:03 +0000)
ext/pdo/pdo_stmt.c

index 6127a443dca4a5db3afe85df39ac9b303304aa3c..c57a14a781c93fb9092d4c96a266263f762331c7 100755 (executable)
@@ -1624,18 +1624,20 @@ static int register_bound_param(INTERNAL_FUNCTION_PARAMETERS, pdo_stmt_t *stmt,
 static PHP_METHOD(PDOStatement, bindValue)
 {
        struct pdo_bound_param_data param = {0};
+       long param_type = PDO_PARAM_STR;
        PHP_STMT_GET_OBJ;
 
        param.paramno = -1;
-       param.param_type = PDO_PARAM_STR;
        
        if (FAILURE == zend_parse_parameters_ex(ZEND_PARSE_PARAMS_QUIET, ZEND_NUM_ARGS() TSRMLS_CC,
-                       "lz/|l", &param.paramno, &param.parameter, &param.param_type)) {
+                       "lz/|l", &param.paramno, &param.parameter, &param_type)) {
                if (FAILURE == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "sz/|l", &param.name,
-                               &param.namelen, &param.parameter, &param.param_type)) {
+                               &param.namelen, &param.parameter, &param_type)) {
                        RETURN_FALSE;
                }
        }
+
+       param.param_type = (int) param_type;
        
        if (param.paramno > 0) {
                --param.paramno; /* make it zero-based internally */