X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Ftypes%2Fimpl.c;h=1c4152a06f78c50c73cdf0b46f6d1c0362a63c25;hb=e918b10a9b5a8de154d12385665728f7408e5cc7;hp=33d3301fa8a7863abe0e63dfbebabc072f8eb575;hpb=9bcb1df0786a8193d65949c857baaba2f4296e84;p=m6w6%2Fext-psi diff --git a/src/types/impl.c b/src/types/impl.c index 33d3301..1c4152a 100644 --- a/src/types/impl.c +++ b/src/types/impl.c @@ -23,7 +23,11 @@ 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 @@ -31,7 +35,7 @@ struct psi_impl *psi_impl_init(struct psi_impl_func *func, struct psi_plist *stmts) { - struct psi_impl *impl = calloc(1, sizeof(*impl)); + struct psi_impl *impl = pecalloc(1, sizeof(*impl), 1); size_t i = 0; struct psi_token **abstract_stmt; @@ -39,6 +43,7 @@ struct psi_impl *psi_impl_init(struct psi_impl_func *func, impl->stmts.let = psi_plist_init((psi_plist_dtor) psi_let_stmt_free); impl->stmts.set = psi_plist_init((psi_plist_dtor) psi_set_stmt_free); impl->stmts.fre = psi_plist_init((psi_plist_dtor) psi_free_stmt_free); + impl->stmts.ass = psi_plist_init((psi_plist_dtor) psi_assert_stmt_free); while (psi_plist_get(stmts, i++, &abstract_stmt)) { switch ((*abstract_stmt)->type) { @@ -55,6 +60,10 @@ struct psi_impl *psi_impl_init(struct psi_impl_func *func, case PSI_T_FREE: impl->stmts.fre = psi_plist_add(impl->stmts.fre, &abstract_stmt); break; + case PSI_T_PRE_ASSERT: + case PSI_T_POST_ASSERT: + impl->stmts.ass = psi_plist_add(impl->stmts.ass, &abstract_stmt); + break; default: assert(0); } @@ -77,50 +86,61 @@ void psi_impl_free(struct psi_impl **impl_ptr) psi_plist_free(impl->stmts.let); psi_plist_free(impl->stmts.set); psi_plist_free(impl->stmts.fre); + psi_plist_free(impl->stmts.ass); free(impl); } } -void psi_impl_dump(int fd, struct psi_impl *impl) +void psi_impl_dump(struct psi_dump *dump, struct psi_impl *impl) { size_t i; struct psi_return_stmt *ret; struct psi_let_stmt *let; struct psi_set_stmt *set; struct psi_free_stmt *fre; + struct psi_assert_stmt *ass; - psi_impl_func_dump(fd, impl->func); - dprintf(fd, " {\n"); + psi_impl_func_dump(dump, impl->func); + PSI_DUMP(dump, " {\n"); for (i = 0; psi_plist_get(impl->stmts.let, i, &let); ++i) { - psi_let_stmt_dump(fd, let); + psi_let_stmt_dump(dump, let); + } + for (i = 0; psi_plist_get(impl->stmts.ass, i, &ass); ++i) { + psi_assert_stmt_dump(dump, ass); } for (i = 0; psi_plist_get(impl->stmts.ret, i, &ret); ++i) { - psi_return_stmt_dump(fd, ret); + psi_return_stmt_dump(dump, ret); } for (i = 0; psi_plist_get(impl->stmts.set, i, &set); ++i) { - psi_set_stmt_dump(fd, set); + psi_set_stmt_dump(dump, set); } for (i = 0; psi_plist_get(impl->stmts.fre, i, &fre); ++i) { - psi_free_stmt_dump(fd, fre); + psi_free_stmt_dump(dump, fre); } - dprintf(fd, "}\n"); + PSI_DUMP(dump, "}\n"); } -bool psi_impl_validate(struct psi_data *data, struct psi_impl *impl) +bool psi_impl_validate(struct psi_data *data, struct psi_impl *impl, + struct psi_validate_scope *scope) { - if (!psi_impl_func_validate(data, impl->func)) { + scope->impl = impl; + + if (!psi_impl_func_validate(data, impl->func, scope)) { + return false; + } + if (!psi_return_stmt_validate(data, scope)) { return false; } - if (!psi_return_stmt_validate(data, impl)) { + if (!psi_let_stmts_validate(data, scope)) { return false; } - if (!psi_let_stmts_validate(data, impl)) { + if (!psi_set_stmts_validate(data, scope)) { return false; } - if (!psi_set_stmts_validate(data, impl)) { + if (!psi_assert_stmts_validate(data, scope)) { return false; } - if (!psi_free_stmts_validate(data, impl)) { + if (!psi_free_stmts_validate(data, scope)) { return false; } return true; @@ -154,11 +174,36 @@ void psi_impl_stmt_free(struct psi_token ***abstract_stmt) case PSI_T_FREE: psi_free_stmt_free((void *) abstract_stmt); break; + case PSI_T_PRE_ASSERT: + case PSI_T_POST_ASSERT: + psi_assert_stmt_free((void *) abstract_stmt); + break; default: assert(0); } } +struct psi_decl_arg *psi_impl_get_decl_arg(struct psi_impl *impl, + struct psi_decl_var *var) +{ + struct psi_return_stmt *ret; + + if (psi_plist_get(impl->stmts.ret, 0, &ret)) { + if (ret->exp->args) { + size_t i = 0; + struct psi_decl_var *arg; + + while (psi_plist_get(ret->exp->args, i++, &arg)) { + if (zend_string_equals(var->name, arg->name)) { + return var->arg = arg->arg; + } + } + } + } + + return psi_decl_get_arg(impl->decl, var); +} + struct psi_let_stmt *psi_impl_get_let(struct psi_impl *impl, struct psi_decl_var* var) { @@ -180,7 +225,7 @@ struct psi_impl_arg *psi_impl_get_arg(struct psi_impl *impl, struct psi_impl_arg *iarg; while (psi_plist_get(impl->func->args, i++, &iarg)) { - if (!strcmp(var->name, iarg->var->name)) { + if (zend_string_equals(var->name, iarg->var->name)) { return var->arg = iarg; } } @@ -197,7 +242,7 @@ struct psi_decl_arg *psi_impl_get_temp_let_arg(struct psi_impl *impl, if (let->exp->kind != PSI_LET_TMP) { continue; } - if (strcmp(let->exp->var->name, var->name)) { + if (!zend_string_equals(let->exp->var->name, var->name)) { continue; } return var->arg = let->exp->var->arg;