]> granicus.if.org Git - php/commitdiff
ZTS fix
authorDmitry Stogov <dmitry@php.net>
Wed, 25 Apr 2007 14:18:01 +0000 (14:18 +0000)
committerDmitry Stogov <dmitry@php.net>
Wed, 25 Apr 2007 14:18:01 +0000 (14:18 +0000)
main/SAPI.c

index 968b96bd6aa51ae33a3d69007ed706fdef1bf024..0e955e4a7ac9a258c63cf3af3d74edb72f92639c 100644 (file)
@@ -861,7 +861,7 @@ SAPI_API int sapi_register_post_entries(sapi_post_entry *post_entries TSRMLS_DC)
 
 SAPI_API int sapi_register_post_entry(sapi_post_entry *post_entry TSRMLS_DC)
 {
-       if (EG(in_execution)) {
+       if (SG(sapi_started) && EG(in_execution)) {
                return FAILURE;
        }
        return zend_hash_add(&SG(known_post_content_types),
@@ -871,7 +871,7 @@ SAPI_API int sapi_register_post_entry(sapi_post_entry *post_entry TSRMLS_DC)
 
 SAPI_API void sapi_unregister_post_entry(sapi_post_entry *post_entry TSRMLS_DC)
 {
-       if (EG(in_execution)) {
+       if (SG(sapi_started) && EG(in_execution)) {
                return;
        }
        zend_hash_del(&SG(known_post_content_types), post_entry->content_type,
@@ -882,7 +882,7 @@ SAPI_API void sapi_unregister_post_entry(sapi_post_entry *post_entry TSRMLS_DC)
 SAPI_API int sapi_register_default_post_reader(void (*default_post_reader)(TSRMLS_D))
 {
        TSRMLS_FETCH();
-       if (EG(in_execution)) {
+       if (SG(sapi_started) && EG(in_execution)) {
                return FAILURE;
        }
        sapi_module.default_post_reader = default_post_reader;
@@ -893,7 +893,7 @@ SAPI_API int sapi_register_default_post_reader(void (*default_post_reader)(TSRML
 SAPI_API int sapi_register_treat_data(void (*treat_data)(int arg, char *str, zval *destArray TSRMLS_DC))
 {
        TSRMLS_FETCH();
-       if (EG(in_execution)) {
+       if (SG(sapi_started) && EG(in_execution)) {
                return FAILURE;
        }
        sapi_module.treat_data = treat_data;
@@ -903,7 +903,7 @@ SAPI_API int sapi_register_treat_data(void (*treat_data)(int arg, char *str, zva
 SAPI_API int sapi_register_input_filter(unsigned int (*input_filter)(int arg, char *var, char **val, unsigned int val_len, unsigned int *new_val_len TSRMLS_DC))
 {
        TSRMLS_FETCH();
-       if (EG(in_execution)) {
+       if (SG(sapi_started) && EG(in_execution)) {
                return FAILURE;
        }
        sapi_module.input_filter = input_filter;