summaryrefslogtreecommitdiff
path: root/ext/fbsql/php_fbsql.c
diff options
context:
space:
mode:
Diffstat (limited to 'ext/fbsql/php_fbsql.c')
-rw-r--r--ext/fbsql/php_fbsql.c235
1 files changed, 193 insertions, 42 deletions
diff --git a/ext/fbsql/php_fbsql.c b/ext/fbsql/php_fbsql.c
index c0f619effd..08c763522c 100644
--- a/ext/fbsql/php_fbsql.c
+++ b/ext/fbsql/php_fbsql.c
@@ -255,7 +255,13 @@ ZEND_DECLARE_MODULE_GLOBALS(fbsql)
ZEND_GET_MODULE(fbsql)
#endif
-#define CHECK_LINK(link) { if (link==-1) { php_error(E_WARNING, "FrontBase: A link to the server could not be established"); RETURN_FALSE; } }
+#define CHECK_LINK(link) { \
+ if (link==-1) { \
+ if (FB_SQL_G(generateWarnings)) \
+ php_error(E_WARNING, "FrontBase: A link to the server could not be established"); \
+ RETURN_FALSE; \
+ } \
+}
static void phpfbReleaseResult (zend_rsrc_list_entry *rsrc TSRMLS_DC);
static void phpfbReleaseLink (zend_rsrc_list_entry *rsrc TSRMLS_DC);
@@ -515,13 +521,15 @@ static void php_fbsql_do_connect(INTERNAL_FUNCTION_PARAMETERS, int persistant)
if ((FB_SQL_G(maxLinks) != -1 && FB_SQL_G(linkCount) == FB_SQL_G(maxLinks)))
{
- php_error(E_WARNING, "FrontBase link limit %d exceeded ", FB_SQL_G(maxLinks));
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "FrontBase link limit %d exceeded ", FB_SQL_G(maxLinks));
RETURN_FALSE;
}
if ((FB_SQL_G(maxPersistant) != -1 && FB_SQL_G(persistantCount) == FB_SQL_G(maxPersistant)))
{
- php_error(E_WARNING, "FrontBase persistant link limit %d exceeded ", FB_SQL_G(maxPersistant));
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "FrontBase persistant link limit %d exceeded ", FB_SQL_G(maxPersistant));
RETURN_FALSE;
}
@@ -562,7 +570,8 @@ static void php_fbsql_do_connect(INTERNAL_FUNCTION_PARAMETERS, int persistant)
if ((FB_SQL_G(maxLinks) != -1 && FB_SQL_G(linkCount) == FB_SQL_G(maxLinks)))
{
- php_error(E_WARNING, "FrontBase link limit %d exceeded ", FB_SQL_G(maxLinks));
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "FrontBase link limit %d exceeded ", FB_SQL_G(maxLinks));
RETURN_FALSE;
}
@@ -709,7 +718,8 @@ static int php_fbsql_select_db(char *databaseName, PHPFBLink *link TSRMLS_DC)
c = fbcdcConnectToDatabase(databaseName, link->hostName, link->databasePassword);
if (c == NULL)
{
- php_error(E_WARNING, fbcdcClassErrorMessage());
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, fbcdcClassErrorMessage());
return 0;
}
md = fbcdcCreateSession(c, "PHP", link->userName, link->userPassword, link->userName);
@@ -717,10 +727,15 @@ static int php_fbsql_select_db(char *databaseName, PHPFBLink *link TSRMLS_DC)
{
FBCErrorMetaData* emd = fbcdcErrorMetaData(c, md);
char* emg = fbcemdAllErrorMessages(emd);
- if (emg)
- php_error(E_WARNING, emg);
- else
- php_error(E_WARNING, "No message");
+ if (FB_SQL_G(generateWarnings))
+ {
+ if (emg)
+ php_error(E_WARNING, emg);
+ else
+ php_error(E_WARNING, "No message");
+ }
+ link->errorText = strdup(emg);
+ link->errorNo = fbcemdErrorCodeAtIndex(emd, 0);;
free(emg);
fbcemdRelease(emd);
fbcmdRelease(md);
@@ -1276,8 +1291,10 @@ PHP_FUNCTION(fbsql_select_db)
{
int port = atoi(name);
if (port == 0 || port > 64535) {
- php_error(E_WARNING, "Cannot connect to FBExec for database '%s'", name);
- php_error(E_WARNING, fbcehClassErrorMessage());
+ if (FB_SQL_G(generateWarnings)) {
+ php_error(E_WARNING, "Cannot connect to FBExec for database '%s'", name);
+ php_error(E_WARNING, fbcehClassErrorMessage());
+ }
RETURN_FALSE;
}
}
@@ -1390,13 +1407,15 @@ PHP_FUNCTION(fbsql_create_db)
else if (status == FBRunning ) txt = "running";
else if (status == FBStopping) txt = "stopping";
else if (status == FBNoExec ) txt = "no exec";
- php_error(E_WARNING, "Could not create %s@%s, database is %s", databaseName, phpLink->hostName, txt);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Could not create %s@%s, database is %s", databaseName, phpLink->hostName, txt);
RETURN_FALSE;
}
if (!fbcehCreateDatabaseNamedWithOptions(phpLink->execHandler, databaseName, ""))
{
char* error = fbechErrorMessage(phpLink->execHandler);
- php_error(E_WARNING, "Could not create %s@%s. %s.", databaseName, phpLink->hostName, error);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Could not create %s@%s. %s.", databaseName, phpLink->hostName, error);
RETURN_FALSE;
}
for (i=0; i < 20; i++)
@@ -1411,7 +1430,8 @@ PHP_FUNCTION(fbsql_create_db)
}
if (status != FBRunning)
{
- php_error(E_WARNING, "Database %s@%s created -- status unknown", databaseName, phpLink->hostName);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Database %s@%s created -- status unknown", databaseName, phpLink->hostName);
RETURN_FALSE;
}
RETURN_TRUE;
@@ -1461,14 +1481,16 @@ PHP_FUNCTION(fbsql_drop_db)
else if (status == FBRunning ) txt = "running";
else if (status == FBStopping ) txt = "stopping";
else if (status == FBNoExec ) txt = "no exec";
- php_error(E_WARNING, "Could not drop %s@%s, database is %s.", databaseName, phpLink->hostName, txt);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Could not drop %s@%s, database is %s.", databaseName, phpLink->hostName, txt);
RETURN_FALSE;
}
if (! fbcehDeleteDatabaseNamed (phpLink->execHandler, databaseName))
{
char* error = fbechErrorMessage(phpLink->execHandler);
- php_error(E_WARNING, "Could not drop %s@%s. %s.", databaseName, phpLink->hostName, error);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Could not drop %s@%s. %s.", databaseName, phpLink->hostName, error);
RETURN_FALSE;
}
for (i=0; i < 20; i++)
@@ -1483,7 +1505,8 @@ PHP_FUNCTION(fbsql_drop_db)
}
if (status != FBUnknownStatus)
{
- php_error(E_WARNING, "Database %s@%s dropped -- status unknown", databaseName, phpLink->hostName);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Database %s@%s dropped -- status unknown", databaseName, phpLink->hostName);
RETURN_FALSE;
}
}
@@ -1531,7 +1554,8 @@ PHP_FUNCTION(fbsql_start_db)
else if (status == FBRunning ) txt = "running";
else if (status == FBStopping) txt = "stopping";
else if (status == FBNoExec ) txt = "no exec";
- php_error(E_WARNING, "Could not start %s@%s, as database is %s.", databaseName, phpLink->hostName, txt);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Could not start %s@%s, as database is %s.", databaseName, phpLink->hostName, txt);
RETURN_FALSE;
}
@@ -1540,7 +1564,8 @@ PHP_FUNCTION(fbsql_start_db)
if (!fbcehStartDatabaseNamed (phpLink->execHandler, databaseName))
{
char* error = fbechErrorMessage(phpLink->execHandler);
- php_error(E_WARNING, "Could not start %s@%s. %s.", databaseName, phpLink->hostName, error);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Could not start %s@%s. %s.", databaseName, phpLink->hostName, error);
RETURN_FALSE;
}
}
@@ -1557,7 +1582,8 @@ PHP_FUNCTION(fbsql_start_db)
}
if (status != FBRunning)
{
- php_error(E_WARNING, "Database %s@%s started -- status unknown", databaseName, phpLink->hostName);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Database %s@%s started -- status unknown", databaseName, phpLink->hostName);
RETURN_FALSE;
}
RETURN_TRUE;
@@ -1604,7 +1630,8 @@ PHP_FUNCTION(fbsql_stop_db)
/* printf("Stop db %x\n", phpDatabase->connection); */
if (!fbcdcStopDatabase(phpLink->connection))
{
- php_error(E_WARNING, "Cannot stop database %s@%s", databaseName, phpLink->hostName);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Cannot stop database %s@%s", databaseName, phpLink->hostName);
RETURN_FALSE;
}
@@ -1696,7 +1723,7 @@ int mdOk(PHPFBLink* link, FBCMetaData* md, char* sql)
php_error(E_WARNING, "No message");
}
link->errorText = strdup(emg);
- link->errorNo = 1;
+ link->errorNo = fbcemdErrorCodeAtIndex(emd, 0);;
free(emg);
fbcemdRelease(emd);
result = 0;
@@ -2325,7 +2352,7 @@ void phpfbColumnAsString (PHPFBResult* result, int column, void* data , int* len
break;
default:
- php_error(E_WARNING, "Unimplemented type");
+ php_error(E_ERROR, "Unimplemented type");
break;
}
}
@@ -2369,12 +2396,14 @@ void phpfbSqlResult(INTERNAL_FUNCTION_PARAMETERS, PHPFBResult* result, int rowIn
}
else if (!phpfbFetchRow(result, rowIndex))
{
- php_error(E_WARNING, "No such row %d in result set %d", rowIndex, rowIndex);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "No such row %d in result set %d", rowIndex, rowIndex);
RETURN_FALSE;
}
else if (columnIndex >= result->columnCount)
{
- php_error(E_WARNING, "No such column %d in result set %d", columnIndex, rowIndex);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "No such column %d in result set %d", columnIndex, rowIndex);
RETURN_FALSE;
}
else
@@ -2454,7 +2483,8 @@ PHP_FUNCTION(fbsql_result)
columnIndex = Z_LVAL_PP(field);
if (columnIndex < 0)
{
- php_error(E_WARNING, "Illegal column index - %d", columnIndex);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Illegal column index - %d", columnIndex);
RETURN_FALSE;
}
}
@@ -2611,6 +2641,50 @@ PHP_FUNCTION(fbsql_fetch_array)
}
/* }}} */
+static void _parse_list(zval** return_value, FBCPList* list)
+{
+ int count = fbcplCount(list);
+ int i,j;
+
+ for (i=0; i<count; i++)
+ {
+ char* key = (char*)fbcplKeyAtIndex(list, i);
+ FBCPList* value = (FBCPList*)fbcplValueForKey(list, key);
+ if (fbcplIsDictionary(value))
+ {
+ zval *value_array;
+
+ MAKE_STD_ZVAL(value_array);
+ array_init(value_array);
+
+ _parse_list(&value_array, value);
+ add_assoc_zval(*return_value, key, value_array);
+ }
+ else if (fbcplIsArray(value))
+ {
+ zval *value_array;
+ int valcount = fbcplCount(value);
+
+ MAKE_STD_ZVAL(value_array);
+ array_init(value_array);
+
+ for (j=0; j<valcount; j++)
+ {
+ FBCPList* arrayValue = (FBCPList*)fbcplValueAtIndex(value, j);
+ if (fbcplIsString(arrayValue))
+ add_index_string(value_array, j, (char*)fbcplString(arrayValue), 1);
+ else {
+ _parse_list(&value_array, arrayValue);
+ }
+ }
+ add_assoc_zval(*return_value, key, value_array);
+ }
+ else if (fbcplIsString(value)) {
+ add_assoc_string(*return_value, key, (char*)fbcplString(value), 1);
+ }
+ }
+}
+
static void php_fbsql_fetch_hash(INTERNAL_FUNCTION_PARAMETERS, int result_type)
{
@@ -2642,7 +2716,8 @@ static void php_fbsql_fetch_hash(INTERNAL_FUNCTION_PARAMETERS, int result_type)
rowIndex = result->rowIndex;
if (((result_type & FBSQL_NUM) != FBSQL_NUM) && ((result_type & FBSQL_ASSOC) != FBSQL_ASSOC))
{
- php_error(E_WARNING, "Illegal result type use FBSQL_NUM, FBSQL_ASSOC, or FBSQL_BOTH.");
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Illegal result type use FBSQL_NUM, FBSQL_ASSOC, or FBSQL_BOTH.");
RETURN_FALSE;
}
if (array_init(return_value)==FAILURE)
@@ -2651,7 +2726,7 @@ static void php_fbsql_fetch_hash(INTERNAL_FUNCTION_PARAMETERS, int result_type)
}
if (result->fetchHandle == NULL)
{
- if (result->array == NULL)
+ if (result->array == NULL && result->list == NULL)
{
RETURN_FALSE;
}
@@ -2659,13 +2734,81 @@ static void php_fbsql_fetch_hash(INTERNAL_FUNCTION_PARAMETERS, int result_type)
{
RETURN_FALSE;
}
- if (result_type & FBSQL_NUM)
- {
- add_index_string(return_value, 0, estrdup(fbaObjectAtIndex(result->array, result->rowIndex)), 0);
+ if (result->list) {
+ char* key;
+ FBCPList* value;
+
+ if (result->rowCount == 0 || result->rowIndex >= result->rowCount) {
+ RETURN_FALSE;
+ }
+
+ value = (FBCPList*)fbcplValueAtIndex(result->list, result->rowIndex);
+ key = (char*)fbcplKeyAtIndex(result->list, result->rowIndex);
+ if (key && key[0] == 2)
+ key = NULL;
+
+ if (fbcplIsDictionary(value)) {
+ zval *value_array;
+
+ MAKE_STD_ZVAL(value_array);
+ array_init(value_array);
+
+ _parse_list(&value_array, value);
+ if (result_type & FBSQL_NUM || key == NULL)
+ {
+ add_index_zval(return_value, 0, value_array);
+ }
+ if (result_type & FBSQL_ASSOC && key != NULL)
+ {
+ add_assoc_zval(return_value, key, value_array);
+ }
+ }
+ else if (fbcplIsArray(value)) {
+ zval *value_array;
+ int valcount = fbcplCount(value);
+ int j;
+
+ MAKE_STD_ZVAL(value_array);
+ array_init(value_array);
+
+ for (j=0; j<valcount; j++)
+ {
+ FBCPList* arrayValue = (FBCPList*)fbcplValueAtIndex(value, j);
+ if (fbcplIsString(arrayValue))
+ add_index_string(value_array, j, (char*)fbcplString(arrayValue), 1);
+ else {
+ _parse_list(&value_array, arrayValue);
+ }
+ }
+ if (result_type & FBSQL_NUM || key == NULL)
+ {
+ add_index_zval(return_value, 0, value_array);
+ }
+ if (result_type & FBSQL_ASSOC && key != NULL)
+ {
+ add_assoc_zval(return_value, key, value_array);
+ }
+ }
+ else if (fbcplIsString(value)) {
+ if (result_type & FBSQL_NUM)
+ {
+ add_index_string(return_value, 0, (char*)fbcplString(value), 1);
+ }
+ if (result_type & FBSQL_ASSOC)
+ {
+ add_assoc_string(return_value, key, (char*)fbcplString(value), 1);
+ }
+ }
}
- if (result_type & FBSQL_ASSOC)
- {
- add_assoc_string(return_value, "Database", estrdup(fbaObjectAtIndex(result->array, result->rowIndex)), 0);
+ else {
+ if (result_type & FBSQL_NUM)
+ {
+ add_index_string(return_value, 0, estrdup(fbaObjectAtIndex(result->array, result->rowIndex)), 0);
+ }
+ if (result_type & FBSQL_ASSOC)
+ {
+ add_assoc_string(return_value, "Database", estrdup(fbaObjectAtIndex(result->array, result->rowIndex)), 0);
+ }
}
}
else {
@@ -2745,7 +2888,8 @@ PHP_FUNCTION(fbsql_data_seek)
if (rowIndex < 0)
{
- php_error(E_WARNING, "Illegal row_index (%i)", rowIndex);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "Illegal row_index (%i)", rowIndex);
RETURN_FALSE;
}
@@ -2820,7 +2964,8 @@ PHP_FUNCTION(fbsql_fetch_field)
column = Z_LVAL_PP(field_index);
if (column < 0 || column >= result->columnCount)
{
- php_error(E_WARNING, "%d no such column in result", column);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "%d no such column in result", column);
RETURN_FALSE;
}
}
@@ -2876,7 +3021,8 @@ PHP_FUNCTION(fbsql_field_seek)
column = Z_LVAL_PP(field_index);
if (column < 0 || column >= result->columnCount)
{
- php_error(E_WARNING, "%d no such column in result", column);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "%d no such column in result", column);
RETURN_FALSE;
}
}
@@ -2918,7 +3064,8 @@ PHP_FUNCTION(fbsql_field_name)
column = Z_LVAL_PP(field_index);
if (column < 0 || column >= result->columnCount)
{
- php_error(E_WARNING, "%d no such column in result", column);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "%d no such column in result", column);
RETURN_FALSE;
}
}
@@ -2966,7 +3113,8 @@ PHP_FUNCTION(fbsql_field_table)
column = Z_LVAL_PP(field_index);
if (column < 0 || column >= result->columnCount)
{
- php_error(E_WARNING, "%d no such column in result", column);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "%d no such column in result", column);
RETURN_FALSE;
}
}
@@ -3006,7 +3154,8 @@ PHP_FUNCTION(fbsql_field_len)
column = Z_LVAL_PP(field_index);
if (column < 0 || column >= result->columnCount)
{
- php_error(E_WARNING, "%d no such column in result", column);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "%d no such column in result", column);
RETURN_FALSE;
}
}
@@ -3057,7 +3206,8 @@ PHP_FUNCTION(fbsql_field_type)
column = Z_LVAL_PP(field_index);
if (column < 0 || column >= result->columnCount)
{
- php_error(E_WARNING, "%d no such column in result", column);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "%d no such column in result", column);
RETURN_FALSE;
}
}
@@ -3110,7 +3260,8 @@ PHP_FUNCTION(fbsql_field_flags)
column = Z_LVAL_PP(field_index);
if (column < 0 || column >= result->columnCount)
{
- php_error(E_WARNING, "%d no such column in result", column);
+ if (FB_SQL_G(generateWarnings))
+ php_error(E_WARNING, "%d no such column in result", column);
RETURN_FALSE;
}
}