X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Ftypes%2Flet_callback.c;h=f5c7a46299f63e44818d8bb00bda4e53388d03ab;hb=cd0567b4052ee24259bc6b8a9858af9d26f3de48;hp=7d44f33a98c9b7f73ea7826a7641ffbd519ab144;hpb=46a52f66821e6fb4d0fbce884a69e8e57244c008;p=m6w6%2Fext-psi diff --git a/src/types/let_callback.c b/src/types/let_callback.c index 7d44f33..f5c7a46 100644 --- a/src/types/let_callback.c +++ b/src/types/let_callback.c @@ -23,13 +23,17 @@ 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" struct psi_let_callback *psi_let_callback_init(struct psi_let_func *func, struct psi_plist *args, struct psi_plist *cb_args) { - struct psi_let_callback *cb = calloc(1, sizeof(*cb)); + struct psi_let_callback *cb = pecalloc(1, sizeof(*cb), 1); cb->func = func; cb->args = args; cb->cb_args = cb_args; @@ -44,10 +48,10 @@ void psi_let_callback_free(struct psi_let_callback **cb_ptr) *cb_ptr = NULL; psi_let_func_free(&cb->func); psi_plist_free(cb->args); - psi_plist_free(cb->cb_args); - if (cb->token) { - free(cb->token); + if (cb->cb_args) { + psi_plist_free(cb->cb_args); } + psi_token_free(&cb->token); free(cb); } } @@ -65,7 +69,7 @@ static inline bool psi_let_callback_validate_decl_args(struct psi_data *data, data->error(data, cb->token, PSI_WARNING, "Argument count of callback statement of implementation '%s'" "does not match argument count of callback declaration '%s'", - impl->func->name, cb_decl->func->var->name); + impl->func->name->val, cb_decl->func->var->name->val); return false; } @@ -76,75 +80,86 @@ static inline bool psi_let_callback_validate_decl_args(struct psi_data *data, return true; } -bool psi_let_callback_validate(struct psi_data *data, struct psi_let_exp *exp, - struct psi_let_callback *cb, struct psi_impl *impl) +bool psi_let_callback_validate(struct psi_data *data, struct psi_let_callback *cb, + struct psi_validate_scope *scope) { size_t i = 0; struct psi_decl_type *cb_type; + struct psi_let_exp *exp = scope->current_let; struct psi_decl_var *cb_var = exp->var; - struct psi_set_exp *set_exp; + struct psi_set_exp *set_exp, *parent_set = scope->current_set; cb_type = psi_decl_type_get_real(cb_var->arg->type); if (cb_type->type != PSI_T_FUNCTION) { data->error(data, cb_var->token, PSI_WARNING, "Expected a function: %s", - cb_var->name); + cb_var->name->val); return false; } cb->decl = cb_type->real.func; - if (!psi_decl_validate_nodl(data, cb->decl, NULL /* FIXME type_stack */)) { + if (!psi_decl_validate_nodl(data, cb->decl, scope)) { return false; } - if (!psi_let_callback_validate_decl_args(data, cb, cb->decl, impl)) { + if (!psi_let_callback_validate_decl_args(data, cb, cb->decl, scope->impl)) { return false; } while (psi_plist_get(cb->args, i++, &set_exp)) { - struct psi_decl_var *cb_var, *dvar = psi_set_exp_get_decl_var(set_exp); + if (cb->cb_args) { + struct psi_decl_var *cb_var; - if (psi_plist_get(cb->cb_args, i - 1, &cb_var)) { - dvar->arg = cb_var->arg; + if (psi_plist_get(cb->cb_args, i - 1, &cb_var)) { + struct psi_decl_var *dvar = psi_set_exp_get_decl_var(set_exp); + dvar->arg = cb_var->arg; + } } - if (!psi_set_exp_validate(data, set_exp, impl, cb->decl)) { + scope->current_set = set_exp; + scope->cb_decl = cb->decl; + + if (!psi_set_exp_validate(data, set_exp, scope)) { + scope->cb_decl = NULL; + scope->current_set = parent_set; return false; } + scope->cb_decl = NULL; + scope->current_set = parent_set; } return true; } -void psi_let_callback_dump(int fd, struct psi_let_callback *callback, +void psi_let_callback_dump(struct psi_dump *dump, struct psi_let_callback *callback, unsigned level) { - dprintf(fd, "callback("); + PSI_DUMP(dump, "callback("); if (callback->cb_args) { size_t i = 0; struct psi_decl_var *cb_arg; while (psi_plist_get(callback->cb_args, i++, &cb_arg)) { if (i > 1) { - dprintf(fd, ", "); + PSI_DUMP(dump, ", "); } - psi_decl_var_dump(fd, cb_arg); + psi_decl_var_dump(dump, cb_arg); } } - dprintf(fd, ") as %s(%s(", - callback->func->name, - callback->func->var->name); + PSI_DUMP(dump, ") as %s(%s(", + callback->func->name->val, + callback->func->var->name->val); if (callback->args) { size_t i = 0, last = psi_plist_count(callback->args); struct psi_set_exp *set; - dprintf(fd, "\n"); + PSI_DUMP(dump, "\n"); ++level; while (psi_plist_get(callback->args, i++, &set)) { - psi_set_exp_dump(fd, set, level, i == last); - dprintf(fd, "\n"); + psi_set_exp_dump(dump, set, level, i == last); + PSI_DUMP(dump, "\n"); } --level; - dprintf(fd, "%s", psi_t_indent(level)); + PSI_DUMP(dump, "%s", psi_t_indent(level)); } - dprintf(fd, "))"); + PSI_DUMP(dump, "))"); }