diff options
| author | Dorin Marcoci <dorin.marcoci@marcodor.com> | 2017-01-02 16:46:09 +0200 | 
|---|---|---|
| committer | Anatol Belski <ab@php.net> | 2017-01-06 17:43:46 +0100 | 
| commit | 826122fa8e1db4a0deee3830660ae3b8b5626534 (patch) | |
| tree | 9843697d42fbfb82219308f3899893feb36c3d8f /ext/pdo_firebird/firebird_statement.c | |
| parent | e55e93a1e335bec39b7edb28f0b8470fa974f4e3 (diff) | |
| download | php-git-826122fa8e1db4a0deee3830660ae3b8b5626534.tar.gz | |
Return integer field types as native integers instead of strings
Use another define for better compatibility
Test case for #72583 Feature. Small optimisations.
Adjust conditional directives according to coding standards
Add more compatibility for "end of line" on multiple environements
Updated execute.phpt test after switching to integer mapping
Diffstat (limited to 'ext/pdo_firebird/firebird_statement.c')
| -rw-r--r-- | ext/pdo_firebird/firebird_statement.c | 34 | 
1 files changed, 29 insertions, 5 deletions
| diff --git a/ext/pdo_firebird/firebird_statement.c b/ext/pdo_firebird/firebird_statement.c index c83ba38db5..3feeedf39f 100644 --- a/ext/pdo_firebird/firebird_statement.c +++ b/ext/pdo_firebird/firebird_statement.c @@ -217,7 +217,23 @@ static int firebird_stmt_describe(pdo_stmt_t *stmt, int colno) /* {{{ */  	}  	memmove(cp, var->aliasname, var->aliasname_length);  	*(cp+var->aliasname_length) = '\0'; -	col->param_type = PDO_PARAM_STR; + +	if (var->sqlscale < 0) { +		col->param_type = PDO_PARAM_STR; +	} else { +		switch (var->sqltype & ~1) { +			case SQL_SHORT: +			case SQL_LONG: +#if SIZEOF_ZEND_LONG >= 8  +			case SQL_INT64: +#endif +				col->param_type = PDO_PARAM_INT; +				break; +			default: +				col->param_type = PDO_PARAM_STR; +				break; +		} +	}  	return 1;  } @@ -373,16 +389,24 @@ static int firebird_stmt_get_col(pdo_stmt_t *stmt, int colno, char **ptr,  /* {{  					*len = var->sqllen;  					break;  				case SQL_SHORT: -				    *ptr = FETCH_BUF(S->fetch_buf[colno], char, CHAR_BUF_LEN, NULL); -					*len = slprintf(*ptr, CHAR_BUF_LEN, "%d", *(short*)var->sqldata); +					*len = sizeof(zend_long); +					*ptr = FETCH_BUF(S->fetch_buf[colno], zend_long, 1, NULL); +					*(zend_long *)*ptr = *(short*)var->sqldata;  					break;  				case SQL_LONG: -					*ptr = FETCH_BUF(S->fetch_buf[colno], char, CHAR_BUF_LEN, NULL); -					*len = slprintf(*ptr, CHAR_BUF_LEN, "%d", *(ISC_LONG*)var->sqldata); +					*len = sizeof(zend_long); +					*ptr = FETCH_BUF(S->fetch_buf[colno], zend_long, 1, NULL); +					*(zend_long *)*ptr = *(ISC_LONG*)var->sqldata;  					break;  				case SQL_INT64: +#if SIZEOF_ZEND_LONG >= 8  +					*len = sizeof(zend_long); +					*ptr = FETCH_BUF(S->fetch_buf[colno], zend_long, 1, NULL); +					*(zend_long *)*ptr = *(ISC_INT64*)var->sqldata; +#else  					*ptr = FETCH_BUF(S->fetch_buf[colno], char, CHAR_BUF_LEN, NULL);  					*len = slprintf(*ptr, CHAR_BUF_LEN, "%" LL_MASK "d", *(ISC_INT64*)var->sqldata); +#endif  					break;  				case SQL_FLOAT:  					*ptr = FETCH_BUF(S->fetch_buf[colno], char, CHAR_BUF_LEN, NULL); | 
