X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=src%2Ftypes%2Fimpl.c;h=e679f1f2add7ae8fa49135a5dc697f837aa26e97;hp=33d3301fa8a7863abe0e63dfbebabc072f8eb575;hb=f15288e185e65bcdfde87c217fb6bd7ff12eb653;hpb=e11280a7b6ed67a4d79b14569ca06131ea2338bd diff --git a/src/types/impl.c b/src/types/impl.c index 33d3301..e679f1f 100644 --- a/src/types/impl.c +++ b/src/types/impl.c @@ -39,6 +39,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 +56,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,6 +82,7 @@ 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); } } @@ -88,12 +94,16 @@ void psi_impl_dump(int fd, struct psi_impl *impl) 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"); for (i = 0; psi_plist_get(impl->stmts.let, i, &let); ++i) { psi_let_stmt_dump(fd, let); } + for (i = 0; psi_plist_get(impl->stmts.ass, i, &ass); ++i) { + psi_assert_stmt_dump(fd, ass); + } for (i = 0; psi_plist_get(impl->stmts.ret, i, &ret); ++i) { psi_return_stmt_dump(fd, ret); } @@ -120,6 +130,9 @@ bool psi_impl_validate(struct psi_data *data, struct psi_impl *impl) if (!psi_set_stmts_validate(data, impl)) { return false; } + if (!psi_assert_stmts_validate(data, impl)) { + return false; + } if (!psi_free_stmts_validate(data, impl)) { return false; } @@ -154,6 +167,10 @@ 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); }