diff options
author | Zeev Suraski <zeev@php.net> | 2001-07-28 10:51:54 +0000 |
---|---|---|
committer | Zeev Suraski <zeev@php.net> | 2001-07-28 10:51:54 +0000 |
commit | b4f3b9d3ce9f55cf040fb5aa8f201c64646cab43 (patch) | |
tree | 8d4a54f5763387c1a31a4e382e07138bcfde4857 /Zend | |
parent | 633a1c30d115baa6436883ff44fd5abb127e0a7f (diff) | |
download | php-git-b4f3b9d3ce9f55cf040fb5aa8f201c64646cab43.tar.gz |
Redesigned thread safety mechanism - nua nua
Diffstat (limited to 'Zend')
-rw-r--r-- | Zend/Zend.dsp | 20 | ||||
-rw-r--r-- | Zend/ZendTS.dsp | 26 | ||||
-rw-r--r-- | Zend/zend.c | 45 | ||||
-rw-r--r-- | Zend/zend.h | 2 | ||||
-rw-r--r-- | Zend/zend_API.c | 10 | ||||
-rw-r--r-- | Zend/zend_alloc.c | 16 | ||||
-rw-r--r-- | Zend/zend_alloc.h | 5 | ||||
-rw-r--r-- | Zend/zend_builtin_functions.c | 3 | ||||
-rw-r--r-- | Zend/zend_compile.c | 490 | ||||
-rw-r--r-- | Zend/zend_compile.h | 234 | ||||
-rw-r--r-- | Zend/zend_execute.c | 10 | ||||
-rw-r--r-- | Zend/zend_execute.h | 6 | ||||
-rw-r--r-- | Zend/zend_execute_API.c | 21 | ||||
-rw-r--r-- | Zend/zend_fast_cache.h | 4 | ||||
-rw-r--r-- | Zend/zend_globals_macros.h | 24 | ||||
-rw-r--r-- | Zend/zend_highlight.c | 10 | ||||
-rw-r--r-- | Zend/zend_indent.c | 8 | ||||
-rw-r--r-- | Zend/zend_ini_parser.y | 4 | ||||
-rw-r--r-- | Zend/zend_ini_scanner.l | 10 | ||||
-rw-r--r-- | Zend/zend_language_parser.y | 392 | ||||
-rw-r--r-- | Zend/zend_language_scanner.h | 2 | ||||
-rw-r--r-- | Zend/zend_language_scanner.l | 82 | ||||
-rw-r--r-- | Zend/zend_opcode.c | 16 |
23 files changed, 699 insertions, 741 deletions
diff --git a/Zend/Zend.dsp b/Zend/Zend.dsp index eae7f9042c..e2a8fe6611 100644 --- a/Zend/Zend.dsp +++ b/Zend/Zend.dsp @@ -215,10 +215,6 @@ SOURCE=.\FlexLexer.h # End Source File
# Begin Source File
-SOURCE=.\zend_modules.h
-# End Source File
-# Begin Source File
-
SOURCE=.\zend.h
# End Source File
# Begin Source File
@@ -299,6 +295,10 @@ SOURCE=.\zend_llist.h # End Source File
# Begin Source File
+SOURCE=.\zend_modules.h
+# End Source File
+# Begin Source File
+
SOURCE=.\zend_operators.h
# End Source File
# Begin Source File
@@ -330,8 +330,7 @@ InputDir=. InputPath=.\zend_ini_parser.y
BuildCmds= \
- bison --output=zend_ini_parser.c -v -d -p ini_ zend_ini_parser.y \
-
+ bison --output=zend_ini_parser.c -v -d -p ini_ zend_ini_parser.y
"$(InputDir)\zend_ini_parser.c" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
$(BuildCmds)
@@ -356,8 +355,7 @@ InputDir=. InputPath=".\zend_language_parser.y"
BuildCmds= \
- bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y \
-
+ bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y
"$(InputDir)\zend_language_parser.c" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
$(BuildCmds)
@@ -373,8 +371,7 @@ InputDir=. InputPath=".\zend_language_parser.y"
BuildCmds= \
- bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y \
-
+ bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y
"$(InputDir)\zend_language_parser.c" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
$(BuildCmds)
@@ -390,8 +387,7 @@ InputDir=. InputPath=".\zend_language_parser.y"
BuildCmds= \
- bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y \
-
+ bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y
"$(InputDir)\zend_language_parser.c" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
$(BuildCmds)
diff --git a/Zend/ZendTS.dsp b/Zend/ZendTS.dsp index bee0e0cae9..0a1bfdd446 100644 --- a/Zend/ZendTS.dsp +++ b/Zend/ZendTS.dsp @@ -244,10 +244,6 @@ SOURCE=.\FlexLexer.h # End Source File
# Begin Source File
-SOURCE=.\zend_modules.h
-# End Source File
-# Begin Source File
-
SOURCE=.\zend.h
# End Source File
# Begin Source File
@@ -352,6 +348,10 @@ SOURCE=.\zend_llist.h # End Source File
# Begin Source File
+SOURCE=.\zend_modules.h
+# End Source File
+# Begin Source File
+
SOURCE=.\zend_operators.h
# End Source File
# Begin Source File
@@ -381,8 +381,7 @@ InputDir=. InputPath=.\zend_ini_parser.y
BuildCmds= \
- bison --output=zend_ini_parser.c -v -d -p ini_ zend_ini_parser.y \
-
+ bison --output=zend_ini_parser.c -v -d -p ini_ zend_ini_parser.y
"$(InputDir)\zend_ini_parser.c" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
$(BuildCmds)
@@ -398,8 +397,7 @@ InputDir=. InputPath=.\zend_ini_parser.y
BuildCmds= \
- bison --output=zend_ini_parser.c -v -d -p ini_ zend_ini_parser.y \
-
+ bison --output=zend_ini_parser.c -v -d -p ini_ zend_ini_parser.y
"$(InputDir)\zend_ini_parser.c" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
$(BuildCmds)
@@ -415,8 +413,7 @@ InputDir=. InputPath=.\zend_ini_parser.y
BuildCmds= \
- bison --output=zend_ini_parser.c -v -d -p ini_ zend_ini_parser.y \
-
+ bison --output=zend_ini_parser.c -v -d -p ini_ zend_ini_parser.y
"$(InputDir)\zend_ini_parser.c" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
$(BuildCmds)
@@ -455,8 +452,7 @@ InputDir=. InputPath=".\zend_language_parser.y"
BuildCmds= \
- bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y \
-
+ bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y
"$(InputDir)\zend_language_parser.c" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
$(BuildCmds)
@@ -472,8 +468,7 @@ InputDir=. InputPath=".\zend_language_parser.y"
BuildCmds= \
- bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y \
-
+ bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y
"$(InputDir)\zend_language_parser.c" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
$(BuildCmds)
@@ -489,8 +484,7 @@ InputDir=. InputPath=".\zend_language_parser.y"
BuildCmds= \
- bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y \
-
+ bison --output=zend_language_parser.c -v -d -p zend zend_language_parser.y
"$(InputDir)\zend_language_parser.c" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
$(BuildCmds)
diff --git a/Zend/zend.c b/Zend/zend.c index 1d962f227a..09b14723e1 100644 --- a/Zend/zend.c +++ b/Zend/zend.c @@ -250,7 +250,7 @@ static void register_standard_class(void) } -static void zend_set_default_compile_time_values(CLS_D) +static void zend_set_default_compile_time_values(TSRMLS_D) { /* default compile-time values */ CG(asp_tags) = 0; @@ -276,7 +276,7 @@ static void compiler_globals_ctor(zend_compiler_globals *compiler_globals TSRMLS zend_hash_init_ex(compiler_globals->class_table, 10, NULL, ZEND_CLASS_DTOR, 1, 0); zend_hash_copy(compiler_globals->class_table, global_class_table, (copy_ctor_func_t) zend_class_add_ref, &tmp_class, sizeof(zend_class_entry)); - zend_set_default_compile_time_values(CLS_C); + zend_set_default_compile_time_values(TSRMLS_C); CG(interactive) = 0; } @@ -316,9 +316,9 @@ static void executor_globals_dtor(zend_executor_globals *executor_globals TSRMLS } -static void alloc_globals_ctor(zend_alloc_globals *alloc_globals TSRMLS_DC) +static void alloc_globals_ctor(zend_alloc_globals *alloc_globals_p TSRMLS_DC) { - start_memory_manager(ALS_C); + start_memory_manager(TSRMLS_C); } #endif @@ -348,7 +348,7 @@ int zend_startup(zend_utility_functions *utility_functions, char **extensions, i ts_allocate_id(&alloc_globals_id, sizeof(zend_alloc_globals), (ts_allocate_ctor) alloc_globals_ctor, NULL); #else - start_memory_manager(ALS_C); + start_memory_manager(TSRMLS_C); #endif #ifdef __FreeBSD__ @@ -406,7 +406,7 @@ int zend_startup(zend_utility_functions *utility_functions, char **extensions, i GLOBAL_CONSTANTS_TABLE = EG(zend_constants); #else zend_startup_constants(); - zend_set_default_compile_time_values(CLS_C); + zend_set_default_compile_time_values(TSRMLS_C); EG(user_error_handler) = NULL; #endif zend_register_standard_constants(TSRMLS_C); @@ -468,7 +468,6 @@ void zenderror(char *error) BEGIN_EXTERN_C() ZEND_API void _zend_bailout(char *filename, uint lineno) { - CLS_FETCH(); TSRMLS_FETCH(); if (!EG(bailout_set)) { @@ -510,12 +509,12 @@ ZEND_API char *get_zend_version() } -void zend_activate(CLS_D TSRMLS_DC) +void zend_activate(TSRMLS_D) { EG(bailout_set) = 0; - init_compiler(CLS_C TSRMLS_CC); - init_executor(CLS_C TSRMLS_CC); - startup_scanner(CLS_C); + init_compiler(TSRMLS_C); + init_executor(TSRMLS_C); + startup_scanner(TSRMLS_C); } @@ -534,21 +533,21 @@ void zend_deactivate_modules() } zend_end_try(); } -void zend_deactivate(CLS_D TSRMLS_DC) +void zend_deactivate(TSRMLS_D) { /* we're no longer executing anything */ EG(opline_ptr) = NULL; EG(active_symbol_table) = NULL; zend_try { - shutdown_scanner(CLS_C); + shutdown_scanner(TSRMLS_C); } zend_end_try(); /* shutdown_executor() takes care of its own bailout handling */ shutdown_executor(TSRMLS_C); zend_try { - shutdown_compiler(CLS_C); + shutdown_compiler(TSRMLS_C); } zend_end_try(); zend_try { @@ -589,7 +588,6 @@ ZEND_API void zend_error(int type, const char *format, ...) uint error_lineno; zval *orig_user_error_handler; TSRMLS_FETCH(); - CLS_FETCH(); /* Obtain relevant filename and lineno */ switch (type) { @@ -608,8 +606,8 @@ ZEND_API void zend_error(int type, const char *format, ...) case E_USER_WARNING: case E_USER_NOTICE: if (zend_is_compiling()) { - error_filename = zend_get_compiled_filename(CLS_C); - error_lineno = zend_get_compiled_lineno(CLS_C); + error_filename = zend_get_compiled_filename(TSRMLS_C); + error_lineno = zend_get_compiled_lineno(TSRMLS_C); } else if (zend_is_executing()) { error_filename = zend_get_executed_filename(TSRMLS_C); error_lineno = zend_get_executed_lineno(TSRMLS_C); @@ -711,7 +709,7 @@ ZEND_API void zend_error(int type, const char *format, ...) va_end(args); if (type==E_PARSE) { - zend_init_compiler_data_structures(CLS_C); + zend_init_compiler_data_structures(TSRMLS_C); } } @@ -742,7 +740,7 @@ ZEND_API void zend_output_debug_string(zend_bool trigger_break, char *format, .. } -ZEND_API int zend_execute_scripts(int type CLS_DC TSRMLS_DC, int file_count, ...) +ZEND_API int zend_execute_scripts(int type TSRMLS_DC, int file_count, ...) { va_list files; int i; @@ -755,8 +753,8 @@ ZEND_API int zend_execute_scripts(int type CLS_DC TSRMLS_DC, int file_count, ... if (!file_handle) { continue; } - EG(active_op_array) = zend_compile_file(file_handle, ZEND_INCLUDE CLS_CC); - zend_destroy_file_handle(file_handle CLS_CC); + EG(active_op_array) = zend_compile_file(file_handle, ZEND_INCLUDE TSRMLS_CC); + zend_destroy_file_handle(file_handle TSRMLS_CC); if (EG(active_op_array)) { zend_execute(EG(active_op_array) TSRMLS_CC); zval_ptr_dtor(EG(return_value_ptr_ptr)); @@ -783,12 +781,11 @@ ZEND_API char *zend_make_compiled_string_description(char *name) char *cur_filename; int cur_lineno; char *compiled_string_description; - CLS_FETCH(); TSRMLS_FETCH(); if (zend_is_compiling()) { - cur_filename = zend_get_compiled_filename(CLS_C); - cur_lineno = zend_get_compiled_lineno(CLS_C); + cur_filename = zend_get_compiled_filename(TSRMLS_C); + cur_lineno = zend_get_compiled_lineno(TSRMLS_C); } else if (zend_is_executing()) { cur_filename = zend_get_executed_filename(TSRMLS_C); cur_lineno = zend_get_executed_lineno(TSRMLS_C); diff --git a/Zend/zend.h b/Zend/zend.h index 89bebbcbaa..579813d351 100644 --- a/Zend/zend.h +++ b/Zend/zend.h @@ -23,8 +23,6 @@ #define ZEND_VERSION "1.0.7" -#include "../TSRM/TSRM.h" - #ifdef __cplusplus #define BEGIN_EXTERN_C() extern "C" { #define END_EXTERN_C() } diff --git a/Zend/zend_API.c b/Zend/zend_API.c index f7db730588..6305346ecd 100644 --- a/Zend/zend_API.c +++ b/Zend/zend_API.c @@ -1033,7 +1033,7 @@ int zend_register_functions(zend_function_entry *functions, HashTable *function_ int count=0,unload=0; HashTable *target_function_table = function_table; int error_type; - CLS_FETCH(); + TSRMLS_FETCH(); if (type==MODULE_PERSISTENT) { error_type = E_CORE_WARNING; @@ -1083,7 +1083,7 @@ void zend_unregister_functions(zend_function_entry *functions, int count, HashTa zend_function_entry *ptr = functions; int i=0; HashTable *target_function_table = function_table; - CLS_FETCH(); + TSRMLS_FETCH(); if (!target_function_table) { target_function_table = CG(function_table); @@ -1199,7 +1199,7 @@ int zend_next_free_module(void) ZEND_API zend_class_entry *zend_register_internal_class_ex(zend_class_entry *class_entry, zend_class_entry *parent_ce, char *parent_name) { zend_class_entry *register_class; - CLS_FETCH(); + TSRMLS_FETCH(); if (!parent_ce && parent_name) { if (zend_hash_find(CG(class_table), parent_name, strlen(parent_name)+1, (void **) &parent_ce)==FAILURE) { @@ -1219,7 +1219,7 @@ ZEND_API zend_class_entry *zend_register_internal_class(zend_class_entry *class_ { zend_class_entry *register_class; char *lowercase_name = zend_strndup(class_entry->name, class_entry->name_length); - CLS_FETCH(); + TSRMLS_FETCH(); zend_str_tolower(lowercase_name, class_entry->name_length); @@ -1292,7 +1292,7 @@ static zend_function_entry disabled_function[] = { ZEND_API int zend_disable_function(char *function_name, uint function_name_length) { - CLS_FETCH(); + TSRMLS_FETCH(); if (zend_hash_del(CG(function_table), function_name, function_name_length+1)==FAILURE) { return FAILURE; diff --git a/Zend/zend_alloc.c b/Zend/zend_alloc.c index 42bc335a9b..98b4442446 100644 --- a/Zend/zend_alloc.c +++ b/Zend/zend_alloc.c @@ -123,7 +123,7 @@ ZEND_API void *_emalloc(size_t size ZEND_FILE_LINE_DC ZEND_FILE_LINE_ORIG_DC) { zend_mem_header *p; DECLARE_CACHE_VARS(); - ALS_FETCH(); + TSRMLS_FETCH(); CALCULATE_REAL_SIZE_AND_CACHE_INDEX(size); @@ -198,7 +198,7 @@ ZEND_API void _efree(void *ptr ZEND_FILE_LINE_DC ZEND_FILE_LINE_ORIG_DC) { zend_mem_header *p = (zend_mem_header *) ((char *)ptr - sizeof(zend_mem_header) - MEM_HEADER_PADDING); DECLARE_CACHE_VARS(); - ALS_FETCH(); + TSRMLS_FETCH(); #if defined(ZTS) && TSRM_DEBUG if (p->thread_id != tsrm_thread_id()) { @@ -260,7 +260,7 @@ ZEND_API void *_erealloc(void *ptr, size_t size, int allow_failure ZEND_FILE_LIN zend_mem_header *p; zend_mem_header *orig; DECLARE_CACHE_VARS(); - ALS_FETCH(); + TSRMLS_FETCH(); if (!ptr) { return _emalloc(size ZEND_FILE_LINE_RELAY_CC ZEND_FILE_LINE_ORIG_RELAY_CC); @@ -374,7 +374,7 @@ ZEND_API char *zend_strndup(const char *s, uint length) ZEND_API int zend_set_memory_limit(unsigned int memory_limit) { #if MEMORY_LIMIT - ALS_FETCH(); + TSRMLS_FETCH(); AG(memory_limit) = memory_limit; return SUCCESS; @@ -384,7 +384,7 @@ ZEND_API int zend_set_memory_limit(unsigned int memory_limit) } -ZEND_API void start_memory_manager(ALS_D) +ZEND_API void start_memory_manager(TSRMLS_D) { #if 0 #ifndef ZTS @@ -439,7 +439,7 @@ ZEND_API void shutdown_memory_manager(int silent, int clean_cache) int had_leaks = 0; #endif zend_fast_cache_list_entry *fast_cache_list_entry, *next_fast_cache_list_entry; - ALS_FETCH(); + TSRMLS_FETCH(); for (fci=0; fci<MAX_FAST_CACHE_TYPES; fci++) { fast_cache_list_entry = AG(fast_cache_list_head)[fci]; @@ -690,7 +690,7 @@ ZEND_API void _full_mem_check(int silent ZEND_FILE_LINE_DC ZEND_FILE_LINE_ORIG_D { zend_mem_header *p; int errors=0; - ALS_FETCH(); + TSRMLS_FETCH(); p = AG(head); @@ -713,7 +713,7 @@ ZEND_API void _full_mem_check(int silent ZEND_FILE_LINE_DC ZEND_FILE_LINE_ORIG_D ZEND_API int _persist_alloc(void *ptr ZEND_FILE_LINE_DC ZEND_FILE_LINE_ORIG_DC) { zend_mem_header *p = (zend_mem_header *) ((char *)ptr-sizeof(zend_mem_header)-MEM_HEADER_PADDING); - ALS_FETCH(); + TSRMLS_FETCH(); #if ZEND_DEBUG _mem_block_check(ptr, 1 ZEND_FILE_LINE_RELAY_CC ZEND_FILE_LINE_ORIG_RELAY_CC); diff --git a/Zend/zend_alloc.h b/Zend/zend_alloc.h index 964e2e4ce2..7afda73737 100644 --- a/Zend/zend_alloc.h +++ b/Zend/zend_alloc.h @@ -23,10 +23,7 @@ #include <stdio.h> -#ifdef ZTS #include "../TSRM/TSRM.h" -#endif - #include "zend_globals_macros.h" #define MEM_BLOCK_START_MAGIC 0x7312F8DCL @@ -117,7 +114,7 @@ ZEND_API int _persist_alloc(void *ptr ZEND_FILE_LINE_DC ZEND_FILE_LINE_ORIG_DC); ZEND_API int zend_set_memory_limit(unsigned int memory_limit); -ZEND_API void start_memory_manager(ALS_D); +ZEND_API void start_memory_manager(TSRMLS_D); ZEND_API void shutdown_memory_manager(int silent, int clean_cache); #if ZEND_DEBUG diff --git a/Zend/zend_builtin_functions.c b/Zend/zend_builtin_functions.c index cdcaab0ce4..5185115548 100644 --- a/Zend/zend_builtin_functions.c +++ b/Zend/zend_builtin_functions.c @@ -926,7 +926,6 @@ ZEND_FUNCTION(create_function) zval **z_function_args, **z_function_code; int retval; char *eval_name; - CLS_FETCH(); if (ZEND_NUM_ARGS()!=2 || zend_get_parameters_ex(2, &z_function_args, &z_function_code)==FAILURE) { ZEND_WRONG_PARAM_COUNT(); @@ -945,7 +944,7 @@ ZEND_FUNCTION(create_function) sprintf(eval_code, "function " LAMBDA_TEMP_FUNCNAME "(%s){%s}", Z_STRVAL_PP(z_function_args), Z_STRVAL_PP(z_function_code)); eval_name = zend_make_compiled_string_description("runtime-created function"); - retval = zend_eval_string(eval_code, NULL, eval_name CLS_CC TSRMLS_CC); + retval = zend_eval_string(eval_code, NULL, eval_name TSRMLS_CC); efree(eval_code); efree(eval_name); diff --git a/Zend/zend_compile.c b/Zend/zend_compile.c index 8b53efbed0..c7e9ef3925 100644 --- a/Zend/zend_compile.c +++ b/Zend/zend_compile.c @@ -26,7 +26,7 @@ #include "zend_fast_cache.h" -ZEND_API zend_op_array *(*zend_compile_file)(zend_file_handle *file_handle, int type CLS_DC); +ZEND_API zend_op_array *(*zend_compile_file)(zend_file_handle *file_handle, int type TSRMLS_DC); #ifndef ZTS @@ -35,7 +35,7 @@ ZEND_API zend_executor_globals executor_globals; #endif -static void build_runtime_defined_function_key(zval *result, zval *name, zend_op *opline CLS_DC) +static void build_runtime_defined_function_key(zval *result, zval *name, zend_op *opline TSRMLS_DC) { char lineno_buf[32]; uint lineno_len; @@ -57,7 +57,7 @@ static void build_runtime_defined_function_key(zval *result, zval *name, zend_op } -static void init_compiler_declarables(CLS_D) +static void init_compiler_declarables(TSRMLS_D) { CG(declarables).ticks.type = IS_LONG; CG(declarables).ticks.value.lval = 0; @@ -65,7 +65,7 @@ static void init_compiler_declarables(CLS_D) -void zend_init_compiler_data_structures(CLS_D) +void zend_init_compiler_data_structures(TSRMLS_D) { zend_stack_init(&CG(bp_stack)); zend_stack_init(&CG(function_call_stack)); @@ -80,13 +80,13 @@ void zend_init_compiler_data_structures(CLS_D) zend_stack_init(&CG(list_stack)); CG(handle_op_arrays) = 1; CG(in_compilation) = 0; - init_compiler_declarables(CLS_C); + init_compiler_declarables(TSRMLS_C); } -void init_compiler(CLS_D TSRMLS_DC) +void init_compiler(TSRMLS_D) { - zend_init_compiler_data_structures(CLS_C); + zend_init_compiler_data_structures(TSRMLS_C); zend_init_rsrc_list(TSRMLS_C); zend_hash_init(&CG(filenames_table), 5, NULL, (dtor_func_t) free_estring, 0); zend_llist_init(&CG(open_files), sizeof(zend_file_handle), (void (*)(void *)) zend_file_handle_dtor, 0); @@ -94,7 +94,7 @@ void init_compiler(CLS_D TSRMLS_DC) } -void shutdown_compiler(CLS_D) +void shutdown_compiler(TSRMLS_D) { zend_stack_destroy(&CG(bp_stack)); zend_stack_destroy(&CG(function_call_stack)); @@ -112,7 +112,7 @@ ZEND_API char *zend_set_compiled_filename(char *new_compiled_filename) { char **pp, *p; int length = strlen(new_compiled_filename); - CLS_FETCH(); + TSRMLS_FETCH(); if (zend_hash_find(&CG(filenames_table), new_compiled_filename, length+1, (void **) &pp)==SUCCESS) { CG(compiled_filename) = *pp; @@ -127,19 +127,19 @@ ZEND_API char *zend_set_compiled_filename(char *new_compiled_filename) ZEND_API void zend_restore_compiled_filename(char *original_compiled_filename) { - CLS_FETCH(); + TSRMLS_FETCH(); CG(compiled_filename) = original_compiled_filename; } -ZEND_API char *zend_get_compiled_filename(CLS_D) +ZEND_API char *zend_get_compiled_filename(TSRMLS_D) { return CG(compiled_filename); } -ZEND_API int zend_get_compiled_lineno(CLS_D) +ZEND_API int zend_get_compiled_lineno(TSRMLS_D) { return CG(zend_lineno); } @@ -147,7 +147,7 @@ ZEND_API int zend_get_compiled_lineno(CLS_D) ZEND_API zend_bool zend_is_compiling() { - CLS_FETCH(); + TSRMLS_FETCH(); return CG(in_compilation); } @@ -159,9 +159,9 @@ static zend_uint get_temporary_variable(zend_op_array *op_array) } -void zend_do_binary_op(int op, znode *result, znode *op1, znode *op2 CLS_DC) +void zend_do_binary_op(int op, znode *result, znode *op1, znode *op2 TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = op; opline->result.op_type = IS_TMP_VAR; @@ -172,9 +172,9 @@ void zend_do_binary_op(int op, znode *result, znode *op1, znode *op2 CLS_DC) } -void zend_do_unary_op(int op, znode *result, znode *op1 CLS_DC) +void zend_do_unary_op(int op, znode *result, znode *op1 TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = op; opline->result.op_type = IS_TMP_VAR; @@ -185,9 +185,9 @@ void zend_do_unary_op(int op, znode *result, znode *op1 CLS_DC) } -void zend_do_binary_assign_op(int op, znode *result, znode *op1, znode *op2 CLS_DC) +void zend_do_binary_assign_op(int op, znode *result, znode *op1, znode *op2 TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = op; opline->result.op_type = IS_VAR; @@ -200,7 +200,7 @@ void zend_do_binary_assign_op(int op, znode *result, znode *op1, znode *op2 CLS_ -void zend_do_fetch_globals(znode *varname CLS_DC) +void zend_do_fetch_globals(znode *varname TSRMLS_DC) { if (!CG(active_op_array)->uses_globals && varname->op_type == IS_CONST @@ -211,7 +211,7 @@ void zend_do_fetch_globals(znode *varname CLS_DC) } } -void fetch_simple_variable_ex(znode *result, znode *varname, int bp, int op CLS_DC) +void fetch_simple_variable_ex(znode *result, znode *varname, int bp, int op TSRMLS_DC) { zend_op opline; zend_op *opline_ptr; @@ -219,9 +219,9 @@ void fetch_simple_variable_ex(znode *result, znode *varname, int bp, int op CLS_ if (bp) { opline_ptr = &opline; - init_op(opline_ptr CLS_CC); + init_op(opline_ptr TSRMLS_CC); } else { - opline_ptr = get_next_op(CG(active_op_array) CLS_CC); + opline_ptr = get_next_op(CG(active_op_array) TSRMLS_CC); } opline_ptr->opcode = op; @@ -239,27 +239,27 @@ void fetch_simple_variable_ex(znode *result, znode *varname, int bp, int op CLS_ } } -void fetch_simple_variable(znode *result, znode *varname, int bp CLS_DC) +void fetch_simple_variable(znode *result, znode *varname, int bp TSRMLS_DC) { /* the default mode must be Write, since fetch_simple_variable() is used to define function arguments */ - fetch_simple_variable_ex(result, varname, bp, ZEND_FETCH_W CLS_CC); + fetch_simple_variable_ex(result, varname, bp, ZEND_FETCH_W TSRMLS_CC); } -void fetch_array_begin(znode *result, znode *varname, znode *first_dim CLS_DC) +void fetch_array_begin(znode *result, znode *varname, znode *first_dim TSRMLS_DC) { - fetch_simple_variable(result, varname, 1 CLS_CC); + fetch_simple_variable(result, varname, 1 TSRMLS_CC); - fetch_array_dim(result, result, first_dim CLS_CC); + fetch_array_dim(result, result, first_dim TSRMLS_CC); } -void fetch_array_dim(znode *result, znode *parent, znode *dim CLS_DC) +void fetch_array_dim(znode *result, znode *parent, znode *dim TSRMLS_DC) { zend_op opline; zend_llist *fetch_list_ptr; - init_op(&opline CLS_CC); + init_op(&opline TSRMLS_CC); opline.opcode = ZEND_FETCH_DIM_W; /* the backpatching routine assumes W */ opline.result.op_type = IS_VAR; opline.result.u.EA.type = 0; @@ -274,15 +274,15 @@ void fetch_array_dim(znode *result, znode *parent, znode *dim CLS_DC) } -void fetch_string_offset(znode *result, znode *parent, znode *offset CLS_DC) +void fetch_string_offset(znode *result, znode *parent, znode *offset TSRMLS_DC) { - fetch_array_dim(result, parent, offset CLS_CC); + fetch_array_dim(result, parent, offset TSRMLS_CC); } -void zend_do_print(znode *result, znode *arg CLS_DC) +void zend_do_print(znode *result, znode *arg TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->result.op_type = IS_TMP_VAR; opline->result.u.var = get_temporary_variable(CG(active_op_array)); @@ -293,9 +293,9 @@ void zend_do_print(znode *result, znode *arg CLS_DC) } -void zend_do_echo(znode *arg CLS_DC) +void zend_do_echo(znode *arg TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_ECHO; opline->op1 = *arg; @@ -303,9 +303,9 @@ void zend_do_echo(znode *arg CLS_DC) } -void zend_do_assign(znode *result, znode *variable, znode *value CLS_DC) +void zend_do_assign(znode *result, znode *variable, znode *value TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_ASSIGN; opline->result.op_type = IS_VAR; @@ -317,9 +317,9 @@ void zend_do_assign(znode *result, znode *variable, znode *value CLS_DC) } -void zend_do_assign_ref(znode *result, znode *lvar, znode *rvar CLS_DC) +void zend_do_assign_ref(znode *result, znode *lvar, znode *rvar TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_ASSIGN_REF; if (result) { @@ -336,7 +336,7 @@ void zend_do_assign_ref(znode *result, znode *lvar, znode *rvar CLS_DC) } -static inline void do_begin_loop(CLS_D) +static inline void do_begin_loop(TSRMLS_D) { zend_brk_cont_element *brk_cont_element; int parent; @@ -348,7 +348,7 @@ static inline void do_begin_loop(CLS_D) } -static inline void do_end_loop(int cont_addr CLS_DC) +static inline void do_end_loop(int cont_addr TSRMLS_DC) { CG(active_op_array)->brk_cont_array[CG(active_op_array)->current_brk_cont].cont = cont_addr; CG(active_op_array)->brk_cont_array[CG(active_op_array)->current_brk_cont].brk = get_next_op_number(CG(active_op_array)); @@ -356,24 +356,24 @@ static inline void do_end_loop(int cont_addr CLS_DC) } -void zend_do_while_cond(znode *expr, znode *close_bracket_token CLS_DC) +void zend_do_while_cond(znode *expr, znode *close_bracket_token TSRMLS_DC) { int while_cond_op_number = get_next_op_number(CG(active_op_array)); - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMPZ; opline->op1 = *expr; close_bracket_token->u.opline_num = while_cond_op_number; SET_UNUSED(opline->op2); - do_begin_loop(CLS_C); + do_begin_loop(TSRMLS_C); INC_BPC(CG(active_op_array)); } -void zend_do_while_end(znode *while_token, znode *close_bracket_token CLS_DC) +void zend_do_while_end(znode *while_token, znode *close_bracket_token TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); /* add unconditional jump */ opline->opcode = ZEND_JMP; @@ -384,16 +384,16 @@ void zend_do_while_end(znode *while_token, znode *close_bracket_token CLS_DC) /* update while's conditional jmp */ CG(active_op_array)->opcodes[close_bracket_token->u.opline_num].op2.u.opline_num = get_next_op_number(CG(active_op_array)); - do_end_loop(while_token->u.opline_num CLS_CC); + do_end_loop(while_token->u.opline_num TSRMLS_CC); DEC_BPC(CG(active_op_array)); } -void zend_do_for_cond(znode *expr, znode *second_semicolon_token CLS_DC) +void zend_do_for_cond(znode *expr, znode *second_semicolon_token TSRMLS_DC) { int for_cond_op_number = get_next_op_number(CG(active_op_array)); - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMPZNZ; opline->op1 = *expr; /* the conditional expression */ @@ -402,9 +402,9 @@ void zend_do_for_cond(znode *expr, znode *second_semicolon_token CLS_DC) } -void zend_do_for_before_statement(znode *cond_start, znode *second_semicolon_token CLS_DC) +void zend_do_for_before_statement(znode *cond_start, znode *second_semicolon_token TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMP; opline->op1.u.opline_num = cond_start->u.opline_num; @@ -412,15 +412,15 @@ void zend_do_for_before_statement(znode *cond_start, znode *second_semicolon_tok SET_UNUSED(opline->op1); SET_UNUSED(opline->op2); - do_begin_loop(CLS_C); + do_begin_loop(TSRMLS_C); INC_BPC(CG(active_op_array)); } -void zend_do_for_end(znode *second_semicolon_token CLS_DC) +void zend_do_for_end(znode *second_semicolon_token TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMP; opline->op1.u.opline_num = second_semicolon_token->u.opline_num+1; @@ -428,15 +428,15 @@ void zend_do_for_end(znode *second_semicolon_token CLS_DC) SET_UNUSED(opline->op1); SET_UNUSED(opline->op2); - do_end_loop(second_semicolon_token->u.opline_num+1 CLS_CC); + do_end_loop(second_semicolon_token->u.opline_num+1 TSRMLS_CC); DEC_BPC(CG(active_op_array)); } -void zend_do_pre_incdec(znode *result, znode *op1, int op CLS_DC) +void zend_do_pre_incdec(znode *result, znode *op1, int op TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = op; opline->result.op_type = IS_VAR; @@ -448,9 +448,9 @@ void zend_do_pre_incdec(znode *result, znode *op1, int op CLS_DC) } -void zend_do_post_incdec(znode *result, znode *op1, int op CLS_DC) +void zend_do_post_incdec(znode *result, znode *op1, int op TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = op; opline->result.op_type = IS_TMP_VAR; @@ -461,10 +461,10 @@ void zend_do_post_incdec(znode *result, znode *op1, int op CLS_DC) } -void zend_do_if_cond(znode *cond, znode *closing_bracket_token CLS_DC) +void zend_do_if_cond(znode *cond, znode *closing_bracket_token TSRMLS_DC) { int if_cond_op_number = get_next_op_number(CG(active_op_array)); - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMPZ; opline->op1 = *cond; @@ -474,10 +474,10 @@ void zend_do_if_cond(znode *cond, znode *closing_bracket_token CLS_DC) } -void zend_do_if_after_statement(znode *closing_bracket_token, unsigned char initialize CLS_DC) +void zend_do_if_after_statement(znode *closing_bracket_token, unsigned char initialize TSRMLS_DC) { int if_end_op_number = get_next_op_number(CG(active_op_array)); - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); zend_llist *jmp_list_ptr; opline->opcode = ZEND_JMP; @@ -497,7 +497,7 @@ void zend_do_if_after_statement(znode *closing_bracket_token, unsigned char init } -void zend_do_if_end(CLS_D) +void zend_do_if_end(TSRMLS_D) { int next_op_number = get_next_op_number(CG(active_op_array)); zend_llist *jmp_list_ptr; @@ -513,7 +513,7 @@ void zend_do_if_end(CLS_D) } -void zend_do_begin_variable_parse(CLS_D) +void zend_do_begin_variable_parse(TSRMLS_D) { zend_llist fetch_list; @@ -522,7 +522,7 @@ void zend_do_begin_variable_parse(CLS_D) } -void zend_do_end_variable_parse(int type, int arg_offset CLS_DC) +void zend_do_end_variable_parse(int type, int arg_offset TSRMLS_DC) { zend_llist *fetch_list_ptr; zend_llist_element *le; @@ -534,7 +534,7 @@ void zend_do_end_variable_parse(int type, int arg_offset CLS_DC) while (le) { opline_ptr = (zend_op *)le->data; - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); memcpy(opline, opline_ptr, sizeof(zend_op)); switch (type) { case BP_VAR_R: @@ -566,7 +566,7 @@ void zend_do_end_variable_parse(int type, int arg_offset CLS_DC) } -static zend_bool is_method_call(CLS_D) +static zend_bool is_method_call(TSRMLS_D) { zend_llist *fetch_list_ptr; zend_llist_element *cur; @@ -587,9 +587,9 @@ static zend_bool is_method_call(CLS_D) } -void zend_do_init_string(znode *result CLS_DC) +void zend_do_init_string(znode *result TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_INIT_STRING; opline->result.op_type = IS_TMP_VAR; @@ -600,9 +600,9 @@ void zend_do_init_string(znode *result CLS_DC) } -void zend_do_add_char(znode *result, znode *op1, znode *op2 CLS_DC) +void zend_do_add_char(znode *result, znode *op1, znode *op2 TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_ADD_CHAR; opline->op1 = *op1; @@ -613,9 +613,9 @@ void zend_do_add_char(znode *result, znode *op1, znode *op2 CLS_DC) } -void zend_do_add_string(znode *result, znode *op1, znode *op2 CLS_DC) +void zend_do_add_string(znode *result, znode *op1, znode *op2 TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_ADD_STRING; opline->op1 = *op1; @@ -626,12 +626,12 @@ void zend_do_add_string(znode *result, znode *op1, znode *op2 CLS_DC) } -void zend_do_add_variable(znode *result, znode *op1, znode *op2 CLS_DC) +void zend_do_add_variable(znode *result, znode *op1, znode *op2 TSRMLS_DC) { zend_op *opline; if (op1->op_type == IS_CONST) { - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_INIT_STRING; opline->result.op_type = IS_TMP_VAR; opline->result.u.var = get_temporary_variable(CG(active_op_array)); @@ -640,7 +640,7 @@ void zend_do_add_variable(znode *result, znode *op1, znode *op2 CLS_DC) SET_UNUSED(opline->op2); if (op1->u.constant.value.str.len>0) { - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_ADD_STRING; opline->result = *result; opline->op1 = *result; @@ -653,7 +653,7 @@ void zend_do_add_variable(znode *result, znode *op1, znode *op2 CLS_DC) *result = *op1; } - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_ADD_VAR; opline->result = *result; opline->op1 = *result; @@ -662,10 +662,10 @@ void zend_do_add_variable(znode *result, znode *op1, znode *op2 CLS_DC) } -void zend_do_free(znode *op1 CLS_DC) +void zend_do_free(znode *op1 TSRMLS_DC) { if (op1->op_type==IS_TMP_VAR) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_FREE; opline->op1 = *op1; @@ -710,7 +710,7 @@ void zend_do_free(znode *op1 CLS_DC) } -void zend_do_begin_function_declaration(znode *function_token, znode *function_name, int is_method, int return_reference CLS_DC) +void zend_do_begin_function_declaration(znode *function_token, znode *function_name, int is_method, int return_reference TSRMLS_DC) { zend_op_array op_array; char *name = function_name->u.constant.value.str.val; @@ -720,7 +720,7 @@ void zend_do_begin_function_declaration(znode *function_token, znode *function_n function_token->u.op_array = CG(active_op_array); zend_str_tolower(name, name_len); - init_op_array(&op_array, ZEND_USER_FUNCTION, INITIAL_OP_ARRAY_SIZE CLS_CC); + init_op_array(&op_array, ZEND_USER_FUNCTION, INITIAL_OP_ARRAY_SIZE TSRMLS_CC); op_array.function_name = name; op_array.arg_types = NULL; @@ -729,11 +729,11 @@ void zend_do_begin_function_declaration(znode *function_token, znode *function_n if (is_method) { zend_hash_update(&CG(active_class_entry)->function_table, name, name_len+1, &op_array, sizeof(zend_op_array), (void **) &CG(active_op_array)); } else { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_DECLARE_FUNCTION_OR_CLASS; opline->op1.op_type = IS_CONST; - build_runtime_defined_function_key(&opline->op1.u.constant, &function_name->u.constant, opline CLS_CC); + build_runtime_defined_function_key(&opline->op1.u.constant, &function_name->u.constant, opline TSRMLS_CC); opline->op2.op_type = IS_CONST; opline->op2.u.constant.type = IS_STRING; opline->op2.u.constant.value.str.val = estrndup(name, name_len); @@ -744,7 +744,7 @@ void zend_do_begin_function_declaration(znode *function_token, znode *function_n } if (CG(extended_info)) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_EXT_NOP; opline->lineno = function_begin_line; @@ -767,10 +767,10 @@ void zend_do_begin_function_declaration(znode *function_token, znode *function_n } -void zend_do_end_function_declaration(znode *function_token CLS_DC) +void zend_do_end_function_declaration(znode *function_token TSRMLS_DC) { - zend_do_extended_info(CLS_C); - zend_do_return(NULL, 0 CLS_CC); + zend_do_extended_info(TSRMLS_C); + zend_do_return(NULL, 0 TSRMLS_CC); pass_two(CG(active_op_array)); CG(active_op_array) = function_token->u.op_array; @@ -780,9 +780,9 @@ void zend_do_end_function_declaration(znode *function_token CLS_DC) } -void zend_do_receive_arg(int op, znode *var, znode *offset, znode *initialization, unsigned char pass_type CLS_DC) +void zend_do_receive_arg(int op, znode *var, znode *offset, znode *initialization, unsigned char pass_type TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = op; opline->result = *var; @@ -811,7 +811,7 @@ void zend_do_receive_arg(int op, znode *var, znode *offset, znode *initializatio } -int zend_do_begin_function_call(znode *function_name CLS_DC) +int zend_do_begin_function_call(znode *function_name TSRMLS_DC) { zend_function *function; @@ -820,7 +820,7 @@ int zend_do_begin_function_call(znode *function_name CLS_DC) znode tmp = *function_name; zval_copy_ctor(&tmp.u.constant); - zend_do_begin_dynamic_function_call(&tmp CLS_CC); + zend_do_begin_dynamic_function_call(&tmp TSRMLS_CC); return 1; /* Dynamic */ } @@ -838,19 +838,19 @@ int zend_do_begin_function_call(znode *function_name CLS_DC) } break; } - zend_do_extended_fcall_begin(CLS_C); + zend_do_extended_fcall_begin(TSRMLS_C); return 0; } -void zend_do_begin_dynamic_function_call(znode *function_name CLS_DC) +void zend_do_begin_dynamic_function_call(znode *function_name TSRMLS_DC) { unsigned char *ptr = NULL; int last_op_number; zend_op *last_op; - if (function_name->op_type != IS_CONST && is_method_call(CLS_C)) { - zend_do_end_variable_parse(BP_VAR_W, 0 CLS_CC); + if (function_name->op_type != IS_CONST && is_method_call(TSRMLS_C)) { + zend_do_end_variable_parse(BP_VAR_W, 0 TSRMLS_CC); last_op_number = get_next_op_number(CG(active_op_array))-1; last_op = &CG(active_op_array)->opcodes[last_op_number]; last_op->opcode = ZEND_INIT_FCALL_BY_NAME; @@ -859,24 +859,24 @@ void zend_do_begin_dynamic_function_call(znode *function_name CLS_DC) zend_op *opline; if (function_name->op_type != IS_CONST) { - zend_do_end_variable_parse(BP_VAR_R, 0 CLS_CC); + zend_do_end_variable_parse(BP_VAR_R, 0 TSRMLS_CC); } - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_INIT_FCALL_BY_NAME; opline->op2 = *function_name; opline->extended_value = 0; SET_UNUSED(opline->op1); } zend_stack_push(&CG(function_call_stack), (void *) &ptr, sizeof(zend_function *)); - zend_do_extended_fcall_begin(CLS_C); + zend_do_extended_fcall_begin(TSRMLS_C); } -void zend_do_begin_class_member_function_call(znode *class_name, znode *function_name CLS_DC) +void zend_do_begin_class_member_function_call(znode *class_name, znode *function_name TSRMLS_DC) { unsigned char *ptr = NULL; - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_INIT_FCALL_BY_NAME; zend_str_tolower(class_name->u.constant.value.str.val, class_name->u.constant.value.str.len); @@ -895,9 +895,9 @@ void zend_do_begin_class_member_function_call(znode *class_name, znode *function } -void zend_do_end_function_call(znode *function_name, znode *result, znode *argument_list, int is_method, int is_dynamic_fcall CLS_DC) +void zend_do_end_function_call(znode *function_name, znode *result, znode *argument_list, int is_method, int is_dynamic_fcall TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); if (function_name->op_type==IS_CONST && !is_method && !is_dynamic_fcall) { opline->opcode = ZEND_DO_FCALL; @@ -915,7 +915,7 @@ void zend_do_end_function_call(znode *function_name, znode *result, znode *argum } -void zend_do_pass_param(znode *param, int op, int offset CLS_DC) +void zend_do_pass_param(znode *param, int op, int offset TSRMLS_DC) { zend_op *opline; unsigned char *arg_types; @@ -966,22 +966,22 @@ void zend_do_pass_param(znode *param, int op, int offset CLS_DC) if (original_op == ZEND_SEND_VAR) { switch(op) { case ZEND_SEND_VAR_NO_REF: - zend_do_end_variable_parse(BP_VAR_R, 0 CLS_CC); + zend_do_end_variable_parse(BP_VAR_R, 0 TSRMLS_CC); break; case ZEND_SEND_VAR: if (function_ptr) { - zend_do_end_variable_parse(BP_VAR_R, 0 CLS_CC); + zend_do_end_variable_parse(BP_VAR_R, 0 TSRMLS_CC); } else { - zend_do_end_variable_parse(BP_VAR_FUNC_ARG, offset CLS_CC); + zend_do_end_variable_parse(BP_VAR_FUNC_ARG, offset TSRMLS_CC); } break; case ZEND_SEND_REF: - zend_do_end_variable_parse(BP_VAR_W, 0 CLS_CC); + zend_do_end_variable_parse(BP_VAR_W, 0 TSRMLS_CC); break; } } - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); if (op == ZEND_SEND_VAR_NO_REF) { if (function_ptr) { @@ -1003,7 +1003,7 @@ void zend_do_pass_param(znode *param, int op, int offset CLS_DC) } -static int generate_free_switch_expr(zend_switch_entry *switch_entry CLS_DC) +static int generate_free_switch_expr(zend_switch_entry *switch_entry TSRMLS_DC) { zend_op *opline; @@ -1011,7 +1011,7 @@ static int generate_free_switch_expr(zend_switch_entry *switch_entry CLS_DC) return 1; } - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_SWITCH_FREE; opline->op1 = switch_entry->cond; @@ -1020,7 +1020,7 @@ static int generate_free_switch_expr(zend_switch_entry *switch_entry CLS_DC) return 0; } -static int generate_free_foreach_copy(znode *foreach_copy CLS_DC) +static int generate_free_foreach_copy(znode *foreach_copy TSRMLS_DC) { zend_op *opline; @@ -1028,7 +1028,7 @@ static int generate_free_foreach_copy(znode *foreach_copy CLS_DC) return 1; } - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_SWITCH_FREE; opline->op1 = *foreach_copy; @@ -1037,15 +1037,15 @@ static int generate_free_foreach_copy(znode *foreach_copy CLS_DC) return 0; } -void zend_do_return(znode *expr, int do_end_vparse CLS_DC) +void zend_do_return(znode *expr, int do_end_vparse TSRMLS_DC) { zend_op *opline; if (do_end_vparse) { if (CG(active_op_array)->return_reference) { - zend_do_end_variable_parse(BP_VAR_W, 0 CLS_CC); + zend_do_end_variable_parse(BP_VAR_W, 0 TSRMLS_CC); } else { - zend_do_end_variable_parse(BP_VAR_R, 0 CLS_CC); + zend_do_end_variable_parse(BP_VAR_R, 0 TSRMLS_CC); } #if 0 } else if (expr && CG(active_op_array)->return_reference) { @@ -1054,14 +1054,14 @@ void zend_do_return(znode *expr, int do_end_vparse CLS_DC) } #ifdef ZTS - zend_stack_apply_with_argument(&CG(switch_cond_stack), ZEND_STACK_APPLY_TOPDOWN, (int (*)(void *element, void *)) generate_free_switch_expr CLS_CC); - zend_stack_apply_with_argument(&CG(foreach_copy_stack), ZEND_STACK_APPLY_TOPDOWN, (int (*)(void *element, void *)) generate_free_foreach_copy CLS_CC); + zend_stack_apply_with_argument(&CG(switch_cond_stack), ZEND_STACK_APPLY_TOPDOWN, (int (*)(void *element, void *)) generate_free_switch_expr TSRMLS_CC); + zend_stack_apply_with_argument(&CG(foreach_copy_stack), ZEND_STACK_APPLY_TOPDOWN, (int (*)(void *element, void *)) generate_free_foreach_copy TSRMLS_CC); #else zend_stack_apply(&CG(switch_cond_stack), ZEND_STACK_APPLY_TOPDOWN, (int (*)(void *element)) generate_free_switch_expr); zend_stack_apply(&CG(foreach_copy_stack), ZEND_STACK_APPLY_TOPDOWN, (int (*)(void *element)) generate_free_foreach_copy); #endif - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_RETURN; @@ -1220,7 +1220,7 @@ ZEND_API int do_bind_function_or_class(zend_op *opline, HashTable *function_tabl } -void zend_do_early_binding(CLS_D) +void zend_do_early_binding(TSRMLS_D) { zend_op *opline = &CG(active_op_array)->opcodes[CG(active_op_array)->last-1]; HashTable *table; @@ -1250,10 +1250,10 @@ void zend_do_early_binding(CLS_D) } -void zend_do_boolean_or_begin(znode *expr1, znode *op_token CLS_DC) +void zend_do_boolean_or_begin(znode *expr1, znode *op_token TSRMLS_DC) { int next_op_number = get_next_op_number(CG(active_op_array)); - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMPNZ_EX; if (expr1->op_type == IS_TMP_VAR) { @@ -1271,9 +1271,9 @@ void zend_do_boolean_or_begin(znode *expr1, znode *op_token CLS_DC) } -void zend_do_boolean_or_end(znode *result, znode *expr1, znode *expr2, znode *op_token CLS_DC) +void zend_do_boolean_or_end(znode *result, znode *expr1, znode *expr2, znode *op_token TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); *result = *expr1; /* we saved the original result in expr1 */ opline->opcode = ZEND_BOOL; @@ -1285,10 +1285,10 @@ void zend_do_boolean_or_end(znode *result, znode *expr1, znode *expr2, znode *op } -void zend_do_boolean_and_begin(znode *expr1, znode *op_token CLS_DC) +void zend_do_boolean_and_begin(znode *expr1, znode *op_token TSRMLS_DC) { int next_op_number = get_next_op_number(CG(active_op_array)); - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMPZ_EX; if (expr1->op_type == IS_TMP_VAR) { @@ -1306,9 +1306,9 @@ void zend_do_boolean_and_begin(znode *expr1, znode *op_token CLS_DC) } -void zend_do_boolean_and_end(znode *result, znode *expr1, znode *expr2, znode *op_token CLS_DC) +void zend_do_boolean_and_end(znode *result, znode *expr1, znode *expr2, znode *op_token TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); *result = *expr1; /* we saved the original result in expr1 */ opline->opcode = ZEND_BOOL; @@ -1320,31 +1320,31 @@ void zend_do_boolean_and_end(znode *result, znode *expr1, znode *expr2, znode *o } -void zend_do_do_while_begin(CLS_D) +void zend_do_do_while_begin(TSRMLS_D) { - do_begin_loop(CLS_C); + do_begin_loop(TSRMLS_C); INC_BPC(CG(active_op_array)); } -void zend_do_do_while_end(znode *do_token, znode *expr_open_bracket, znode *expr CLS_DC) +void zend_do_do_while_end(znode *do_token, znode *expr_open_bracket, znode *expr TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMPNZ; opline->op1 = *expr; opline->op2.u.opline_num = do_token->u.opline_num; SET_UNUSED(opline->op2); - do_end_loop(expr_open_bracket->u.opline_num CLS_CC); + do_end_loop(expr_open_bracket->u.opline_num TSRMLS_CC); DEC_BPC(CG(active_op_array)); } -void zend_do_brk_cont(int op, znode *expr CLS_DC) +void zend_do_brk_cont(int op, znode *expr TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = op; opline->op1.u.opline_num = CG(active_op_array)->current_brk_cont; @@ -1360,13 +1360,13 @@ void zend_do_brk_cont(int op, znode *expr CLS_DC) } -void zend_do_switch_cond(znode *cond CLS_DC) +void zend_do_switch_cond(znode *cond TSRMLS_DC) { zend_switch_entry switch_entry; zend_op *opline; /* Initialize the conditional value */ - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_BOOL; opline->result.u.var = get_temporary_variable(CG(active_op_array)); opline->result.op_type = IS_TMP_VAR; @@ -1381,14 +1381,14 @@ void zend_do_switch_cond(znode *cond CLS_DC) switch_entry.control_var = opline->result.u.var; zend_stack_push(&CG(switch_cond_stack), (void *) &switch_entry, sizeof(switch_entry)); - do_begin_loop(CLS_C); + do_begin_loop(TSRMLS_C); INC_BPC(CG(active_op_array)); } -void zend_do_switch_end(znode *case_list CLS_DC) +void zend_do_switch_end(znode *case_list TSRMLS_DC) { zend_op *opline; zend_switch_entry *switch_entry_ptr; @@ -1403,7 +1403,7 @@ void zend_do_switch_end(znode *case_list CLS_DC) /* add code to jmp to default case */ if (switch_entry_ptr->default_case != -1) { - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMPZ; opline->op1.op_type = IS_TMP_VAR; opline->op1.u.var = switch_entry_ptr->control_var; @@ -1418,7 +1418,7 @@ void zend_do_switch_end(znode *case_list CLS_DC) if (switch_entry_ptr->cond.op_type==IS_VAR || switch_entry_ptr->cond.op_type==IS_TMP_VAR) { /* emit free for the switch condition*/ - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_SWITCH_FREE; opline->op1 = switch_entry_ptr->cond; SET_UNUSED(opline->op2); @@ -1433,9 +1433,9 @@ void zend_do_switch_end(znode *case_list CLS_DC) } -void zend_do_case_before_statement(znode *case_list, znode *case_token, znode *case_expr CLS_DC) +void zend_do_case_before_statement(znode *case_list, znode *case_token, znode *case_expr TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); int next_op_number; zend_switch_entry *switch_entry_ptr; znode result; @@ -1453,7 +1453,7 @@ void zend_do_case_before_statement(znode *case_list, znode *case_token, znode *c result = opline->result; next_op_number = get_next_op_number(CG(active_op_array)); - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMPZ; opline->op1 = result; SET_UNUSED(opline->op2); @@ -1467,10 +1467,10 @@ void zend_do_case_before_statement(znode *case_list, znode *case_token, znode *c } -void zend_do_case_after_statement(znode *result, znode *case_token CLS_DC) +void zend_do_case_after_statement(znode *result, znode *case_token TSRMLS_DC) { int next_op_number = get_next_op_number(CG(active_op_array)); - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMP; SET_UNUSED(opline->op1); @@ -1489,10 +1489,10 @@ void zend_do_case_after_statement(znode *result, znode *case_token CLS_DC) -void zend_do_default_before_statement(znode *case_list, znode *default_token CLS_DC) +void zend_do_default_before_statement(znode *case_list, znode *default_token TSRMLS_DC) { int next_op_number = get_next_op_number(CG(active_op_array)); - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); zend_switch_entry *switch_entry_ptr; zend_stack_top(&CG(switch_cond_stack), (void **) &switch_entry_ptr); @@ -1503,7 +1503,7 @@ void zend_do_default_before_statement(znode *case_list, znode *default_token CLS default_token->u.opline_num = next_op_number; next_op_number = get_next_op_number(CG(active_op_array)); - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_BOOL; opline->result.u.var = switch_entry_ptr->control_var; opline->result.op_type = IS_TMP_VAR; @@ -1522,9 +1522,9 @@ void zend_do_default_before_statement(znode *case_list, znode *default_token CLS } -void zend_do_begin_class_declaration(znode *class_name, znode *parent_class_name CLS_DC) +void zend_do_begin_class_declaration(znode *class_name, znode *parent_class_name TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); int runtime_inheritance = 0; if (CG(active_class_entry)) { @@ -1582,7 +1582,7 @@ void zend_do_begin_class_declaration(znode *class_name, znode *parent_class_name opline->opcode = ZEND_DECLARE_FUNCTION_OR_CLASS; opline->op1.op_type = IS_CONST; - build_runtime_defined_function_key(&opline->op1.u.constant, &class_name->u.constant, opline CLS_CC); + build_runtime_defined_function_key(&opline->op1.u.constant, &class_name->u.constant, opline TSRMLS_CC); opline->op2.op_type = IS_CONST; opline->op2.u.constant.type = IS_STRING; opline->op2.u.constant.refcount = 1; @@ -1611,7 +1611,7 @@ void zend_do_begin_class_declaration(znode *class_name, znode *parent_class_name } -void zend_do_end_class_declaration(CLS_D) +void zend_do_end_class_declaration(TSRMLS_D) { do_inherit_parent_constructor(CG(active_class_entry)); CG(active_class_entry) = NULL; @@ -1622,7 +1622,7 @@ void zend_do_end_class_declaration(CLS_D) } -void zend_do_declare_property(znode *var_name, znode *value CLS_DC) +void zend_do_declare_property(znode *var_name, znode *value TSRMLS_DC) { if (value) { zval *property; @@ -1636,12 +1636,12 @@ void zend_do_declare_property(znode *var_name, znode *value CLS_DC) } -void zend_do_fetch_property(znode *result, znode *object, znode *property CLS_DC) +void zend_do_fetch_property(znode *result, znode *object, znode *property TSRMLS_DC) { zend_op opline; zend_llist *fetch_list_ptr; - init_op(&opline CLS_CC); + init_op(&opline TSRMLS_CC); opline.opcode = ZEND_FETCH_OBJ_W; /* the backpatching routine assumes W */ opline.result.op_type = IS_VAR; opline.result.u.EA.type = 0; @@ -1655,13 +1655,13 @@ void zend_do_fetch_property(znode *result, znode *object, znode *property CLS_DC } -void zend_do_push_object(znode *object CLS_DC) +void zend_do_push_object(znode *object TSRMLS_DC) { zend_stack_push(&CG(object_stack), object, sizeof(znode)); } -void zend_do_pop_object(znode *object CLS_DC) +void zend_do_pop_object(znode *object TSRMLS_DC) { znode *tmp; @@ -1671,9 +1671,9 @@ void zend_do_pop_object(znode *object CLS_DC) } -void zend_do_begin_new_object(znode *new_token, znode *class_name CLS_DC) +void zend_do_begin_new_object(znode *new_token, znode *class_name TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); unsigned char *ptr = NULL; opline->opcode = ZEND_NEW; @@ -1683,7 +1683,7 @@ void zend_do_begin_new_object(znode *new_token, znode *class_name CLS_DC) SET_UNUSED(opline->op2); new_token->u.opline_num = get_next_op_number(CG(active_op_array)); - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMP_NO_CTOR; opline->op1 = (opline-1)->result; SET_UNUSED(opline->op2); @@ -1691,7 +1691,7 @@ void zend_do_begin_new_object(znode *new_token, znode *class_name CLS_DC) if (class_name->op_type == IS_CONST) { zval_copy_ctor(&class_name->u.constant); } - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_INIT_FCALL_BY_NAME; opline->op1 = (opline-2)->result; opline->op2 = *class_name; @@ -1700,22 +1700,22 @@ void zend_do_begin_new_object(znode *new_token, znode *class_name CLS_DC) } -void zend_do_end_new_object(znode *result, znode *class_name, znode *new_token, znode *argument_list CLS_DC) +void zend_do_end_new_object(znode *result, znode *class_name, znode *new_token, znode *argument_list TSRMLS_DC) { znode ctor_result; if (class_name->op_type == IS_CONST) { zval_copy_ctor(&class_name->u.constant); } - zend_do_end_function_call(class_name, &ctor_result, argument_list, 1, 0 CLS_CC); - zend_do_free(&ctor_result CLS_CC); + zend_do_end_function_call(class_name, &ctor_result, argument_list, 1, 0 TSRMLS_CC); + zend_do_free(&ctor_result TSRMLS_CC); CG(active_op_array)->opcodes[new_token->u.opline_num].op2.u.opline_num = get_next_op_number(CG(active_op_array)); *result = CG(active_op_array)->opcodes[new_token->u.opline_num].op1; } -void zend_do_fetch_constant(znode *result, znode *constant_name, int mode CLS_DC) +void zend_do_fetch_constant(znode *result, znode *constant_name, int mode TSRMLS_DC) { switch (mode) { case ZEND_CT: @@ -1723,7 +1723,7 @@ void zend_do_fetch_constant(znode *result, znode *constant_name, int mode CLS_DC result->u.constant.type = IS_CONSTANT; break; case ZEND_RT: { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_FETCH_CONSTANT; opline->result.op_type = IS_TMP_VAR; @@ -1737,9 +1737,9 @@ void zend_do_fetch_constant(znode *result, znode *constant_name, int mode CLS_DC } -void zend_do_shell_exec(znode *result, znode *cmd CLS_DC) +void zend_do_shell_exec(znode *result, znode *cmd TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); switch (cmd->op_type) { case IS_TMP_VAR: @@ -1754,7 +1754,7 @@ void zend_do_shell_exec(znode *result, znode *cmd CLS_DC) opline->extended_value = ZEND_DO_FCALL; SET_UNUSED(opline->op2); - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_DO_FCALL; opline->result.u.var = get_temporary_variable(CG(active_op_array)); opline->result.op_type = IS_VAR; @@ -1770,9 +1770,9 @@ void zend_do_shell_exec(znode *result, znode *cmd CLS_DC) -void zend_do_init_array(znode *result, znode *expr, znode *offset, int is_ref CLS_DC) +void zend_do_init_array(znode *result, znode *expr, znode *offset, int is_ref TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_INIT_ARRAY; opline->result.u.var = get_temporary_variable(CG(active_op_array)); @@ -1793,9 +1793,9 @@ void zend_do_init_array(znode *result, znode *expr, znode *offset, int is_ref CL } -void zend_do_add_array_element(znode *result, znode *expr, znode *offset, int is_ref CLS_DC) +void zend_do_add_array_element(znode *result, znode *expr, znode *offset, int is_ref TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_ADD_ARRAY_ELEMENT; opline->result = *result; @@ -1836,7 +1836,7 @@ void zend_do_add_static_array_element(znode *result, znode *offset, znode *expr) } -void zend_do_add_list_element(znode *element CLS_DC) +void zend_do_add_list_element(znode *element TSRMLS_DC) { list_llist_element lle; @@ -1849,31 +1849,31 @@ void zend_do_add_list_element(znode *element CLS_DC) } -void zend_do_new_list_begin(CLS_D) +void zend_do_new_list_begin(TSRMLS_D) { int current_dimension = 0; zend_llist_add_element(&CG(dimension_llist), ¤t_dimension); } -void zend_do_new_list_end(CLS_D) +void zend_do_new_list_end(TSRMLS_D) { zend_llist_remove_tail(&CG(dimension_llist)); (*((int *)CG(dimension_llist).tail->data))++; } -void zend_do_list_init(CLS_D) +void zend_do_list_init(TSRMLS_D) { zend_stack_push(&CG(list_stack), &CG(list_llist), sizeof(zend_llist)); zend_stack_push(&CG(list_stack), &CG(dimension_llist), sizeof(zend_llist)); zend_llist_init(&CG(list_llist), sizeof(list_llist_element), NULL, 0); zend_llist_init(&CG(dimension_llist), sizeof(int), NULL, 0); - zend_do_new_list_begin(CLS_C); + zend_do_new_list_begin(TSRMLS_C); } -void zend_do_list_end(znode *result, znode *expr CLS_DC) +void zend_do_list_end(znode *result, znode *expr TSRMLS_DC) { zend_llist_element *le; zend_llist_element *dimension; @@ -1885,7 +1885,7 @@ void zend_do_list_end(znode *result, znode *expr CLS_DC) zend_llist *tmp_dimension_llist = &((list_llist_element *)le->data)->dimensions; dimension = tmp_dimension_llist->head; while (dimension) { - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); if (dimension == tmp_dimension_llist->head) { /* first */ last_container = *expr; switch(expr->op_type) { @@ -1917,8 +1917,8 @@ void zend_do_list_end(znode *result, znode *expr CLS_DC) } ((list_llist_element *) le->data)->value = last_container; zend_llist_destroy(&((list_llist_element *) le->data)->dimensions); - zend_do_end_variable_parse(BP_VAR_W, 0 CLS_CC); - zend_do_assign(result, &((list_llist_element *) le->data)->var, &((list_llist_element *) le->data)->value CLS_CC); + zend_do_end_variable_parse(BP_VAR_W, 0 TSRMLS_CC); + zend_do_assign(result, &((list_llist_element *) le->data)->var, &((list_llist_element *) le->data)->value TSRMLS_CC); CG(active_op_array)->opcodes[CG(active_op_array)->last-1].result.u.EA.type |= EXT_TYPE_UNUSED; le = le->next; } @@ -1939,9 +1939,9 @@ void zend_do_list_end(znode *result, znode *expr CLS_DC) } -void zend_do_fetch_global_or_static_variable(znode *varname, znode *static_assignment, int fetch_type CLS_DC) +void zend_do_fetch_global_or_static_variable(znode *varname, znode *static_assignment, int fetch_type TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); znode lval; znode result; @@ -1971,16 +1971,16 @@ void zend_do_fetch_global_or_static_variable(znode *varname, znode *static_assig if (varname->op_type == IS_CONST) { zval_copy_ctor(&varname->u.constant); } - fetch_simple_variable(&lval, varname, 0 CLS_CC); /* Relies on the fact that the default fetch is BP_VAR_W */ + fetch_simple_variable(&lval, varname, 0 TSRMLS_CC); /* Relies on the fact that the default fetch is BP_VAR_W */ - zend_do_assign_ref(NULL, &lval, &result CLS_CC); + zend_do_assign_ref(NULL, &lval, &result TSRMLS_CC); CG(active_op_array)->opcodes[CG(active_op_array)->last-1].result.u.EA.type |= EXT_TYPE_UNUSED; } -void zend_do_cast(znode *result, znode *expr, int type CLS_DC) +void zend_do_cast(znode *result, znode *expr, int type TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_CAST; opline->result.op_type = IS_TMP_VAR; @@ -1992,11 +1992,11 @@ void zend_do_cast(znode *result, znode *expr, int type CLS_DC) } -void zend_do_include_or_eval(int type, znode *result, znode *op1 CLS_DC) +void zend_do_include_or_eval(int type, znode *result, znode *op1 TSRMLS_DC) { - zend_do_extended_fcall_begin(CLS_C); + zend_do_extended_fcall_begin(TSRMLS_C); { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_INCLUDE_OR_EVAL; opline->result.op_type = IS_VAR; @@ -2009,25 +2009,25 @@ void zend_do_include_or_eval(int type, znode *result, znode *op1 CLS_DC) opline->result.u.EA.type |= EXT_TYPE_UNUSED; } } - zend_do_extended_fcall_end(CLS_C); + zend_do_extended_fcall_end(TSRMLS_C); } -void zend_do_indirect_references(znode *result, znode *num_references, znode *variable CLS_DC) +void zend_do_indirect_references(znode *result, znode *num_references, znode *variable TSRMLS_DC) { int i; - zend_do_end_variable_parse(BP_VAR_R, 0 CLS_CC); + zend_do_end_variable_parse(BP_VAR_R, 0 TSRMLS_CC); for (i=1; i<num_references->u.constant.value.lval; i++) { - fetch_simple_variable_ex(result, variable, 0, ZEND_FETCH_R CLS_CC); + fetch_simple_variable_ex(result, variable, 0, ZEND_FETCH_R TSRMLS_CC); *variable = *result; } - zend_do_begin_variable_parse(CLS_C); - fetch_simple_variable(result, variable, 1 CLS_CC); + zend_do_begin_variable_parse(TSRMLS_C); + fetch_simple_variable(result, variable, 1 TSRMLS_CC); } -void zend_do_unset(znode *variable CLS_DC) +void zend_do_unset(znode *variable TSRMLS_DC) { zend_op *last_op; @@ -2046,12 +2046,12 @@ void zend_do_unset(znode *variable CLS_DC) } -void zend_do_isset_or_isempty(int type, znode *result, znode *variable CLS_DC) +void zend_do_isset_or_isempty(int type, znode *result, znode *variable TSRMLS_DC) { zend_op *opline; - zend_do_end_variable_parse(BP_VAR_IS, 0 CLS_CC); - opline = get_next_op(CG(active_op_array) CLS_CC); + zend_do_end_variable_parse(BP_VAR_IS, 0 TSRMLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_ISSET_ISEMPTY; opline->result.op_type = IS_TMP_VAR; @@ -2063,9 +2063,9 @@ void zend_do_isset_or_isempty(int type, znode *result, znode *variable CLS_DC) } -void zend_do_foreach_begin(znode *foreach_token, znode *array, znode *open_brackets_token, znode *as_token, int variable CLS_DC) +void zend_do_foreach_begin(znode *foreach_token, znode *array, znode *open_brackets_token, znode *as_token, int variable TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); /* Preform array reset */ opline->opcode = ZEND_FE_RESET; @@ -2085,7 +2085,7 @@ void zend_do_foreach_begin(znode *foreach_token, znode *array, znode *open_brack /* save the location of the beginning of the loop (array fetching) */ foreach_token->u.opline_num = get_next_op_number(CG(active_op_array)); - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_FE_FETCH; opline->result.op_type = IS_TMP_VAR; opline->result.u.var = get_temporary_variable(CG(active_op_array)); @@ -2095,9 +2095,9 @@ void zend_do_foreach_begin(znode *foreach_token, znode *array, znode *open_brack } -void zend_do_foreach_cont(znode *value, znode *key, znode *as_token CLS_DC) +void zend_do_foreach_cont(znode *value, znode *key, znode *as_token TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); znode result_value, result_key, dummy; if (key->op_type != IS_UNUSED) { @@ -2121,7 +2121,7 @@ void zend_do_foreach_cont(znode *value, znode *key, znode *as_token CLS_DC) result_value = opline->result; if (key->op_type != IS_UNUSED) { - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_FETCH_DIM_TMP_VAR; opline->result.op_type = IS_VAR; opline->result.u.EA.type = 0; @@ -2134,22 +2134,22 @@ void zend_do_foreach_cont(znode *value, znode *key, znode *as_token CLS_DC) result_key = opline->result; } - zend_do_assign(&dummy, value, &result_value CLS_CC); + zend_do_assign(&dummy, value, &result_value TSRMLS_CC); CG(active_op_array)->opcodes[CG(active_op_array)->last-1].result.u.EA.type |= EXT_TYPE_UNUSED; if (key->op_type != IS_UNUSED) { - zend_do_assign(&dummy, key, &result_key CLS_CC); + zend_do_assign(&dummy, key, &result_key TSRMLS_CC); CG(active_op_array)->opcodes[CG(active_op_array)->last-1].result.u.EA.type |= EXT_TYPE_UNUSED; } - zend_do_free(as_token CLS_CC); + zend_do_free(as_token TSRMLS_CC); - do_begin_loop(CLS_C); + do_begin_loop(TSRMLS_C); INC_BPC(CG(active_op_array)); } -void zend_do_foreach_end(znode *foreach_token, znode *open_brackets_token CLS_DC) +void zend_do_foreach_end(znode *foreach_token, znode *open_brackets_token TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMP; opline->op1.u.opline_num = foreach_token->u.opline_num; @@ -2158,9 +2158,9 @@ void zend_do_foreach_end(znode *foreach_token, znode *open_brackets_token CLS_DC CG(active_op_array)->opcodes[foreach_token->u.opline_num].op2.u.opline_num = get_next_op_number(CG(active_op_array)); - do_end_loop(foreach_token->u.opline_num CLS_CC); + do_end_loop(foreach_token->u.opline_num TSRMLS_CC); - generate_free_foreach_copy(open_brackets_token CLS_CC); + generate_free_foreach_copy(open_brackets_token TSRMLS_CC); zend_stack_del_top(&CG(foreach_copy_stack)); @@ -2168,13 +2168,13 @@ void zend_do_foreach_end(znode *foreach_token, znode *open_brackets_token CLS_DC } -void zend_do_declare_begin(CLS_D) +void zend_do_declare_begin(TSRMLS_D) { zend_stack_push(&CG(declare_stack), &CG(declarables), sizeof(zend_declarables)); } -void zend_do_declare_stmt(znode *var, znode *val CLS_DC) +void zend_do_declare_stmt(znode *var, znode *val TSRMLS_DC) { convert_to_string(&var->u.constant); @@ -2186,7 +2186,7 @@ void zend_do_declare_stmt(znode *var, znode *val CLS_DC) } -void zend_do_declare_end(CLS_D) +void zend_do_declare_end(TSRMLS_D) { zend_declarables *declarables; @@ -2195,7 +2195,7 @@ void zend_do_declare_end(CLS_D) } -void zend_do_end_heredoc(CLS_D) +void zend_do_end_heredoc(TSRMLS_D) { int opline_num = get_next_op_number(CG(active_op_array))-1; zend_op *opline = &CG(active_op_array)->opcodes[opline_num]; @@ -2213,9 +2213,9 @@ void zend_do_end_heredoc(CLS_D) } -void zend_do_exit(znode *result, znode *message CLS_DC) +void zend_do_exit(znode *result, znode *message TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_EXIT; opline->op1 = *message; @@ -2227,9 +2227,9 @@ void zend_do_exit(znode *result, znode *message CLS_DC) } -void zend_do_begin_silence(znode *strudel_token CLS_DC) +void zend_do_begin_silence(znode *strudel_token TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_BEGIN_SILENCE; opline->result.op_type = IS_TMP_VAR; @@ -2240,9 +2240,9 @@ void zend_do_begin_silence(znode *strudel_token CLS_DC) } -void zend_do_end_silence(znode *strudel_token CLS_DC) +void zend_do_end_silence(znode *strudel_token TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_END_SILENCE; opline->op1 = *strudel_token; @@ -2250,12 +2250,12 @@ void zend_do_end_silence(znode *strudel_token CLS_DC) } -void zend_do_begin_qm_op(znode *cond, znode *qm_token CLS_DC) +void zend_do_begin_qm_op(znode *cond, znode *qm_token TSRMLS_DC) { int jmpz_op_number = get_next_op_number(CG(active_op_array)); zend_op *opline; - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMPZ; opline->op1 = *cond; @@ -2267,9 +2267,9 @@ void zend_do_begin_qm_op(znode *cond, znode *qm_token CLS_DC) } -void zend_do_qm_true(znode *true_value, znode *qm_token, znode *colon_token CLS_DC) +void zend_do_qm_true(znode *true_value, znode *qm_token, znode *colon_token TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); CG(active_op_array)->opcodes[qm_token->u.opline_num].op2.u.opline_num = get_next_op_number(CG(active_op_array))+1; /* jmp over the ZEND_JMP */ @@ -2282,16 +2282,16 @@ void zend_do_qm_true(znode *true_value, znode *qm_token, znode *colon_token CLS_ *qm_token = opline->result; colon_token->u.opline_num = get_next_op_number(CG(active_op_array)); - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_JMP; SET_UNUSED(opline->op1); SET_UNUSED(opline->op2); } -void zend_do_qm_false(znode *result, znode *false_value, znode *qm_token, znode *colon_token CLS_DC) +void zend_do_qm_false(znode *result, znode *false_value, znode *qm_token, znode *colon_token TSRMLS_DC) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_QM_ASSIGN; opline->result = *qm_token; @@ -2306,7 +2306,7 @@ void zend_do_qm_false(znode *result, znode *false_value, znode *qm_token, znode } -void zend_do_extended_info(CLS_D) +void zend_do_extended_info(TSRMLS_D) { zend_op *opline; @@ -2314,7 +2314,7 @@ void zend_do_extended_info(CLS_D) return; } - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_EXT_STMT; SET_UNUSED(opline->op1); @@ -2322,7 +2322,7 @@ void zend_do_extended_info(CLS_D) } -void zend_do_extended_fcall_begin(CLS_D) +void zend_do_extended_fcall_begin(TSRMLS_D) { zend_op *opline; @@ -2330,7 +2330,7 @@ void zend_do_extended_fcall_begin(CLS_D) return; } - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_EXT_FCALL_BEGIN; SET_UNUSED(opline->op1); @@ -2338,7 +2338,7 @@ void zend_do_extended_fcall_begin(CLS_D) } -void zend_do_extended_fcall_end(CLS_D) +void zend_do_extended_fcall_end(TSRMLS_D) { zend_op *opline; @@ -2346,17 +2346,17 @@ void zend_do_extended_fcall_end(CLS_D) return; } - opline = get_next_op(CG(active_op_array) CLS_CC); + opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_EXT_FCALL_END; SET_UNUSED(opline->op1); SET_UNUSED(opline->op2); } -void zend_do_ticks(CLS_D) +void zend_do_ticks(TSRMLS_D) { if (CG(declarables).ticks.value.lval) { - zend_op *opline = get_next_op(CG(active_op_array) CLS_CC); + zend_op *opline = get_next_op(CG(active_op_array) TSRMLS_CC); opline->opcode = ZEND_TICKS; opline->op1.u.constant = CG(declarables).ticks; @@ -2366,17 +2366,17 @@ void zend_do_ticks(CLS_D) } -int zendlex(znode *zendlval CLS_DC) +int zendlex(znode *zendlval TSRMLS_DC) { int retval; zendlval->u.constant.type = IS_LONG; - retval = lex_scan(&zendlval->u.constant CLS_CC); + retval = lex_scan(&zendlval->u.constant TSRMLS_CC); switch(retval) { case T_COMMENT: case T_OPEN_TAG: case T_WHITESPACE: - retval = zendlex(zendlval CLS_CC); + retval = zendlex(zendlval TSRMLS_CC); break; case T_CLOSE_TAG: retval = ';'; /* implicit ; */ diff --git a/Zend/zend_compile.h b/Zend/zend_compile.h index 976b8d152d..b9d14b3c62 100644 --- a/Zend/zend_compile.h +++ b/Zend/zend_compile.h @@ -42,7 +42,7 @@ #define INC_BPC(op_array) if (CG(interactive)) { ((op_array)->backpatch_count++); } #define DEC_BPC(op_array) if (CG(interactive)) { ((op_array)->backpatch_count--); } -#define HANDLE_INTERACTIVE() if (CG(interactive)) { execute_new_code(CLS_C); } +#define HANDLE_INTERACTIVE() if (CG(interactive)) { execute_new_code(TSRMLS_C); } typedef struct _zend_op_array zend_op_array; @@ -196,166 +196,166 @@ typedef struct _zend_file_handle { BEGIN_EXTERN_C() -void init_compiler(CLS_D TSRMLS_DC); -void shutdown_compiler(CLS_D); -void zend_init_compiler_data_structures(CLS_D); +void init_compiler(TSRMLS_D); +void shutdown_compiler(TSRMLS_D); +void zend_init_compiler_data_structures(TSRMLS_D); -extern ZEND_API zend_op_array *(*zend_compile_file)(zend_file_handle *file_handle, int type CLS_DC); +extern ZEND_API zend_op_array *(*zend_compile_file)(zend_file_handle *file_handle, int type TSRMLS_DC); -void zend_activate(CLS_D TSRMLS_DC); -void zend_deactivate(CLS_D TSRMLS_DC); +void zend_activate(TSRMLS_D); +void zend_deactivate(TSRMLS_D); void zend_activate_modules(void); void zend_deactivate_modules(void); -int lex_scan(zval *zendlval CLS_DC); -void startup_scanner(CLS_D); -void shutdown_scanner(CLS_D); +int lex_scan(zval *zendlval TSRMLS_DC); +void startup_scanner(TSRMLS_D); +void shutdown_scanner(TSRMLS_D); ZEND_API char *zend_set_compiled_filename(char *new_compiled_filename); ZEND_API void zend_restore_compiled_filename(char *original_compiled_filename); -ZEND_API char *zend_get_compiled_filename(CLS_D); -ZEND_API int zend_get_compiled_lineno(CLS_D); +ZEND_API char *zend_get_compiled_filename(TSRMLS_D); +ZEND_API int zend_get_compiled_lineno(TSRMLS_D); #ifdef ZTS -const char *zend_get_zendtext(CLS_D); -int zend_get_zendleng(CLS_D); +const char *zend_get_zendtext(TSRMLS_D); +int zend_get_zendleng(TSRMLS_D); #endif /* parser-driven code generators */ -void zend_do_binary_op(int op, znode *result, znode *op1, znode *op2 CLS_DC); -void zend_do_unary_op(int op, znode *result, znode *op1 CLS_DC); -void zend_do_binary_assign_op(int op, znode *result, znode *op1, znode *op2 CLS_DC); -void zend_do_assign(znode *result, znode *variable, znode *value CLS_DC); -void zend_do_assign_ref(znode *result, znode *lvar, znode *rvar CLS_DC); -void fetch_simple_variable(znode *result, znode *varname, int bp CLS_DC); -void fetch_simple_variable_ex(znode *result, znode *varname, int bp, int op CLS_DC); -void zend_do_indirect_references(znode *result, znode *num_references, znode *variable CLS_DC); -void zend_do_fetch_global_or_static_variable(znode *varname, znode *static_assignment, int fetch_type CLS_DC); -void zend_do_fetch_globals(znode *varname CLS_DC); - -void fetch_array_begin(znode *result, znode *varname, znode *first_dim CLS_DC); -void fetch_array_dim(znode *result, znode *parent, znode *dim CLS_DC); -void fetch_string_offset(znode *result, znode *parent, znode *offset CLS_DC); -void zend_do_print(znode *result, znode *arg CLS_DC); -void zend_do_echo(znode *arg CLS_DC); +void zend_do_binary_op(int op, znode *result, znode *op1, znode *op2 TSRMLS_DC); +void zend_do_unary_op(int op, znode *result, znode *op1 TSRMLS_DC); +void zend_do_binary_assign_op(int op, znode *result, znode *op1, znode *op2 TSRMLS_DC); +void zend_do_assign(znode *result, znode *variable, znode *value TSRMLS_DC); +void zend_do_assign_ref(znode *result, znode *lvar, znode *rvar TSRMLS_DC); +void fetch_simple_variable(znode *result, znode *varname, int bp TSRMLS_DC); +void fetch_simple_variable_ex(znode *result, znode *varname, int bp, int op TSRMLS_DC); +void zend_do_indirect_references(znode *result, znode *num_references, znode *variable TSRMLS_DC); +void zend_do_fetch_global_or_static_variable(znode *varname, znode *static_assignment, int fetch_type TSRMLS_DC); +void zend_do_fetch_globals(znode *varname TSRMLS_DC); + +void fetch_array_begin(znode *result, znode *varname, znode *first_dim TSRMLS_DC); +void fetch_array_dim(znode *result, znode *parent, znode *dim TSRMLS_DC); +void fetch_string_offset(znode *result, znode *parent, znode *offset TSRMLS_DC); +void zend_do_print(znode *result, znode *arg TSRMLS_DC); +void zend_do_echo(znode *arg TSRMLS_DC); typedef int (*unary_op_type)(zval *, zval *); ZEND_API unary_op_type get_unary_op(int opcode); ZEND_API void *get_binary_op(int opcode); -void zend_do_while_cond(znode *expr, znode *close_bracket_token CLS_DC); -void zend_do_while_end(znode *while_token, znode *close_bracket_token CLS_DC); -void zend_do_do_while_begin(CLS_D); -void zend_do_do_while_end(znode *do_token, znode *expr_open_bracket, znode *expr CLS_DC); +void zend_do_while_cond(znode *expr, znode *close_bracket_token TSRMLS_DC); +void zend_do_while_end(znode *while_token, znode *close_bracket_token TSRMLS_DC); +void zend_do_do_while_begin(TSRMLS_D); +void zend_do_do_while_end(znode *do_token, znode *expr_open_bracket, znode *expr TSRMLS_DC); -void zend_do_if_cond(znode *cond, znode *closing_bracket_token CLS_DC); -void zend_do_if_after_statement(znode *closing_bracket_token, unsigned char initialize CLS_DC); -void zend_do_if_end(CLS_D); +void zend_do_if_cond(znode *cond, znode *closing_bracket_token TSRMLS_DC); +void zend_do_if_after_statement(znode *closing_bracket_token, unsigned char initialize TSRMLS_DC); +void zend_do_if_end(TSRMLS_D); -void zend_do_for_cond(znode *expr, znode *second_semicolon_token CLS_DC); -void zend_do_for_before_statement(znode *cond_start, znode *second_semicolon_token CLS_DC); -void zend_do_for_end(znode *second_semicolon_token CLS_DC); +void zend_do_for_cond(znode *expr, znode *second_semicolon_token TSRMLS_DC); +void zend_do_for_before_statement(znode *cond_start, znode *second_semicolon_token TSRMLS_DC); +void zend_do_for_end(znode *second_semicolon_token TSRMLS_DC); -void zend_do_pre_incdec(znode *result, znode *op1, int op CLS_DC); -void zend_do_post_incdec(znode *result, znode *op1, int op CLS_DC); +void zend_do_pre_incdec(znode *result, znode *op1, int op TSRMLS_DC); +void zend_do_post_incdec(znode *result, znode *op1, int op TSRMLS_DC); -void zend_do_begin_variable_parse(CLS_D); -void zend_do_end_variable_parse(int type, int arg_offset CLS_DC); +void zend_do_begin_variable_parse(TSRMLS_D); +void zend_do_end_variable_parse(int type, int arg_offset TSRMLS_DC); -void zend_do_free(znode *op1 CLS_DC); +void zend_do_free(znode *op1 TSRMLS_DC); -void zend_do_init_string(znode *result CLS_DC); -void zend_do_add_char(znode *result, znode *op1, znode *op2 CLS_DC); -void zend_do_add_string(znode *result, znode *op1, znode *op2 CLS_DC); -void zend_do_add_variable(znode *result, znode *op1, znode *op2 CLS_DC); +void zend_do_init_string(znode *result TSRMLS_DC); +void zend_do_add_char(znode *result, znode *op1, znode *op2 TSRMLS_DC); +void zend_do_add_string(znode *result, znode *op1, znode *op2 TSRMLS_DC); +void zend_do_add_variable(znode *result, znode *op1, znode *op2 TSRMLS_DC); -void zend_do_begin_function_declaration(znode *function_token, znode *function_name, int is_method, int return_reference CLS_DC); -void zend_do_end_function_declaration(znode *function_token CLS_DC); -void zend_do_receive_arg(int op, znode *var, znode *offset, znode *initialization, unsigned char pass_type CLS_DC); -int zend_do_begin_function_call(znode *function_name CLS_DC); -void zend_do_begin_dynamic_function_call(znode *function_name CLS_DC); -void zend_do_begin_class_member_function_call(znode *class_name, znode *function_name CLS_DC); -void zend_do_end_function_call(znode *function_name, znode *result, znode *argument_list, int is_method, int is_dynamic_fcall CLS_DC); -void zend_do_return(znode *expr, int do_end_vparse CLS_DC); +void zend_do_begin_function_declaration(znode *function_token, znode *function_name, int is_method, int return_reference TSRMLS_DC); +void zend_do_end_function_declaration(znode *function_token TSRMLS_DC); +void zend_do_receive_arg(int op, znode *var, znode *offset, znode *initialization, unsigned char pass_type TSRMLS_DC); +int zend_do_begin_function_call(znode *function_name TSRMLS_DC); +void zend_do_begin_dynamic_function_call(znode *function_name TSRMLS_DC); +void zend_do_begin_class_member_function_call(znode *class_name, znode *function_name TSRMLS_DC); +void zend_do_end_function_call(znode *function_name, znode *result, znode *argument_list, int is_method, int is_dynamic_fcall TSRMLS_DC); +void zend_do_return(znode *expr, int do_end_vparse TSRMLS_DC); ZEND_API int do_bind_function_or_class(zend_op *opline, HashTable *function_table, HashTable *class_table, int compile_time); void zend_do_inheritance(zend_class_entry *ce, zend_class_entry *parent_ce); -void zend_do_early_binding(CLS_D); +void zend_do_early_binding(TSRMLS_D); -void zend_do_pass_param(znode *param, int op, int offset CLS_DC); +void zend_do_pass_param(znode *param, int op, int offset TSRMLS_DC); -void zend_do_boolean_or_begin(znode *expr1, znode *op_token CLS_DC); -void zend_do_boolean_or_end(znode *result, znode *expr1, znode *expr2, znode *op_token CLS_DC); -void zend_do_boolean_and_begin(znode *expr1, znode *op_token CLS_DC); -void zend_do_boolean_and_end(znode *result, znode *expr1, znode *expr2, znode *op_token CLS_DC); +void zend_do_boolean_or_begin(znode *expr1, znode *op_token TSRMLS_DC); +void zend_do_boolean_or_end(znode *result, znode *expr1, znode *expr2, znode *op_token TSRMLS_DC); +void zend_do_boolean_and_begin(znode *expr1, znode *op_token TSRMLS_DC); +void zend_do_boolean_and_end(znode *result, znode *expr1, znode *expr2, znode *op_token TSRMLS_DC); -void zend_do_brk_cont(int op, znode *expr CLS_DC); +void zend_do_brk_cont(int op, znode *expr TSRMLS_DC); -void zend_do_switch_cond(znode *cond CLS_DC); -void zend_do_switch_end(znode *case_list CLS_DC); -void zend_do_case_before_statement(znode *case_list, znode *case_token, znode *case_expr CLS_DC); -void zend_do_case_after_statement(znode *result, znode *case_token CLS_DC); -void zend_do_default_before_statement(znode *case_list, znode *default_token CLS_DC); +void zend_do_switch_cond(znode *cond TSRMLS_DC); +void zend_do_switch_end(znode *case_list TSRMLS_DC); +void zend_do_case_before_statement(znode *case_list, znode *case_token, znode *case_expr TSRMLS_DC); +void zend_do_case_after_statement(znode *result, znode *case_token TSRMLS_DC); +void zend_do_default_before_statement(znode *case_list, znode *default_token TSRMLS_DC); -void zend_do_begin_class_declaration(znode *class_name, znode *parent_class_name CLS_DC); -void zend_do_end_class_declaration(CLS_D); -void zend_do_declare_property(znode *var_name, znode *value CLS_DC); +void zend_do_begin_class_declaration(znode *class_name, znode *parent_class_name TSRMLS_DC); +void zend_do_end_class_declaration(TSRMLS_D); +void zend_do_declare_property(znode *var_name, znode *value TSRMLS_DC); -void zend_do_fetch_property(znode *result, znode *object, znode *property CLS_DC); +void zend_do_fetch_property(znode *result, znode *object, znode *property TSRMLS_DC); -void zend_do_push_object(znode *object CLS_DC); -void zend_do_pop_object(znode *object CLS_DC); +void zend_do_push_object(znode *object TSRMLS_DC); +void zend_do_pop_object(znode *object TSRMLS_DC); -void zend_do_begin_new_object(znode *new_token, znode *class_name CLS_DC); -void zend_do_end_new_object(znode *result, znode *class_name, znode *new_token, znode *argument_list CLS_DC); +void zend_do_begin_new_object(znode *new_token, znode *class_name TSRMLS_DC); +void zend_do_end_new_object(znode *result, znode *class_name, znode *new_token, znode *argument_list TSRMLS_DC); -void zend_do_fetch_constant(znode *result, znode *constant_name, int mode CLS_DC); +void zend_do_fetch_constant(znode *result, znode *constant_name, int mode TSRMLS_DC); -void zend_do_shell_exec(znode *result, znode *cmd CLS_DC); +void zend_do_shell_exec(znode *result, znode *cmd TSRMLS_DC); -void zend_do_init_array(znode *result, znode *expr, znode *offset, int is_ref CLS_DC); -void zend_do_add_array_element(znode *result, znode *expr, znode *offset, int is_ref CLS_DC); +void zend_do_init_array(znode *result, znode *expr, znode *offset, int is_ref TSRMLS_DC); +void zend_do_add_array_element(znode *result, znode *expr, znode *offset, int is_ref TSRMLS_DC); void zend_do_add_static_array_element(znode *result, znode *offset, znode *expr); -void zend_do_list_init(CLS_D); -void zend_do_list_end(znode *result, znode *expr CLS_DC); -void zend_do_add_list_element(znode *element CLS_DC); -void zend_do_new_list_begin(CLS_D); -void zend_do_new_list_end(CLS_D); +void zend_do_list_init(TSRMLS_D); +void zend_do_list_end(znode *result, znode *expr TSRMLS_DC); +void zend_do_add_list_element(znode *element TSRMLS_DC); +void zend_do_new_list_begin(TSRMLS_D); +void zend_do_new_list_end(TSRMLS_D); -void zend_do_cast(znode *result, znode *expr, int type CLS_DC); -void zend_do_include_or_eval(int type, znode *result, znode *op1 CLS_DC); +void zend_do_cast(znode *result, znode *expr, int type TSRMLS_DC); +void zend_do_include_or_eval(int type, znode *result, znode *op1 TSRMLS_DC); -void zend_do_unset(znode *variable CLS_DC); -void zend_do_isset_or_isempty(int type, znode *result, znode *variable CLS_DC); +void zend_do_unset(znode *variable TSRMLS_DC); +void zend_do_isset_or_isempty(int type, znode *result, znode *variable TSRMLS_DC); -void zend_do_foreach_begin(znode *foreach_token, znode *array, znode *open_brackets_token, znode *as_token, int variable CLS_DC); -void zend_do_foreach_cont(znode *value, znode *key, znode *as_token CLS_DC); -void zend_do_foreach_end(znode *foreach_token, znode *open_brackets_token CLS_DC); +void zend_do_foreach_begin(znode *foreach_token, znode *array, znode *open_brackets_token, znode *as_token, int variable TSRMLS_DC); +void zend_do_foreach_cont(znode *value, znode *key, znode *as_token TSRMLS_DC); +void zend_do_foreach_end(znode *foreach_token, znode *open_brackets_token TSRMLS_DC); -void zend_do_declare_begin(CLS_D); -void zend_do_declare_stmt(znode *var, znode *val CLS_DC); -void zend_do_declare_end(CLS_D); +void zend_do_declare_begin(TSRMLS_D); +void zend_do_declare_stmt(znode *var, znode *val TSRMLS_DC); +void zend_do_declare_end(TSRMLS_D); -void zend_do_end_heredoc(CLS_D); +void zend_do_end_heredoc(TSRMLS_D); -void zend_do_exit(znode *result, znode *message CLS_DC); +void zend_do_exit(znode *result, znode *message TSRMLS_DC); -void zend_do_begin_silence(znode *strudel_token CLS_DC); -void zend_do_end_silence(znode *strudel_token CLS_DC); +void zend_do_begin_silence(znode *strudel_token TSRMLS_DC); +void zend_do_end_silence(znode *strudel_token TSRMLS_DC); -void zend_do_begin_qm_op(znode *cond, znode *qm_token CLS_DC); -void zend_do_qm_true(znode *true_value, znode *qm_token, znode *colon_token CLS_DC); -void zend_do_qm_false(znode *result, znode *false_value, znode *qm_token, znode *colon_token CLS_DC); +void zend_do_begin_qm_op(znode *cond, znode *qm_token TSRMLS_DC); +void zend_do_qm_true(znode *true_value, znode *qm_token, znode *colon_token TSRMLS_DC); +void zend_do_qm_false(znode *result, znode *false_value, znode *qm_token, znode *colon_token TSRMLS_DC); -void zend_do_extended_info(CLS_D); -void zend_do_extended_fcall_begin(CLS_D); -void zend_do_extended_fcall_end(CLS_D); +void zend_do_extended_info(TSRMLS_D); +void zend_do_extended_fcall_begin(TSRMLS_D); +void zend_do_extended_fcall_end(TSRMLS_D); -void zend_do_ticks(CLS_D); +void zend_do_ticks(TSRMLS_D); ZEND_API void function_add_ref(zend_function *function); @@ -363,14 +363,14 @@ ZEND_API void function_add_ref(zend_function *function); /* helper functions in zend_language_scanner.l */ -ZEND_API zend_op_array *compile_file(zend_file_handle *file_handle, int type CLS_DC); -ZEND_API zend_op_array *compile_string(zval *source_string, char *filename CLS_DC); -ZEND_API zend_op_array *compile_filename(int type, zval *filename CLS_DC TSRMLS_DC); -ZEND_API int zend_execute_scripts(int type CLS_DC TSRMLS_DC, int file_count, ...); -ZEND_API int open_file_for_scanning(zend_file_handle *file_handle CLS_DC); -ZEND_API void init_op_array(zend_op_array *op_array, int type, int initial_ops_size CLS_DC); +ZEND_API zend_op_array *compile_file(zend_file_handle *file_handle, int type TSRMLS_DC); +ZEND_API zend_op_array *compile_string(zval *source_string, char *filename TSRMLS_DC); +ZEND_API zend_op_array *compile_filename(int type, zval *filename TSRMLS_DC); +ZEND_API int zend_execute_scripts(int type TSRMLS_DC, int file_count, ...); +ZEND_API int open_file_for_scanning(zend_file_handle *file_handle TSRMLS_DC); +ZEND_API void init_op_array(zend_op_array *op_array, int type, int initial_ops_size TSRMLS_DC); ZEND_API void destroy_op_array(zend_op_array *op_array); -ZEND_API void zend_destroy_file_handle(zend_file_handle *file_handle CLS_DC); +ZEND_API void zend_destroy_file_handle(zend_file_handle *file_handle TSRMLS_DC); ZEND_API void zend_file_handle_dtor(zend_file_handle *fh); ZEND_API void destroy_zend_function(zend_function *function); @@ -380,8 +380,8 @@ void zend_class_add_ref(zend_class_entry *ce); #define ZEND_FUNCTION_DTOR (void (*)(void *)) destroy_zend_function #define ZEND_CLASS_DTOR (void (*)(void *)) destroy_zend_class -zend_op *get_next_op(zend_op_array *op_array CLS_DC); -void init_op(zend_op *op CLS_DC); +zend_op *get_next_op(zend_op_array *op_array TSRMLS_DC); +void init_op(zend_op *op TSRMLS_DC); int get_next_op_number(zend_op_array *op_array); int print_class(zend_class_entry *class_entry); void print_op_array(zend_op_array *op_array, int optimizations); @@ -390,7 +390,7 @@ zend_brk_cont_element *get_next_brk_cont_element(zend_op_array *op_array); ZEND_API zend_bool zend_is_compiling(void); ZEND_API char *zend_make_compiled_string_description(char *name); -int zendlex(znode *zendlval CLS_DC); +int zendlex(znode *zendlval TSRMLS_DC); #define ZEND_NOP 0 diff --git a/Zend/zend_execute.c b/Zend/zend_execute.c index 3a0ada3dcc..0f1b31d1a2 100644 --- a/Zend/zend_execute.c +++ b/Zend/zend_execute.c @@ -2036,7 +2036,7 @@ send_by_ref: int return_value_used; zval *inc_filename = get_zval_ptr(&opline->op1, Ts, &EG(free_op1), BP_VAR_R); zval tmp_inc_filename; - CLS_FETCH(); + TSRMLS_FETCH(); if (inc_filename->type!=IS_STRING) { tmp_inc_filename = *inc_filename; @@ -2062,8 +2062,8 @@ send_by_ref: if (file_handle.handle.fp) { if (!opened_path || zend_hash_add(&EG(included_files), opened_path, strlen(opened_path)+1, (void *)&dummy, sizeof(int), NULL)==SUCCESS) { - new_op_array = zend_compile_file(&file_handle, (opline->op2.u.constant.value.lval==ZEND_INCLUDE_ONCE?ZEND_INCLUDE:ZEND_REQUIRE) CLS_CC); - zend_destroy_file_handle(&file_handle CLS_CC); + new_op_array = zend_compile_file(&file_handle, (opline->op2.u.constant.value.lval==ZEND_INCLUDE_ONCE?ZEND_INCLUDE:ZEND_REQUIRE) TSRMLS_CC); + zend_destroy_file_handle(&file_handle TSRMLS_CC); opened_path = NULL; /* zend_destroy_file_handle() already frees it */ } else { fclose(file_handle.handle.fp); @@ -2083,12 +2083,12 @@ send_by_ref: break; case ZEND_INCLUDE: case ZEND_REQUIRE: - new_op_array = compile_filename(opline->op2.u.constant.value.lval, inc_filename CLS_CC TSRMLS_CC); + new_op_array = compile_filename(opline->op2.u.constant.value.lval, inc_filename TSRMLS_CC); break; case ZEND_EVAL: { char *eval_desc = zend_make_compiled_string_description("eval()'d code"); - new_op_array = compile_string(inc_filename, eval_desc CLS_CC); + new_op_array = compile_string(inc_filename, eval_desc TSRMLS_CC); efree(eval_desc); } break; diff --git a/Zend/zend_execute.h b/Zend/zend_execute.h index 19fcdeec36..5aebab318f 100644 --- a/Zend/zend_execute.h +++ b/Zend/zend_execute.h @@ -49,7 +49,7 @@ typedef union _temp_variable { ZEND_API extern void (*zend_execute)(zend_op_array *op_array TSRMLS_DC); -void init_executor(CLS_D TSRMLS_DC); +void init_executor(TSRMLS_D); void shutdown_executor(TSRMLS_D); ZEND_API void execute(zend_op_array *op_array TSRMLS_DC); ZEND_API int zend_is_true(zval *op); @@ -62,7 +62,7 @@ static inline void safe_free_zval_ptr(zval *p) } } -ZEND_API int zend_eval_string(char *str, zval *retval_ptr, char *string_name CLS_DC TSRMLS_DC); +ZEND_API int zend_eval_string(char *str, zval *retval_ptr, char *string_name TSRMLS_DC); static inline int i_zend_is_true(zval *op) { int result; @@ -127,7 +127,7 @@ static inline int zend_ptr_stack_get_arg(int requested_arg, void **data TSRMLS_D return SUCCESS; } -void execute_new_code(CLS_D); +void execute_new_code(TSRMLS_D); /* services */ diff --git a/Zend/zend_execute_API.c b/Zend/zend_execute_API.c index 8e9f0a44c0..42137cff0c 100644 --- a/Zend/zend_execute_API.c +++ b/Zend/zend_execute_API.c @@ -102,7 +102,7 @@ static int is_not_internal_class(zend_class_entry *ce) } -void init_executor(CLS_D TSRMLS_DC) +void init_executor(TSRMLS_D) { INIT_ZVAL(EG(uninitialized_zval)); INIT_ZVAL(EG(error_zval)); @@ -529,7 +529,7 @@ int call_user_function_ex(HashTable *function_table, zval **object_pp, zval *fun } -ZEND_API int zend_eval_string(char *str, zval *retval_ptr, char *string_name CLS_DC TSRMLS_DC) +ZEND_API int zend_eval_string(char *str, zval *retval_ptr, char *string_name TSRMLS_DC) { zval pv; zend_op_array *new_op_array; @@ -554,7 +554,7 @@ ZEND_API int zend_eval_string(char *str, zval *retval_ptr, char *string_name CLS original_handle_op_arrays = CG(handle_op_arrays); CG(handle_op_arrays) = 0; - new_op_array = compile_string(&pv, string_name CLS_CC); + new_op_array = compile_string(&pv, string_name TSRMLS_CC); CG(handle_op_arrays) = original_handle_op_arrays; if (new_op_array) { @@ -596,11 +596,10 @@ ZEND_API int zend_eval_string(char *str, zval *retval_ptr, char *string_name CLS } -void execute_new_code(CLS_D) +void execute_new_code(TSRMLS_D) { zend_op *opline, *end; zend_op *ret_opline; - TSRMLS_FETCH(); if (!CG(interactive) || CG(active_op_array)->backpatch_count>0 @@ -609,7 +608,7 @@ void execute_new_code(CLS_D) return; } - ret_opline = get_next_op(CG(active_op_array) CLS_CC); + ret_opline = get_next_op(CG(active_op_array) TSRMLS_CC); ret_opline->opcode = ZEND_RETURN; ret_opline->op1.op_type = IS_CONST; INIT_ZVAL(ret_opline->op1.u.constant); @@ -647,8 +646,6 @@ ZEND_API void zend_timeout(int dummy) TSRMLS_FETCH(); /* is there any point in this? we're terminating the request anyway... - PLS_FETCH(); - PG(connection_status) |= PHP_CONNECTION_TIMEOUT; */ zend_error(E_ERROR, "Maximum execution time of %d second%s exceeded", @@ -677,16 +674,16 @@ static LRESULT CALLBACK zend_timeout_WndProc(HWND hWnd, UINT message, WPARAM wPa break; case WM_TIMER: { #ifdef ZTS - zend_executor_globals *executor_globals; + void ***tsrm_ls; - executor_globals = ts_resource_ex(executor_globals_id, &wParam); - if (!executor_globals) { + tsrm_ls = ts_resource_ex(0, &wParam); + if (!tsrm_ls) { /* Thread died before receiving its timeout? */ break; } #endif KillTimer(timeout_window, wParam); - executor_globals->timed_out = 1; + EG(timed_out) = 1; } break; default: diff --git a/Zend/zend_fast_cache.h b/Zend/zend_fast_cache.h index f3e7a15492..a13b5a185f 100644 --- a/Zend/zend_fast_cache.h +++ b/Zend/zend_fast_cache.h @@ -58,7 +58,7 @@ typedef struct _zend_fast_cache_list_entry { #define ZEND_FAST_ALLOC(p, type, fc_type) \ { \ - ALS_FETCH(); \ + TSRMLS_FETCH(); \ \ if (((p) = (type *) AG(fast_cache_list_head)[fc_type])) { \ AG(fast_cache_list_head)[fc_type] = ((zend_fast_cache_list_entry *) AG(fast_cache_list_head)[fc_type])->next; \ @@ -72,7 +72,7 @@ typedef struct _zend_fast_cache_list_entry { #define ZEND_FAST_FREE(p, fc_type) \ { \ - ALS_FETCH(); \ + TSRMLS_FETCH(); \ \ ((zend_fast_cache_list_entry *) (p))->next = (zend_fast_cache_list_entry *) AG(fast_cache_list_head)[fc_type]; \ AG(fast_cache_list_head)[fc_type] = (zend_fast_cache_list_entry *) (p); \ diff --git a/Zend/zend_globals_macros.h b/Zend/zend_globals_macros.h index fbb4e71995..5ad45d4675 100644 --- a/Zend/zend_globals_macros.h +++ b/Zend/zend_globals_macros.h @@ -27,22 +27,12 @@ typedef struct _zend_alloc_globals zend_alloc_globals; /* Compiler */ #ifdef ZTS -# define CLS_D zend_compiler_globals *compiler_globals -# define CLS_DC , CLS_D -# define CLS_C compiler_globals -# define CLS_CC , CLS_C -# define CG(v) (((zend_compiler_globals *) compiler_globals)->v) -# define CLS_FETCH() zend_compiler_globals *compiler_globals = (zend_compiler_globals *) ts_resource(compiler_globals_id) +# define CG(v) TSRMG(compiler_globals_id, zend_compiler_globals *, v) BEGIN_EXTERN_C() int zendparse(void *compiler_globals); END_EXTERN_C() #else -# define CLS_D void -# define CLS_DC -# define CLS_C -# define CLS_CC # define CG(v) (compiler_globals.v) -# define CLS_FETCH() extern ZEND_API struct _zend_compiler_globals compiler_globals; int zendparse(void); #endif @@ -59,19 +49,9 @@ extern ZEND_API zend_executor_globals executor_globals; /* Memory Manager */ #ifdef ZTS -# define ALS_D zend_alloc_globals *alloc_globals -# define ALS_DC , ALS_D -# define ALS_C alloc_globals -# define ALS_CC , ALS_C -# define AG(v) (((zend_alloc_globals *) alloc_globals)->v) -# define ALS_FETCH() zend_alloc_globals *alloc_globals = (zend_alloc_globals *) ts_resource(alloc_globals_id) +# define AG(v) TSRMG(alloc_globals_id, zend_alloc_globals *, v) #else -# define ALS_D void -# define ALS_DC -# define ALS_C -# define ALS_CC # define AG(v) (alloc_globals.v) -# define ALS_FETCH() extern ZEND_API zend_alloc_globals alloc_globals; #endif diff --git a/Zend/zend_highlight.c b/Zend/zend_highlight.c index 889374a140..dee5a30e0e 100644 --- a/Zend/zend_highlight.c +++ b/Zend/zend_highlight.c @@ -29,8 +29,8 @@ extern char *zendtext; extern int zendleng; #else -#define zendtext ((char *) zend_get_zendtext(CLS_C)) -#define zendleng zend_get_zendleng(CLS_C) +#define zendtext ((char *) zend_get_zendtext(TSRMLS_C)) +#define zendleng zend_get_zendleng(TSRMLS_C) #endif ZEND_API void zend_html_putc(char c) @@ -88,13 +88,13 @@ ZEND_API void zend_highlight(zend_syntax_highlighter_ini *syntax_highlighter_ini char *last_color = syntax_highlighter_ini->highlight_html; char *next_color; int in_string=0; - CLS_FETCH(); + TSRMLS_FETCH(); zend_printf("<code>"); zend_printf("<font color=\"%s\">\n", last_color); /* highlight stuff coming back from zendlex() */ token.type = 0; - while ((token_type=lex_scan(&token CLS_CC))) { + while ((token_type=lex_scan(&token TSRMLS_CC))) { switch (token_type) { case T_INLINE_HTML: next_color = syntax_highlighter_ini->highlight_html; @@ -170,7 +170,7 @@ ZEND_API void zend_highlight(zend_syntax_highlighter_ini *syntax_highlighter_ini efree(token.value.str.val); if (has_semicolon) { /* the following semicolon was unput(), ignore it */ - lex_scan(&token CLS_CC); + lex_scan(&token TSRMLS_CC); } } token.type = 0; diff --git a/Zend/zend_indent.c b/Zend/zend_indent.c index 32f074db70..ff9d41f0a4 100644 --- a/Zend/zend_indent.c +++ b/Zend/zend_indent.c @@ -30,8 +30,8 @@ extern char *zendtext; extern int zendleng; #else -#define zendtext ((char *) zend_get_zendtext(CLS_C)) -#define zendleng zend_get_zendleng(CLS_C) +#define zendtext ((char *) zend_get_zendtext(TSRMLS_C)) +#define zendleng zend_get_zendleng(TSRMLS_C) #endif @@ -59,13 +59,13 @@ ZEND_API void zend_indent() int nest_level=0; int emit_whitespace[256]; int i; - CLS_FETCH(); + TSRMLS_FETCH(); memset(emit_whitespace, 0, sizeof(int)*256); /* highlight stuff coming back from zendlex() */ token.type = 0; - while ((token_type=lex_scan(&token CLS_CC))) { + while ((token_type=lex_scan(&token TSRMLS_CC))) { switch (token_type) { case T_INLINE_HTML: zend_write(zendtext, zendleng); diff --git a/Zend/zend_ini_parser.y b/Zend/zend_ini_parser.y index 4fc7731293..6b4f431e34 100644 --- a/Zend/zend_ini_parser.y +++ b/Zend/zend_ini_parser.y @@ -123,7 +123,7 @@ static void ini_error(char *str) char *error_buf; int error_buf_len; char *currently_parsed_filename = zend_ini_scanner_get_filename(); - CLS_FETCH(); + TSRMLS_FETCH(); error_buf_len = 128+strlen(currently_parsed_filename); /* should be more than enough */ error_buf = (char *) emalloc(error_buf_len); @@ -147,7 +147,7 @@ int zend_parse_ini_file(zend_file_handle *fh, zend_bool unbuffered_errors, zend_ { zend_ini_parser_param ini_parser_param; int retval; - CLS_FETCH(); + TSRMLS_FETCH(); ini_parser_param.ini_parser_cb = ini_parser_cb; ini_parser_param.arg = arg; diff --git a/Zend/zend_ini_scanner.l b/Zend/zend_ini_scanner.l index d78a146dfe..fd04482367 100644 --- a/Zend/zend_ini_scanner.l +++ b/Zend/zend_ini_scanner.l @@ -72,21 +72,21 @@ char *zend_ini_scanner_get_filename() int zend_ini_scanner_get_lineno() { - CLS_FETCH(); + TSRMLS_FETCH(); return CG(ini_scanner)->lineno(); } char *zend_ini_scanner_get_filename() { - CLS_FETCH(); + TSRMLS_FETCH(); return CG(ini_scanner)->filename; } int ini_lex(zval *ini_lval) { - CLS_FETCH(); + TSRMLS_FETCH(); return CG(ini_scanner)->lex_scan(ini_lval); } @@ -110,7 +110,7 @@ int yyFlexLexer::yylex() int zend_ini_open_file_for_scanning(zend_file_handle *fh) { FILE *fp; - CLS_FETCH(); + TSRMLS_FETCH(); switch (fh->type) { case ZEND_HANDLE_FP: @@ -152,7 +152,7 @@ void zend_ini_close_file(zend_file_handle *fh) break; #ifdef ZTS case ZEND_HANDLE_STDIOSTREAM: { - CLS_FETCH(); + TSRMLS_FETCH(); delete CG(ini_scanner); } break; diff --git a/Zend/zend_language_parser.y b/Zend/zend_language_parser.y index 1dceae6f04..e3fd1fd782 100644 --- a/Zend/zend_language_parser.y +++ b/Zend/zend_language_parser.y @@ -37,8 +37,8 @@ #define YYERROR_VERBOSE #define YYSTYPE znode #ifdef ZTS -# define YYPARSE_PARAM compiler_globals -# define YYLEX_PARAM compiler_globals +# define YYPARSE_PARAM tsrm_ls +# define YYLEX_PARAM tsrm_ls #endif @@ -138,20 +138,20 @@ start: top_statement_list ; -top_statement_list: - top_statement_list { zend_do_extended_info(CLS_C); } top_statement { TSRMLS_FETCH(); HANDLE_INTERACTIVE(); } +top_statement_list: + top_statement_list { zend_do_extended_info(TSRMLS_C); } top_statement { TSRMLS_FETCH(); HANDLE_INTERACTIVE(); } | /* empty */ ; top_statement: statement - | declaration_statement { zend_do_early_binding(CLS_C); } + | declaration_statement { zend_do_early_binding(TSRMLS_C); } ; inner_statement_list: - inner_statement_list { zend_do_extended_info(CLS_C); } inner_statement { TSRMLS_FETCH(); HANDLE_INTERACTIVE(); } + inner_statement_list { zend_do_extended_info(TSRMLS_C); } inner_statement { TSRMLS_FETCH(); HANDLE_INTERACTIVE(); } | /* empty */ ; @@ -163,43 +163,43 @@ inner_statement: statement: - unticked_statement { zend_do_ticks(CLS_C); } + unticked_statement { zend_do_ticks(TSRMLS_C); } ; unticked_statement: '{' inner_statement_list '}' - | T_IF '(' expr ')' { zend_do_if_cond(&$3, &$4 CLS_CC); } statement { zend_do_if_after_statement(&$4, 1 CLS_CC); } elseif_list else_single { zend_do_if_end(CLS_C); } - | T_IF '(' expr ')' ':' { zend_do_if_cond(&$3, &$4 CLS_CC); } inner_statement_list { zend_do_if_after_statement(&$4, 1 CLS_CC); } new_elseif_list new_else_single T_ENDIF ';' { zend_do_if_end(CLS_C); } - | T_WHILE '(' { $1.u.opline_num = get_next_op_number(CG(active_op_array)); } expr ')' { zend_do_while_cond(&$4, &$5 CLS_CC); } while_statement { zend_do_while_end(&$1, &$5 CLS_CC); } - | T_DO { $1.u.opline_num = get_next_op_number(CG(active_op_array)); zend_do_do_while_begin(CLS_C); } statement T_WHILE '(' { $5.u.opline_num = get_next_op_number(CG(active_op_array)); } expr ')' ';' { zend_do_do_while_end(&$1, &$5, &$7 CLS_CC); } + | T_IF '(' expr ')' { zend_do_if_cond(&$3, &$4 TSRMLS_CC); } statement { zend_do_if_after_statement(&$4, 1 TSRMLS_CC); } elseif_list else_single { zend_do_if_end(TSRMLS_C); } + | T_IF '(' expr ')' ':' { zend_do_if_cond(&$3, &$4 TSRMLS_CC); } inner_statement_list { zend_do_if_after_statement(&$4, 1 TSRMLS_CC); } new_elseif_list new_else_single T_ENDIF ';' { zend_do_if_end(TSRMLS_C); } + | T_WHILE '(' { $1.u.opline_num = get_next_op_number(CG(active_op_array)); } expr ')' { zend_do_while_cond(&$4, &$5 TSRMLS_CC); } while_statement { zend_do_while_end(&$1, &$5 TSRMLS_CC); } + | T_DO { $1.u.opline_num = get_next_op_number(CG(active_op_array)); zend_do_do_while_begin(TSRMLS_C); } statement T_WHILE '(' { $5.u.opline_num = get_next_op_number(CG(active_op_array)); } expr ')' ';' { zend_do_do_while_end(&$1, &$5, &$7 TSRMLS_CC); } | T_FOR '(' for_expr - ';' { zend_do_free(&$3 CLS_CC); $4.u.opline_num = get_next_op_number(CG(active_op_array)); } + ';' { zend_do_free(&$3 TSRMLS_CC); $4.u.opline_num = get_next_op_number(CG(active_op_array)); } for_expr - ';' { zend_do_extended_info(CLS_C); zend_do_for_cond(&$6, &$7 CLS_CC); } + ';' { zend_do_extended_info(TSRMLS_C); zend_do_for_cond(&$6, &$7 TSRMLS_CC); } for_expr - ')' { zend_do_free(&$9 CLS_CC); zend_do_for_before_statement(&$4, &$7 CLS_CC); } - for_statement { zend_do_for_end(&$7 CLS_CC); } - | T_SWITCH '(' expr ')' { zend_do_switch_cond(&$3 CLS_CC); } switch_case_list { zend_do_switch_end(&$6 CLS_CC); } - | T_BREAK ';' { zend_do_brk_cont(ZEND_BRK, NULL CLS_CC); } - | T_BREAK expr ';' { zend_do_brk_cont(ZEND_BRK, &$2 CLS_CC); } - | T_CONTINUE ';' { zend_do_brk_cont(ZEND_CONT, NULL CLS_CC); } - | T_CONTINUE expr ';' { zend_do_brk_cont(ZEND_CONT, &$2 CLS_CC); } - | T_RETURN ';' { zend_do_return(NULL, 0 CLS_CC); } - | T_RETURN expr_without_variable ';' { zend_do_return(&$2, 0 CLS_CC); } - | T_RETURN cvar ';' { zend_do_return(&$2, 1 CLS_CC); } + ')' { zend_do_free(&$9 TSRMLS_CC); zend_do_for_before_statement(&$4, &$7 TSRMLS_CC); } + for_statement { zend_do_for_end(&$7 TSRMLS_CC); } + | T_SWITCH '(' expr ')' { zend_do_switch_cond(&$3 TSRMLS_CC); } switch_case_list { zend_do_switch_end(&$6 TSRMLS_CC); } + | T_BREAK ';' { zend_do_brk_cont(ZEND_BRK, NULL TSRMLS_CC); } + | T_BREAK expr ';' { zend_do_brk_cont(ZEND_BRK, &$2 TSRMLS_CC); } + | T_CONTINUE ';' { zend_do_brk_cont(ZEND_CONT, NULL TSRMLS_CC); } + | T_CONTINUE expr ';' { zend_do_brk_cont(ZEND_CONT, &$2 TSRMLS_CC); } + | T_RETURN ';' { zend_do_return(NULL, 0 TSRMLS_CC); } + | T_RETURN expr_without_variable ';' { zend_do_return(&$2, 0 TSRMLS_CC); } + | T_RETURN cvar ';' { zend_do_return(&$2, 1 TSRMLS_CC); } | T_GLOBAL global_var_list ';' | T_STATIC static_var_list ';' | T_ECHO echo_expr_list ';' - | T_INLINE_HTML { zend_do_echo(&$1 CLS_CC); } - | expr ';' { zend_do_free(&$1 CLS_CC); } + | T_INLINE_HTML { zend_do_echo(&$1 TSRMLS_CC); } + | expr ';' { zend_do_free(&$1 TSRMLS_CC); } | T_USE use_filename ';' { zend_error(E_COMPILE_ERROR,"use: Not yet supported. Please use include_once() or require_once()"); zval_dtor(&$2.u.constant); } | T_UNSET '(' unset_variables ')' ';' - | T_FOREACH '(' w_cvar T_AS { zend_do_foreach_begin(&$1, &$3, &$2, &$4, 1 CLS_CC); } w_cvar foreach_optional_arg ')' { zend_do_foreach_cont(&$6, &$7, &$4 CLS_CC); } foreach_statement { zend_do_foreach_end(&$1, &$2 CLS_CC); } - | T_FOREACH '(' expr_without_variable T_AS { zend_do_foreach_begin(&$1, &$3, &$2, &$4, 0 CLS_CC); } w_cvar foreach_optional_arg ')' { zend_do_foreach_cont(&$6, &$7, &$4 CLS_CC); } foreach_statement { zend_do_foreach_end(&$1, &$2 CLS_CC); } - | T_DECLARE { zend_do_declare_begin(CLS_C); } '(' declare_list ')' declare_statement { zend_do_declare_end(CLS_C); } + | T_FOREACH '(' w_cvar T_AS { zend_do_foreach_begin(&$1, &$3, &$2, &$4, 1 TSRMLS_CC); } w_cvar foreach_optional_arg ')' { zend_do_foreach_cont(&$6, &$7, &$4 TSRMLS_CC); } foreach_statement { zend_do_foreach_end(&$1, &$2 TSRMLS_CC); } + | T_FOREACH '(' expr_without_variable T_AS { zend_do_foreach_begin(&$1, &$3, &$2, &$4, 0 TSRMLS_CC); } w_cvar foreach_optional_arg ')' { zend_do_foreach_cont(&$6, &$7, &$4 TSRMLS_CC); } foreach_statement { zend_do_foreach_end(&$1, &$2 TSRMLS_CC); } + | T_DECLARE { zend_do_declare_begin(TSRMLS_C); } '(' declare_list ')' declare_statement { zend_do_declare_end(TSRMLS_C); } | ';' /* empty statement */ ; @@ -209,7 +209,7 @@ unset_variables: ; unset_variable: - cvar { zend_do_end_variable_parse(BP_VAR_UNSET, 0 CLS_CC); zend_do_unset(&$1 CLS_CC); } + cvar { zend_do_end_variable_parse(BP_VAR_UNSET, 0 TSRMLS_CC); zend_do_unset(&$1 TSRMLS_CC); } ; use_filename: @@ -219,17 +219,17 @@ use_filename: declaration_statement: - unticked_declaration_statement { zend_do_ticks(CLS_C); } + unticked_declaration_statement { zend_do_ticks(TSRMLS_C); } ; unticked_declaration_statement: - T_FUNCTION { $1.u.opline_num = CG(zend_lineno); } is_reference T_STRING { zend_do_begin_function_declaration(&$1, &$4, 0, $3.op_type CLS_CC); } - '(' parameter_list ')' '{' inner_statement_list '}' { zend_do_end_function_declaration(&$1 CLS_CC); } - | T_OLD_FUNCTION { $1.u.opline_num = CG(zend_lineno); } is_reference T_STRING { zend_do_begin_function_declaration(&$1, &$4, 0, $3.op_type CLS_CC); } - parameter_list '(' inner_statement_list ')' ';' { zend_do_end_function_declaration(&$1 CLS_CC); } - | T_CLASS T_STRING { zend_do_begin_class_declaration(&$2, NULL CLS_CC); } '{' class_statement_list '}' { zend_do_end_class_declaration(CLS_C); } - | T_CLASS T_STRING T_EXTENDS T_STRING { zend_do_begin_class_declaration(&$2, &$4 CLS_CC); } '{' class_statement_list '}' { zend_do_end_class_declaration(CLS_C); } + T_FUNCTION { $1.u.opline_num = CG(zend_lineno); } is_reference T_STRING { zend_do_begin_function_declaration(&$1, &$4, 0, $3.op_type TSRMLS_CC); } + '(' parameter_list ')' '{' inner_statement_list '}' { zend_do_end_function_declaration(&$1 TSRMLS_CC); } + | T_OLD_FUNCTION { $1.u.opline_num = CG(zend_lineno); } is_reference T_STRING { zend_do_begin_function_declaration(&$1, &$4, 0, $3.op_type TSRMLS_CC); } + parameter_list '(' inner_statement_list ')' ';' { zend_do_end_function_declaration(&$1 TSRMLS_CC); } + | T_CLASS T_STRING { zend_do_begin_class_declaration(&$2, NULL TSRMLS_CC); } '{' class_statement_list '}' { zend_do_end_class_declaration(TSRMLS_C); } + | T_CLASS T_STRING T_EXTENDS T_STRING { zend_do_begin_class_declaration(&$2, &$4 TSRMLS_CC); } '{' class_statement_list '}' { zend_do_end_class_declaration(TSRMLS_C); } ; @@ -258,8 +258,8 @@ declare_statement: declare_list: - T_STRING '=' static_scalar { zend_do_declare_stmt(&$1, &$3 CLS_CC); } - | declare_list ',' T_STRING '=' static_scalar { zend_do_declare_stmt(&$3, &$5 CLS_CC); } + T_STRING '=' static_scalar { zend_do_declare_stmt(&$1, &$3 TSRMLS_CC); } + | declare_list ',' T_STRING '=' static_scalar { zend_do_declare_stmt(&$3, &$5 TSRMLS_CC); } ; @@ -273,8 +273,8 @@ switch_case_list: case_list: /* empty */ { $$.op_type = IS_UNUSED; } - | case_list T_CASE expr case_separator { zend_do_extended_info(CLS_C); zend_do_case_before_statement(&$1, &$2, &$3 CLS_CC); } inner_statement_list { zend_do_case_after_statement(&$$, &$2 CLS_CC); $$.op_type = IS_CONST } - | case_list T_DEFAULT case_separator { zend_do_extended_info(CLS_C); zend_do_default_before_statement(&$1, &$2 CLS_CC); } inner_statement_list { zend_do_case_after_statement(&$$, &$2 CLS_CC); $$.op_type = IS_CONST; } + | case_list T_CASE expr case_separator { zend_do_extended_info(TSRMLS_C); zend_do_case_before_statement(&$1, &$2, &$3 TSRMLS_CC); } inner_statement_list { zend_do_case_after_statement(&$$, &$2 TSRMLS_CC); $$.op_type = IS_CONST } + | case_list T_DEFAULT case_separator { zend_do_extended_info(TSRMLS_C); zend_do_default_before_statement(&$1, &$2 TSRMLS_CC); } inner_statement_list { zend_do_case_after_statement(&$$, &$2 TSRMLS_CC); $$.op_type = IS_CONST; } ; @@ -293,13 +293,13 @@ while_statement: elseif_list: /* empty */ - | elseif_list T_ELSEIF '(' expr ')' { zend_do_if_cond(&$4, &$5 CLS_CC); } statement { zend_do_if_after_statement(&$5, 0 CLS_CC); } + | elseif_list T_ELSEIF '(' expr ')' { zend_do_if_cond(&$4, &$5 TSRMLS_CC); } statement { zend_do_if_after_statement(&$5, 0 TSRMLS_CC); } ; new_elseif_list: /* empty */ - | new_elseif_list T_ELSEIF '(' expr ')' ':' { zend_do_if_cond(&$4, &$5 CLS_CC); } inner_statement_list { zend_do_if_after_statement(&$5, 0 CLS_CC); } + | new_elseif_list T_ELSEIF '(' expr ')' ':' { zend_do_if_cond(&$4, &$5 TSRMLS_CC); } inner_statement_list { zend_do_if_after_statement(&$5, 0 TSRMLS_CC); } ; @@ -322,14 +322,14 @@ parameter_list: non_empty_parameter_list: - T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$1, 0 CLS_CC); $$.op_type = IS_CONST; $$.u.constant.value.lval=1; $$.u.constant.type=IS_LONG; INIT_PZVAL(&$$.u.constant); zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_NONE CLS_CC); } - | '&' T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$2, 0 CLS_CC); $$.op_type = IS_CONST; $$.u.constant.value.lval=1; $$.u.constant.type=IS_LONG; INIT_PZVAL(&$$.u.constant); zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_FORCE CLS_CC); } - | T_CONST T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$2, 0 CLS_CC); $$.op_type = IS_CONST; $$.u.constant.value.lval=1; $$.u.constant.type=IS_LONG; INIT_PZVAL(&$$.u.constant); zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_NONE CLS_CC); } - | T_VARIABLE '=' static_scalar { znode tmp; fetch_simple_variable(&tmp, &$1, 0 CLS_CC); $$.op_type = IS_CONST; $$.u.constant.value.lval=1; $$.u.constant.type=IS_LONG; INIT_PZVAL(&$$.u.constant); zend_do_receive_arg(ZEND_RECV_INIT, &tmp, &$$, &$3, BYREF_NONE CLS_CC); } - | non_empty_parameter_list ',' T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$3, 0 CLS_CC); $$=$1; $$.u.constant.value.lval++; zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_NONE CLS_CC); } - | non_empty_parameter_list ',' '&' T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$4, 0 CLS_CC); $$=$1; $$.u.constant.value.lval++; zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_FORCE CLS_CC); } - | non_empty_parameter_list ',' T_CONST T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$4, 0 CLS_CC); $$=$1; $$.u.constant.value.lval++; zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_NONE CLS_CC); } - | non_empty_parameter_list ',' T_VARIABLE '=' static_scalar { znode tmp; fetch_simple_variable(&tmp, &$3, 0 CLS_CC); $$=$1; $$.u.constant.value.lval++; zend_do_receive_arg(ZEND_RECV_INIT, &tmp, &$$, &$5, BYREF_NONE CLS_CC); } + T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$1, 0 TSRMLS_CC); $$.op_type = IS_CONST; $$.u.constant.value.lval=1; $$.u.constant.type=IS_LONG; INIT_PZVAL(&$$.u.constant); zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_NONE TSRMLS_CC); } + | '&' T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$2, 0 TSRMLS_CC); $$.op_type = IS_CONST; $$.u.constant.value.lval=1; $$.u.constant.type=IS_LONG; INIT_PZVAL(&$$.u.constant); zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_FORCE TSRMLS_CC); } + | T_CONST T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$2, 0 TSRMLS_CC); $$.op_type = IS_CONST; $$.u.constant.value.lval=1; $$.u.constant.type=IS_LONG; INIT_PZVAL(&$$.u.constant); zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_NONE TSRMLS_CC); } + | T_VARIABLE '=' static_scalar { znode tmp; fetch_simple_variable(&tmp, &$1, 0 TSRMLS_CC); $$.op_type = IS_CONST; $$.u.constant.value.lval=1; $$.u.constant.type=IS_LONG; INIT_PZVAL(&$$.u.constant); zend_do_receive_arg(ZEND_RECV_INIT, &tmp, &$$, &$3, BYREF_NONE TSRMLS_CC); } + | non_empty_parameter_list ',' T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$3, 0 TSRMLS_CC); $$=$1; $$.u.constant.value.lval++; zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_NONE TSRMLS_CC); } + | non_empty_parameter_list ',' '&' T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$4, 0 TSRMLS_CC); $$=$1; $$.u.constant.value.lval++; zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_FORCE TSRMLS_CC); } + | non_empty_parameter_list ',' T_CONST T_VARIABLE { znode tmp; fetch_simple_variable(&tmp, &$4, 0 TSRMLS_CC); $$=$1; $$.u.constant.value.lval++; zend_do_receive_arg(ZEND_RECV, &tmp, &$$, NULL, BYREF_NONE TSRMLS_CC); } + | non_empty_parameter_list ',' T_VARIABLE '=' static_scalar { znode tmp; fetch_simple_variable(&tmp, &$3, 0 TSRMLS_CC); $$=$1; $$.u.constant.value.lval++; zend_do_receive_arg(ZEND_RECV_INIT, &tmp, &$$, &$5, BYREF_NONE TSRMLS_CC); } ; @@ -340,17 +340,17 @@ function_call_parameter_list: non_empty_function_call_parameter_list: - expr_without_variable { $$.u.constant.value.lval = 1; zend_do_pass_param(&$1, ZEND_SEND_VAL, $$.u.constant.value.lval CLS_CC); } - | cvar { $$.u.constant.value.lval = 1; zend_do_pass_param(&$1, ZEND_SEND_VAR, $$.u.constant.value.lval CLS_CC); } - | '&' w_cvar { $$.u.constant.value.lval = 1; zend_do_pass_param(&$2, ZEND_SEND_REF, $$.u.constant.value.lval CLS_CC); } - | non_empty_function_call_parameter_list ',' expr_without_variable { $$.u.constant.value.lval=$1.u.constant.value.lval+1; zend_do_pass_param(&$3, ZEND_SEND_VAL, $$.u.constant.value.lval CLS_CC); } - | non_empty_function_call_parameter_list ',' cvar { $$.u.constant.value.lval=$1.u.constant.value.lval+1; zend_do_pass_param(&$3, ZEND_SEND_VAR, $$.u.constant.value.lval CLS_CC); } - | non_empty_function_call_parameter_list ',' '&' w_cvar { $$.u.constant.value.lval=$1.u.constant.value.lval+1; zend_do_pass_param(&$4, ZEND_SEND_REF, $$.u.constant.value.lval CLS_CC); } + expr_without_variable { $$.u.constant.value.lval = 1; zend_do_pass_param(&$1, ZEND_SEND_VAL, $$.u.constant.value.lval TSRMLS_CC); } + | cvar { $$.u.constant.value.lval = 1; zend_do_pass_param(&$1, ZEND_SEND_VAR, $$.u.constant.value.lval TSRMLS_CC); } + | '&' w_cvar { $$.u.constant.value.lval = 1; zend_do_pass_param(&$2, ZEND_SEND_REF, $$.u.constant.value.lval TSRMLS_CC); } + | non_empty_function_call_parameter_list ',' expr_without_variable { $$.u.constant.value.lval=$1.u.constant.value.lval+1; zend_do_pass_param(&$3, ZEND_SEND_VAL, $$.u.constant.value.lval TSRMLS_CC); } + | non_empty_function_call_parameter_list ',' cvar { $$.u.constant.value.lval=$1.u.constant.value.lval+1; zend_do_pass_param(&$3, ZEND_SEND_VAR, $$.u.constant.value.lval TSRMLS_CC); } + | non_empty_function_call_parameter_list ',' '&' w_cvar { $$.u.constant.value.lval=$1.u.constant.value.lval+1; zend_do_pass_param(&$4, ZEND_SEND_REF, $$.u.constant.value.lval TSRMLS_CC); } ; global_var_list: - global_var_list ',' global_var { zend_do_fetch_global_or_static_variable(&$3, NULL, ZEND_FETCH_GLOBAL CLS_CC); } - | global_var { zend_do_fetch_global_or_static_variable(&$1, NULL, ZEND_FETCH_GLOBAL CLS_CC); } + global_var_list ',' global_var { zend_do_fetch_global_or_static_variable(&$3, NULL, ZEND_FETCH_GLOBAL TSRMLS_CC); } + | global_var { zend_do_fetch_global_or_static_variable(&$1, NULL, ZEND_FETCH_GLOBAL TSRMLS_CC); } ; @@ -362,10 +362,10 @@ global_var: static_var_list: - static_var_list ',' T_VARIABLE { zend_do_fetch_global_or_static_variable(&$3, NULL, ZEND_FETCH_STATIC CLS_CC); } - | static_var_list ',' T_VARIABLE '=' static_scalar { zend_do_fetch_global_or_static_variable(&$3, &$5, ZEND_FETCH_STATIC CLS_CC); } - | T_VARIABLE { zend_do_fetch_global_or_static_variable(&$1, NULL, ZEND_FETCH_STATIC CLS_CC); } - | T_VARIABLE '=' static_scalar { zend_do_fetch_global_or_static_variable(&$1, &$3, ZEND_FETCH_STATIC CLS_CC); } + static_var_list ',' T_VARIABLE { zend_do_fetch_global_or_static_variable(&$3, NULL, ZEND_FETCH_STATIC TSRMLS_CC); } + | static_var_list ',' T_VARIABLE '=' static_scalar { zend_do_fetch_global_or_static_variable(&$3, &$5, ZEND_FETCH_STATIC TSRMLS_CC); } + | T_VARIABLE { zend_do_fetch_global_or_static_variable(&$1, NULL, ZEND_FETCH_STATIC TSRMLS_CC); } + | T_VARIABLE '=' static_scalar { zend_do_fetch_global_or_static_variable(&$1, &$3, ZEND_FETCH_STATIC TSRMLS_CC); } ; @@ -378,10 +378,10 @@ class_statement_list: class_statement: T_VAR class_variable_decleration ';' - | T_FUNCTION { $1.u.opline_num = CG(zend_lineno); } is_reference T_STRING { zend_do_begin_function_declaration(&$1, &$4, 1, $3.op_type CLS_CC); } '(' - parameter_list ')' '{' inner_statement_list '}' { zend_do_end_function_declaration(&$1 CLS_CC); } - | T_OLD_FUNCTION { $1.u.opline_num = CG(zend_lineno); } is_reference T_STRING { zend_do_begin_function_declaration(&$1, &$4, 1, $3.op_type CLS_CC); } - parameter_list '(' inner_statement_list ')' ';' { zend_do_end_function_declaration(&$1 CLS_CC); } + | T_FUNCTION { $1.u.opline_num = CG(zend_lineno); } is_reference T_STRING { zend_do_begin_function_declaration(&$1, &$4, 1, $3.op_type TSRMLS_CC); } '(' + parameter_list ')' '{' inner_statement_list '}' { zend_do_end_function_declaration(&$1 TSRMLS_CC); } + | T_OLD_FUNCTION { $1.u.opline_num = CG(zend_lineno); } is_reference T_STRING { zend_do_begin_function_declaration(&$1, &$4, 1, $3.op_type TSRMLS_CC); } + parameter_list '(' inner_statement_list ')' ';' { zend_do_end_function_declaration(&$1 TSRMLS_CC); } ; @@ -390,16 +390,16 @@ is_reference: | '&' { $$.op_type = ZEND_RETURN_REF; } class_variable_decleration: - class_variable_decleration ',' T_VARIABLE { zend_do_declare_property(&$3, NULL CLS_CC); } - | class_variable_decleration ',' T_VARIABLE '=' static_scalar { zend_do_declare_property(&$3, &$5 CLS_CC); } - | T_VARIABLE { zend_do_declare_property(&$1, NULL CLS_CC); } - | T_VARIABLE '=' static_scalar { zend_do_declare_property(&$1, &$3 CLS_CC); } + class_variable_decleration ',' T_VARIABLE { zend_do_declare_property(&$3, NULL TSRMLS_CC); } + | class_variable_decleration ',' T_VARIABLE '=' static_scalar { zend_do_declare_property(&$3, &$5 TSRMLS_CC); } + | T_VARIABLE { zend_do_declare_property(&$1, NULL TSRMLS_CC); } + | T_VARIABLE '=' static_scalar { zend_do_declare_property(&$1, &$3 TSRMLS_CC); } ; echo_expr_list: - | echo_expr_list ',' expr { zend_do_echo(&$3 CLS_CC); } - | expr { zend_do_echo(&$1 CLS_CC); } + | echo_expr_list ',' expr { zend_do_echo(&$3 TSRMLS_CC); } + | expr { zend_do_echo(&$1 TSRMLS_CC); } ; @@ -409,92 +409,92 @@ for_expr: ; non_empty_for_expr: - non_empty_for_expr ',' { zend_do_free(&$1 CLS_CC); } expr { $$ = $4; } + non_empty_for_expr ',' { zend_do_free(&$1 TSRMLS_CC); } expr { $$ = $4; } | expr { $$ = $1; } ; expr_without_variable: - T_LIST '(' { zend_do_list_init(CLS_C); } assignment_list ')' '=' expr { zend_do_list_end(&$$, &$7 CLS_CC); } - | cvar '=' expr { zend_do_end_variable_parse(BP_VAR_W, 0 CLS_CC); zend_do_assign(&$$, &$1, &$3 CLS_CC); } - | cvar '=' '&' w_cvar { zend_do_end_variable_parse(BP_VAR_W, 0 CLS_CC); zend_do_assign_ref(&$$, &$1, &$4 CLS_CC); } - | cvar '=' '&' function_call { zend_do_end_variable_parse(BP_VAR_W, 0 CLS_CC); zend_do_assign_ref(&$$, &$1, &$4 CLS_CC); } - | cvar '=' '&' T_NEW static_or_variable_string { zend_do_extended_fcall_begin(CLS_C); zend_do_begin_new_object(&$4, &$5 CLS_CC); } ctor_arguments { zend_do_end_new_object(&$3, &$5, &$4, &$7 CLS_CC); zend_do_extended_fcall_end(CLS_C); zend_do_end_variable_parse(BP_VAR_W, 0 CLS_CC); zend_do_assign_ref(&$$, &$1, &$3 CLS_CC); } - | T_NEW static_or_variable_string { zend_do_extended_fcall_begin(CLS_C); zend_do_begin_new_object(&$1, &$2 CLS_CC); } ctor_arguments { zend_do_end_new_object(&$$, &$2, &$1, &$4 CLS_CC); zend_do_extended_fcall_end(CLS_C);} - | cvar T_PLUS_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_ADD, &$$, &$1, &$3 CLS_CC); } - | cvar T_MINUS_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_SUB, &$$, &$1, &$3 CLS_CC); } - | cvar T_MUL_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_MUL, &$$, &$1, &$3 CLS_CC); } - | cvar T_DIV_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_DIV, &$$, &$1, &$3 CLS_CC); } - | cvar T_CONCAT_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_CONCAT, &$$, &$1, &$3 CLS_CC); } - | cvar T_MOD_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_MOD, &$$, &$1, &$3 CLS_CC); } - | cvar T_AND_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_BW_AND, &$$, &$1, &$3 CLS_CC); } - | cvar T_OR_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_BW_OR, &$$, &$1, &$3 CLS_CC); } - | cvar T_XOR_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_BW_XOR, &$$, &$1, &$3 CLS_CC); } - | cvar T_SL_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_SL, &$$, &$1, &$3 CLS_CC); } - | cvar T_SR_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_SR, &$$, &$1, &$3 CLS_CC); } - | rw_cvar T_INC { zend_do_post_incdec(&$$, &$1, ZEND_POST_INC CLS_CC); } - | T_INC rw_cvar { zend_do_pre_incdec(&$$, &$2, ZEND_PRE_INC CLS_CC); } - | rw_cvar T_DEC { zend_do_post_incdec(&$$, &$1, ZEND_POST_DEC CLS_CC); } - | T_DEC rw_cvar { zend_do_pre_incdec(&$$, &$2, ZEND_PRE_DEC CLS_CC); } - | expr T_BOOLEAN_OR { zend_do_boolean_or_begin(&$1, &$2 CLS_CC); } expr { zend_do_boolean_or_end(&$$, &$1, &$4, &$2 CLS_CC); } - | expr T_BOOLEAN_AND { zend_do_boolean_and_begin(&$1, &$2 CLS_CC); } expr { zend_do_boolean_and_end(&$$, &$1, &$4, &$2 CLS_CC); } - | expr T_LOGICAL_OR { zend_do_boolean_or_begin(&$1, &$2 CLS_CC); } expr { zend_do_boolean_or_end(&$$, &$1, &$4, &$2 CLS_CC); } - | expr T_LOGICAL_AND { zend_do_boolean_and_begin(&$1, &$2 CLS_CC); } expr { zend_do_boolean_and_end(&$$, &$1, &$4, &$2 CLS_CC); } - | expr T_LOGICAL_XOR expr { zend_do_binary_op(ZEND_BOOL_XOR, &$$, &$1, &$3 CLS_CC); } - | expr '|' expr { zend_do_binary_op(ZEND_BW_OR, &$$, &$1, &$3 CLS_CC); } - | expr '&' expr { zend_do_binary_op(ZEND_BW_AND, &$$, &$1, &$3 CLS_CC); } - | expr '^' expr { zend_do_binary_op(ZEND_BW_XOR, &$$, &$1, &$3 CLS_CC); } - | expr '.' expr { zend_do_binary_op(ZEND_CONCAT,&$$,&$1,&$3 CLS_CC); } - | expr '+' expr { zend_do_binary_op(ZEND_ADD,&$$,&$1,&$3 CLS_CC); } - | expr '-' expr { zend_do_binary_op(ZEND_SUB,&$$,&$1,&$3 CLS_CC); } - | expr '*' expr { zend_do_binary_op(ZEND_MUL,&$$,&$1,&$3 CLS_CC); } - | expr '/' expr { zend_do_binary_op(ZEND_DIV,&$$,&$1,&$3 CLS_CC); } - | expr '%' expr { zend_do_binary_op(ZEND_MOD,&$$,&$1,&$3 CLS_CC); } - | expr T_SL expr { zend_do_binary_op(ZEND_SL, &$$, &$1, &$3 CLS_CC); } - | expr T_SR expr { zend_do_binary_op(ZEND_SR, &$$, &$1, &$3 CLS_CC); } - | '+' expr { $1.u.constant.value.lval=0; $1.u.constant.type=IS_LONG; $1.op_type = IS_CONST; INIT_PZVAL(&$1.u.constant); zend_do_binary_op(ZEND_ADD, &$$, &$1, &$2 CLS_CC); } - | '-' expr { $1.u.constant.value.lval=0; $1.u.constant.type=IS_LONG; $1.op_type = IS_CONST; INIT_PZVAL(&$1.u.constant); zend_do_binary_op(ZEND_SUB, &$$, &$1, &$2 CLS_CC); } - | '!' expr { zend_do_unary_op(ZEND_BOOL_NOT, &$$, &$2 CLS_CC); } - | '~' expr { zend_do_unary_op(ZEND_BW_NOT, &$$, &$2 CLS_CC); } - | expr T_IS_IDENTICAL expr { zend_do_binary_op(ZEND_IS_IDENTICAL, &$$, &$1, &$3 CLS_CC); } - | expr T_IS_NOT_IDENTICAL expr { zend_do_binary_op(ZEND_IS_NOT_IDENTICAL, &$$, &$1, &$3 CLS_CC); } - | expr T_IS_EQUAL expr { zend_do_binary_op(ZEND_IS_EQUAL, &$$, &$1, &$3 CLS_CC); } - | expr T_IS_NOT_EQUAL expr { zend_do_binary_op(ZEND_IS_NOT_EQUAL, &$$, &$1, &$3 CLS_CC); } - | expr '<' expr { zend_do_binary_op(ZEND_IS_SMALLER, &$$, &$1, &$3 CLS_CC); } - | expr T_IS_SMALLER_OR_EQUAL expr { zend_do_binary_op(ZEND_IS_SMALLER_OR_EQUAL, &$$, &$1, &$3 CLS_CC); } - | expr '>' expr { zend_do_binary_op(ZEND_IS_SMALLER, &$$, &$3, &$1 CLS_CC); } - | expr T_IS_GREATER_OR_EQUAL expr { zend_do_binary_op(ZEND_IS_SMALLER_OR_EQUAL, &$$, &$3, &$1 CLS_CC); } + T_LIST '(' { zend_do_list_init(TSRMLS_C); } assignment_list ')' '=' expr { zend_do_list_end(&$$, &$7 TSRMLS_CC); } + | cvar '=' expr { zend_do_end_variable_parse(BP_VAR_W, 0 TSRMLS_CC); zend_do_assign(&$$, &$1, &$3 TSRMLS_CC); } + | cvar '=' '&' w_cvar { zend_do_end_variable_parse(BP_VAR_W, 0 TSRMLS_CC); zend_do_assign_ref(&$$, &$1, &$4 TSRMLS_CC); } + | cvar '=' '&' function_call { zend_do_end_variable_parse(BP_VAR_W, 0 TSRMLS_CC); zend_do_assign_ref(&$$, &$1, &$4 TSRMLS_CC); } + | cvar '=' '&' T_NEW static_or_variable_string { zend_do_extended_fcall_begin(TSRMLS_C); zend_do_begin_new_object(&$4, &$5 TSRMLS_CC); } ctor_arguments { zend_do_end_new_object(&$3, &$5, &$4, &$7 TSRMLS_CC); zend_do_extended_fcall_end(TSRMLS_C); zend_do_end_variable_parse(BP_VAR_W, 0 TSRMLS_CC); zend_do_assign_ref(&$$, &$1, &$3 TSRMLS_CC); } + | T_NEW static_or_variable_string { zend_do_extended_fcall_begin(TSRMLS_C); zend_do_begin_new_object(&$1, &$2 TSRMLS_CC); } ctor_arguments { zend_do_end_new_object(&$$, &$2, &$1, &$4 TSRMLS_CC); zend_do_extended_fcall_end(TSRMLS_C);} + | cvar T_PLUS_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_ADD, &$$, &$1, &$3 TSRMLS_CC); } + | cvar T_MINUS_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_SUB, &$$, &$1, &$3 TSRMLS_CC); } + | cvar T_MUL_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_MUL, &$$, &$1, &$3 TSRMLS_CC); } + | cvar T_DIV_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_DIV, &$$, &$1, &$3 TSRMLS_CC); } + | cvar T_CONCAT_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_CONCAT, &$$, &$1, &$3 TSRMLS_CC); } + | cvar T_MOD_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_MOD, &$$, &$1, &$3 TSRMLS_CC); } + | cvar T_AND_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_BW_AND, &$$, &$1, &$3 TSRMLS_CC); } + | cvar T_OR_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_BW_OR, &$$, &$1, &$3 TSRMLS_CC); } + | cvar T_XOR_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_BW_XOR, &$$, &$1, &$3 TSRMLS_CC); } + | cvar T_SL_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_SL, &$$, &$1, &$3 TSRMLS_CC); } + | cvar T_SR_EQUAL expr { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); zend_do_binary_assign_op(ZEND_ASSIGN_SR, &$$, &$1, &$3 TSRMLS_CC); } + | rw_cvar T_INC { zend_do_post_incdec(&$$, &$1, ZEND_POST_INC TSRMLS_CC); } + | T_INC rw_cvar { zend_do_pre_incdec(&$$, &$2, ZEND_PRE_INC TSRMLS_CC); } + | rw_cvar T_DEC { zend_do_post_incdec(&$$, &$1, ZEND_POST_DEC TSRMLS_CC); } + | T_DEC rw_cvar { zend_do_pre_incdec(&$$, &$2, ZEND_PRE_DEC TSRMLS_CC); } + | expr T_BOOLEAN_OR { zend_do_boolean_or_begin(&$1, &$2 TSRMLS_CC); } expr { zend_do_boolean_or_end(&$$, &$1, &$4, &$2 TSRMLS_CC); } + | expr T_BOOLEAN_AND { zend_do_boolean_and_begin(&$1, &$2 TSRMLS_CC); } expr { zend_do_boolean_and_end(&$$, &$1, &$4, &$2 TSRMLS_CC); } + | expr T_LOGICAL_OR { zend_do_boolean_or_begin(&$1, &$2 TSRMLS_CC); } expr { zend_do_boolean_or_end(&$$, &$1, &$4, &$2 TSRMLS_CC); } + | expr T_LOGICAL_AND { zend_do_boolean_and_begin(&$1, &$2 TSRMLS_CC); } expr { zend_do_boolean_and_end(&$$, &$1, &$4, &$2 TSRMLS_CC); } + | expr T_LOGICAL_XOR expr { zend_do_binary_op(ZEND_BOOL_XOR, &$$, &$1, &$3 TSRMLS_CC); } + | expr '|' expr { zend_do_binary_op(ZEND_BW_OR, &$$, &$1, &$3 TSRMLS_CC); } + | expr '&' expr { zend_do_binary_op(ZEND_BW_AND, &$$, &$1, &$3 TSRMLS_CC); } + | expr '^' expr { zend_do_binary_op(ZEND_BW_XOR, &$$, &$1, &$3 TSRMLS_CC); } + | expr '.' expr { zend_do_binary_op(ZEND_CONCAT,&$$,&$1,&$3 TSRMLS_CC); } + | expr '+' expr { zend_do_binary_op(ZEND_ADD,&$$,&$1,&$3 TSRMLS_CC); } + | expr '-' expr { zend_do_binary_op(ZEND_SUB,&$$,&$1,&$3 TSRMLS_CC); } + | expr '*' expr { zend_do_binary_op(ZEND_MUL,&$$,&$1,&$3 TSRMLS_CC); } + | expr '/' expr { zend_do_binary_op(ZEND_DIV,&$$,&$1,&$3 TSRMLS_CC); } + | expr '%' expr { zend_do_binary_op(ZEND_MOD,&$$,&$1,&$3 TSRMLS_CC); } + | expr T_SL expr { zend_do_binary_op(ZEND_SL, &$$, &$1, &$3 TSRMLS_CC); } + | expr T_SR expr { zend_do_binary_op(ZEND_SR, &$$, &$1, &$3 TSRMLS_CC); } + | '+' expr { $1.u.constant.value.lval=0; $1.u.constant.type=IS_LONG; $1.op_type = IS_CONST; INIT_PZVAL(&$1.u.constant); zend_do_binary_op(ZEND_ADD, &$$, &$1, &$2 TSRMLS_CC); } + | '-' expr { $1.u.constant.value.lval=0; $1.u.constant.type=IS_LONG; $1.op_type = IS_CONST; INIT_PZVAL(&$1.u.constant); zend_do_binary_op(ZEND_SUB, &$$, &$1, &$2 TSRMLS_CC); } + | '!' expr { zend_do_unary_op(ZEND_BOOL_NOT, &$$, &$2 TSRMLS_CC); } + | '~' expr { zend_do_unary_op(ZEND_BW_NOT, &$$, &$2 TSRMLS_CC); } + | expr T_IS_IDENTICAL expr { zend_do_binary_op(ZEND_IS_IDENTICAL, &$$, &$1, &$3 TSRMLS_CC); } + | expr T_IS_NOT_IDENTICAL expr { zend_do_binary_op(ZEND_IS_NOT_IDENTICAL, &$$, &$1, &$3 TSRMLS_CC); } + | expr T_IS_EQUAL expr { zend_do_binary_op(ZEND_IS_EQUAL, &$$, &$1, &$3 TSRMLS_CC); } + | expr T_IS_NOT_EQUAL expr { zend_do_binary_op(ZEND_IS_NOT_EQUAL, &$$, &$1, &$3 TSRMLS_CC); } + | expr '<' expr { zend_do_binary_op(ZEND_IS_SMALLER, &$$, &$1, &$3 TSRMLS_CC); } + | expr T_IS_SMALLER_OR_EQUAL expr { zend_do_binary_op(ZEND_IS_SMALLER_OR_EQUAL, &$$, &$1, &$3 TSRMLS_CC); } + | expr '>' expr { zend_do_binary_op(ZEND_IS_SMALLER, &$$, &$3, &$1 TSRMLS_CC); } + | expr T_IS_GREATER_OR_EQUAL expr { zend_do_binary_op(ZEND_IS_SMALLER_OR_EQUAL, &$$, &$3, &$1 TSRMLS_CC); } | '(' expr ')' { $$ = $2; } - | expr '?' { zend_do_begin_qm_op(&$1, &$2 CLS_CC); } - expr ':' { zend_do_qm_true(&$4, &$2, &$5 CLS_CC); } - expr { zend_do_qm_false(&$$, &$7, &$2, &$5 CLS_CC); } + | expr '?' { zend_do_begin_qm_op(&$1, &$2 TSRMLS_CC); } + expr ':' { zend_do_qm_true(&$4, &$2, &$5 TSRMLS_CC); } + expr { zend_do_qm_false(&$$, &$7, &$2, &$5 TSRMLS_CC); } | function_call { $$ = $1; } | internal_functions_in_yacc { $$ = $1; } - | T_INT_CAST expr { zend_do_cast(&$$, &$2, IS_LONG CLS_CC); } - | T_DOUBLE_CAST expr { zend_do_cast(&$$, &$2, IS_DOUBLE CLS_CC); } - | T_STRING_CAST expr { zend_do_cast(&$$, &$2, IS_STRING CLS_CC); } - | T_ARRAY_CAST expr { zend_do_cast(&$$, &$2, IS_ARRAY CLS_CC); } - | T_OBJECT_CAST expr { zend_do_cast(&$$, &$2, IS_OBJECT CLS_CC); } - | T_BOOL_CAST expr { zend_do_cast(&$$, &$2, IS_BOOL CLS_CC); } - | T_UNSET_CAST expr { zend_do_cast(&$$, &$2, IS_NULL CLS_CC); } - | T_EXIT exit_expr { zend_do_exit(&$$, &$2 CLS_CC); } - | '@' { zend_do_begin_silence(&$1 CLS_CC); } expr { zend_do_end_silence(&$1 CLS_CC); $$ = $3; } + | T_INT_CAST expr { zend_do_cast(&$$, &$2, IS_LONG TSRMLS_CC); } + | T_DOUBLE_CAST expr { zend_do_cast(&$$, &$2, IS_DOUBLE TSRMLS_CC); } + | T_STRING_CAST expr { zend_do_cast(&$$, &$2, IS_STRING TSRMLS_CC); } + | T_ARRAY_CAST expr { zend_do_cast(&$$, &$2, IS_ARRAY TSRMLS_CC); } + | T_OBJECT_CAST expr { zend_do_cast(&$$, &$2, IS_OBJECT TSRMLS_CC); } + | T_BOOL_CAST expr { zend_do_cast(&$$, &$2, IS_BOOL TSRMLS_CC); } + | T_UNSET_CAST expr { zend_do_cast(&$$, &$2, IS_NULL TSRMLS_CC); } + | T_EXIT exit_expr { zend_do_exit(&$$, &$2 TSRMLS_CC); } + | '@' { zend_do_begin_silence(&$1 TSRMLS_CC); } expr { zend_do_end_silence(&$1 TSRMLS_CC); $$ = $3; } | scalar { $$ = $1; } | T_ARRAY '(' array_pair_list ')' { $$ = $3; } - | '`' encaps_list '`' { zend_do_shell_exec(&$$, &$2 CLS_CC); } - | T_PRINT expr { zend_do_print(&$$, &$2 CLS_CC); } + | '`' encaps_list '`' { zend_do_shell_exec(&$$, &$2 TSRMLS_CC); } + | T_PRINT expr { zend_do_print(&$$, &$2 TSRMLS_CC); } ; function_call: - T_STRING '(' { $2.u.opline_num = zend_do_begin_function_call(&$1 CLS_CC); } + T_STRING '(' { $2.u.opline_num = zend_do_begin_function_call(&$1 TSRMLS_CC); } function_call_parameter_list - ')' { zend_do_end_function_call(&$1, &$$, &$4, 0, $2.u.opline_num CLS_CC); zend_do_extended_fcall_end(CLS_C); } - | cvar '(' { zend_do_begin_dynamic_function_call(&$1 CLS_CC); } + ')' { zend_do_end_function_call(&$1, &$$, &$4, 0, $2.u.opline_num TSRMLS_CC); zend_do_extended_fcall_end(TSRMLS_C); } + | cvar '(' { zend_do_begin_dynamic_function_call(&$1 TSRMLS_CC); } function_call_parameter_list - ')' { zend_do_end_function_call(&$1, &$$, &$4, 0, 1 CLS_CC); zend_do_extended_fcall_end(CLS_C);} - | T_STRING T_PAAMAYIM_NEKUDOTAYIM static_or_variable_string '(' { zend_do_extended_fcall_begin(CLS_C); zend_do_begin_class_member_function_call(&$1, &$3 CLS_CC); } + ')' { zend_do_end_function_call(&$1, &$$, &$4, 0, 1 TSRMLS_CC); zend_do_extended_fcall_end(TSRMLS_C);} + | T_STRING T_PAAMAYIM_NEKUDOTAYIM static_or_variable_string '(' { zend_do_extended_fcall_begin(TSRMLS_C); zend_do_begin_class_member_function_call(&$1, &$3 TSRMLS_CC); } function_call_parameter_list - ')' { zend_do_end_function_call(&$3, &$$, &$6, 1, 1 CLS_CC); zend_do_extended_fcall_end(CLS_C);} + ')' { zend_do_end_function_call(&$3, &$$, &$6, 1, 1 TSRMLS_CC); zend_do_extended_fcall_end(TSRMLS_C);} ; @@ -528,7 +528,7 @@ common_scalar: static_scalar: /* compile-time evaluated scalars */ common_scalar { $$ = $1; } - | T_STRING { zend_do_fetch_constant(&$$, &$1, ZEND_CT CLS_CC); } + | T_STRING { zend_do_fetch_constant(&$$, &$1, ZEND_CT TSRMLS_CC); } | '+' static_scalar { $$ = $1; } | '-' static_scalar { zval minus_one; minus_one.type = IS_LONG; minus_one.value.lval = -1; mul_function(&$2.u.constant, &$2.u.constant, &minus_one); $$ = $2; } | T_ARRAY '(' static_array_pair_list ')' { $$ = $3; $$.u.constant.type = IS_CONSTANT_ARRAY; } @@ -536,12 +536,12 @@ static_scalar: /* compile-time evaluated scalars */ scalar: - T_STRING { zend_do_fetch_constant(&$$, &$1, ZEND_RT CLS_CC); } + T_STRING { zend_do_fetch_constant(&$$, &$1, ZEND_RT TSRMLS_CC); } | T_STRING_VARNAME { $$ = $1; } | common_scalar { $$ = $1; } | '"' encaps_list '"' { $$ = $2; } | '\'' encaps_list '\'' { $$ = $2; } - | T_START_HEREDOC encaps_list T_END_HEREDOC { $$ = $2; zend_do_end_heredoc(CLS_C); } + | T_START_HEREDOC encaps_list T_END_HEREDOC { $$ = $2; zend_do_end_heredoc(TSRMLS_C); } ; @@ -569,36 +569,36 @@ expr: r_cvar: - cvar { zend_do_end_variable_parse(BP_VAR_R, 0 CLS_CC); $$ = $1; } + cvar { zend_do_end_variable_parse(BP_VAR_R, 0 TSRMLS_CC); $$ = $1; } ; w_cvar: - cvar { zend_do_end_variable_parse(BP_VAR_W, 0 CLS_CC); $$ = $1; } + cvar { zend_do_end_variable_parse(BP_VAR_W, 0 TSRMLS_CC); $$ = $1; } ; rw_cvar: - cvar { zend_do_end_variable_parse(BP_VAR_RW, 0 CLS_CC); $$ = $1; } + cvar { zend_do_end_variable_parse(BP_VAR_RW, 0 TSRMLS_CC); $$ = $1; } ; cvar: cvar_without_objects { $$ = $1; } - | cvar_without_objects T_OBJECT_OPERATOR { zend_do_push_object(&$1 CLS_CC); } ref_list { $$ = $4; } + | cvar_without_objects T_OBJECT_OPERATOR { zend_do_push_object(&$1 TSRMLS_CC); } ref_list { $$ = $4; } ; cvar_without_objects: reference_variable { $$ = $1; } - | simple_indirect_reference reference_variable { zend_do_indirect_references(&$$, &$1, &$2 CLS_CC); } + | simple_indirect_reference reference_variable { zend_do_indirect_references(&$$, &$1, &$2 TSRMLS_CC); } ; reference_variable: - reference_variable '[' dim_offset ']' { fetch_array_dim(&$$, &$1, &$3 CLS_CC); } - | reference_variable '{' expr '}' { fetch_string_offset(&$$, &$1, &$3 CLS_CC); } - | compound_variable { zend_do_fetch_globals(&$1 CLS_CC); zend_do_begin_variable_parse(CLS_C); fetch_simple_variable(&$$, &$1, 1 CLS_CC); } + reference_variable '[' dim_offset ']' { fetch_array_dim(&$$, &$1, &$3 TSRMLS_CC); } + | reference_variable '{' expr '}' { fetch_string_offset(&$$, &$1, &$3 TSRMLS_CC); } + | compound_variable { zend_do_fetch_globals(&$1 TSRMLS_CC); zend_do_begin_variable_parse(TSRMLS_C); fetch_simple_variable(&$$, &$1, 1 TSRMLS_CC); } ; @@ -614,18 +614,18 @@ dim_offset: ref_list: object_property { $$ = $1; } - | ref_list T_OBJECT_OPERATOR { zend_do_push_object(&$1 CLS_CC); } object_property { $$ = $4; } + | ref_list T_OBJECT_OPERATOR { zend_do_push_object(&$1 TSRMLS_CC); } object_property { $$ = $4; } ; object_property: object_dim_list { $$ = $1; } - | cvar_without_objects { zend_do_end_variable_parse(BP_VAR_R, 0 CLS_CC); } { znode tmp_znode; zend_do_pop_object(&tmp_znode CLS_CC); zend_do_fetch_property(&$$, &tmp_znode, &$1 CLS_CC);} + | cvar_without_objects { zend_do_end_variable_parse(BP_VAR_R, 0 TSRMLS_CC); } { znode tmp_znode; zend_do_pop_object(&tmp_znode TSRMLS_CC); zend_do_fetch_property(&$$, &tmp_znode, &$1 TSRMLS_CC);} ; object_dim_list: - object_dim_list '[' dim_offset ']' { fetch_array_dim(&$$, &$1, &$3 CLS_CC); } - | object_dim_list '{' expr '}' { fetch_string_offset(&$$, &$1, &$3 CLS_CC); } - | variable_name { znode tmp_znode; zend_do_pop_object(&tmp_znode CLS_CC); zend_do_fetch_property(&$$, &tmp_znode, &$1 CLS_CC);} + object_dim_list '[' dim_offset ']' { fetch_array_dim(&$$, &$1, &$3 TSRMLS_CC); } + | object_dim_list '{' expr '}' { fetch_string_offset(&$$, &$1, &$3 TSRMLS_CC); } + | variable_name { znode tmp_znode; zend_do_pop_object(&tmp_znode TSRMLS_CC); zend_do_fetch_property(&$$, &tmp_znode, &$1 TSRMLS_CC);} ; variable_name: @@ -646,52 +646,52 @@ assignment_list: assignment_list_element: - cvar { zend_do_add_list_element(&$1 CLS_CC); } - | T_LIST '(' { zend_do_new_list_begin(CLS_C); } assignment_list ')' { zend_do_new_list_end(CLS_C); } - | /* empty */ { zend_do_add_list_element(NULL CLS_CC); } + cvar { zend_do_add_list_element(&$1 TSRMLS_CC); } + | T_LIST '(' { zend_do_new_list_begin(TSRMLS_C); } assignment_list ')' { zend_do_new_list_end(TSRMLS_C); } + | /* empty */ { zend_do_add_list_element(NULL TSRMLS_CC); } ; array_pair_list: - /* empty */ { zend_do_init_array(&$$, NULL, NULL, 0 CLS_CC); } + /* empty */ { zend_do_init_array(&$$, NULL, NULL, 0 TSRMLS_CC); } | non_empty_array_pair_list possible_comma { $$ = $1; } ; non_empty_array_pair_list: - non_empty_array_pair_list ',' expr T_DOUBLE_ARROW expr { zend_do_add_array_element(&$$, &$5, &$3, 0 CLS_CC); } - | non_empty_array_pair_list ',' expr { zend_do_add_array_element(&$$, &$3, NULL, 0 CLS_CC); } - | expr T_DOUBLE_ARROW expr { zend_do_init_array(&$$, &$3, &$1, 0 CLS_CC); } - | expr { zend_do_init_array(&$$, &$1, NULL, 0 CLS_CC); } - | non_empty_array_pair_list ',' expr T_DOUBLE_ARROW '&' w_cvar { zend_do_add_array_element(&$$, &$6, &$3, 1 CLS_CC); } - | non_empty_array_pair_list ',' '&' w_cvar { zend_do_add_array_element(&$$, &$4, NULL, 1 CLS_CC); } - | expr T_DOUBLE_ARROW '&' w_cvar { zend_do_init_array(&$$, &$4, &$1, 1 CLS_CC); } - | '&' w_cvar { zend_do_init_array(&$$, &$2, NULL, 1 CLS_CC); } + non_empty_array_pair_list ',' expr T_DOUBLE_ARROW expr { zend_do_add_array_element(&$$, &$5, &$3, 0 TSRMLS_CC); } + | non_empty_array_pair_list ',' expr { zend_do_add_array_element(&$$, &$3, NULL, 0 TSRMLS_CC); } + | expr T_DOUBLE_ARROW expr { zend_do_init_array(&$$, &$3, &$1, 0 TSRMLS_CC); } + | expr { zend_do_init_array(&$$, &$1, NULL, 0 TSRMLS_CC); } + | non_empty_array_pair_list ',' expr T_DOUBLE_ARROW '&' w_cvar { zend_do_add_array_element(&$$, &$6, &$3, 1 TSRMLS_CC); } + | non_empty_array_pair_list ',' '&' w_cvar { zend_do_add_array_element(&$$, &$4, NULL, 1 TSRMLS_CC); } + | expr T_DOUBLE_ARROW '&' w_cvar { zend_do_init_array(&$$, &$4, &$1, 1 TSRMLS_CC); } + | '&' w_cvar { zend_do_init_array(&$$, &$2, NULL, 1 TSRMLS_CC); } ; encaps_list: - encaps_list encaps_var { zend_do_end_variable_parse(BP_VAR_R, 0 CLS_CC); zend_do_add_variable(&$$, &$1, &$2 CLS_CC); } - | encaps_list T_STRING { zend_do_add_string(&$$, &$1, &$2 CLS_CC); } - | encaps_list T_NUM_STRING { zend_do_add_string(&$$, &$1, &$2 CLS_CC); } - | encaps_list T_ENCAPSED_AND_WHITESPACE { zend_do_add_string(&$$, &$1, &$2 CLS_CC); } - | encaps_list T_CHARACTER { zend_do_add_char(&$$, &$1, &$2 CLS_CC); } - | encaps_list T_BAD_CHARACTER { zend_do_add_string(&$$, &$1, &$2 CLS_CC); } - | encaps_list '[' { $2.u.constant.value.lval = (long) '['; zend_do_add_char(&$$, &$1, &$2 CLS_CC); } - | encaps_list ']' { $2.u.constant.value.lval = (long) ']'; zend_do_add_char(&$$, &$1, &$2 CLS_CC); } - | encaps_list '{' { $2.u.constant.value.lval = (long) '{'; zend_do_add_char(&$$, &$1, &$2 CLS_CC); } - | encaps_list '}' { $2.u.constant.value.lval = (long) '}'; zend_do_add_char(&$$, &$1, &$2 CLS_CC); } - | encaps_list T_OBJECT_OPERATOR { znode tmp; $2.u.constant.value.lval = (long) '-'; zend_do_add_char(&tmp, &$1, &$2 CLS_CC); $2.u.constant.value.lval = (long) '>'; zend_do_add_char(&$$, &tmp, &$2 CLS_CC); } - | /* empty */ { zend_do_init_string(&$$ CLS_CC); } + encaps_list encaps_var { zend_do_end_variable_parse(BP_VAR_R, 0 TSRMLS_CC); zend_do_add_variable(&$$, &$1, &$2 TSRMLS_CC); } + | encaps_list T_STRING { zend_do_add_string(&$$, &$1, &$2 TSRMLS_CC); } + | encaps_list T_NUM_STRING { zend_do_add_string(&$$, &$1, &$2 TSRMLS_CC); } + | encaps_list T_ENCAPSED_AND_WHITESPACE { zend_do_add_string(&$$, &$1, &$2 TSRMLS_CC); } + | encaps_list T_CHARACTER { zend_do_add_char(&$$, &$1, &$2 TSRMLS_CC); } + | encaps_list T_BAD_CHARACTER { zend_do_add_string(&$$, &$1, &$2 TSRMLS_CC); } + | encaps_list '[' { $2.u.constant.value.lval = (long) '['; zend_do_add_char(&$$, &$1, &$2 TSRMLS_CC); } + | encaps_list ']' { $2.u.constant.value.lval = (long) ']'; zend_do_add_char(&$$, &$1, &$2 TSRMLS_CC); } + | encaps_list '{' { $2.u.constant.value.lval = (long) '{'; zend_do_add_char(&$$, &$1, &$2 TSRMLS_CC); } + | encaps_list '}' { $2.u.constant.value.lval = (long) '}'; zend_do_add_char(&$$, &$1, &$2 TSRMLS_CC); } + | encaps_list T_OBJECT_OPERATOR { znode tmp; $2.u.constant.value.lval = (long) '-'; zend_do_add_char(&tmp, &$1, &$2 TSRMLS_CC); $2.u.constant.value.lval = (long) '>'; zend_do_add_char(&$$, &tmp, &$2 TSRMLS_CC); } + | /* empty */ { zend_do_init_string(&$$ TSRMLS_CC); } ; encaps_var: - T_VARIABLE { zend_do_fetch_globals(&$1 CLS_CC); zend_do_begin_variable_parse(CLS_C); fetch_simple_variable(&$$, &$1, 1 CLS_CC); } - | T_VARIABLE '[' { zend_do_begin_variable_parse(CLS_C); } encaps_var_offset ']' { zend_do_fetch_globals(&$1 CLS_CC); fetch_array_begin(&$$, &$1, &$4 CLS_CC); } - | T_VARIABLE T_OBJECT_OPERATOR T_STRING { zend_do_begin_variable_parse(CLS_C); fetch_simple_variable(&$2, &$1, 1 CLS_CC); zend_do_fetch_property(&$$, &$2, &$3 CLS_CC); } - | T_DOLLAR_OPEN_CURLY_BRACES expr '}' { zend_do_begin_variable_parse(CLS_C); fetch_simple_variable(&$$, &$2, 1 CLS_CC); } - | T_DOLLAR_OPEN_CURLY_BRACES T_STRING_VARNAME '[' expr ']' '}' { zend_do_begin_variable_parse(CLS_C); fetch_array_begin(&$$, &$2, &$4 CLS_CC); } + T_VARIABLE { zend_do_fetch_globals(&$1 TSRMLS_CC); zend_do_begin_variable_parse(TSRMLS_C); fetch_simple_variable(&$$, &$1, 1 TSRMLS_CC); } + | T_VARIABLE '[' { zend_do_begin_variable_parse(TSRMLS_C); } encaps_var_offset ']' { zend_do_fetch_globals(&$1 TSRMLS_CC); fetch_array_begin(&$$, &$1, &$4 TSRMLS_CC); } + | T_VARIABLE T_OBJECT_OPERATOR T_STRING { zend_do_begin_variable_parse(TSRMLS_C); fetch_simple_variable(&$2, &$1, 1 TSRMLS_CC); zend_do_fetch_property(&$$, &$2, &$3 TSRMLS_CC); } + | T_DOLLAR_OPEN_CURLY_BRACES expr '}' { zend_do_begin_variable_parse(TSRMLS_C); fetch_simple_variable(&$$, &$2, 1 TSRMLS_CC); } + | T_DOLLAR_OPEN_CURLY_BRACES T_STRING_VARNAME '[' expr ']' '}' { zend_do_begin_variable_parse(TSRMLS_C); fetch_array_begin(&$$, &$2, &$4 TSRMLS_CC); } | T_CURLY_OPEN cvar '}' { $$ = $2; } ; @@ -699,23 +699,23 @@ encaps_var: encaps_var_offset: T_STRING { $$ = $1; } | T_NUM_STRING { $$ = $1; } - | T_VARIABLE { fetch_simple_variable(&$$, &$1, 1 CLS_CC); } + | T_VARIABLE { fetch_simple_variable(&$$, &$1, 1 TSRMLS_CC); } ; internal_functions_in_yacc: T_ISSET '(' isset_variables ')' { $$ = $3; } - | T_EMPTY '(' cvar ')' { zend_do_isset_or_isempty(ZEND_ISEMPTY, &$$, &$3 CLS_CC); } - | T_INCLUDE expr { zend_do_include_or_eval(ZEND_INCLUDE, &$$, &$2 CLS_CC); } - | T_INCLUDE_ONCE expr { zend_do_include_or_eval(ZEND_INCLUDE_ONCE, &$$, &$2 CLS_CC); } - | T_EVAL '(' expr ')' { zend_do_include_or_eval(ZEND_EVAL, &$$, &$3 CLS_CC); } - | T_REQUIRE expr { zend_do_include_or_eval(ZEND_REQUIRE, &$$, &$2 CLS_CC); } - | T_REQUIRE_ONCE expr { zend_do_include_or_eval(ZEND_REQUIRE_ONCE, &$$, &$2 CLS_CC); } + | T_EMPTY '(' cvar ')' { zend_do_isset_or_isempty(ZEND_ISEMPTY, &$$, &$3 TSRMLS_CC); } + | T_INCLUDE expr { zend_do_include_or_eval(ZEND_INCLUDE, &$$, &$2 TSRMLS_CC); } + | T_INCLUDE_ONCE expr { zend_do_include_or_eval(ZEND_INCLUDE_ONCE, &$$, &$2 TSRMLS_CC); } + | T_EVAL '(' expr ')' { zend_do_include_or_eval(ZEND_EVAL, &$$, &$3 TSRMLS_CC); } + | T_REQUIRE expr { zend_do_include_or_eval(ZEND_REQUIRE, &$$, &$2 TSRMLS_CC); } + | T_REQUIRE_ONCE expr { zend_do_include_or_eval(ZEND_REQUIRE_ONCE, &$$, &$2 TSRMLS_CC); } ; isset_variables: - cvar { zend_do_isset_or_isempty(ZEND_ISSET, &$$, &$1 CLS_CC); } - | isset_variables ',' { zend_do_boolean_and_begin(&$1, &$2 CLS_CC); } cvar { znode tmp; zend_do_isset_or_isempty(ZEND_ISSET, &tmp, &$4 CLS_CC); zend_do_boolean_and_end(&$$, &$1, &tmp, &$2 CLS_CC); } + cvar { zend_do_isset_or_isempty(ZEND_ISSET, &$$, &$1 TSRMLS_CC); } + | isset_variables ',' { zend_do_boolean_and_begin(&$1, &$2 TSRMLS_CC); } cvar { znode tmp; zend_do_isset_or_isempty(ZEND_ISSET, &tmp, &$4 TSRMLS_CC); zend_do_boolean_and_end(&$$, &$1, &tmp, &$2 TSRMLS_CC); } ; %% diff --git a/Zend/zend_language_scanner.h b/Zend/zend_language_scanner.h index 66a0e5962c..f3b478d06b 100644 --- a/Zend/zend_language_scanner.h +++ b/Zend/zend_language_scanner.h @@ -26,7 +26,7 @@ class ZendFlexLexer : public yyFlexLexer { public: virtual ~ZendFlexLexer(); - int lex_scan(zval *zendlval CLS_DC); + int lex_scan(zval *zendlval TSRMLS_DC); void BeginState(int state); }; diff --git a/Zend/zend_language_scanner.l b/Zend/zend_language_scanner.l index 94cf3952e4..3e124adeff 100644 --- a/Zend/zend_language_scanner.l +++ b/Zend/zend_language_scanner.l @@ -73,9 +73,9 @@ #endif #ifdef ZTS -#define YY_DECL int ZendFlexLexer::lex_scan(zval *zendlval CLS_DC) +#define YY_DECL int ZendFlexLexer::lex_scan(zval *zendlval TSRMLS_DC) #else -#define YY_DECL int lex_scan(zval *zendlval CLS_DC) +#define YY_DECL int lex_scan(zval *zendlval TSRMLS_DC) #endif #define YY_INTERACTIVE @@ -124,14 +124,14 @@ void zend_fatal_scanner_error(char *message) } BEGIN_EXTERN_C() -void startup_scanner(CLS_D) +void startup_scanner(TSRMLS_D) { CG(heredoc) = NULL; CG(heredoc_len)=0; } -void shutdown_scanner(CLS_D) +void shutdown_scanner(TSRMLS_D) { if (CG(heredoc)) { efree(CG(heredoc)); @@ -141,7 +141,7 @@ void shutdown_scanner(CLS_D) END_EXTERN_C() -static inline void save_lexical_state(zend_lex_state *lex_state CLS_DC) +static inline void save_lexical_state(zend_lex_state *lex_state TSRMLS_DC) { #ifndef ZTS memcpy(&lex_state->buffer_state,&YY_CURRENT_BUFFER,sizeof(YY_BUFFER_STATE)); @@ -150,12 +150,12 @@ static inline void save_lexical_state(zend_lex_state *lex_state CLS_DC) #else lex_state->ZFL = CG(ZFL); #endif - lex_state->filename = zend_get_compiled_filename(CLS_C); + lex_state->filename = zend_get_compiled_filename(TSRMLS_C); lex_state->lineno = CG(zend_lineno); } -static inline void restore_lexical_state(zend_lex_state *lex_state CLS_DC) +static inline void restore_lexical_state(zend_lex_state *lex_state TSRMLS_DC) { #ifndef ZTS YY_BUFFER_STATE original_buffer_state = YY_CURRENT_BUFFER; @@ -233,13 +233,13 @@ int zend_compare_file_handles(zend_file_handle *fh1, zend_file_handle *fh2) } -ZEND_API void zend_destroy_file_handle(zend_file_handle *file_handle CLS_DC) +ZEND_API void zend_destroy_file_handle(zend_file_handle *file_handle TSRMLS_DC) { zend_llist_del_element(&CG(open_files), file_handle, (int (*)(void *, void *)) zend_compare_file_handles); } -ZEND_API int open_file_for_scanning(zend_file_handle *file_handle CLS_DC) +ZEND_API int open_file_for_scanning(zend_file_handle *file_handle TSRMLS_DC) { char *file_path=NULL; @@ -321,7 +321,7 @@ ZEND_API int open_file_for_scanning(zend_file_handle *file_handle CLS_DC) END_EXTERN_C() -ZEND_API zend_op_array *compile_file(zend_file_handle *file_handle, int type CLS_DC) +ZEND_API zend_op_array *compile_file(zend_file_handle *file_handle, int type TSRMLS_DC) { zend_lex_state original_lex_state; zend_op_array *op_array = (zend_op_array *) emalloc(sizeof(zend_op_array)); @@ -338,11 +338,11 @@ ZEND_API zend_op_array *compile_file(zend_file_handle *file_handle, int type CLS retval_znode.u.constant.is_ref = 0; retval_znode.u.constant.refcount = 1; - save_lexical_state(&original_lex_state CLS_CC); + save_lexical_state(&original_lex_state TSRMLS_CC); retval = op_array; /* success oriented */ - if (open_file_for_scanning(file_handle CLS_CC)==FAILURE) { + if (open_file_for_scanning(file_handle TSRMLS_CC)==FAILURE) { if (type==ZEND_REQUIRE) { zend_message_dispatcher(ZMSG_FAILED_REQUIRE_FOPEN, file_handle->filename); zend_bailout(); @@ -351,11 +351,11 @@ ZEND_API zend_op_array *compile_file(zend_file_handle *file_handle, int type CLS } compilation_successful=0; } else { - init_op_array(op_array, ZEND_USER_FUNCTION, INITIAL_OP_ARRAY_SIZE CLS_CC); + init_op_array(op_array, ZEND_USER_FUNCTION, INITIAL_OP_ARRAY_SIZE TSRMLS_CC); CG(in_compilation) = 1; CG(active_op_array) = op_array; - compiler_result = zendparse(CLS_C); - zend_do_return(&retval_znode, 0 CLS_CC); + compiler_result = zendparse(TSRMLS_C); + zend_do_return(&retval_znode, 0 TSRMLS_CC); CG(in_compilation) = original_in_compilation; if (compiler_result==1) { /* parser error */ CG(unclean_shutdown) = 1; @@ -374,13 +374,13 @@ ZEND_API zend_op_array *compile_file(zend_file_handle *file_handle, int type CLS } } if (compilation_successful) { - restore_lexical_state(&original_lex_state CLS_CC); + restore_lexical_state(&original_lex_state TSRMLS_CC); } return retval; } -zend_op_array *compile_filename(int type, zval *filename CLS_DC TSRMLS_DC) +zend_op_array *compile_filename(int type, zval *filename TSRMLS_DC) { zend_file_handle file_handle; zval tmp; @@ -398,12 +398,12 @@ zend_op_array *compile_filename(int type, zval *filename CLS_DC TSRMLS_DC) file_handle.opened_path = NULL; - retval = zend_compile_file(&file_handle, type CLS_CC); + retval = zend_compile_file(&file_handle, type TSRMLS_CC); if (retval && file_handle.opened_path) { int dummy = 1; zend_hash_add(&EG(included_files), file_handle.opened_path, strlen(file_handle.opened_path)+1, (void *)&dummy, sizeof(int), NULL); } - zend_destroy_file_handle(&file_handle CLS_CC); + zend_destroy_file_handle(&file_handle TSRMLS_CC); if (filename==&tmp) { zval_dtor(&tmp); @@ -414,7 +414,7 @@ zend_op_array *compile_filename(int type, zval *filename CLS_DC TSRMLS_DC) #ifndef ZTS static inline int prepare_string_for_scanning(zval *str, char *filename) #else -static inline int prepare_string_for_scanning(zval *str, istrstream **input_stream, char *filename CLS_DC) +static inline int prepare_string_for_scanning(zval *str, istrstream **input_stream, char *filename TSRMLS_DC) #endif { #ifndef ZTS @@ -437,7 +437,7 @@ static inline int prepare_string_for_scanning(zval *str, istrstream **input_stre } -zend_op_array *compile_string(zval *source_string, char *filename CLS_DC) +zend_op_array *compile_string(zval *source_string, char *filename TSRMLS_DC) { zend_lex_state original_lex_state; zend_op_array *op_array = (zend_op_array *) emalloc(sizeof(zend_op_array)); @@ -462,35 +462,35 @@ zend_op_array *compile_string(zval *source_string, char *filename CLS_DC) convert_to_string(&tmp); source_string = &tmp; - save_lexical_state(&original_lex_state CLS_CC); + save_lexical_state(&original_lex_state TSRMLS_CC); #ifndef ZTS if (prepare_string_for_scanning(source_string, filename)==FAILURE) { #else - if (prepare_string_for_scanning(source_string, &input_stream, filename CLS_CC)==FAILURE) { + if (prepare_string_for_scanning(source_string, &input_stream, filename TSRMLS_CC)==FAILURE) { #endif efree(op_array); retval = NULL; } else { - init_op_array(op_array, ZEND_EVAL_CODE, INITIAL_OP_ARRAY_SIZE CLS_CC); + init_op_array(op_array, ZEND_EVAL_CODE, INITIAL_OP_ARRAY_SIZE TSRMLS_CC); CG(active_op_array) = op_array; #ifndef ZTS BEGIN(ST_IN_SCRIPTING); #else CG(ZFL)->BeginState(ST_IN_SCRIPTING); #endif - compiler_result = zendparse(CLS_C); + compiler_result = zendparse(TSRMLS_C); if (compiler_result==1) { CG(active_op_array) = original_active_op_array; CG(unclean_shutdown)=1; retval = NULL; } else { - zend_do_return(NULL, 0 CLS_CC); + zend_do_return(NULL, 0 TSRMLS_CC); CG(active_op_array) = original_active_op_array; pass_two(op_array); retval = op_array; } - restore_lexical_state(&original_lex_state CLS_CC); + restore_lexical_state(&original_lex_state TSRMLS_CC); } #ifdef ZTS delete input_stream; @@ -506,20 +506,20 @@ int highlight_file(char *filename, zend_syntax_highlighter_ini *syntax_highlight { zend_lex_state original_lex_state; zend_file_handle file_handle; - CLS_FETCH(); + TSRMLS_FETCH(); file_handle.type = ZEND_HANDLE_FILENAME; file_handle.filename = filename; file_handle.free_filename = 0; file_handle.opened_path = NULL; - save_lexical_state(&original_lex_state CLS_CC); - if (open_file_for_scanning(&file_handle CLS_CC)==FAILURE) { + save_lexical_state(&original_lex_state TSRMLS_CC); + if (open_file_for_scanning(&file_handle TSRMLS_CC)==FAILURE) { zend_message_dispatcher(ZMSG_FAILED_HIGHLIGHT_FOPEN, filename); return FAILURE; } zend_highlight(syntax_highlighter_ini); - zend_destroy_file_handle(&file_handle CLS_CC); - restore_lexical_state(&original_lex_state CLS_CC); + zend_destroy_file_handle(&file_handle TSRMLS_CC); + restore_lexical_state(&original_lex_state TSRMLS_CC); return SUCCESS; } @@ -530,20 +530,20 @@ int highlight_string(zval *str, zend_syntax_highlighter_ini *syntax_highlighter_ #ifdef ZTS istrstream *input_stream; #endif - CLS_FETCH(); + TSRMLS_FETCH(); str = &tmp; zval_copy_ctor(str); - save_lexical_state(&original_lex_state CLS_CC); + save_lexical_state(&original_lex_state TSRMLS_CC); #ifndef ZTS if (prepare_string_for_scanning(str, str_name)==FAILURE) { #else - if (prepare_string_for_scanning(str, &input_stream, str_name CLS_CC)==FAILURE) { + if (prepare_string_for_scanning(str, &input_stream, str_name TSRMLS_CC)==FAILURE) { #endif return FAILURE; } zend_highlight(syntax_highlighter_ini); - restore_lexical_state(&original_lex_state CLS_CC); + restore_lexical_state(&original_lex_state TSRMLS_CC); #ifdef ZTS delete input_stream; #endif @@ -554,19 +554,19 @@ END_EXTERN_C() #ifdef ZTS BEGIN_EXTERN_C() -int lex_scan(zval *zendlval CLS_DC) +int lex_scan(zval *zendlval TSRMLS_DC) { - return CG(ZFL)->lex_scan(zendlval CLS_CC); + return CG(ZFL)->lex_scan(zendlval TSRMLS_CC); } -const char *zend_get_zendtext(CLS_D) +const char *zend_get_zendtext(TSRMLS_D) { return CG(ZFL)->YYText(); } -int zend_get_zendleng(CLS_D) +int zend_get_zendleng(TSRMLS_D) { return CG(ZFL)->YYLeng(); } @@ -1048,7 +1048,7 @@ NEWLINE ("\r"|"\n"|"\r\n") } <ST_IN_SCRIPTING>"__FILE__" { - char *filename = zend_get_compiled_filename(CLS_C); + char *filename = zend_get_compiled_filename(TSRMLS_C); if (!filename) { filename = ""; diff --git a/Zend/zend_opcode.c b/Zend/zend_opcode.c index d454b5c3ae..122cab58de 100644 --- a/Zend/zend_opcode.c +++ b/Zend/zend_opcode.c @@ -50,7 +50,7 @@ static void op_array_alloc_ops(zend_op_array *op_array) -void init_op_array(zend_op_array *op_array, int type, int initial_ops_size CLS_DC) +void init_op_array(zend_op_array *op_array, int type, int initial_ops_size TSRMLS_DC) { op_array->type = type; @@ -72,7 +72,7 @@ void init_op_array(zend_op_array *op_array, int type, int initial_ops_size CLS_D op_array->T = 0; op_array->function_name = NULL; - op_array->filename = zend_get_compiled_filename(CLS_C); + op_array->filename = zend_get_compiled_filename(TSRMLS_C); op_array->arg_types = NULL; @@ -181,7 +181,7 @@ ZEND_API void destroy_op_array(zend_op_array *op_array) } -void init_op(zend_op *op CLS_DC) +void init_op(zend_op *op TSRMLS_DC) { memset(&op->result, 0, sizeof(znode)); op->lineno = CG(zend_lineno); @@ -191,7 +191,7 @@ void init_op(zend_op *op CLS_DC) memset(&op->op2, 0, sizeof(znode)); } -zend_op *get_next_op(zend_op_array *op_array CLS_DC) +zend_op *get_next_op(zend_op_array *op_array TSRMLS_DC) { zend_uint next_op_num = op_array->last++; zend_op *next_op; @@ -209,7 +209,7 @@ zend_op *get_next_op(zend_op_array *op_array CLS_DC) next_op = &(op_array->opcodes[next_op_num]); - init_op(next_op CLS_CC); + init_op(next_op TSRMLS_CC); return next_op; } @@ -231,7 +231,7 @@ zend_brk_cont_element *get_next_brk_cont_element(zend_op_array *op_array) } -static void zend_update_extended_info(zend_op_array *op_array CLS_DC) +static void zend_update_extended_info(zend_op_array *op_array TSRMLS_DC) { zend_op *opline = op_array->opcodes, *end=opline+op_array->last; @@ -267,13 +267,13 @@ static void zend_extension_op_array_handler(zend_extension *extension, zend_op_a int pass_two(zend_op_array *op_array) { zend_op *opline, *end; - CLS_FETCH(); + TSRMLS_FETCH(); if (op_array->type!=ZEND_USER_FUNCTION && op_array->type!=ZEND_EVAL_CODE) { return 0; } if (CG(extended_info)) { - zend_update_extended_info(op_array CLS_CC); + zend_update_extended_info(op_array TSRMLS_CC); } if (CG(handle_op_arrays)) { zend_llist_apply_with_argument(&zend_extensions, (void (*)(void *, void *)) zend_extension_op_array_handler, op_array); |