diff options
Diffstat (limited to 'ext/sqlite3/sqlite3.c')
| -rw-r--r-- | ext/sqlite3/sqlite3.c | 32 | 
1 files changed, 30 insertions, 2 deletions
| diff --git a/ext/sqlite3/sqlite3.c b/ext/sqlite3/sqlite3.c index 3c7239021f..d7f7722959 100644 --- a/ext/sqlite3/sqlite3.c +++ b/ext/sqlite3/sqlite3.c @@ -683,7 +683,6 @@ static int sqlite3_do_callback(struct php_sqlite3_fci *fc, zval *cb, int argc, s  	fake_argc = argc + is_agg;  	fc->fci.size = sizeof(fc->fci); -	fc->fci.function_table = EG(function_table);  	ZVAL_COPY_VALUE(&fc->fci.function_name, cb);  	fc->fci.object = NULL;  	fc->fci.retval = &retval; @@ -841,7 +840,6 @@ static int php_sqlite3_callback_compare(void *coll, int a_len, const void *a, in  	int ret;  	collation->fci.fci.size = (sizeof(collation->fci.fci)); -	collation->fci.fci.function_table = EG(function_table);  	ZVAL_COPY_VALUE(&collation->fci.fci.function_name, &collation->cmp_func);  	collation->fci.fci.object = NULL;  	collation->fci.fci.retval = &retval; @@ -1392,6 +1390,26 @@ static int register_bound_parameter_to_sqlite(struct php_sqlite3_bound_param *pa  }  /* }}} */ +/* {{{ Best try to map between PHP and SQLite. Default is still text. */ +#define PHP_SQLITE3_SET_TYPE(z, p) \ +	switch (Z_TYPE_P(z)) { \ +		default: \ +			(p).type = SQLITE_TEXT; \ +			break; \ +		case IS_LONG: \ +		case IS_TRUE: \ +		case IS_FALSE: \ +			(p).type = SQLITE_INTEGER; \ +			break; \ +		case IS_DOUBLE: \ +			(p).type = SQLITE_FLOAT; \ +			break; \ +		case IS_NULL: \ +			(p).type = SQLITE_NULL; \ +			break; \ +	} +/* }}} */ +  /* {{{ proto bool SQLite3Stmt::bindParam(int parameter_number, mixed parameter [, int type])     Bind Parameter to a stmt variable. */  PHP_METHOD(sqlite3stmt, bindParam) @@ -1416,6 +1434,10 @@ PHP_METHOD(sqlite3stmt, bindParam)  	ZVAL_COPY(¶m.parameter, parameter); +	if (ZEND_NUM_ARGS() < 3) { +		PHP_SQLITE3_SET_TYPE(parameter, param); +	} +  	if (!register_bound_parameter_to_sqlite(¶m, stmt_obj)) {  		if (!Z_ISUNDEF(param.parameter)) {  			zval_ptr_dtor(&(param.parameter)); @@ -1451,6 +1473,10 @@ PHP_METHOD(sqlite3stmt, bindValue)  	ZVAL_COPY(¶m.parameter, parameter); +	if (ZEND_NUM_ARGS() < 3) { +		PHP_SQLITE3_SET_TYPE(parameter, param); +	} +  	if (!register_bound_parameter_to_sqlite(¶m, stmt_obj)) {  		if (!Z_ISUNDEF(param.parameter)) {  			zval_ptr_dtor(&(param.parameter)); @@ -1462,6 +1488,8 @@ PHP_METHOD(sqlite3stmt, bindValue)  }  /* }}} */ +#undef PHP_SQLITE3_SET_TYPE +  /* {{{ proto SQLite3Result SQLite3Stmt::execute()     Executes a prepared statement and returns a result set object. */  PHP_METHOD(sqlite3stmt, execute) | 
