X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Ftypes%2Fset_exp.c;h=f5d67de3eeede8d80ee3cf4a393d0e05d5a1b0c3;hb=HEAD;hp=ac55c3ad4bcc3a0282196cc825b76fc9eecf2bca;hpb=9bcb1df0786a8193d65949c857baaba2f4296e84;p=m6w6%2Fext-psi diff --git a/src/types/set_exp.c b/src/types/set_exp.c index ac55c3a..f5d67de 100644 --- a/src/types/set_exp.c +++ b/src/types/set_exp.c @@ -23,14 +23,21 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *******************************************************************************/ -#include "php_psi_stdinc.h" +#ifdef HAVE_CONFIG_H +# include "config.h" +#else +# include "php_config.h" +#endif #include "data.h" #include "call.h" +#include "calc.h" #include "marshal.h" +#include + struct psi_set_exp *psi_set_exp_init(enum psi_set_exp_kind kind, void *data) { - struct psi_set_exp *val = calloc(1, sizeof(*val)); + struct psi_set_exp *val = pecalloc(1, sizeof(*val), 1); switch (val->kind = kind) { case PSI_SET_FUNC: @@ -49,7 +56,7 @@ struct psi_set_exp *psi_set_exp_init(enum psi_set_exp_kind kind, void *data) void psi_set_exp_exec(struct psi_set_exp *val, struct psi_call_frame *frame) { - struct psi_call_frame_symbol *frame_sym = NULL; + struct psi_call_frame_symbol *frame_sym; struct psi_call_frame_argument *frame_arg; struct psi_decl_var *set_dvar = psi_set_exp_get_decl_var(val); struct psi_impl_var *set_ivar = psi_set_exp_get_impl_var(val); @@ -74,8 +81,16 @@ void psi_set_exp_exec_ex(struct psi_set_exp *val, zval *zv, impl_val *iv, val->data.func->handler(zv, val, iv, frame); break; case PSI_SET_NUMEXP: - psi_num_exp_exec(val->data.num, iv, frame); - psi_set_to_int(zv, val, iv, frame); + switch (psi_num_exp_exec(val->data.num, iv, frame, NULL)) { + case PSI_T_FLOAT: + case PSI_T_DOUBLE: + case PSI_T_LONG_DOUBLE: + psi_set_to_float(zv, val, iv, frame); + break; + default: + psi_set_to_int(zv, val, iv, frame); + break; + } break; default: assert(0); @@ -112,37 +127,37 @@ void psi_set_exp_free(struct psi_set_exp **exp_ptr) } } -void psi_set_exp_dump(int fd, struct psi_set_exp *set, unsigned level, int last) +void psi_set_exp_dump(struct psi_dump *dump, struct psi_set_exp *set, unsigned level, int last) { if (level > 1) { /* only if not directly after `set ...` */ - dprintf(fd, "%s", psi_t_indent(level)); + PSI_DUMP(dump, "%s", psi_t_indent(level)); } if (set->var) { /* parsed, or generated */ if (set->var->token) { - dprintf(fd, "%s = ", set->var->name); + PSI_DUMP(dump, "%s = ", set->var->name->val); } } switch (set->kind) { case PSI_SET_FUNC: - psi_set_func_dump(fd, set->data.func, level); + psi_set_func_dump(dump, set->data.func, level); break; case PSI_SET_NUMEXP: - psi_num_exp_dump(fd, set->data.num); + psi_num_exp_dump(dump, set->data.num); break; default: assert(0); } if (!last) { - dprintf(fd, ","); + PSI_DUMP(dump, ","); } if (set->var) { - dprintf(fd, "\t/* fqn=%s */", set->var->fqn); + PSI_DUMP(dump, "\t/* fqn=%s */", set->var->fqn->val); } } @@ -160,39 +175,42 @@ struct psi_impl_var *psi_set_exp_get_impl_var(struct psi_set_exp *exp) { if (!exp->var) { struct psi_decl_var *dvar = psi_set_exp_get_decl_var(exp); - char *dollar_name; + zend_string *dollar_name; + smart_str name = {0}; if (!dvar) { return NULL; } - dollar_name = psi_impl_var_name_prepend(strdup("$"), dvar->name); + smart_str_appendc_ex(&name, '$', 1); + smart_str_append_ex(&name, dvar->name, 1); + dollar_name = smart_str_extract(&name); exp->var = psi_impl_var_init(dollar_name, 0); - free(dollar_name); + zend_string_release(dollar_name); } return exp->var; } bool psi_set_exp_validate(struct psi_data *data, struct psi_set_exp *set, - struct psi_impl *impl, struct psi_decl *cb_decl) + struct psi_validate_scope *scope) { struct psi_impl_var *ivar = psi_set_exp_get_impl_var(set); - if (ivar && !psi_impl_var_validate(data, ivar, impl, NULL, set)) { + if (ivar && !psi_impl_var_validate(data, ivar, scope)) { data->error(data, ivar->token ? : **(struct psi_token ***) &set->data, - PSI_WARNING, "Unknown variable '%s'", ivar->name); + PSI_WARNING, "Unknown variable '%s'", ivar->name->val); return false; } switch (set->kind) { case PSI_SET_NUMEXP: - if (!psi_num_exp_validate(data, set->data.num, impl, cb_decl, NULL, set, NULL)) { + if (!psi_num_exp_validate(data, set->data.num, scope)) { return false; } break; case PSI_SET_FUNC: - if (!psi_set_func_validate(data, set->data.func, set, impl, cb_decl)) { + if (!psi_set_func_validate(data, set->data.func, scope)) { return false; } break;