17#ifndef ZEND_FRAMELESS_FUNCTION_H
18#define ZEND_FRAMELESS_FUNCTION_H
24# include <config.w32.h>
26# include <php_config.h>
31#define ZEND_FRAMELESS_FUNCTION_PARAMETERS_0 zval *return_value
32#define ZEND_FRAMELESS_FUNCTION_PARAMETERS_1 zval *return_value, zval *arg1
33#define ZEND_FRAMELESS_FUNCTION_PARAMETERS_2 zval *return_value, zval *arg1, zval *arg2
34#define ZEND_FRAMELESS_FUNCTION_PARAMETERS_3 zval *return_value, zval *arg1, zval *arg2, zval *arg3
36#define ZEND_FRAMELESS_FUNCTION_NAME(name, arity) zflf_##name##_##arity
37#define ZEND_OP_IS_FRAMELESS_ICALL(opcode) ((opcode) >= ZEND_FRAMELESS_ICALL_0 && (opcode) <= ZEND_FRAMELESS_ICALL_3)
38#define ZEND_FLF_NUM_ARGS(opcode) ((opcode) - ZEND_FRAMELESS_ICALL_0)
39#define ZEND_FLF_FUNC(opline) (zend_flf_functions[(opline)->extended_value])
40#define ZEND_FLF_HANDLER(opline) (zend_flf_handlers[(opline)->extended_value])
42#define ZEND_FRAMELESS_FUNCTION(name, arity) \
43 void ZEND_FRAMELESS_FUNCTION_NAME(name, arity)(ZEND_FRAMELESS_FUNCTION_PARAMETERS_##arity)
45#define Z_FLF_PARAM_ZVAL(arg_num, dest) \
46 dest = arg ## arg_num;
47#define Z_FLF_PARAM_ARRAY(arg_num, dest) \
48 if (!zend_parse_arg_array(arg ## arg_num, &dest, false, false)) { \
49 zend_wrong_parameter_type_error(arg_num, Z_EXPECTED_ARRAY, arg ## arg_num); \
52#define Z_FLF_PARAM_ARRAY_OR_NULL(arg_num, dest) \
53 if (!zend_parse_arg_array(arg ## arg_num, &dest, true, false)) { \
54 zend_wrong_parameter_type_error(arg_num, Z_EXPECTED_ARRAY_OR_NULL, arg ## arg_num); \
57#define Z_FLF_PARAM_ARRAY_HT_OR_STR(arg_num, dest_ht, dest_str, str_tmp) \
58 if (Z_TYPE_P(arg ## arg_num) == IS_STRING) { \
60 dest_str = Z_STR_P(arg ## arg_num); \
61 } else if (EXPECTED(Z_TYPE_P(arg ## arg_num) == IS_ARRAY)) { \
62 dest_ht = Z_ARRVAL_P(arg ## arg_num); \
66 ZVAL_COPY(&str_tmp, arg ## arg_num); \
67 arg ## arg_num = &str_tmp; \
68 if (!zend_flf_parse_arg_str_slow(arg ## arg_num, &dest_str, arg_num)) { \
69 zend_wrong_parameter_type_error(arg_num, Z_EXPECTED_ARRAY_OR_STRING, arg ## arg_num); \
73#define Z_FLF_PARAM_BOOL(arg_num, dest) \
74 if (!zend_parse_arg_bool_ex(arg ## arg_num, &dest, NULL, false, arg_num, true)) { \
75 zend_wrong_parameter_type_error(arg_num, Z_EXPECTED_BOOL, arg ## arg_num); \
78#define Z_FLF_PARAM_LONG(arg_num, dest) \
79 if (!zend_parse_arg_long_ex(arg ## arg_num, &dest, NULL, false, arg_num, true)) { \
80 zend_wrong_parameter_type_error(arg_num, Z_EXPECTED_LONG, arg ## arg_num); \
83#define Z_FLF_PARAM_LONG_OR_NULL(arg_num, is_null, dest) \
84 if (!zend_parse_arg_long_ex(arg ## arg_num, &dest, &is_null, true, arg_num, true)) { \
85 zend_wrong_parameter_type_error(arg_num, Z_EXPECTED_LONG_OR_NULL, arg ## arg_num); \
88#define Z_FLF_PARAM_STR(arg_num, dest, tmp) \
89 if (Z_TYPE_P(arg ## arg_num) == IS_STRING) { \
90 dest = Z_STR_P(arg ## arg_num); \
92 ZVAL_COPY(&tmp, arg ## arg_num); \
93 arg ## arg_num = &tmp; \
94 if (!zend_parse_arg_str_ex(arg ## arg_num, &dest, false, arg_num, true)) { \
95 zend_wrong_parameter_type_error(arg_num, Z_EXPECTED_STRING, arg ## arg_num); \
99#define Z_FLF_PARAM_FREE_STR(arg_num, tmp) \
100 if (UNEXPECTED(arg ## arg_num == &tmp)) { \
101 zval_ptr_dtor(arg ## arg_num); \
zend_function ** zend_flf_functions
ZEND_API void ** zend_flf_handlers
union _zend_function zend_function
void(* zend_frameless_function_1)(zval *return_value, zval *op1)
void(* zend_frameless_function_3)(zval *return_value, zval *op1, zval *op2, zval *op3)
void(* zend_frameless_function_0)(zval *return_value)
void(* zend_frameless_function_2)(zval *return_value, zval *op1, zval *op2)