Close a MySQL connection */
PHP_FUNCTION(mysql_close)
{
- pval *mysql_link;
- int id,type;
+ pval *mysql_link=NULL;
+ int id;
MYSQL *mysql;
MySLS_FETCH();
if (getParameters(ht, 1, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
php3_list_delete(id);
RETURN_TRUE;
PHP_FUNCTION(mysql_select_db)
{
pval *db,*mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MySLS_FETCH();
RETURN_FALSE;
}
id = php3_mysql_get_default_link(INTERNAL_FUNCTION_PARAM_PASSTHRU MySLS_CC);
+ CHECK_LINK(id);
break;
case 2:
if (getParameters(ht, 2, &db, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
- CHECK_LINK(id);
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
convert_to_string(db);
PHP_FUNCTION(mysql_create_db)
{
pval *db,*mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MySLS_FETCH();
RETURN_FALSE;
}
id = php3_mysql_get_default_link(INTERNAL_FUNCTION_PARAM_PASSTHRU MySLS_CC);
+ CHECK_LINK(id);
break;
case 2:
if (getParameters(ht, 2, &db, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
- CHECK_LINK(id);
-
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
convert_to_string(db);
if (mysql_create_db(mysql,db->value.str.val)==0) {
PHP_FUNCTION(mysql_drop_db)
{
pval *db,*mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MySLS_FETCH();
RETURN_FALSE;
}
id = php3_mysql_get_default_link(INTERNAL_FUNCTION_PARAM_PASSTHRU MySLS_CC);
+ CHECK_LINK(id);
break;
case 2:
if (getParameters(ht, 2, &db, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
- CHECK_LINK(id);
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
convert_to_string(db);
if (mysql_drop_db(mysql,db->value.str.val)==0) {
PHP_FUNCTION(mysql_query)
{
pval *query,*mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MYSQL_RES *mysql_result;
MySLS_FETCH();
RETURN_FALSE;
}
id = php3_mysql_get_default_link(INTERNAL_FUNCTION_PARAM_PASSTHRU MySLS_CC);
+ CHECK_LINK(id);
break;
case 2:
if (getParameters(ht, 2, &query, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
convert_to_string(query);
/* mysql_query binary unsafe, use mysql_real_query */
PHP_FUNCTION(mysql_db_query)
{
pval *db,*query,*mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MYSQL_RES *mysql_result;
MySLS_FETCH();
RETURN_FALSE;
}
id = php3_mysql_get_default_link(INTERNAL_FUNCTION_PARAM_PASSTHRU MySLS_CC);
+ CHECK_LINK(id);
break;
case 3:
if (getParameters(ht, 3, &db, &query, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
- CHECK_LINK(id);
-
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
convert_to_string(db);
if (mysql_select_db(mysql,db->value.str.val)!=0) {
PHP_FUNCTION(mysql_list_dbs)
{
pval *mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MYSQL_RES *mysql_result;
MySLS_FETCH();
switch(ARG_COUNT(ht)) {
case 0:
id = php3_mysql_get_default_link(INTERNAL_FUNCTION_PARAM_PASSTHRU MySLS_CC);
+ CHECK_LINK(id);
break;
case 1:
if (getParameters(ht, 1, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
- CHECK_LINK(id);
-
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
+
if ((mysql_result=mysql_list_dbs(mysql,NULL))==NULL) {
php_error(E_WARNING,"Unable to save MySQL query result");
RETURN_FALSE;
PHP_FUNCTION(mysql_list_tables)
{
pval *db,*mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MYSQL_RES *mysql_result;
MySLS_FETCH();
RETURN_FALSE;
}
id = php3_mysql_get_default_link(INTERNAL_FUNCTION_PARAM_PASSTHRU MySLS_CC);
+ CHECK_LINK(id);
break;
case 2:
if (getParameters(ht, 2, &db, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
-
- CHECK_LINK(id);
-
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
convert_to_string(db);
if (mysql_select_db(mysql,db->value.str.val)!=0) {
PHP_FUNCTION(mysql_list_fields)
{
pval *db,*table,*mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MYSQL_RES *mysql_result;
MySLS_FETCH();
RETURN_FALSE;
}
id = php3_mysql_get_default_link(INTERNAL_FUNCTION_PARAM_PASSTHRU MySLS_CC);
+ CHECK_LINK(id);
break;
case 3:
if (getParameters(ht, 3, &db, &table, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
-
- CHECK_LINK(id);
-
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
convert_to_string(db);
if (mysql_select_db(mysql,db->value.str.val)!=0) {
PHP_FUNCTION(mysql_error)
{
pval *mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MySLS_FETCH();
switch(ARG_COUNT(ht)) {
case 0:
id = MySG(default_link);
+ if (id==-1) {
+ RETURN_FALSE;
+ }
break;
case 1:
if (getParameters(ht, 1, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
- if (id==-1) {
- RETURN_FALSE;
- }
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
RETURN_STRING(mysql_error(mysql),1);
}
PHP_FUNCTION(mysql_errno)
{
pval *mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MySLS_FETCH();
switch(ARG_COUNT(ht)) {
case 0:
id = MySG(default_link);
+ if (id==-1) {
+ RETURN_FALSE;
+ }
break;
case 1:
if (getParameters(ht, 1, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
- if (id==-1) {
- RETURN_FALSE;
- }
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
RETURN_LONG(mysql_errno(mysql));
}
PHP_FUNCTION(mysql_affected_rows)
{
pval *mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MySLS_FETCH();
switch(ARG_COUNT(ht)) {
case 0:
id = MySG(default_link);
+ CHECK_LINK(id);
break;
case 1:
if (getParameters(ht, 1, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
/* conversion from int64 to long happing here */
return_value->value.lval = (long)mysql_affected_rows(mysql);
PHP_FUNCTION(mysql_insert_id)
{
pval *mysql_link;
- int id,type;
+ int id;
MYSQL *mysql;
MySLS_FETCH();
switch(ARG_COUNT(ht)) {
case 0:
id = MySG(default_link);
+ CHECK_LINK(id);
break;
case 1:
if (getParameters(ht, 1, &mysql_link)==FAILURE) {
RETURN_FALSE;
}
- convert_to_long(mysql_link);
- id = mysql_link->value.lval;
+ id = -1;
break;
default:
WRONG_PARAM_COUNT;
break;
}
- mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=le_link && type!=le_plink) {
- php_error(E_WARNING,"%d is not a MySQL link index",id);
- RETURN_FALSE;
- }
+ mysql = (MYSQL *) zend_fetch_resource_ex(mysql_link, id, "MySQL link", 2, le_link, le_plink);
+ ZEND_VERIFY_RESOURCE(mysql);
/* conversion from int64 to long happing here */
return_value->value.lval = (long)mysql_insert_id(mysql);
MYSQL_RES *mysql_result;
MYSQL_ROW sql_row;
mysql_row_length_type *sql_row_lengths;
- int type,field_offset=0;
+ int field_offset=0;
PLS_FETCH();
switch (ARG_COUNT(ht)) {
break;
}
- convert_to_long(result);
- mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
-
- if (type!=le_result) {
- php_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
- RETURN_FALSE;
- }
-
+ ZEND_FETCH_RESOURCE(mysql_result, MYSQL_RES *, result, -1, "MySQL result", le_result);
+
convert_to_long(row);
if (row->value.lval<0 || row->value.lval>=(int)mysql_num_rows(mysql_result)) {
php_error(E_WARNING,"Unable to jump to row %d on MySQL result index %d",row->value.lval,result->value.lval);
{
pval *result;
MYSQL_RES *mysql_result;
- int type;
-
if (ARG_COUNT(ht)!=1 || getParameters(ht, 1, &result)==FAILURE) {
WRONG_PARAM_COUNT;
}
- convert_to_long(result);
- mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
-
- if (type!=le_result) {
- php_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
- RETURN_FALSE;
- }
+ ZEND_FETCH_RESOURCE(mysql_result, MYSQL_RES *, result, -1, "MySQL result", le_result);
/* conversion from int64 to long happing here */
return_value->value.lval = (long)mysql_num_rows(mysql_result);
{
pval *result;
MYSQL_RES *mysql_result;
- int type;
-
if (ARG_COUNT(ht)!=1 || getParameters(ht, 1, &result)==FAILURE) {
WRONG_PARAM_COUNT;
}
- convert_to_long(result);
- mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
-
- if (type!=le_result) {
- php_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
- RETURN_FALSE;
- }
+ ZEND_FETCH_RESOURCE(mysql_result, MYSQL_RES *, result, -1, "MySQL result", le_result);
return_value->value.lval = mysql_num_fields(mysql_result);
return_value->type = IS_LONG;
MYSQL_ROW mysql_row;
MYSQL_FIELD *mysql_field;
mysql_row_length_type *mysql_row_lengths;
- int type;
int num_fields;
int i;
PLS_FETCH();
break;
}
- convert_to_long(result);
- mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
-
- if (type!=le_result) {
- php_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
- RETURN_FALSE;
- }
+ ZEND_FETCH_RESOURCE(mysql_result, MYSQL_RES *, result, -1, "MySQL result", le_result);
+
if ((mysql_row=mysql_fetch_row(mysql_result))==NULL
|| (mysql_row_lengths=mysql_fetch_lengths(mysql_result))==NULL) {
RETURN_FALSE;
{
pval *result,*offset;
MYSQL_RES *mysql_result;
- int type;
-
if (ARG_COUNT(ht)!=2 || getParameters(ht, 2, &result, &offset)==FAILURE) {
WRONG_PARAM_COUNT;
}
- convert_to_long(result);
- mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
-
- if (type!=le_result) {
- php_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
- RETURN_FALSE;
- }
+ ZEND_FETCH_RESOURCE(mysql_result, MYSQL_RES *, result, -1, "MySQL result", le_result);
+
convert_to_long(offset);
if (offset->value.lval<0 || offset->value.lval>=(int)mysql_num_rows(mysql_result)) {
php_error(E_WARNING,"Offset %d is invalid for MySQL result index %d",offset->value.lval,result->value.lval);
pval *result;
MYSQL_RES *mysql_result;
mysql_row_length_type *lengths;
- int type;
int num_fields;
int i;
WRONG_PARAM_COUNT;
}
- convert_to_long(result);
- mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
-
- if (type!=le_result) {
- php_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
- RETURN_FALSE;
- }
+ ZEND_FETCH_RESOURCE(mysql_result, MYSQL_RES *, result, -1, "MySQL result", le_result);
+
if ((lengths=mysql_fetch_lengths(mysql_result))==NULL) {
RETURN_FALSE;
}
pval *result,*field=NULL;
MYSQL_RES *mysql_result;
MYSQL_FIELD *mysql_field;
- int type;
-
switch (ARG_COUNT(ht)) {
case 1:
WRONG_PARAM_COUNT;
}
- convert_to_long(result);
- mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
-
- if (type!=le_result) {
- php_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
- RETURN_FALSE;
- }
+ ZEND_FETCH_RESOURCE(mysql_result, MYSQL_RES *, result, -1, "MySQL result", le_result);
+
if (field) {
if (field->value.lval<0 || field->value.lval>=(int)mysql_num_fields(mysql_result)) {
php_error(E_WARNING,"MySQL: Bad field offset");
{
pval *result, *offset;
MYSQL_RES *mysql_result;
- int type;
-
if (ARG_COUNT(ht)!=2 || getParameters(ht, 2, &result, &offset)==FAILURE) {
WRONG_PARAM_COUNT;
}
- convert_to_long(result);
- mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
-
- if (type!=le_result) {
- php_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
- RETURN_FALSE;
- }
+ ZEND_FETCH_RESOURCE(mysql_result, MYSQL_RES *, result, -1, "MySQL result", le_result);
+
convert_to_long(offset);
if (offset->value.lval<0 || offset->value.lval>=(int)mysql_num_fields(mysql_result)) {
php_error(E_WARNING,"Field %d is invalid for MySQL result index %d",offset->value.lval,result->value.lval);
pval *result, *field;
MYSQL_RES *mysql_result;
MYSQL_FIELD *mysql_field;
- int type;
char buf[512];
int len;
WRONG_PARAM_COUNT;
}
- convert_to_long(result);
- mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
-
- if (type!=le_result) {
- php_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
- RETURN_FALSE;
- }
+ ZEND_FETCH_RESOURCE(mysql_result, MYSQL_RES *, result, -1, "MySQL result", le_result);
convert_to_long(field);
if (field->value.lval<0 || field->value.lval>=(int)mysql_num_fields(mysql_result)) {
{
pval *result;
MYSQL_RES *mysql_result;
- int type;
if (ARG_COUNT(ht)!=1 || getParameters(ht, 1, &result)==FAILURE) {
WRONG_PARAM_COUNT;
}
- convert_to_long(result);
- if (result->value.lval==0) {
+ if (result->type==IS_RESOURCE && result->value.lval==0) {
RETURN_FALSE;
}
- mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
-
- if (type!=le_result) {
- php_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
- RETURN_FALSE;
- }
+ ZEND_FETCH_RESOURCE(mysql_result, MYSQL_RES *, result, -1, "MySQL result", le_result);
+
php3_list_delete(result->value.lval);
RETURN_TRUE;
}