#endif
+/* True globals, no need for thread safety */
+int le_result,le_link,le_plink;
+
#include "php_ini.h"
#if HAVE_MYSQL
PHP_INI_END()
+#ifdef ZTS
+static void php_mysql_init_globals(php_mysql_globals *mysql_globals)
+{
+ MySG(num_persistent) = 0;
+}
+#endif
+
+
int php3_minit_mysql(INIT_FUNC_ARGS)
{
- REGISTER_INI_ENTRIES();
+#ifdef ZTS
+ mysql_globals_id = tsrm_allocate_id(sizeof(php_mysql_globals), php_mysql_init_globals, NULL);
+#else
MySG(num_persistent)=0;
- MySG(le_result) = register_list_destructors(_free_mysql_result,NULL);
- MySG(le_link) = register_list_destructors(_close_mysql_link,NULL);
- MySG(le_plink) = register_list_destructors(NULL,_close_mysql_plink);
-
-#if 0
- printf("Registered: %d,%d,%d\n",MySG(le_result),MySG(le_link),MySG(le_plink));
#endif
+
+ REGISTER_INI_ENTRIES();
+ le_result = register_list_destructors(_free_mysql_result,NULL);
+ le_link = register_list_destructors(_close_mysql_link,NULL);
+ le_plink = register_list_destructors(NULL,_close_mysql_plink);
mysql_module_entry.type = type;
return SUCCESS;
return SUCCESS;
}
+
int php3_rinit_mysql(INIT_FUNC_ARGS)
{
MySLS_FETCH();
}
/* hash it up */
- new_le.type = MySG(le_plink);
+ new_le.type = le_plink;
new_le.ptr = mysql;
if (_php3_hash_update(plist, hashed_details, hashed_details_length+1, (void *) &new_le, sizeof(list_entry), NULL)==FAILURE) {
free(mysql);
MySG(num_persistent)++;
MySG(num_links)++;
} else { /* we do */
- if (le->type != MySG(le_plink)) {
+ if (le->type != le_plink) {
RETURN_FALSE;
}
/* ensure that the link did not die */
#endif
mysql = (MYSQL *) le->ptr;
}
- return_value->value.lval = php3_list_insert(mysql,MySG(le_plink));
+ return_value->value.lval = php3_list_insert(mysql,le_plink);
return_value->type = IS_RESOURCE;
} else { /* non persistent */
list_entry *index_ptr,new_index_ptr;
}
link = (int) index_ptr->ptr;
ptr = php3_list_find(link,&type); /* check if the link is still there */
- if (ptr && (type==MySG(le_link) || type==MySG(le_plink))) {
+ if (ptr && (type==le_link || type==le_plink)) {
zend_list_addref(link);
return_value->value.lval = link;
php_mysql_set_default_link(link);
}
/* add it to the list */
- return_value->value.lval = php3_list_insert(mysql,MySG(le_link));
+ return_value->value.lval = php3_list_insert(mysql,le_link);
return_value->type = IS_RESOURCE;
/* add it to the hash */
}
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
CHECK_LINK(id);
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
CHECK_LINK(id);
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
CHECK_LINK(id);
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
}
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
*/
RETURN_TRUE;
}
- return_value->value.lval = php3_list_insert(mysql_result,MySG(le_result));
+ return_value->value.lval = php3_list_insert(mysql_result,le_result);
return_value->type = IS_RESOURCE;
}
/* }}} */
CHECK_LINK(id);
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
*/
RETURN_TRUE;
}
- return_value->value.lval = php3_list_insert(mysql_result,MySG(le_result));
+ return_value->value.lval = php3_list_insert(mysql_result,le_result);
return_value->type = IS_RESOURCE;
}
/* }}} */
CHECK_LINK(id);
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
php3_error(E_WARNING,"Unable to save MySQL query result");
RETURN_FALSE;
}
- return_value->value.lval = php3_list_insert(mysql_result,MySG(le_result));
+ return_value->value.lval = php3_list_insert(mysql_result,le_result);
return_value->type = IS_RESOURCE;
}
/* }}} */
CHECK_LINK(id);
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
php3_error(E_WARNING,"Unable to save MySQL query result");
RETURN_FALSE;
}
- return_value->value.lval = php3_list_insert(mysql_result,MySG(le_result));
+ return_value->value.lval = php3_list_insert(mysql_result,le_result);
return_value->type = IS_RESOURCE;
}
/* }}} */
CHECK_LINK(id);
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
php3_error(E_WARNING,"Unable to save MySQL query result");
RETURN_FALSE;
}
- return_value->value.lval = php3_list_insert(mysql_result,MySG(le_result));
+ return_value->value.lval = php3_list_insert(mysql_result,le_result);
return_value->type = IS_RESOURCE;
}
/* }}} */
RETURN_FALSE;
}
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
RETURN_FALSE;
}
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
}
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
}
mysql = (MYSQL *) php3_list_find(id,&type);
- if (type!=MySG(le_link) && type!=MySG(le_plink)) {
+ if (type!=le_link && type!=le_plink) {
php3_error(E_WARNING,"%d is not a MySQL link index",id);
RETURN_FALSE;
}
convert_to_long(result);
mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
- if (type!=MySG(le_result)) {
+ if (type!=le_result) {
php3_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
RETURN_FALSE;
}
convert_to_long(result);
mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
- if (type!=MySG(le_result)) {
+ if (type!=le_result) {
php3_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
RETURN_FALSE;
}
convert_to_long(result);
mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
- if (type!=MySG(le_result)) {
+ if (type!=le_result) {
php3_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
RETURN_FALSE;
}
convert_to_long(result);
mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
- if (type!=MySG(le_result)) {
+ if (type!=le_result) {
php3_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
RETURN_FALSE;
}
convert_to_long(result);
mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
- if (type!=MySG(le_result)) {
+ if (type!=le_result) {
php3_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
RETURN_FALSE;
}
convert_to_long(result);
mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
- if (type!=MySG(le_result)) {
+ if (type!=le_result) {
php3_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
RETURN_FALSE;
}
convert_to_long(result);
mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
- if (type!=MySG(le_result)) {
+ if (type!=le_result) {
php3_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
RETURN_FALSE;
}
convert_to_long(result);
mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
- if (type!=MySG(le_result)) {
+ if (type!=le_result) {
php3_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
RETURN_FALSE;
}
convert_to_long(result);
mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
- if (type!=MySG(le_result)) {
+ if (type!=le_result) {
php3_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
RETURN_FALSE;
}
convert_to_long(result);
mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
- if (type!=MySG(le_result)) {
+ if (type!=le_result) {
php3_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
RETURN_FALSE;
}
mysql_result = (MYSQL_RES *) php3_list_find(result->value.lval,&type);
- if (type!=MySG(le_result)) {
+ if (type!=le_result) {
php3_error(E_WARNING,"%d is not a MySQL result index",result->value.lval);
RETURN_FALSE;
}