X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=src%2Ftypes%2Flet_stmt.h;h=37ef1185dc0db909eedcb84102688d4ca1ddb2c9;hp=1ffd56ed5bf8269aa936c60302d4d285c01395eb;hb=c9384515a81cb64d345b299908b2852f51bb8e6e;hpb=2f5af21b263403997e154658635d6b6e6eaab453 diff --git a/src/types/let_stmt.h b/src/types/let_stmt.h index 1ffd56e..37ef118 100644 --- a/src/types/let_stmt.h +++ b/src/types/let_stmt.h @@ -26,21 +26,22 @@ #ifndef PSI_TYPES_LET_STMT_H #define PSI_TYPES_LET_STMT_H -#include "decl_var.h" -#include "let_val.h" - -typedef struct let_stmt { - decl_var *var; - let_val *val; -} let_stmt; - -let_stmt *init_let_stmt(decl_var *var, let_val *val); -void free_let_stmt(let_stmt *stmt); -void dump_let_stmt(int fd, let_stmt *let); - struct psi_data; -struct impl; - -int validate_let_stmts(struct psi_data *data, struct impl *impl); +struct psi_token; +struct psi_let_exp; +struct psi_call_frame; +struct psi_impl; + +struct psi_let_stmt { + struct psi_token *token; + struct psi_let_exp *exp; +}; + +struct psi_let_stmt *psi_let_stmt_init(struct psi_let_exp *exp); +void psi_let_stmt_free(struct psi_let_stmt **stmt_ptr); +void psi_let_stmt_dump(int fd, struct psi_let_stmt *stmt); + +void *psi_let_stmt_exec(struct psi_let_stmt *stmt, struct psi_call_frame *frame); +bool psi_let_stmts_validate(struct psi_data *data, struct psi_validate_scope *scope); #endif